:root {
    --base-bg: #0f1521;
    --new-year-bg: radial-gradient( circle at 50% -10%, #355c92 0%, #1d2e4a 40%, #0f1521 100% );
    --tg-content-safe-area-inset-top: env(safe-area-inset-top, 0px);
    --tg-content-safe-area-inset-bottom: env(safe-area-inset-bottom, 0px);
    --header-bg: rgba(44, 44, 44, .5);
    --element-bg: rgba(44, 44, 44, .5);
    --element-hover-bg: rgba(54, 54, 54, .9);
    --text-primary: #ffffff;
    --text-secondary: #8a8a8a;
    --text-tertiary: #505050;
    --blur-effect: blur(14px);
    --blur-hard-effect: blur(50px);
    --nav-indicator-bg: rgba(0, 0, 0, .35);
    --profile-modal-bg: rgba(45, 45, 45, .75);
    --profile-border: 1px solid rgba(255, 255, 255, .1);
    --button-bg: rgba(255, 255, 255, .08);
    --button-hover-bg: rgba(255, 255, 255, .15);
    --success-color: #4aa657;
    --danger-color: #c8313e;
    --info-tooltip-bg: rgba(20, 20, 20, .9);
    --access-banner-bg: rgba(200, 49, 62, .9);
    --access-banner-hover-bg: rgba(200, 49, 62, .95);
    --info-color: #0a84ff;
    --header-top-inset: var(--tg-content-safe-area-inset-top);
    --header-base-offset: 30px;
    --green-accent: #4ade80;
    --text-color-muted: #9ca3af;
    --edge-height: 9.6vh;
    --card-bg: rgba(26, 26, 26, .4);
    --card-radius: 16px;
    --background: #111;
    --text-color: #fff;
    --modal-content-bg: rgba(45, 45, 45, .6);
    --award-bg: rgba(48, 48, 48, .8);
    --color-green-dark: #387c2b;
    --color-green-dark-transparent: rgba(56, 124, 43, .3);
    --color-green-claimed: rgba(0, 123, 4, .4);
    --color-white-transparent: rgba(255, 255, 255, .2);
    --card-background-color: rgba(26, 26, 26, .4);
    --gradient-gold: #ffd700;
    --gradient-silver: #c0c0c0;
    --gradient-bronze: #cd7f32;
    --gradient-gray: #808080;
    --edge-fade-height: 40px;
    color-scheme: light dark;
    --user-icon: url('data:image/svg+xml;utf8,<svg viewBox="0 0 11 13" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M10.9558 10.7939C10.5684 8.63776 8.7437 7.06209 6.61199 7.06209H4.39988C2.22 7.06209 0.379062 8.6877 0.0238357 10.8934C-0.153954 12.0048 0.686122 13 1.76774 13H9.22784C10.3257 13 11.1658 11.9715 10.9721 10.8601L10.9558 10.7939Z" fill="%23ffffff"/><path d="M3.23716 5.28737C4.49657 6.58113 6.53124 6.61407 7.82323 5.3536L7.8551 5.32031C8.96966 4.22594 9.08263 2.45087 8.09771 1.22369C6.7572 -0.435212 4.27061 -0.401921 2.97862 1.28992C2.07444 2.48416 2.17113 4.19265 3.22087 5.27072L3.23716 5.28737Z" fill="%23ffffff"/></svg>');
    --gift-icon: url('data:image/svg+xml;utf8,<svg viewBox="0 0 29 28" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M14,5.03v3.53M14,5.03c0-1.95,1.55-3.53,3.47-3.53s3.47,1.58,3.47,3.53-1.55,3.53-3.47,3.53M14,5.03c0-1.95-1.55-3.53-3.47-3.53s-3.47,1.58-3.47,3.53,1.55,3.53,3.47,3.53M14,8.56h3.47M14,8.56h-3.47M14,8.56v8.47M17.47,8.56h4.58c1.56,0,2.33,0,2.93.31.52.27.95.7,1.22,1.23.3.6.3,1.39.3,2.97v3.96M10.53,8.56h-4.58c-1.56,0-2.33,0-2.93.31-.52.27-.95.7-1.21,1.23-.3.6-.3,1.4-.3,2.98v3.95M1.5,17.03v3.95c0,1.58,0,2.37.3,2.98.27.53.69.96,1.21,1.23.59.31,1.37.31,2.92.31h8.06M1.5,17.03h12.5M14,25.5h8.06c1.55,0,2.33,0,2.92-.31.52-.27.95-.7,1.22-1.23.3-.6.3-1.39.3-2.97v-3.96h-12.5v8.47" stroke="white" stroke-width="3" stroke-linecap="round" stroke-linejoin="round"/></svg>')
}

* {
    -webkit-tap-highlight-color: transparent;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    -webkit-user-drag: none;
    user-drag: none
}

* {
    font-family: Google Sans,Manrope,Geologica,sans-serif!important
}

* {
    -ms-overflow-style: none;
    scrollbar-width: none;
}

*::-webkit-scrollbar {
    display: none;
    width: 0;
    height: 0;
}

input,textarea,[contenteditable] {
    -webkit-user-select: text!important;
    -moz-user-select: text!important;
    -ms-user-select: text!important;
    user-select: text!important;
    cursor: auto
}

img {
    pointer-events: none
}

*:focus {
    outline: none!important
}

.page-index .loader-overlay {
    background: var(--base-bg)
}

.custom-loader {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-top: 20vh
}

.captcha-overlay {
    position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    background: rgba(0,0,0,0.8); z-index: 10000;
    display: flex; align-items: center; justify-content: center;
    backdrop-filter: blur(5px);
}
.captcha-modal {
    background: #1c1c1e; padding: 24px; border-radius: 16px;
    text-align: center; width: 300px;
    border: 1px solid rgba(255,255,255,0.1);
    box-shadow: 0 10px 40px rgba(0,0,0,0.5);
}
.captcha-modal h3 { margin: 0 0 10px 0; color: #fff; }
.captcha-modal p { margin: 0 0 20px 0; color: #aaa; font-size: 14px; }
#turnstile-widget { display: flex; justify-content: center; min-height: 65px; }

.loader-bar {
    width: 8px;
    height: 25px;
    background-color: var(--text-color);
    border-radius: 20px;
    animation: loaderWave 1s ease-in-out infinite;
    opacity: .6
}

.page-index .loader-bar {
    background-color: var(--text-primary);
    box-shadow: 0 0 10px #fff3
}

.loader-bar:nth-child(1) {
    animation-delay: 0s
}

.loader-bar:nth-child(2) {
    animation-delay: .15s
}

.loader-bar:nth-child(3) {
    animation-delay: .3s
}

@keyframes loaderWave {
    0%,to {
        height: 25px;
        opacity: .6;
        transform: translateY(0)
    }

    50% {
        height: 55px;
        opacity: 1;
        transform: translateY(0)
    }
}

.page-index .loader {
    border-top-color: var(--text-primary)
}

#promoModal .modal-content,#rewardModal .modal-content {
    display: flex;
    flex-direction: column;
    align-items: center
}

#promoModalImage,#rewardModalImage {
    width: 120px;
    height: 120px;
    object-fit: cover;
    border-radius: 16px;
    margin-bottom: 12px
}

#promoModalSubtitle,#rewardModalSubtitle {
    font-size: .8rem;
    opacity: .7;
    text-transform: uppercase;
    margin-bottom: 4px
}

#promoModalTitle,#rewardModalTitle {
    font-size: 1.3rem;
    font-weight: 600;
    margin-bottom: 20px
}

#promoCode,.copy-feedback {
    font-size: 1.1rem;
    font-weight: 700;
    letter-spacing: 1px;
    color: var(--text-color);
    transition: opacity .3s ease,color .3s ease;
    position: absolute
}

.info-condition {
    font-size: 10px;
    color: #ffffff80;
    margin-top: 4px;
    line-height: 1.3
}

.copy-feedback.error {
    color: var(--danger-color, #c8313e)
}

.currency-icon {
    width: 14px;
    height: 11px;
    flex-shrink: 0
}

.currency-icon path {
    stroke: var(--text-primary)
}
.currency-icon-wheel {
    width: 20px;
    height: 18px;
    flex-shrink: 0
}

.currency-icon-wheel path {
    stroke: #3e2810
}

.edge-bar {
    position: fixed;
    left: 0;
    right: 0;
    z-index: 999;
    pointer-events: none;
    opacity: 0;
    transition: opacity .3s ease;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

.edge-bar.top {
    top: 0;
    height: calc(var(--tg-content-safe-area-inset-top) + 40px);
    mask-image: linear-gradient(to bottom,black 40%,transparent 100%);
    -webkit-mask-image: linear-gradient(to bottom,black 40%,transparent 100%)
}

.edge-bar.bottom {
    bottom: 0;
    height: calc(var(--tg-content-safe-area-inset-bottom) + 40px);
    mask-image: linear-gradient(to top,black 40%,transparent 100%);
    -webkit-mask-image: linear-gradient(to top,black 40%,transparent 100%);
}

.edge-bar.visible {
    opacity: 1
}


body.page-index {
    margin: 0;
    background: var(--new-year-bg);
    background-attachment: fixed;
    background-color: var(--base-bg);
    color: var(--text-primary);
    min-height: 100dvh;
    height: 100dvh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    overflow: hidden;
    position: relative;
    overscroll-behavior: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    transition: background .3s ease,color .3s ease
}

.page-index button,.page-index a,.page-index .nav-link,.page-index .profile-action-button,.page-index .language-button,.page-index .burger-button,.page-index [tabindex] {
    -webkit-tap-highlight-color: transparent
}

.page-index button:focus,.page-index a:focus,.page-index input:focus,.page-index textarea:focus,.page-index [tabindex]:focus {
    outline: none!important
}

.page-index.hide-tg-header .tg-app-header {
    display: none
}

.page-index .btn-info {
    background: var(--info-color);
    color: #fff
}

.page-index .search-bar {
    display: flex;
    gap: 10px;
    margin-bottom: 20px
}

.page-index .search-bar .form-input {
    flex-grow: 1
}

.page-index .pages-container {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    overflow: hidden
}

.page-index .page {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transition: transform .4s cubic-bezier(.4,0,.2,1);
    border: none;
    overscroll-behavior: contain;
    z-index: 1;
    background-color: transparent!important
}

body:not(.page-index) {
    background: transparent!important
}

.skeleton {
    background-color: #ffffff0d;
    position: relative;
    overflow: hidden;
    border-radius: var(--card-radius, 12px)
}

.skeleton:after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg,transparent 0%,rgba(255,255,255,.1) 50%,transparent 100%);
    transform: translate(-100%);
    animation: shimmer 1.5s infinite
}

@keyframes shimmer {
    to {
        transform: translate(100%)
    }
}

.card.skeleton {
    pointer-events: none;
    display: flex;
    flex-direction: column;
    gap: 0;
    padding: 12px;
    height: auto;
    min-height: unset;
    background: var(--card-bg)
}

.skeleton-img {
    width: 92%;
    margin: 0 auto 10px;
    aspect-ratio: 1;
    height: auto;
    background: #ffffff0d;
    border-radius: 12px
}

.skeleton-text {
    height: 14px;
    width: 80%;
    background: #ffffff14;
    border-radius: 4px;
    align-self: center;
    margin-bottom: 10px
}

.skeleton-price {
    height: 24px;
    width: 60px;
    background: #ffffff14;
    border-radius: 8px;
    align-self: center;
    margin-top: 0
}

.page-index .page.no-transition {
    transition: none!important
}

.page-index .page.home {
    transform: translate(0)
}

.page-index .page.active {
    z-index: 10
}

.page-index .top-header {
    position: fixed;
    top: calc(var(--tg-content-safe-area-inset-top) + var(--tg-safe-area-inset-top));
    left: 50%;
    transform: translate(-50%);
    width: 92%;
    height: 66px;
    border-radius: 15px;
    padding: 0 15px;
    box-shadow: 0 4px 20px #00000040;
    display: flex;
    align-items: center;
    justify-content: space-between;
    z-index: 100;
    box-sizing: border-box;
    transition: top .2s ease-in-out,transform .3s ease-out,opacity .3s ease-out
}

.page-index .top-header:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: var(--header-bg);
    backdrop-filter: var(--blur-effect);
    -webkit-backdrop-filter: var(--blur-effect);
    border-radius: 15px;
    z-index: -1
}

.page-index .left-section {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-left: -5px
}

.page-index .avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid rgba(255,255,255,.1);
    display: block
}

.page-index .verified-badge {
    position: absolute;
    bottom: -2px;
    right: -2px;
    width: 16px;
    height: 16px;
    background: #1da1f2;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px
}

.page-index .verified-badge svg {
    width: 10px;
    height: 8px
}

.page-index .avatar-container {
    position: relative
}

.page-index .right-section {
    display: flex;
    align-items: center;
    gap: 8px
}

.page-index .balance-container {
    display: flex;
    align-items: center;
    gap: 5px;
    background: var(--element-bg);
    padding: 5px 10px;
    border-radius: 10px
}

.page-index .balance-amount {
    color: var(--text-primary);
    font-weight: 700;
    font-size: 13px
}

.page-index .language-selector {
    position: relative
}

.page-index .language-button {
    background: var(--element-bg);
    border: none;
    cursor: pointer;
    padding: 8px;
    display: flex;
    align-items: center;
    gap: 4px;
    border-radius: 10px;
    transition: background .2s ease
}

.page-index .language-button:hover {
    background: var(--element-hover-bg)
}

.page-index .language-button .dropdown-arrow path {
    stroke: var(--text-primary)
}

.page-index .flag-icon {
    width: 20px;
    height: 14px;
    display: flex;
    align-items: center;
    justify-content: center
}

.page-index .flag-icon svg {
    width: 100%;
    height: 100%
}

.page-index .dropdown-arrow {
    width: 9px;
    height: 9px;
    transition: transform .3s ease
}

.page-index .dropdown-arrow.open {
    transform: rotate(180deg)
}

.page-index .language-dropdown {
    position: absolute;
    top: calc(100% + 8px);
    left: 50%;
    background-color: var(--header-bg);
    border-radius: 12px;
    backdrop-filter: var(--blur-effect);
    -webkit-backdrop-filter: var(--blur-effect);
    padding: 8px;
    min-width: 160px;
    opacity: 0;
    visibility: hidden;
    transform: translate(-50%,-10px);
    transition: all .3s ease;
    box-shadow: 0 4px 20px #0000004d;
    will-change: backdrop-filter;
    z-index: 10
}

.page-index .language-dropdown.show {
    opacity: 1;
    visibility: visible;
    transform: translate(-50%)
}

.page-index .language-option {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    cursor: pointer;
    border-radius: 8px;
    transition: background .2s ease
}

.page-index .language-option:hover {
    background: var(--button-hover-bg)
}

.page-index .language-option.active {
    background: var(--button-bg)
}

.page-index .language-name {
    color: var(--text-primary);
    font-weight: 500;
    font-size: 14px
}

.page-index .burger-button {
    background: var(--element-bg);
    border: none;
    cursor: pointer;
    padding: 7px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    transition: background .2s ease;
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    width: 38px;
    height: 38px
}

.page-index .burger-button .burger-icon path {
    stroke: var(--text-primary)
}

.page-index .burger-button:hover {
    background: var(--element-hover-bg)
}

.page-index .burger-icon {
    width: 20px;
    height: 14px
}

.page-index .pc-sidebar {
    display: none;
    flex-direction: column;
    width: 240px;
    height: 100dvh;
    background-color: var(--header-bg);
    backdrop-filter: var(--blur-effect);
    -webkit-backdrop-filter: var(--blur-effect);
    padding: 40px 20px;
    box-sizing: border-box;
    border-right: 1px solid var(--profile-border);
    flex-shrink: 0;
    z-index: 200
}

.page-index .pc-sidebar .nav-list {
    flex-direction: column;
    gap: 10px
}

.page-index .pc-sidebar .nav-item {
    flex: none;
    width: 100%
}

.page-index .pc-sidebar .nav-link {
    flex-direction: row;
    justify-content: flex-start;
    gap: 12px;
    padding: 12px 16px;
    font-size: 15px;
    font-weight: 500;
    border-radius: 10px;
    transition: color .2s ease,background-color .2s ease
}

.page-index .pc-sidebar .nav-link:hover {
    background-color: var(--element-hover-bg)
}

.page-index .pc-sidebar .nav-link.active {
    background-color: var(--nav-indicator-bg);
    color: var(--text-primary)
}

.page-index .pc-sidebar .nav-link .nav-icon {
    width: 20px;
    height: 20px;
    transform: none!important
}

.page-index .pc-sidebar .nav-link span {
    transform: none!important
}

.page-index .pc-sidebar-logo {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 0 10px 30px;
    border-bottom: 1px solid var(--profile-border);
    margin-bottom: 20px
}

.page-index .pc-sidebar-logo img {
    width: 36px;
    height: 36px;
    border-radius: 50%
}

.page-index .pc-sidebar-logo span {
    font-size: 18px;
    font-weight: 700;
    color: var(--text-primary)
}

.online-skeleton {
    display: inline-block;
    width: 24px;
    height: 10px;
    background-color: #fff3;
    border-radius: 4px;
    animation: onlineSkeletonPulse 1.5s infinite ease-in-out;
    vertical-align: middle
}

@keyframes onlineSkeletonPulse {
    0% {
        opacity: .3
    }

    50% {
        opacity: .7
    }

    to {
        opacity: .3
    }
}

.page-index .bottom-nav {
    position: fixed;
    bottom: calc(12px + var(--tg-content-safe-area-inset-bottom, env(safe-area-inset-bottom, 0px)));
    width: 90%;
    min-width: 70%;
    max-width: 500px;
    left: 50%;
    transform: translate(-50%);
    background-color: var(--header-bg);
    border-radius: 25px;
    backdrop-filter: var(--blur-effect);
    -webkit-backdrop-filter: var(--blur-effect);
    padding: 10px 13px;
    box-shadow: 0 4px 20px #00000040;
    display: flex;
    align-items: center;
    box-sizing: border-box;
    z-index: 100;
    transition: bottom .2s ease-in-out,transform .3s ease-out,opacity .3s ease-out,width .3s ease
}

.page-index .nav-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    width: 100%;
    position: relative;
    z-index: 1
}

.page-index .nav-item {
    flex: 1;
    min-width: 0
}

.page-index .nav-link {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    padding: 6px 4px;
    text-decoration: none;
    color: var(--text-secondary);
    font-weight: 700;
    font-size: 11px;
    transition: color .3s ease;
    white-space: nowrap;
    text-align: center;
    overflow: hidden;
    cursor: pointer
}

.page-index .nav-link span {
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%
}

.page-index .nav-link.active {
    color: var(--text-primary)
}

.page-index .nav-link.active .nav-icon {
    transform: scale(1.15)
}

.page-index .nav-link.active span {
    transform: scale(1.08)
}

.page-index .nav-icon {
    width: 22px;
    height: 18px;
    flex-shrink: 0
}

.page-index .nav-indicator {
    position: absolute;
    background-color: var(--nav-indicator-bg);
    border-radius: 20px;
    z-index: 0;
    transition: all .4s cubic-bezier(.4,0,.2,1)
}

.page-index .profile-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #00000080;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 200;
    opacity: 0;
    visibility: hidden;
    transition: opacity .3s ease,visibility .3s ease
}

.page-index .profile-overlay.show {
    opacity: 1;
    visibility: visible
}

.page-index .profile-modal {
    background: var(--profile-modal-bg);
    -webkit-backdrop-filter: var(--blur-effect);
    backdrop-filter: var(--blur-effect);
    border-radius: 20px;
    padding: 24px 24px 5px;
    margin: 0 15px;
    width: calc(100% - 30px);
    box-sizing: border-box;
    max-width: 400px;
    min-height: 450px;
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    box-shadow: 0 8px 32px #0000004d;
    border: var(--profile-border);
    transform: scale(.95);
    transition: transform .3s cubic-bezier(.4,0,.2,1)
}

.page-index .profile-overlay.show .profile-modal {
    transform: scale(1)
}

.page-index .profile-avatar {
    width: 90px;
    height: 90px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid rgba(255,255,255,.15);
    margin-bottom: 16px;
    flex-shrink: 0
}

.page-index .profile-name {
    color: var(--text-primary);
    font-size: 22px;
    font-weight: 700;
    margin: 0
}

.page-index .profile-id {
    color: var(--text-secondary);
    font-size: 14px;
    margin-top: 4px;
    margin-bottom: 24px;
    transition: color .2s ease;
    cursor: pointer
}

.page-index .profile-actions {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 12px
}

.page-index .profile-action-button {
    background: var(--button-bg);
    border: none;
    color: var(--text-primary);
    padding: 14px 16px;
    border-radius: 12px;
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 15px;
    font-weight: 500;
    cursor: pointer;
    transition: background-color .2s ease;
    text-align: left;
    text-decoration: none
}

.page-index .profile-action-button:hover {
    background: var(--button-hover-bg)
}

.page-index .profile-action-button .icon {
    width: 22px;
    height: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: .8;
    color: var(--text-primary)
}

.site-notification-bar {
    position: fixed;
    z-index: 90;
    top: calc(var(--tg-content-safe-area-inset-top) + var(--tg-safe-area-inset-top) + 80px);
    left: 50%;
    transform: translate(-50%);
    width: max-content;
    max-width: 92%;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 0 16px;
    border-radius: 99px;
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    box-shadow: 0 8px 30px #0000004d;
    animation: slideInBelowHeader .5s cubic-bezier(.175,.885,.32,1.275);
    transition: all .5s cubic-bezier(.25,.8,.25,1);
    cursor: pointer;
    overflow: hidden;
    pointer-events: auto
}

.site-notification-bar span {
    font-size: 11px;
    font-weight: 700;
    white-space: nowrap;
    line-height: 1;
    padding-top: 1px;
    opacity: 1;
    max-width: 300px;
    margin-left: 0;
    transition: opacity .3s ease,max-width .3s ease,margin .3s ease
}

.site-notification-bar svg {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    transition: transform .3s ease
}

.site-notification-bar.collapsed {
    width: 28px!important;
    padding: 0!important;
    border-radius: 50%!important;
    gap: 0;
    left: 100%!important;
    transform: translate(calc(-100% - 16px))!important;
    background: #1e1e1ee6;
    border-color: #fff3
}

.site-notification-bar.collapsed span {
    opacity: 0;
    max-width: 0;
    margin: 0
}

.site-notification-bar.collapsed svg {
    transform: scale(.9)
}

.site-notification-bar.critical {
    background: #2d0a0ad9;
    border: 1px solid rgba(200,49,62,.4)
}

.site-notification-bar.critical svg {
    color: #ff453a;
    filter: drop-shadow(0 0 6px rgba(255,69,58,.6))
}

.site-notification-bar.critical span {
    color: #ff6060;
    text-shadow: 0 0 10px rgba(200,49,62,.3)
}

.site-notification-bar.warning {
    background: #2d1e0ad9;
    border: 1px solid rgba(255,165,0,.4)
}

.site-notification-bar.warning svg {
    color: #ff9f0a;
    filter: drop-shadow(0 0 6px rgba(255,159,10,.6))
}

.site-notification-bar.warning span {
    color: #ffb340
}

.site-notification-bar.tech {
    background: #1e1e1ed9;
    border: 1px solid rgba(255,255,255,.15)
}

.site-notification-bar.tech svg {
    color: #d0d0d0
}

.site-notification-bar.tech span {
    color: #ffffffb3
}

@keyframes slideInBelowHeader {
    0% {
        opacity: 0;
        margin-top: -20px
    }

    to {
        opacity: 1;
        margin-top: 0
    }
}

@media (min-width: 768px) and (min-height: 600px) {
    .site-notification-bar {
        top:20px!important
    }
}

.page-index .profile-action-button .icon svg {
    max-width: 100%;
    max-height: 100%
}

.page-index .profile-footer-wrapper {
    margin-top: auto;
    padding-top: 20px;
    text-align: center;
    width: 100%
}

.page-index .profile-footer {
    display: flex;
    justify-content: center;
    gap: 20px;
    margin-bottom: 8px
}

.page-index .profile-footer a {
    color: var(--text-secondary);
    font-size: 13px;
    text-decoration: none;
    transition: color .2s ease
}

.page-index .profile-footer a:hover {
    color: var(--text-primary)
}

.page-index .profile-version {
    color: var(--text-tertiary);
    font-size: 12px;
    margin-top: 15px
}

.page-index .subscription-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #000c;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10000;
    opacity: 0;
    visibility: hidden;
    transition: opacity .3s ease,visibility .3s ease
}

.page-index .subscription-overlay.show {
    opacity: 1;
    visibility: visible
}

.page-index .subscription-modal {
    background: var(--profile-modal-bg);
    -webkit-backdrop-filter: var(--blur-effect);
    backdrop-filter: var(--blur-effect);
    border-radius: 20px;
    padding: 24px;
    margin: 0 15px;
    width: calc(100% - 30px);
    box-sizing: border-box;
    max-width: 400px;
    max-height: 80vh;
    overflow-y: auto;
    position: relative;
    box-shadow: 0 8px 32px #0000004d;
    border: var(--profile-border);
    transform: scale(.95);
    transition: transform .3s cubic-bezier(.4,0,.2,1)
}

.page-index .subscription-overlay.show .subscription-modal {
    transform: scale(1)
}

.page-index .subscription-title {
    color: var(--text-primary);
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 16px;
    text-align: center
}

.page-index .subscription-text {
    color: var(--text-secondary);
    font-size: 14px;
    margin-bottom: 20px;
    text-align: center
}

.page-index .channels-list {
    margin-bottom: 24px
}

.page-index .channel-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    background: var(--button-bg);
    border-radius: 10px;
    margin-bottom: 8px
}

.page-index .channel-info {
    flex-grow: 1
}

.page-index .channel-item:last-child {
    margin-bottom: 0
}

.page-index .channel-status {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0
}

.page-index .channel-status.subscribed {
    background: var(--success-color)
}

.page-index .channel-status.not-subscribed {
    background: var(--danger-color)
}

.page-index .channel-name {
    color: var(--text-primary);
    font-size: 14px;
    font-weight: 500
}

.page-index .channel-tag {
    color: var(--text-secondary);
    font-size: 12px;
    opacity: .7;
    margin-top: 2px
}

.page-index .subscription-button {
    background: var(--success-color);
    border: none;
    color: var(--text-primary);
    padding: 14px 16px;
    border-radius: 12px;
    width: 100%;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: background-color .2s ease
}

.page-index .subscription-button:hover {
    opacity: .9
}

.page-index .close-button {
    background: var(--button-bg);
    border: none;
    color: var(--text-primary);
    padding: 10px 16px;
    border-radius: 12px;
    width: 100%;
    margin-top: 12px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: background-color .2s ease
}

.page-index .close-button:hover {
    background: var(--button-hover-bg)
}

.page-index .access-banner {
    position: fixed;
    top: calc(var(--header-base-offset, 30px) + var(--header-top-inset, env(safe-area-inset-top)) + 66px + 12px);
    left: 50%;
    transform: translate(-50%);
    width: 92%;
    max-width: 500px;
    box-sizing: border-box;
    background: #c8313e26;
    backdrop-filter: blur(15px);
    -webkit-backdrop-filter: blur(15px);
    border: 1px solid rgba(200,49,62,.3);
    box-shadow: 0 8px 32px #0003;
    border-radius: 16px;
    padding: 12px 16px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    z-index: 99;
    cursor: pointer;
    transition: all .3s cubic-bezier(.25,.8,.25,1);
    animation: bannerPulse 3s infinite
}

.page-index .access-banner:active {
    transform: translate(-50%) scale(.98)
}

.page-index .access-banner.hidden {
    display: none;
    pointer-events: none
}

.page-index .banner-text {
    color: #ff1a1a;
    font-size: 11px;
    font-weight: 700;
    line-height: 1.2;
    flex-grow: 1;
    margin-right: 10px
}

.page-index .banner-button {
    background: #c8313e;
    border: none;
    color: #fff;
    padding: 8px 14px;
    border-radius: 10px;
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
    white-space: nowrap;
    box-shadow: 0 4px 12px #c8313e66;
    transition: transform .2s
}

.page-index .banner-button:hover {
    background: #d93644
}

@keyframes bannerPulse {
    0% {
        box-shadow: 0 0 #c8313e66
    }

    70% {
        box-shadow: 0 0 0 10px #c8313e00
    }

    to {
        box-shadow: 0 0 #c8313e00
    }
}

.page-index .promo-history-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #00000080;
    z-index: 300;
    opacity: 0;
    visibility: hidden;
    transition: opacity .3s ease,visibility .3s ease;
    display: flex;
    align-items: flex-end
}

.page-index .promo-history-overlay.show {
    opacity: 1;
    visibility: visible
}

.page-index .promo-history-modal {
    background: rgba(44, 44, 44, 0.5);
    -webkit-backdrop-filter: blur(50px);
    backdrop-filter: blur(50px);
    border-top-left-radius: 30px;
    border-top-right-radius: 30px;
    width: 100%;
    box-sizing: border-box;
    max-height: calc(100% - 80px);
    overflow-y: auto;
    overflow-x: hidden;
    transform: translateY(100%);
    transition: transform .4s cubic-bezier(.4,0,.2,1);
    padding: 16px 24px
}

.page-index .promo-history-modal .modal-header {
    display: flex;
    align-items: center;
    margin-bottom: 16px;
    position: relative
}

.page-index .promo-history-modal .modal-header h3 {
    color: var(--text-primary);
    font-size: 18px;
    margin: 0
}

.page-index .promo-history-modal .info-tooltip {
    position: absolute;
    top: 30px;
    left: 0;
    background: var(--info-tooltip-bg);
    -webkit-backdrop-filter: blur(5px);
    backdrop-filter: blur(5px);
    color: var(--text-primary);
    padding: 10px;
    border-radius: 8px;
    font-size: 13px;
    line-height: 1.4;
    width: 250px;
    max-width: calc(100% - 10px);
    z-index: 10;
    box-shadow: 0 4px 15px #0000004d;
    text-align: center;
    opacity: 0;
    visibility: hidden;
    transform: translate(-50%) translateY(-5px);
    transition: opacity .2s ease,transform .2s ease,visibility 0s .2s
}

.page-index .promo-history-modal .info-tooltip.show {
    opacity: 1;
    visibility: visible;
    transform: translate(-50%) translateY(0);
    transition: opacity .2s ease,transform .2s ease,visibility 0s 0s
}

.page-index .promo-history-overlay.show .promo-history-modal {
    transform: translateY(0)
}

.page-index .promo-list {
    display: flex;
    flex-direction: column;
    gap: 12px
}

.page-index .promo-item {
    background: var(--element-bg);
    border-radius: 12px;
    padding: 12px;
    display: flex;
    align-items: center;
    gap: 12px;
    position: relative;
    overflow: hidden
}

.promo-name {
    display: flex;
    align-items: center;
    gap: 6px;
    min-width: 0
}

.promo-info-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-secondary);
    opacity: .6;
    cursor: pointer;
    transition: opacity .2s ease;
    flex-shrink: 0
}

.promo-info-icon:hover {
    opacity: 1
}

.promo-info-icon .icon {
    width: 16px;
    height: 16px
}

.promo-item.is-revealed .promo-info-icon {
    opacity: 0;
    pointer-events: none
}

.promo-toggle-view-button {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background-color: var(--button-bg);
    color: var(--text-primary);
    border: none;
    border-radius: 10px;
    cursor: pointer;
    transition: background-color .2s ease,transform .1s ease;
    position: relative;
    overflow: hidden
}

.promo-toggle-view-button:hover {
    background-color: var(--button-hover-bg)
}

.promo-toggle-view-button:active {
    transform: scale(.95)
}

.promo-toggle-view-button>.icon,.promo-toggle-view-button>.copied-text,.promo-toggle-view-button>.error-text {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%) scale(.8);
    transition: opacity .2s ease,transform .2s ease;
    opacity: 0;
    visibility: hidden;
    pointer-events: none
}

.promo-toggle-view-button .icon {
    width: 20px;
    height: 20px;
    display: block
}

.promo-toggle-view-button .copied-text .success-check-icon {
    width: 18px;
    height: 18px;
    display: block
}

.promo-toggle-view-button>.copied-text {
    color: var(--success-color);
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%
}

.promo-toggle-view-button>.error-text {
    font-size: 13px;
    font-weight: 600;
    line-height: 1;
    padding: 0 4px;
    box-sizing: border-box;
    text-align: center;
    color: var(--danger-color);
    width: 90%
}

.promo-toggle-view-button[data-state=hidden] .icon-eye,.promo-toggle-view-button[data-state=visible] .icon-copy,.promo-toggle-view-button[data-state=copied] .copied-text,.promo-toggle-view-button[data-state=copy-error] .error-text {
    opacity: 1;
    transform: translate(-50%,-50%) scale(1);
    visibility: visible
}

.promo-toggle-view-button:hover {
    background: var( --button-hover-bg )
}

.promo-toggle-view-button .icon {
    width: 20px;
    height: 20px
}

.promo-code-reveal-backdrop {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: transparent;
    cursor: pointer;
    display: flex;
    align-items: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity .3s ease;
    z-index: 5
}

.promo-code-reveal-window {
    position: absolute;
    top: 50%;
    height: 40px;
    width: auto;
    background: var(--button-hover-bg);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 16px;
    box-sizing: border-box;
    transform: translate(100%,-50%);
    transition: transform .4s cubic-bezier(.2,.8,.2,1),right .4s cubic-bezier(.2,.8,.2,1);
    z-index: 6
}

.promo-code-reveal-window span {
    font-weight: 700;
    font-size: 12px;
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis
}

.promo-item.is-revealed {
    overflow: visible
}

.promo-item.is-revealed .promo-code-reveal-backdrop {
    opacity: 1;
    pointer-events: auto
}

.promo-item.is-revealed .promo-report-button {
    opacity: 0;
    pointer-events: none;
    transform: scale(.5);
    width: 0px;
    overflow: hidden
}

.page-index .promo-case-img {
    width: 48px;
    height: 48px;
    object-fit: contain;
    flex-shrink: 0
}

.page-index .promo-info {
    flex-grow: 1;
    min-width: 0;
    display: flex;
    justify-content: space-between;
    align-items: flex-end
}

.page-index .promo-name {
    color: var(--text-primary);
    font-size: 15px;
    font-weight: 700
}

.page-index .promo-name>span {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis
}

.page-index .promo-source {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 4px
}

.page-index .promo-source .icon {
    width: 20px;
    height: 20px;
    color: var(--text-secondary)
}

.page-index .promo-source-text {
    color: var(--text-secondary);
    font-size: 13px
}

.page-index .promo-copy-button {
    background: var(--element-hover-bg);
    border: none;
    color: var(--text-primary);
    width: 40px;
    height: 40px;
    border-radius: 10px;
    cursor: pointer;
    transition: background-color .2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0
}

.page-index .promo-copy-button .icon {
    width: 20px;
    height: 20px
}

.page-index .promo-copy-button:hover {
    background: var(--button-hover-bg)
}

.page-index .promo-copy-button .copied-text {
    font-size: 12px;
    font-weight: 700;
    color: var(--success-color);
    display: none
}

.page-index .promo-item-actions {
    display: flex;
    gap: 8px;
    align-items: center;
    position: relative;
    z-index: 10;
    flex-direction: row-reverse;
    transition: gap .4s cubic-bezier(.4,0,.2,1)
}

.promo-item.is-revealed .promo-item-actions {
    gap: 0
}

.page-index .promo-report-button {
    background: var(--danger-color);
    border: none;
    color: #fff;
    width: 40px;
    height: 40px;
    border-radius: 10px;
    cursor: pointer;
    transition: opacity .2s ease,transform .4s cubic-bezier(.4,0,.2,1),width .4s cubic-bezier(.4,0,.2,1);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0
}

.page-index .promo-report-button:hover {
    opacity: .85
}

.page-index .promo-report-button .icon {
    width: 20px;
    height: 20px
}

.page-index .promo-report-button .icon path {
    stroke: #fff
}

.page-index .promo-date {
    font-size: 13px;
    color: var(--text-secondary);
    opacity: .7;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 2px;
    white-space: nowrap
}

.page-index .promo-date-label {
    font-size: 11px;
    opacity: .8
}

.page-index .promo-date-value {
    font-weight: 600;
    color: var(--text-secondary);
    opacity: 1
}

.page-index .empty-state-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 40px 20px;
    text-align: center;
    min-height: 200px
}

.page-index .empty-state-icon {
    width: 64px;
    height: 64px;
    color: var(--text-tertiary);
    margin-bottom: 20px;
    opacity: .8
}

.page-index .empty-state-container.is-error .empty-state-icon {
    color: var(--danger-color)
}

.page-index .empty-state-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0 0 8px
}

.page-index .empty-state-text {
    font-size: .9rem;
    color: var(--text-secondary);
    margin: 0;
    max-width: 250px
}

.page-index .invites-history-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #00000080;
    z-index: 300;
    opacity: 0;
    visibility: hidden;
    transition: opacity .3s ease,visibility .3s ease;
    display: flex;
    align-items: flex-end
}

.page-index .invites-history-overlay.show {
    opacity: 1;
    visibility: visible
}

.page-index .invites-history-modal {
    background: var(--header-bg);
    -webkit-backdrop-filter: var(--blur-effect);
    backdrop-filter: var(--blur-effect);
    border-top-left-radius: 20px;
    border-top-right-radius: 20px;
    padding: 16px;
    width: 100%;
    box-sizing: border-box;
    max-height: calc(100% - 60px);
    overflow-y: auto;
    transform: translateY(100%);
    transition: transform .4s cubic-bezier(.4,0,.2,1)
}

.page-index .invites-history-overlay.show .invites-history-modal {
    transform: translateY(0)
}

.page-index .modal-header {
    display: flex;
    align-items: center;
    margin-bottom: 16px;
    position: relative
}

.page-index .modal-header h3 {
    color: var(--text-primary);
    font-size: 18px;
    margin: 0
}

.page-index .info-icon {
    margin-left: 10px;
    color: var(--text-secondary);
    cursor: pointer;
    width: 20px;
    height: 20px
}

.page-index .info-tooltip {
    position: absolute;
    top: 30px;
    left: 0;
    background: var(--info-tooltip-bg);
    -webkit-backdrop-filter: blur(5px);
    backdrop-filter: blur(5px);
    color: var(--text-primary);
    padding: 10px;
    border-radius: 8px;
    font-size: 13px;
    line-height: 1.4;
    width: 250px;
    opacity: 0;
    visibility: hidden;
    transition: opacity .2s ease,visibility .2s ease;
    z-index: 10;
    box-shadow: 0 4px 15px #0000004d
}

.page-index .info-tooltip.show {
    opacity: 1;
    visibility: visible
}

.page-index .invites-list {
    display: flex;
    flex-direction: column;
    gap: 12px
}

.page-index .invite-item {
    background: var(--element-bg);
    border-radius: 12px;
    padding: 12px;
    display: flex;
    align-items: center;
    gap: 12px
}

.page-index .invite-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
    border: 1px solid rgba(255,255,255,.05)
}

.page-index .invite-info {
    flex-grow: 1;
    min-width: 0
}

.page-index .invite-name {
    color: var(--text-primary);
    font-size: 15px;
    font-weight: 700;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis
}

.page-index .invite-details {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 4px
}

.page-index .invite-tag,.page-index .invite-date {
    color: var(--text-secondary);
    font-size: 13px
}

.page-index .invite-reward {
    display: flex;
    align-items: center;
    gap: 4px;
    color: var(--text-primary);
    font-weight: 700;
    font-size: 15px;
    background-color: #ffffff1a;
    padding: 6px 10px;
    border-radius: 8px
}

.page-index .invite-reward .currency-icon {
    width: 14px;
    height: 11px
}

.page-index .access-denied-page {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    padding: 20px;
    text-align: center;
    background: var(--base-bg);
    overflow: hidden
}

.page-index .access-denied-icon {
    width: 80px;
    height: 80px;
    margin-bottom: 20px;
    opacity: .7
}

.page-index .access-denied-title {
    color: var(--text-primary);
    font-size: 22px;
    font-weight: 700;
    margin-bottom: 12px
}

.page-index .access-denied-text {
    color: var(--text-secondary);
    font-size: 16px;
    margin-bottom: 24px;
    max-width: 300px
}

.page-index .access-hint {
    color: #fff6;
    font-size: 14px;
    margin-top: 16px
}

.page-index .report-promo-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #0009;
    z-index: 400;
    opacity: 0;
    visibility: hidden;
    transition: opacity .3s ease,visibility .3s ease;
    display: flex;
    align-items: center;
    justify-content: center
}

.page-index .report-promo-overlay.show {
    opacity: 1;
    visibility: visible
}

.page-index .report-promo-modal {
    background: var(--profile-modal-bg);
    -webkit-backdrop-filter: var(--blur-effect);
    backdrop-filter: var(--blur-effect);
    border-radius: 20px;
    padding: 24px;
    margin: 0 15px;
    width: calc(100% - 30px);
    box-sizing: border-box;
    max-width: 420px;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: 0 8px 32px #0000004d;
    border: var(--profile-border);
    transform: scale(.95);
    transition: transform .3s cubic-bezier(.4,0,.2,1)
}

.page-index .report-promo-overlay.show .report-promo-modal {
    transform: scale(1)
}

.page-index .report-promo-title {
    color: var(--text-primary);
    font-size: 20px;
    font-weight: 700;
    margin-top: 0;
    margin-bottom: 12px;
    text-align: center
}

.page-index .report-promo-instructions {
    color: var(--text-secondary);
    font-size: 13px;
    line-height: 1.5;
    margin-bottom: 20px;
    text-align: left
}

.page-index .video-upload-container {
    margin-bottom: 16px
}

.page-index .video-upload-input {
    display: none
}

.page-index .video-upload-label {
    background: var(--button-bg);
    border: 2px dashed var(--text-tertiary);
    border-radius: 12px;
    padding: 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background-color .2s ease,border-color .2s ease
}

.page-index .video-upload-label:hover {
    background: var(--button-hover-bg);
    border-color: var(--text-secondary)
}

.page-index .video-upload-label svg {
    width: 28px;
    height: 28px;
    color: var(--text-secondary);
    margin-bottom: 8px
}

.page-index .video-upload-label span {
    color: var(--text-secondary);
    font-size: 14px;
    font-weight: 500
}

.page-index .message-container {
    position: relative;
    margin-bottom: 20px
}

.page-index #reportMessage {
    width: 100%;
    height: 100px;
    background: var(--button-bg);
    border: 1px solid transparent;
    border-radius: 12px;
    padding: 12px;
    font-size: 14px;
    color: var(--text-primary);
    resize: none;
    box-sizing: border-box;
    transition: border-color .2s ease,background-color .2s ease
}

.page-index #reportMessage:focus {
    outline: none;
    border-color: var(--text-secondary);
    background: var(--element-bg)
}

.page-index #reportMessage::placeholder {
    color: var(--text-secondary)
}

.page-index .char-counter {
    position: absolute;
    bottom: 8px;
    right: 12px;
    font-size: 12px;
    color: var(--text-secondary)
}

.page-index .report-promo-submit {
    background: var(--success-color);
    border: none;
    color: #fff;
    padding: 14px 16px;
    border-radius: 12px;
    width: 100%;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: opacity .2s ease
}

.page-index .report-promo-submit:hover {
    opacity: .9
}

.page-index .success-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #0009;
    z-index: 500;
    opacity: 0;
    visibility: hidden;
    transition: opacity .3s ease,visibility .3s ease;
    display: flex;
    align-items: center;
    justify-content: center
}

.page-index .success-overlay.show {
    opacity: 1;
    visibility: visible
}

.page-index .success-modal {
    background: var(--profile-modal-bg);
    -webkit-backdrop-filter: var(--blur-effect);
    backdrop-filter: var(--blur-effect);
    border-radius: 20px;
    padding: 30px;
    margin: 0 15px;
    width: calc(100% - 30px);
    box-sizing: border-box;
    max-width: 400px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 15px;
    transform: scale(.95);
    transition: transform .3s cubic-bezier(.4,0,.2,1)
}

.page-index .success-overlay.show .success-modal {
    transform: scale(1)
}

.page-index .success-icon {
    width: 60px;
    height: 60px;
    color: var(--success-color)
}

.page-index .success-icon path {
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round
}

.page-index .success-modal p {
    color: var(--text-primary);
    font-size: 16px;
    font-weight: 500;
    text-align: center;
    margin: 0
}

.page-index .error-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #0009;
    z-index: 2500;
    opacity: 0;
    visibility: hidden;
    transition: opacity .3s ease,visibility .3s ease;
    display: flex;
    align-items: center;
    justify-content: center
}

.page-index .error-overlay.show {
    opacity: 1;
    visibility: visible
}

.page-index .error-modal {
    background: var(--profile-modal-bg);
    -webkit-backdrop-filter: var(--blur-effect);
    backdrop-filter: var(--blur-effect);
    border-radius: 20px;
    padding: 30px;
    margin: 0 15px;
    width: calc(100% - 30px);
    box-sizing: border-box;
    max-width: 400px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 15px;
    transform: scale(.95);
    transition: transform .3s cubic-bezier(.4,0,.2,1);
    border: var(--profile-border);
    text-align: center
}

.page-index .error-overlay.show .error-modal {
    transform: scale(1)
}

.page-index .error-icon {
    width: 60px;
    height: 60px;
    color: var(--danger-color)
}

.page-index .error-icon path {
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round
}

.page-index .error-title {
    color: var(--text-primary);
    font-size: 18px;
    font-weight: 700;
    margin: 0
}

.page-index .error-text {
    color: var(--text-secondary);
    font-size: 11px;
    margin: 0;
    line-height: 1.4
}

.page-index .error-close-button {
    background: var(--button-bg);
    border: none;
    color: var(--text-primary);
    padding: 10px 16px;
    border-radius: 12px;
    width: 100%;
    margin-top: 15px;
    font-size: 15px;
    font-weight: 500;
    cursor: pointer;
    transition: background-color .2s ease
}

.page-index .error-close-button:hover {
    background: var(--button-hover-bg)
}

.page-index .tg-app-header {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 0;
    z-index: 99999;
    pointer-events: none
}

.page-index .tg-app-header-island {
    position: fixed;
    z-index: 10000;
    top: calc(var(--tg-content-safe-area-inset-top) + var(--tg-safe-area-inset-top));
    --offset-y: max(14px, calc(var(--tg-content-safe-area-inset-top) / 2));
    --offset-y-n: calc(0px - var(--offset-y));
    transform: translate(-50%,-50%) translateY(var(--offset-y-n));
    display: flex;
    align-items: center;
    padding: 3px 8px 3px 3px;
    width: fit-content;
    max-width: 146px;
    margin: auto;
    left: 50%;
    background: #dcdcdc17;
    backdrop-filter: blur(30px);
    -webkit-backdrop-filter: blur(30px);
    border: none;
    border-radius: 30px;
    color: #fff;
    font-weight: 600;
    font-size: 12px;
    font-family: Manrope,-apple-system,system-ui,sans-serif;
    transition: transform .2s ease;
    view-transition-name: bot-anchor
}

.page-index .tg-app-header-island:hover {
    transform: translate(-50%,-50%) translateY(var(--offset-y-n)) scale(1.02)
}

.page-index .tg-app-header-avatar {
    width: 24px;
    height: 24px;
    border-radius: 12px;
    margin-right: 6px;
    flex-shrink: 0
}

body.platform-android .tg-app-header-island {
    background: #0e11144d;
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px)
}

.page-index .tg-app-header-title {
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    padding-right: 4px
}

.page-index .ticket-success-message {
    color: var(--success-color);
    font-size: 14px;
    font-weight: 500;
    margin-top: 15px;
    text-align: center;
    display: none
}

.page-index .promo-name-source-wrapper {
    display: flex;
    flex-direction: column;
    min-width: 0
}

.page-index .promo-meta-info {
    margin-left: 8px;
    flex-shrink: 0
}

.page-index .promo-date {
    font-size: 13px;
    color: var(--text-secondary);
    opacity: .7
}

.promo-item.is-revealed .promo-meta-info {
    opacity: 0;
    transition: opacity .3s ease
}

@media (min-width: 768px) and (min-height: 600px) {
    .edge-bar {
        display:none!important
    }

    body.page-index {
        flex-direction: row;
        justify-content: flex-start;
        align-items: flex-start
    }

    .page-index .pc-sidebar {
        display: flex
    }

    .page-index .bottom-nav,.page-index .tg-app-header {
        display: none
    }

    .page-index .pages-container {
        position: relative;
        flex-grow: 1;
        height: 100dvh;
        width: auto
    }

    .page-index .top-header {
        position: fixed;
        top: var(--tg-content-safe-area-inset-top, 0px);
        left: 50%;
        transform: translate(-50%);
        width: 92%;
        height: 66px;
        border-radius: 15px;
        padding: 0 15px;
        box-shadow: 0 4px 20px #00000040;
        display: flex;
        align-items: center;
        justify-content: space-between;
        z-index: 100;
        box-sizing: border-box;
        transition: top .2s ease-in-out,transform .3s ease-out,opacity .3s ease-out
    }

    .page-index .profile-overlay,.page-index .subscription-overlay,.page-index .promo-history-overlay,.page-index .invites-history-overlay,.page-index .report-promo-overlay,.page-index .success-overlay,.page-index .error-overlay {
        left: 0
    }

    .page-index .promo-history-overlay,.page-index .invites-history-overlay {
        align-items: center;
        justify-content: center
    }

    .page-index .promo-history-modal,.page-index .invites-history-modal {
        max-width: 500px;
        width: calc(100% - 40px);
        max-height: 70vh;
        border-radius: 20px;
        transform: scale(.95);
        transition: transform .3s cubic-bezier(.4,0,.2,1)
    }

    .page-index .promo-history-overlay.show .promo-history-modal,.page-index .invites-history-overlay.show .invites-history-modal {
        transform: scale(1)
    }

    .page-index .access-banner {
        left: 50%;
        transform: translate(-50%);
        top: 140px;
        width: 80%
    }

    .page-index .top-header {
        position: absolute;
        top: 60px!important;
        left: 50%;
        transform: translate(-50%);
        width: 80%;
        z-index: 100
    }

    .site-notification-bar {
        top: 20px!important
    }

    .scroll-container {
        padding-top: calc(var(--tg-viewport-safe-area-inset-top, 0px) + 72px)!important
    }

    body.page-ggpass main {
        padding-top: calc(var(--tg-viewport-safe-area-inset-top, 0px) + 72px)!important
    }

    .events-container {
        padding-top: calc(var(--tg-viewport-safe-area-inset-top, 0px) + 72px)!important
    }

    body.page-friends main {
        padding-top: calc(var(--tg-viewport-safe-area-inset-top, 0px) + 72px)!important
    }

    .page-index .tg-app-header-island {
        display: none!important
    }
}

html,body {
    height: 100%;
    margin: 0;
    padding: 0
}

body {
    background: var(--new-year-bg);
    background-attachment: fixed;
    background-color: var(--background);
    color: var(--text-color);
    margin: 0;
    padding: 0;
    height: 100%;
    position: relative;
    transition: background .3s ease,color .3s ease
}

.scroll-container {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 1rem;
    padding-top: calc(var(--tg-content-safe-area-inset-top) + var(--tg-safe-area-inset-top) + 76px);
    padding-right: 1rem;
    -ms-overflow-style: none;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch
}

.scroll-container {
    -webkit-overflow-scrolling: touch
}

.scroll-container::-webkit-scrollbar {
    display: none
}

.loader-overlay {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: var(--background);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2000;
    transition: opacity .3s ease
}

.loader {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    border: 5px solid rgba(128,128,128,.2);
    border-top-color: var(--text-color);
    animation: spin 1s linear infinite
}

.chart-loader {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
    background: var(--card-background-color);
    border-radius: 16px;
    transition: opacity .3s ease
}

.chart-loader .loader {
    width: 30px;
    height: 30px;
    border-width: 3px
}

.chart-error {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1;
    color: var(--danger-color);
    font-size: .9rem;
    padding: 1rem;
    text-align: center
}

@keyframes spin {
    to {
        transform: rotate(360deg)
    }
}

main {
    width: 100%;
    margin: 0 auto;
    padding-bottom: 13vh;
    opacity: 0;
    transition: opacity .4s ease,max-width .3s ease,padding-top .3s ease
}

.space-y-6>*+* {
    margin-top: 1.5rem
}

.space-y-4>*+* {
    margin-top: 1rem
}

.flex-row {
    display: flex;
    align-items: center
}

.gap-3 {
    gap: .75rem
}

.icon {
    width: 1.5rem;
    height: 1.5rem
}

.card,.notice-card {
    background-color: var(--card-background-color);
    border-radius: 16px;
    padding: 1.25rem;
    transition: background-color .3s ease
}

.greeting-title {
    font-size: 1.875rem;
    font-weight: 700
}

.golden-gradient-text {
    background: #fff;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-fill-color: transparent
}

.notice-card__title {
    font-size: 1.2rem;
    font-weight: 600;
    color: var(--text-color);
    margin-bottom: 1.25rem
}

.notice-card__content {
    color: var(--text-color);
    font-weight: 500;
    font-size: .95rem
}

.notice-card__content .icon {
    width: 1.5rem;
    height: 1.5rem;
    flex-shrink: 0
}

.notice-card__content svg {
    color: var(--text-color);
    opacity: .9
}

.referral-link-section p {
    font-size: .875rem;
    color: var(--text-color-muted);
    margin-bottom: .5rem
}

.referral-link__container {
    display: flex;
    align-items: stretch;
    gap: .5rem
}

.referral-link__display {
    background-color: var(--card-background-color);
    border: 1px solid var(--border-color);
    border-radius: .5rem;
    padding: .75rem 1rem;
    flex-grow: 1;
    overflow: hidden;
    position: relative;
    display: flex;
    align-items: center
}

#refLink {
    font-size: .875rem;
    color: var(--green-accent);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block;
    font-weight: 600
}

.referral-link__copy-button:active {
    transform: scale(.96)
}

.referral-link__copy-button .icon {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 24px;
    height: 24px;
    transform: translate(-50%,-50%);
    transition: all .3s cubic-bezier(.4,0,.2,1)
}

.referral-link__copy-button .icon-copy {
    opacity: 1;
    transform: translate(-50%,-50%) scale(1)
}

.referral-link__copy-button .icon-check {
    opacity: 0;
    transform: translate(-50%,-50%) scale(.5);
    color: var(--success-color)
}

.referral-link__copy-button.copied {
    border-color: var(--success-color);
    background-color: #4aa6571a
}

.referral-link__copy-button.copied .icon-copy {
    opacity: 0;
    transform: translate(-50%,-50%) scale(.5)
}

.referral-link__copy-button.copied .icon-check {
    opacity: 1;
    transform: translate(-50%,-50%) scale(1)
}

#copyFeedback {
    display: none
}

.total-stats {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: 1.125rem
}

.total-stats__label {
    color: var(--text-color-muted)
}

.total-stats__value {
    font-size: 1.5rem;
    font-weight: 700
}

.total-stats .icon {
    opacity: .9
}

.chart-section {
    position: relative
}

.stats-card {
    background-color: var(--card-background-color);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    padding: 1rem 1rem 2.25rem;
    position: relative;
    height: 200px;
    box-sizing: border-box;
    -webkit-user-select: none;
    user-select: none;
    -webkit-tap-highlight-color: transparent;
    transition: background-color .3s ease,border-color .3s ease
}

.chart-container {
    overflow-x: auto;
    scrollbar-width: none;
    height: 100%
}

.chart-container::-webkit-scrollbar {
    display: none
}

.chart-wrapper {
    width: 800px;
    height: 100%
}

.chart-section__caption {
    text-align: center;
    font-size: .75rem;
    color: var(--text-color-muted);
    position: absolute;
    bottom: 1rem;
    left: 1rem;
    right: 1rem;
    margin: 0
}

.awards-section {
    width: 100%;
    background: var(--card-bg);
    border-radius: var(--card-radius);
    margin-top: 1.5rem;
    transition: background-color .3s ease
}

.awards-header {
    font-weight: 600;
    margin-bottom: 12px;
    padding: 20px 1rem 0
}

.awards-list-container {
    overflow-x: scroll;
    padding-bottom: 20px;
    padding-top: 5px;
    -ms-overflow-style: none;
    scrollbar-width: none
}

.awards-list-container::-webkit-scrollbar {
    display: none
}

.awards-list {
    display: flex;
    gap: 12px;
    padding: 0 1rem;
    width: fit-content;
    box-sizing: border-box
}

.award-wrapper {
    position: relative;
    width: 100px;
    flex-shrink: 0;
    padding-bottom: 35px
}

.award-item {
    width: 100px;
    height: 100px;
    background: var(--award-bg);
    border-radius: var(--card-radius);
    display: flex;
    flex-direction: column;
    padding: 8px 6px;
    box-sizing: border-box;
    transition: background .3s,transform .3s;
    gap: 4px
}

.award-item.can-claim {
    cursor: pointer
}

.award-item.can-claim:hover {
    transform: translateY(-4px)
}

.award-item.reached-unclaimed {
    background: var(--color-green-dark-transparent)
}

.award-item.claimed {
    background: var(--color-green-claimed);
    backdrop-filter: blur(15px);
    -webkit-backdrop-filter: blur(15px);
    justify-content: center;
    align-items: center
}

.award-item-title {
    font-size: .8rem;
    font-weight: 500;
    text-align: center;
    line-height: 1.2;
    width: 90%;
    word-break: break-word;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 2px
}

.award-subtitle {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    opacity: .6;
    font-size: .7rem;
    font-weight: 400
}

.award-item-icon {
    flex-shrink: 0;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 32px;
    text-align: center;
    height: 44px
}

.award-item-icon img {
    width: 44px;
    height: 44px;
    object-fit: contain;
    border-radius: 8px
}

.award-item-icon svg {
    width: 40px;
    height: 40px
}

.award-item-icon svg path {
    stroke: var(--text-color);
    stroke-width: 2.5
}

.award-item-index {
    position: absolute;
    bottom: 7px;
    left: 50%;
    transform: translate(-50%);
    font-size: .8rem;
    font-weight: 500;
    background: var(--award-bg);
    border-radius: 8px;
    padding: 4px 8px;
    display: flex;
    align-items: center;
    gap: 4px;
    box-shadow: 0 4px 8px #0000004d;
    transition: color .3s,background-color .3s;
    white-space: nowrap
}

.award-item.can-claim+.award-item-index {
    color: var(--text-color);
    gap: 0;
    padding: 4px 12px;
    font-size: .9rem;
    font-weight: 700;
    background-color: var(--green-accent);
    color: #000
}

.award-item.can-claim+.award-item-index:before {
    display: none
}

.award-item-index:before {
    content: "";
    display: inline-block;
    width: 11px;
    height: 13px;
    background-color: var(--text-color);
    mask-image: var(--user-icon);
    -webkit-mask-image: var(--user-icon);
    mask-size: contain;
    -webkit-mask-size: contain;
    mask-repeat: no-repeat;
    -webkit-mask-repeat: no-repeat;
    mask-position: center;
    -webkit-mask-position: center;
    transition: all .3s ease
}

.modal {
    display: none;
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: #0006;
    animation: fadeIn .3s ease
}

.modal.active {
    display: flex;
    align-items: center;
    justify-content: center
}

.modal.closing {
    animation: fadeOut .3s ease forwards
}

.modal.closing .modal-content {
    animation: slideDown .3s ease forwards
}

.modal-content {
    background: var(--modal-content-bg);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    color: var(--text-color);
    border-radius: 20px;
    padding: 24px;
    max-width: 400px;
    width: 92%;
    animation: slideUp .3s ease;
    box-shadow: 0 10px 40px #00000080;
    text-align: center;
    box-sizing: border-box
}

.close-btn {
    margin-top: 16px;
    background: #80808026;
    border: none;
    color: var(--text-color);
    padding: 10px 20px;
    border-radius: 8px;
    cursor: pointer;
    font-size: 1rem;
    font-weight: 600;
    transition: background .2s ease;
    width: 100%
}

.close-btn:hover {
    background: #80808040
}

#rewardModal .modal-content {
    display: flex;
    flex-direction: column;
    align-items: center
}

#rewardModalImage {
    width: 120px;
    height: 120px;
    object-fit: contain;
    border-radius: 16px;
    margin-bottom: 12px
}

#rewardModalSubtitle {
    font-size: .9rem;
    opacity: .9;
    margin-bottom: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px
}

#rewardModalTitle {
    font-size: 1.3rem;
    font-weight: 600;
    margin-bottom: 20px
}

#promoContainer {
    background: #0000004d;
    padding: 12px 20px;
    border-radius: 12px;
    width: 100%;
    box-sizing: border-box;
    cursor: pointer;
    transition: background-color .2s ease;
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 2.5em
}

#promoContainer:hover {
    background: #00000080
}

#promoCode,.copy-feedback {
    font-size: 1.1rem;
    font-weight: 700;
    letter-spacing: 1px;
    color: var(--text-color);
    transition: opacity .3s ease;
    position: absolute
}

.copy-feedback {
    opacity: 0;
    pointer-events: none
}

.copy-feedback.visible {
    opacity: 1
}

#promoCode.hidden {
    opacity: 0
}

.modal-header {
    font-size: 1.2rem;
    font-weight: 600;
    margin-bottom: 16px
}

#errorModal .modal-header {
    color: var(--danger-color)
}

.daily-rewards-locked-overlay {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: #1a1a1ab3;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    z-index: 20;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    border-radius: var(--card-radius);
    opacity: 0;
    visibility: hidden;
    transition: opacity .3s ease,visibility .3s ease
}

.daily-rewards-locked-overlay.active {
    opacity: 1;
    visibility: visible
}

.locked-icon {
    width: 28px;
    height: 28px;
    color: #c8313e;
    background: #c8313e26;
    padding: 12px;
    border-radius: 50%
}

.locked-text {
    font-size: 14px;
    font-weight: 700;
    color: #fff;
    text-align: center;
    max-width: 80%;
    line-height: 1.4
}

.locked-btn {
    background: #c8313e;
    color: #fff;
    border: none;
    padding: 10px 20px;
    border-radius: 10px;
    font-weight: 700;
    font-size: 13px;
    cursor: pointer;
    margin-top: 4px;
    transition: transform .1s
}

.locked-btn:active {
    transform: scale(.96)
}

.currency-icon path {
    stroke: var(--text-color)
}

@keyframes fadeIn {
    0% {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

@keyframes fadeOut {
    0% {
        opacity: 1
    }

    to {
        opacity: 0
    }
}

@keyframes slideUp {
    0% {
        opacity: 0;
        transform: translateY(20px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

@keyframes slideDown {
    0% {
        opacity: 1;
        transform: translateY(0)
    }

    to {
        opacity: 0;
        transform: translateY(20px)
    }
}

@media (min-width: 768px) and (min-height: 600px) {
    .scroll-container {
        right:0;
        padding-right: 1rem
    }

    main {
        max-width: 1050px;
        padding-bottom: 4rem
    }
}

.page-ggpass html {
    overflow: hidden;
    overflow-y: hidden;
    height: 100%
}

.page-ggpass html,body.page-ggpass {
    margin: 0;
    height: 100%;
    background: var(--new-year-bg);
    background-attachment: fixed;
    background-color: var(--background);
    color: var(--text-color);
    overflow-x: hidden;
    transition: background .3s ease,color .3s ease
}

body.page-ggpass {
    scrollbar-width: none;
    -ms-overflow-style: none
}

body.page-ggpass::-webkit-scrollbar {
    display: none
}

.page-ggpass main {
    opacity: 0;
    transition: opacity .4s ease,max-width .3s ease,padding-top .3s ease;
    display: flex;
    flex-direction: column;
    width: 92%;
    margin-left: auto;
    margin-right: auto;
    box-sizing: border-box
}

.page-ggpass .banner-container {
    width: 90%;
    position: fixed;
    left: 50%;
    transform: translate(-50%);
    z-index: 200;
    max-width: 400px
}

.page-ggpass .banner {
    width: 100%;
    border-radius: 25px;
    overflow: hidden;
    position: relative
}

.page-ggpass .banner img {
    display: block;
    width: 100%;
    height: auto
}

.page-ggpass .content-mask {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    background-color: var(--background);
    z-index: 50;
    pointer-events: none
}

.page-ggpass .error {
    text-align: center;
    color: #ff6b6b;
    padding: 2rem
}

.page-ggpass .awards-section {
    width: 100%;
    background: var(--card-bg);
    border-radius: var(--card-radius);
    margin-top: 0;
    transition: background-color .3s ease
}

.page-ggpass .awards-header {
    font-weight: 600;
    margin-bottom: 12px;
    padding: 20px 1rem 0
}

.page-ggpass .awards-list-container {
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding-bottom: 20px
}

.page-ggpass .awards-list-container::-webkit-scrollbar {
    display: none
}

.page-ggpass .awards-list {
    display: flex;
    flex-wrap: nowrap;
    gap: 12px;
    padding: 0 1rem;
    width: max-content;
    box-sizing: border-box
}

.page-ggpass .award-wrapper {
    position: relative;
    width: 100px;
    flex-shrink: 0;
    padding-bottom: 35px
}

.page-ggpass .award-item {
    width: 100px;
    height: 100px;
    background: var(--award-bg);
    border-radius: var(--card-radius);
    display: flex;
    flex-direction: column;
    padding: 8px 6px;
    box-sizing: border-box;
    transition: background .3s,transform .3s
}

.page-ggpass .award-item.can-claim {
    cursor: pointer
}

.page-ggpass .award-item.can-claim:hover {
    transform: translateY(-4px)
}

.page-ggpass .award-item.reached-unclaimed {
    background: var(--color-green-dark-transparent)
}

.page-ggpass .award-item.claimed {
    background: var(--color-green-claimed);
    backdrop-filter: blur(15px);
    -webkit-backdrop-filter: blur(15px);
    justify-content: center;
    align-items: center
}

.page-ggpass .award-item-title {
    font-size: .85rem;
    font-weight: 500;
    text-align: center;
    line-height: .8;
    width: 90%;
    word-break: break-word;
    margin: auto auto 0
}

.page-ggpass .award-subtitle {
    display: block;
    opacity: .6;
    font-size: .6rem;
    font-weight: 400;
    margin-bottom: 0
}

.page-ggpass .award-item-icon {
    flex-shrink: 0;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 32px;
    text-align: center;
    height: 65px
}

.page-ggpass .award-item-icon img {
    width: 65px;
    height: 65px;
    object-fit: cover;
    border-radius: 8px
}

.page-ggpass .award-item-icon svg {
    width: 40px;
    height: 40px
}

.page-ggpass .award-item-icon svg path {
    stroke: var(--text-color);
    stroke-width: 2.5
}

.page-ggpass .award-item-index {
    position: absolute;
    bottom: 7px;
    left: 50%;
    transform: translate(-50%);
    font-size: .8rem;
    font-weight: 500;
    background: var(--award-bg);
    border-radius: 8px;
    padding: 4px 8px;
    display: flex;
    align-items: center;
    gap: 4px;
    box-shadow: 0 4px 8px #0000004d;
    transition: color .3s,background-color .3s
}

.page-ggpass .award-item-index:before {
    content: "";
    display: inline-block;
    width: 11px;
    height: 13px;
    background-color: var(--text-color);
    mask-image: var(--user-icon);
    -webkit-mask-image: var(--user-icon);
    mask-size: contain;
    -webkit-mask-size: contain;
    mask-repeat: no-repeat;
    -webkit-mask-repeat: no-repeat;
    mask-position: center;
    -webkit-mask-position: center;
    transition: all .3s ease
}

.page-ggpass .award-item.can-claim+.award-item-index {
    color: transparent;
    gap: 0;
    padding: 4px 6px;
    font-size: 0;
    background-color: #ffffff41;
    display: flex;
    align-items: center;
    justify-content: center
}

.page-ggpass .award-item.can-claim+.award-item-index:before {
    -webkit-mask-image: var(--gift-icon);
    mask-image: var(--gift-icon);
    width: 26px;
    height: 18px
}

.page-ggpass .awards-progress {
    background: var(--card-bg);
    padding: 12px 1rem 35px;
    border-top: 1px solid rgba(128,128,128,.1);
    border-radius: 0 0 var(--card-radius) var(--card-radius);
    transition: background-color .3s ease
}

.page-ggpass .progress-text {
    font-size: .9rem;
    font-weight: 500;
    margin-bottom: 8px
}

.page-ggpass .progress-bar-container {
    display: flex;
    align-items: center;
    gap: 2px;
    margin-bottom: 0;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding-bottom: 5px
}

.page-ggpass .progress-bar-container::-webkit-scrollbar {
    display: none
}

.page-ggpass .progress-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--color-white-transparent);
    transition: background .3s ease;
    position: relative;
    flex-shrink: 0
}

.page-ggpass .progress-dot.has-award {
    background: #387c2b66
}

.page-ggpass .progress-dot.active {
    background: var(--text-color)
}

.page-ggpass .progress-dot.active.has-award {
    background: var(--color-green-dark)
}

.page-ggpass .progress-dot-label {
    position: absolute;
    bottom: -22px;
    left: 50%;
    transform: translate(-50%);
    font-size: .7rem;
    color: #808080cc
}

@media (min-width: 768px) and (min-height: 600px) {
    .page-ggpass .edge-bar,.page-ggpass .banner-container,.page-ggpass .content-mask {
        display:none
    }

    .page-ggpass main {
        max-width: 900px;
        padding-top: 110px
    }
}

body.page-cells {
    margin: 0;
    padding: 0;
    background: linear-gradient(135deg,#121212,#151515);
    color: #fff;
    height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    transition: background .3s ease,color .3s ease
}

.page-cells .content {
    opacity: 0;
    transition: opacity .3s ease-in
}

.page-cells h1 {
    font-size: 2.5em;
    margin-bottom: 10px
}

.page-cells p {
    font-size: 1.2em;
    margin: 0
}

body.page-events {
    margin: 0;
    padding: 0;
    height: 100vh;
    background: var(--new-year-bg);
    background-attachment: fixed;
    background-color: var(--background);
    color: var(--text-color);
    overflow: hidden;
    transition: background .3s ease,color .3s ease;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none
}

.page-events .top-list-frame,.page-events .top-list-scroller {
    scrollbar-width: none;
    -ms-overflow-style: none
}

.page-events .top-list-frame::-webkit-scrollbar,.page-events .top-list-scroller::-webkit-scrollbar {
    display: none
}

.events-container {
    width: 100%;
    height: 100vh;
    box-sizing: border-box;
    padding-top: calc(var(--tg-content-safe-area-inset-top) + var(--tg-safe-area-inset-top) + 76px);
    padding-bottom: calc(170px + env(safe-area-inset-bottom));
    display: flex;
    flex-direction: column;
    align-items: center;
    opacity: 0;
    transition: opacity .3s ease
}

.page-events .frame-container {
    width: 92%;
    max-width: 500px;
    display: flex;
    flex-direction: column;
    flex-shrink: 1;
    min-height: 0
}

.event-timer {
    background: var(--card-bg);
    border-radius: 16px;
    padding: 12px 16px;
    margin-bottom: 12px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 5px;
    box-sizing: border-box;
    width: 100%
}

.timer-title {
    font-size: 14px;
    font-weight: 500;
    color: var(--text-secondary);
    text-align: center
}

.timer-countdown {
    font-size: 24px;
    font-weight: 700;
    color: var(--text-color);
    letter-spacing: .5px;
    text-align: center
}

.top-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 30px 20px;
    text-align: center;
    margin: auto;
    color: var(--text-secondary)
}

.page-events .empty-state-icon {
    width: 64px;
    height: 64px;
    stroke: currentColor;
    opacity: .5
}

.top-empty-state h3 {
    font-size: 18px;
    font-weight: 700;
    color: var(--text-color);
    margin: 16px 0 4px
}

.top-empty-state p {
    font-size: 14px;
    margin: 0;
    max-width: 250px
}

.top-list-title {
    font-size: 20px;
    font-weight: 700;
    color: var(--text-color);
    margin-bottom: 12px;
    padding-left: 5px
}

.top-list-frame {
    flex-grow: 1;
    max-height: 280px;
    overflow: hidden;
    background: var(--card-bg);
    border-radius: 20px;
    padding: 0;
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
    width: 100%;
    position: relative
}

.top-list-scroller {
    height: 100%;
    width: 100%;
    overflow-y: auto;
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    box-sizing: border-box;
    transition: transform .3s cubic-bezier(.34,1.56,.64,1)
}

.top-list-scroller.pulling {
    transition: transform .1s ease-out
}

.top-list-scroller.released {
    transition: transform .5s cubic-bezier(.34,1.56,.64,1)
}

.how-to-participate {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    color: var(--text-secondary);
    font-size: 14px;
    font-weight: 500;
    margin-top: 15px;
    cursor: pointer;
    transition: color .3s ease;
    align-self: center
}

.how-to-participate:hover {
    color: var(--text-color)
}

.how-to-icon {
    width: 18px;
    height: 18px;
    stroke: currentColor
}

.top-item {
    display: flex;
    align-items: center;
    gap: 12px;
    background: var(--award-bg);
    border-radius: 16px;
    padding: 8px;
    position: relative;
    overflow: hidden;
    border: 1px solid transparent;
    transition: background .3s ease,border-color .3s ease;
    flex-shrink: 0
}

html[data-theme=light] .top-item {
    background: var(--award-bg)
}

.top-item:before {
    content: "";
    position: absolute;
    top: 0;
    right: -1px;
    bottom: 0;
    width: 60%;
    background: linear-gradient(to left,var(--gradient-color, transparent),transparent);
    opacity: .4;
    pointer-events: none;
    transition: background .3s ease
}

.top-item.top-1 {
    --gradient-color: var(--gradient-gold);
    border-color: var(--gradient-gold)
}

.top-item.top-2 {
    --gradient-color: var(--gradient-silver);
    border-color: var(--gradient-silver)
}

.top-item.top-3 {
    --gradient-color: var(--gradient-bronze);
    border-color: var(--gradient-bronze)
}

.top-rank {
    font-size: 1em;
    font-weight: 700;
    color: var(--text-secondary);
    width: 25px;
    text-align: center;
    flex-shrink: 0;
    white-space: nowrap
}

.top-1 .top-rank {
    color: var(--gradient-gold)
}

.top-2 .top-rank {
    color: var(--gradient-silver)
}

.top-3 .top-rank {
    color: var(--gradient-bronze)
}

.top-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0
}

.top-info {
    flex-grow: 1;
    min-width: 0
}

.top-name {
    font-weight: 700;
    font-size: 14px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: var(--text-color)
}

.top-invites {
    font-size: 10px;
    color: var(--text-secondary);
    margin-top: 2px
}

.top-reward {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    min-width: 80px;
    min-height: 45px;
    flex-shrink: 0;
    z-index: 10
}

.reward-case,.reward-nothing {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center
}

.reward-case img,.reward-nothing img {
    width: 35px;
    height: 35px;
    object-fit: contain
}

.reward-nothing img {
    width: 25px;
    height: 25px
}

.reward-case-name {
    font-size: 11px;
    color: var(--text-secondary);
    margin-top: 4px;
    white-space: nowrap
}

.reward-balance {
    display: flex;
    align-items: center;
    gap: 5px;
    font-weight: 700;
    font-size: 15px;
    color: var(--text-color)
}

.reward-balance .currency-icon {
    width: 14px;
    height: 11px
}

.reward-balance .currency-icon path {
    stroke: var(--text-color);
    transition: stroke .3s ease
}

.scroll-hint {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 10px 0;
    color: var(--text-secondary);
    font-size: 13px;
    flex-shrink: 0;
    max-height: 50px;
    overflow: hidden;
    transition: opacity .3s ease,transform .3s ease,max-height .3s ease,padding .3s ease
}

.scroll-hint.hidden {
    opacity: 0;
    transform: translateY(-10px);
    pointer-events: none;
    max-height: 0;
    padding-top: 0;
    padding-bottom: 0
}

.scroll-hint svg {
    width: 16px;
    height: 16px;
    stroke: var(--text-secondary)
}

.user-top-bar {
    position: fixed;
    bottom: calc(110px + env(safe-area-inset-bottom));
    left: 50%;
    transform: translate(-50%);
    width: 92%;
    max-width: 500px;
    z-index: 50
}

.user-top-bar .top-item {
    width: 100%;
    box-sizing: border-box;
    background: var(--card-bg);
    --gradient-color: var(--gradient-gray);
    border-color: #505050;
    box-shadow: 0 -5px 20px #0003;
    padding: 8px
}

.page-events .modal-overlay {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: #0009;
    -webkit-backdrop-filter: blur(5px);
    backdrop-filter: blur(5px);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1000;
    opacity: 0;
    pointer-events: none;
    transition: opacity .3s ease
}

.page-events .modal-overlay.visible {
    opacity: 1;
    pointer-events: auto
}

.page-events .modal-content {
    background: var(--card-bg);
    border-radius: 20px;
    padding: 24px;
    width: 90%;
    max-width: 400px;
    box-shadow: 0 5px 30px #0000004d;
    transform: scale(.9);
    transition: transform .3s ease;
    position: relative;
    box-sizing: border-box
}

.page-events .modal-overlay.visible .modal-content {
    transform: scale(1)
}

.page-events .modal-close {
    position: absolute;
    top: 10px;
    right: 15px;
    font-size: 28px;
    color: var(--text-secondary);
    cursor: pointer;
    transition: color .3s ease
}

.page-events .modal-close:hover {
    color: var(--text-color)
}

.page-events .modal-content h3 {
    font-size: 20px;
    font-weight: 700;
    color: var(--text-color);
    margin: 0 0 12px
}

.page-events .modal-content p {
    font-size: 15px;
    color: var(--text-secondary);
    line-height: 1.5;
    margin: 0
}

.page-events .modal-content p strong {
    color: var(--text-color);
    font-weight: 700
}

.pull-indicator {
    position: absolute;
    top: -40px;
    left: 50%;
    transform: translate(-50%);
    color: var(--text-secondary);
    font-size: 12px;
    font-weight: 500;
    opacity: 0;
    transition: opacity .2s ease;
    pointer-events: none;
    white-space: nowrap
}

.pull-indicator.visible {
    opacity: 1
}

.pull-indicator.ready {
    color: var(--gradient-gold);
    font-weight: 700
}

.page-index .event-reward-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #0009;
    z-index: 1100;
    opacity: 0;
    visibility: hidden;
    transition: opacity .3s ease,visibility .3s ease;
    display: flex;
    align-items: center;
    justify-content: center
}

.page-index .event-reward-overlay.show {
    opacity: 1;
    visibility: visible
}

.page-index .event-reward-modal {
    background: var(--profile-modal-bg);
    -webkit-backdrop-filter: var(--blur-effect);
    backdrop-filter: var(--blur-effect);
    border-radius: 20px;
    padding: 30px;
    margin: 0 15px;
    width: calc(100% - 30px);
    box-sizing: border-box;
    max-width: 400px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 15px;
    transform: scale(.95);
    transition: transform .3s cubic-bezier(.4,0,.2,1);
    border: var(--profile-border);
    text-align: center
}

.page-index .event-reward-overlay.show .event-reward-modal {
    transform: scale(1)
}

.page-index .event-reward-title {
    color: var(--text-primary);
    font-size: 20px;
    font-weight: 700;
    margin: 0
}

.page-index .event-reward-text {
    color: var(--text-secondary);
    font-size: 15px;
    margin: 0;
    line-height: 1.4
}

.page-index .event-reward-item {
    background: var(--button-bg);
    border-radius: 12px;
    padding: 16px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    width: 100%;
    margin-top: 10px
}

.page-index .event-reward-item img {
    width: 80px;
    height: 80px;
    object-fit: contain;
    border-radius: 8px
}

.page-index .event-reward-item-name {
    font-size: 16px;
    font-weight: 600;
    color: var(--text-primary)
}

.page-index .event-reward-item-balance {
    font-size: 24px;
    font-weight: 700;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: 6px
}

.page-index .event-reward-claim-button {
    background: var(--success-color);
    border: none;
    color: #fff;
    padding: 14px 16px;
    border-radius: 12px;
    width: 100%;
    margin-top: 10px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: opacity .2s ease,transform .2s ease
}

.page-index .event-reward-claim-button:hover {
    opacity: .9
}

.page-index .event-reward-claim-button:active {
    transform: scale(.98)
}

.page-index .event-reward-claim-button:disabled {
    opacity: .5;
    cursor: not-allowed
}

.page-index .subscription-modal #subscribeButton {
    display: none
}

.page-index .channels-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-bottom: 24px
}

.page-index .channel-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px;
    background: var(--button-bg);
    border-radius: 12px;
    cursor: default
}

.page-index .channel-item-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
    border: 1px solid rgba(255,255,255,.05);
    background-color: var(--element-hover-bg)
}

.page-index .channel-item-info {
    flex-grow: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px
}

.page-index .channel-item-name {
    color: var(--text-primary);
    font-size: 15px;
    font-weight: 700;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis
}

.page-index .channel-item-tag {
    color: var(--text-secondary);
    font-size: 13px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis
}

.page-index .channel-subscribe-button {
    background: var(--info-color);
    border: none;
    color: var(--text-primary);
    padding: 8px 16px;
    border-radius: 10px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: background-color .2s ease,opacity .2s ease;
    flex-shrink: 0
}

.page-index .channel-subscribe-button:hover {
    opacity: .85
}

.page-index .channel-subscribe-button.subscribed {
    background: var(--success-color);
    opacity: .7;
    cursor: default
}

.onboarding-overlay {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 9998;
    opacity: 0;
    visibility: hidden;
    transition: opacity .4s ease,visibility .4s ease;
    cursor: pointer
}

.onboarding-overlay.welcome,.onboarding-overlay.final-step {
    background: #0000004d;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px)
}

.onboarding-overlay.show {
    opacity: 1;
    visibility: visible
}

.onboarding-spotlight {
    position: absolute;
    top: 0;
    left: 0;
    width: 100px;
    height: 100px;
    background: transparent;
    box-shadow: 0 0 0 9999px #0009;
    border-radius: 12px;
    transition: all .5s cubic-bezier(.4,0,.2,1);
    opacity: 0;
    visibility: hidden
}

.onboarding-overlay.guiding .onboarding-spotlight {
    opacity: 1;
    visibility: visible
}

.onboarding-welcome {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%) scale(.9);
    background: var(--profile-modal-bg);
    -webkit-backdrop-filter: var(--blur-effect);
    backdrop-filter: var(--blur-effect);
    border-radius: 20px;
    padding: 30px;
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 80%;
    max-width: 350px;
    box-sizing: border-box;
    border: var(--profile-border);
    opacity: 0;
    visibility: hidden;
    transition: all .4s ease
}

.onboarding-overlay.welcome .onboarding-welcome {
    opacity: 1;
    visibility: visible;
    transform: translate(-50%,-50%) scale(1)
}

.onboarding-avatar {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    margin-bottom: 16px;
    border: 2px solid var(--text-tertiary);
    background: var( --button-bg )
}

.onboarding-welcome h2 {
    color: var(--text-primary);
    font-size: 22px;
    font-weight: 700;
    margin: 0 0 8px;
    text-align: center
}

.onboarding-welcome p {
    color: var(--text-secondary);
    font-size: 15px;
    text-align: center;
    line-height: 1.5;
    margin: 0
}

.onboarding-tooltip {
    position: absolute;
    width: 80%;
    max-width: 400px;
    background: var(--profile-modal-bg);
    -webkit-backdrop-filter: var(--blur-effect);
    backdrop-filter: var(--blur-effect);
    border-radius: 16px;
    padding: 20px;
    box-sizing: border-box;
    border: var(--profile-border);
    transition: all .3s cubic-bezier(.4,0,.2,1);
    opacity: 0;
    visibility: hidden;
    transform: translateY(20px)
}

.onboarding-overlay.final-step .onboarding-tooltip {
    padding-top: 185px
}

.onboarding-overlay.guiding .onboarding-tooltip {
    opacity: 1;
    visibility: visible;
    transform: translateY(0)
}

.onboarding-tooltip-title {
    color: var(--text-primary);
    font-size: 18px;
    font-weight: 700;
    margin: 0 0 8px
}

.onboarding-tooltip-text {
    color: var(--text-secondary);
    font-size: 14px;
    line-height: 1.5;
    margin: 0 0 16px
}

.onboarding-dots {
    display: flex;
    gap: 8px;
    justify-content: center
}

.onboarding-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--element-hover-bg);
    transition: background .3s ease
}

.onboarding-dot.active {
    background: var(--text-primary)
}

.onboarding-tada {
    position: absolute;
    top: 20px;
    left: 50%;
    width: 150px;
    height: 150px;
    opacity: 0;
    visibility: hidden;
    transform: translate(-50%) scale(.8);
    transition: all .4s cubic-bezier(.4,0,.2,1);
    pointer-events: none
}

.onboarding-overlay.final-step .onboarding-tada {
    opacity: 1;
    visibility: visible;
    transform: translate(-50%) scale(1)
}

.onboarding-tooltip-title:empty {
    margin-bottom: 0
}

.img-loader-wrapper {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background-image: url("data:image/svg+xml,%3Csvg width='512' height='512' viewBox='0 0 512 512' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='256' cy='172' r='67' stroke='white' stroke-width='33'/%3E%3Cpath d='M139 406 A117 117 0 0 1 373 406' stroke='white' stroke-width='33' stroke-linecap='round' fill='none'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 100%;
    animation: pulse-placeholder 1.5s infinite ease-in-out;
    border-radius: 8px
}

.img-loader-wrapper img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
    opacity: 0;
    transition: opacity .3s ease
}

.img-loader-wrapper img.loaded {
    opacity: 1
}

.img-loader-wrapper:has(img.loaded) {
    animation: none;
    background-image: none
}

@keyframes pulse-placeholder {
    0% {
        opacity: .5;
        transform: scale(.98)
    }

    50% {
        opacity: 1;
        transform: scale(1)
    }

    to {
        opacity: .5;
        transform: scale(.98)
    }
}

.banner-section {
    width: 100%;
    max-width: 1250px;
    min-width: 300px;
    margin: 0 auto 24px;
    position: relative;
    border-radius: 20px;
    overflow: hidden;
    height: 300px;
    box-shadow: 0 10px 30px #0000004d;
    z-index: 10;
    box-sizing: border-box;
    user-select: none;
    -webkit-user-select: none;
    touch-action: pan-y
}

.banner-track {
    display: flex;
    height: 100%;
    width: 100%;
    cursor: grab
}

.banner-track.grabbing {
    cursor: grabbing
}

.banner-slide {
    min-width: 100%;
    height: 100%;
    position: relative;
    display: flex;
    overflow: hidden;
    box-sizing: border-box;
    padding: 30px 40px;
    border-radius: 20px;
    background-color: #333;
    pointer-events: none
}

.banner-content {
    position: relative;
    z-index: 2;
    width: 60%;
    height: 100%;
    color: #fff;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    pointer-events: auto
}

.banner-element {
    position: absolute;
    left: 75%;
    transform: translate(-50%);
    bottom: 0;
    top: auto;
    height: 95%;
    width: auto;
    object-fit: contain;
    object-position: bottom;
    z-index: 1;
    transition: left .3s ease;
    pointer-events: none
}

.banner-title {
    font-size: 2.8rem;
    font-weight: 800;
    margin: 0;
    line-height: 1
}

.banner-text {
    font-size: 1rem;
    font-weight: 500;
    line-height: 1.4;
    opacity: .9;
    margin-top: auto;
    margin-bottom: auto;
    padding-right: 20px;
    max-width: 350px
}

.banner-btn {
    background: #fff;
    color: #000;
    border: none;
    padding: 12px 24px;
    border-radius: 12px;
    font-size: 1rem;
    font-weight: 700;
    cursor: pointer;
    transition: transform .2s ease,box-shadow .2s ease;
    margin-top: 0;
    pointer-events: auto
}

.banner-btn:active {
    transform: scale(.95)
}

.banner-dots {
    position: absolute;
    top: 20px;
    right: 20px;
    display: flex;
    gap: 8px;
    z-index: 3;
    pointer-events: auto
}

.banner-dot {
    height: 8px;
    width: 8px;
    background: #fff;
    opacity: .2;
    border-radius: 4px;
    transition: all .3s ease;
    cursor: pointer
}

.banner-dot.active {
    opacity: 1;
    width: 24px
}

.banner-arrows {
    position: absolute;
    bottom: 20px;
    right: 20px;
    display: flex;
    gap: 12px;
    z-index: 3;
    pointer-events: auto
}

.banner-arrow {
    width: 40px;
    height: 40px;
    border-radius: 12px;
    background: #ffffff1a;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    border: none;
    transition: background .2s ease
}

.banner-arrow svg {
    width: 24px;
    height: 24px;
    color: #ffffff80
}

.banner-arrow:hover {
    background: #fff3
}

@media (max-width: 600px) {
    .banner-section {
        width:100%;
        height: 220px;
        border-radius: 20px
    }

    .banner-slide {
        padding: 20px;
        background: radial-gradient(circle at 85% 60%,#e4d6fa,#006fd6 70%)
    }

    .banner-title {
        font-size: 1.8rem
    }

    .banner-text {
        font-size: .85rem
    }

    .banner-btn {
        padding: 8px 16px;
        font-size: .85rem
    }

    .banner-element {
        height: 85%;
        left: auto;
        right: -50px;
        transform: none;
        bottom: 0
    }

    .banner-arrows {
        bottom: 15px;
        right: 15px
    }

    .banner-arrow {
        width: 32px;
        height: 32px
    }
}

@keyframes highlightPulse {
    0% {
        box-shadow: 0 0 #ffdf7ab3;
        transform: scale(1);
        background-color: #ffdf7a1a
    }

    50% {
        box-shadow: 0 0 20px #ffdf7a66;
        transform: scale(1.02);
        background-color: #ffdf7a33
    }

    to {
        box-shadow: 0 0 #ffdf7a00;
        transform: scale(1);
        background-color: transparent
    }
}

.highlight-section {
    animation: highlightPulse 1s ease-in-out;
    border-radius: 12px
}

.banner-track {
    will-change: transform;
    cursor: grab
}

.awards-section {
    position: relative;
    overflow: hidden
}

.right-glow-indicator {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 60px;
    background: radial-gradient(ellipse at right center,rgba(255,223,122,.6) 0%,transparent 70%);
    pointer-events: none;
    z-index: 10;
    opacity: 0;
    transition: opacity .5s ease;
    mix-blend-mode: screen
}

.right-glow-indicator.visible {
    opacity: 1;
    animation: sidePulse 2s infinite ease-in-out
}

@keyframes sidePulse {
    0% {
        transform: scaleX(1);
        filter: brightness(1)
    }

    50% {
        transform: scaleX(1.3);
        filter: brightness(1.5)
    }

    to {
        transform: scaleX(1);
        filter: brightness(1)
    }
}

.award-item.can-claim {
    position: relative;
    z-index: 1;
    box-shadow: 0 0 #ffdf7a00;
    transition: transform .3s,box-shadow .3s ease
}

.award-item.can-claim {
    animation: claimItemPulse 2s infinite ease-in-out
}

@keyframes claimItemPulse {
    0% {
        box-shadow: 0 0 10px #ffdf7a33,inset 0 0 5px #ffdf7a1a;
        border: 1px solid rgba(255,223,122,.3)
    }

    50% {
        box-shadow: 0 0 25px #ffdf7a99,inset 0 0 10px #ffdf7a4d;
        border: 1px solid rgba(255,223,122,.8);
        transform: scale(1.02)
    }

    to {
        box-shadow: 0 0 10px #ffdf7a33,inset 0 0 5px #ffdf7a1a;
        border: 1px solid rgba(255,223,122,.3)
    }
}

.banner-section {
    touch-action: pan-y;
    -webkit-user-select: none;
    user-select: none;
    position: relative;
    overflow: hidden;
    transform: translateZ(0)
}

.banner-track {
    display: flex;
    height: 100%;
    width: 100%;
    will-change: transform;
    cursor: grab
}

.banner-track:active {
    cursor: grabbing
}

body.page-404 {
    margin: 0;
    padding: 0;
    background-color: var(--base-bg, #161616);
    color: var(--text-primary, #ffffff);
    height: 100dvh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    overflow: hidden;
    box-sizing: border-box
}

.container-404 {
    padding: 24px;
    max-width: 360px;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    opacity: 0;
    animation: fadeInUp .6s cubic-bezier(.4,0,.2,1) forwards
}

.illustration-404 {
    width: 140px;
    height: 140px;
    color: var(--text-tertiary, #505050);
    margin-bottom: 32px;
    position: relative
}

.illustration-404 svg {
    width: 100%;
    height: 100%;
    filter: drop-shadow(0 8px 24px rgba(200,49,62,.25))
}

.illustration-accent {
    color: var(--danger-color, #c8313e)
}

.error-code {
    font-size: 14px;
    font-weight: 800;
    letter-spacing: 2px;
    color: var(--danger-color, #c8313e);
    text-transform: uppercase;
    margin-bottom: 12px;
    background: #c8313e1a;
    padding: 6px 12px;
    border-radius: 8px;
    display: inline-block
}

.title-404 {
    font-size: 28px;
    font-weight: 800;
    margin: 0 0 16px;
    color: var(--text-primary, #ffffff)
}

.text-404 {
    font-size: 16px;
    color: var(--text-secondary, #8a8a8a);
    margin: 0 0 40px;
    line-height: 1.6;
    max-width: 320px
}

.home-button {
    background: var(--button-bg, rgba(255, 255, 255, .08));
    color: var(--text-primary, #ffffff);
    border: none;
    padding: 16px 24px;
    border-radius: 14px;
    font-size: 16px;
    font-weight: 700;
    cursor: pointer;
    transition: background-color .2s ease,transform .1s ease;
    text-decoration: none;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    box-sizing: border-box
}

.home-button:hover {
    background: var(--button-hover-bg, rgba(255, 255, 255, .15))
}

.home-button:active {
    transform: scale(.98)
}

@keyframes fadeInUp {
    0% {
        opacity: 0;
        transform: translateY(30px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

body.ban-screen-mode {
    background-color: var(--base-bg);
    margin: 0;
    padding: 0;
    height: 100dvh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden
}

.ban-overlay-static {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    box-sizing: border-box;
    animation: fadeIn .4s ease forwards
}

.ban-card {
    background: var(--profile-modal-bg);
    backdrop-filter: var(--blur-effect);
    -webkit-backdrop-filter: var(--blur-effect);
    border: var(--profile-border);
    border-radius: 24px;
    padding: 32px 24px;
    width: 100%;
    max-width: 380px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    box-shadow: 0 20px 50px #00000080;
    transform: scale(.95);
    animation: scaleIn .4s cubic-bezier(.175,.885,.32,1.275) forwards
}

.ban-icon-wrapper {
    width: 80px;
    height: 80px;
    background: #c8313e1a;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
    border: 1px solid rgba(200,49,62,.2)
}

.ban-icon {
    width: 40px;
    height: 40px;
    color: var(--danger-color)
}

.ban-title {
    font-size: 24px;
    font-weight: 800;
    color: var(--text-primary);
    margin: 0 0 8px
}

.ban-subtitle {
    font-size: 14px;
    color: var(--text-secondary);
    margin-bottom: 24px;
    line-height: 1.5
}

.ban-user-info {
    display: flex;
    align-items: center;
    background: var(--button-bg);
    border: 1px solid rgba(255,255,255,.05);
    padding: 12px;
    border-radius: 14px;
    width: 100%;
    box-sizing: border-box;
    margin-bottom: 20px
}

.ban-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
    margin-right: 12px;
    border: 2px solid rgba(255,255,255,.1)
}

.ban-user-text {
    text-align: left;
    overflow: hidden
}

.ban-nickname {
    font-size: 16px;
    font-weight: 700;
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis
}

.ban-id {
    font-size: 12px;
    color: var(--text-secondary);
    font-family: monospace;
    margin-top: 2px
}

.ban-details-grid {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 0;
    margin-bottom: 24px;
    background: #0003;
    border-radius: 14px;
    padding: 4px 12px;
    box-sizing: border-box
}

.ban-detail-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 14px;
    padding: 12px 0;
    border-bottom: 1px solid rgba(255,255,255,.05)
}

.ban-detail-row:last-child {
    border-bottom: none
}

.ban-reason-static {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    font-size: 14px;
    padding: 12px 0;
    border-bottom: 1px solid rgba(255,255,255,.05);
    width: 100%
}

.ban-reason-box {
    margin-top: 8px;
    width: 100%;
    box-sizing: border-box;
    white-space: pre-wrap;
    word-break: break-word;
    text-align: left;
    color: var(--danger-color);
    padding: 10px;
    font-size: 12px;
    line-height: 1.4
}

.ban-label {
    color: var(--text-secondary)
}

.ban-value {
    color: var(--text-primary);
    font-weight: 600;
    text-align: right
}

.ban-support-btn {
    background: var(--text-primary);
    color: #000;
    border: none;
    width: 100%;
    padding: 16px;
    border-radius: 14px;
    font-size: 16px;
    font-weight: 700;
    cursor: pointer;
    transition: transform .2s ease,opacity .2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px
}

.ban-support-btn:active {
    transform: scale(.98);
    opacity: .9
}

@keyframes scaleIn {
    0% {
        opacity: 0;
        transform: scale(.95)
    }

    to {
        transform: scale(1);
        opacity: 1
    }
}

.snow-container {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 0;
    overflow: hidden
}

.snow-layer {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.snow-layer.far {
    background-image: radial-gradient(1.5px 1.5px at 20px 30px,rgba(255,255,255,.7) 50%,transparent),radial-gradient(1.5px 1.5px at 150px 80px,rgba(255,255,255,.6) 50%,transparent),radial-gradient(1.5px 1.5px at 80px 250px,rgba(255,255,255,.7) 50%,transparent),radial-gradient(1.5px 1.5px at 280px 180px,rgba(255,255,255,.6) 50%,transparent),radial-gradient(1.5px 1.5px at 300px 320px,rgba(255,255,255,.7) 50%,transparent);
    background-size: 400px 400px;
    animation: snowFall 25s linear infinite;
    opacity: .7
}

.snow-layer.mid {
    background-image: radial-gradient(2.5px 2.5px at 50px 150px,rgba(255,255,255,.8) 50%,transparent),radial-gradient(2.5px 2.5px at 220px 40px,rgba(255,255,255,.8) 50%,transparent),radial-gradient(2.5px 2.5px at 310px 280px,rgba(255,255,255,.8) 50%,transparent);
    background-size: 350px 350px;
    animation: snowFall 18s linear infinite;
    opacity: .85
}

.snow-layer.near {
    background-image: radial-gradient(3.5px 3.5px at 100px 100px,rgba(255,255,255,.9) 50%,transparent),radial-gradient(3.5px 3.5px at 250px 350px,rgba(255,255,255,.9) 50%,transparent);
    background-size: 500px 500px;
    animation: snowFall 12s linear infinite;
    filter: blur(1px);
    opacity: .9
}

@keyframes snowFall {
    0% {
        background-position: 0 0
    }

    to {
        background-position: 50px 500px
    }
}

.pages-container,.top-header,.bottom-nav,.page-ggpass main,.page-events .events-container,.page-home main,.scroll-container {
    position: relative;
    z-index: 1
}

body,body.page-index,body.page-ggpass,body.page-events {
    background: var(--new-year-bg);
    background-color: var(--base-bg);
    background-repeat: no-repeat;
    background-attachment: scroll;
    will-change: background-position,background-size
}

.wheel-section {
    width: 100%;
    margin-bottom: 24px;
    position: relative;
    z-index: 10
}

.wheel-card {
    position: relative;
    width: 100%;
    height: 160px;
    background: linear-gradient(103deg, #1e2532c2, #131823db);
    border: 1px solid rgba(255,255,255,.05);
    border-radius: 20px;
    overflow: hidden;
    cursor: pointer;
    box-shadow: 0 4px 15px #0003;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 20px;
    box-sizing: border-box;
    transition: transform .1s
}

.wheel-card:active {
    transform: scale(.98)
}

.wheel-preview-content {
    position: relative;
    z-index: 2;
    max-width: 60%
}

.wheel-title {
    font-size: 20px;
    font-weight: 800;
    color: #fff;
    text-transform: uppercase;
    margin: 0 0 5px;
    line-height: 1.2
}

.wheel-subtitle {
    font-size: 13px;
    color: var(--text-secondary);
    font-weight: 500;
    margin-bottom: 12px
}

.wheel-preview-btn {
    background: #ffffff1a;
    -webkit-backdrop-filter: blur(5px);
    backdrop-filter: blur(5px);
    border-radius: 10px;
    padding: 8px 14px;
    color: #fff;
    font-size: 13px;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    gap: 6px
}

.wheel-idle-img {
    position: absolute;
    top: 50%;
    right: -20px;
    height: 180px;
    width: auto;
    transform: translateY(-50%);
    z-index: 1;
    pointer-events: none;
    filter: drop-shadow(-5px 0 15px rgba(0,0,0,.4))
}

.wheel-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #00000080;
    backdrop-filter: blur(15px);
    -webkit-backdrop-filter: blur(15px);
    z-index: 5000;
    opacity: 0;
    visibility: hidden;
    transition: opacity .3s ease,visibility .3s ease;
    display: flex;
    flex-direction: column;
    justify-content: flex-end
}

.wheel-modal-overlay.active {
    opacity: 1;
    visibility: visible
}

.wheel-modal-content {
    background: #1d1d1ecc;
    width: 100%;
    border-radius: 30px 30px 0 0;
    border-top: 1px solid rgba(255,255,255,.1);
    box-shadow: 0 -10px 50px #0009;
    transform: translateY(100%);
    transition: transform .4s cubic-bezier(.19,1,.22,1);
    position: relative;
    backdrop-filter: blur(10px);
    padding-bottom: calc(20px + env(safe-area-inset-bottom,20px))
}

.wheel-modal-overlay.active .wheel-modal-content {
    transform: translateY(0)
}

.wheel-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 24px 0px 24px;
}

.wheel-modal-title {
    font-size: 20px;
    font-weight: 800;
    color: #fff;
    margin: 0
}

.wheel-close-btn {
    background: #ffffff1a;
    border: none;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center
}

.wheel-container {
    width: 100%;
    height: 230px;
    position: relative;
    overflow: hidden;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    margin-bottom: 10px;
    border-bottom: 1px solid rgba(255,255,255,.05)
}

.roulette-scalable-group {
    width: 952px;
    height: 952px;
    position: relative;
    transform: scale(.55) translateY(-33%);
    transform-origin: center center;
    flex-shrink: 0;
}

.roulette-wheel {
    width: 100%;
    height: 100%;
    position: relative;
    border-radius: 50%;
    will-change: transform
}

.roulette-wheel-image {
    width: 100%;
    height: 100%;
    object-fit: contain
}

.roulette-arrow {
    position: absolute;
    top: 110px;
    left: 50%;
    width: 40px;
    height: 80px;
    transform: translate(-50%) rotate(180deg);
    background: url(https://cdn-1.ggprize.fun/point.png) no-repeat center/contain;
    z-index: 20;
    filter: drop-shadow(0 5px 10px rgba(0,0,0,.7));
    pointer-events: none
}

.roulette-cells {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0
}

.roulette-cell {
    position: absolute;
    transform-origin: center;
    display: flex;
    justify-content: center;
    align-items: center
}

.roulette-cell-icon {
    position: absolute;
    width: 70%;
    height: 70%;
    object-fit: contain;
    transform: rotate(180deg)
}

._wheel-cell-size {
    height: 195px;
    width: 194px
}

.pos-1 {
    left: 831px;
    top: 476px;
    transform: translate(-50%,-50%) rotate(-89deg)
}

.pos-2 {
    left: 809.6px;
    top: 597.4px;
    transform: translate(-50%,-50%) rotate(-69deg)
}

.pos-3 {
    left: 747.9px;
    top: 704.2px;
    transform: translate(-50%,-50%) rotate(-49deg)
}

.pos-4 {
    left: 653.5px;
    top: 783.4px;
    transform: translate(-50%,-50%) rotate(-29deg);
}

.pos-5 {
    left: 537.6px;
    top: 825.6px;
    transform: translate(-50%,-50%) rotate(-9deg)
}

.pos-6 {
    left: 414.3px;
    top: 825.6px;
    transform: translate(-50%,-50%) rotate(11deg)
}

.pos-7 {
    left: 298.5px;
    top: 783.4px;
    transform: translate(-50%,-50%) rotate(31deg)
}

.pos-8 {
    left: 204px;
    top: 704.2px;
    transform: translate(-50%,-50%) rotate(51deg)
}

.pos-9 {
    left: 142.4px;
    top: 597.4px;
    transform: translate(-50%,-50%) rotate(71deg)
}

.pos-10 {
    left: 121px;
    top: 476px;
    transform: translate(-50%,-50%) rotate(91deg)
}

.pos-11 {
    left: 142.4px;
    top: 354.6px;
    transform: translate(-50%,-50%) rotate(111deg)
}

.pos-12 {
    left: 204px;
    top: 247.8px;
    transform: translate(-50%,-50%) rotate(131deg)
}

.pos-13 {
    left: 298.5px;
    top: 168.6px;
    transform: translate(-50%,-50%) rotate(151deg)
}

.pos-14 {
    left: 414.3px;
    top: 126.4px;
    transform: translate(-50%,-50%) rotate(171deg)
}

.pos-15 {
    left: 537.6px;
    top: 126.4px;
    transform: translate(-50%,-50%) rotate(191deg)
}

.pos-16 {
    left: 653.5px;
    top: 168.6px;
    transform: translate(-50%,-50%) rotate(211deg)
}

.pos-17 {
    left: 747.9px;
    top: 247.8px;
    transform: translate(-50%,-50%) rotate(231deg)
}

.pos-18 {
    left: 809.6px;
    top: 354.6px;
    transform: translate(-50%,-50%) rotate(251deg)
}

.icon-pos-adjust {
    height: 90px;
    top: 60px;
    padding-left: 17px
}

.wheel-controls {
    padding: 0 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.rewards-legend {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    padding-bottom: 5px;
    scrollbar-width: none;
}

.rewards-legend::-webkit-scrollbar {
    display:none
}

.legend-item {
    background: #72717126;
    border: 1px solid rgba(255,255,255,.05);
    border-radius: 12px;
    padding: 4px 12px;
    display: flex;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
    font-size: 12px;
    /* color:#ccc; */
    backdrop-filter: blur(10px);
}

.legend-item img {
    width: 35px;
    height: 35px;
    object-fit: contain
}

.legend-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 70px;
    text-align: center
}

.legend-name {
    font-size: 11px;
    line-height: 1.2;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    color: #fff
}

.legend-percent {
    font-size: 10px;
    color: #ffffff80;
    /* margin-top:2px; */
    font-weight: 600;
}

.spin-btn {
    width: 100%;
    padding: 16px;
    border-radius: 16px;
    border: none;
    background: #373636cf;
    font-weight: 800;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    box-shadow: 0 6px 20px #373636cf;
    transition: transform .1s;
    box-sizing: border-box;
}

.spin-btn.is-invite {
    background: #0a84ff;
    color: #fff;
    box-shadow: 0 6px 20px #0a84ff4d;
    font-size: 16px;
    padding: 14px;
    height: auto
}

.spin-btn.is-invite svg {
    width: 20px;
    height: 20px;
    fill: currentColor
}

.spin-btn:active {
    transform: scale(.97)
}

.idle-spin {
    animation: idleSpin 30s linear infinite;
}

@keyframes idleSpin {
    0% {
        transform: rotate(0)
    }

    to {
        transform: rotate(360deg)
    }
}

body.no-wheel-spin .roulette-wheel {
    animation-play-state: paused!important
}

.rewards-header {
    font-size: 1rem;
    font-weight: 700;
    color: #ccc;
    margin-bottom: 15px;
    margin-top: 10px;
    display: flex;
    align-items: center;
    gap: 8px
}

.rewards-header:before {
    content: "";
    display: block;
    width: 4px;
    height: 16px;
    background: #005db3;
    border-radius: 2px
}

.rewards-grid {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 8px;
    margin-bottom: 15px
}

.reward-type-label {
    font-size: 10px;
    color: var(--text-secondary);
    text-transform: uppercase;
    font-weight: 700;
    margin-bottom: 4px;
    opacity: .7;
    height: 12px
}

.reward-type-label:empty {
    display: none
}

.reward-tile {
    background: linear-gradient(145deg,#ffffff14,#ffffff05);
    border: 1px solid rgba(255,255,255,.05);
    border-radius: 12px;
    padding: 10px 4px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    position: relative;
    min-height: 90px
}

.reward-tile:before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: radial-gradient(circle at 50% 0%,rgba(255,223,122,.1),transparent 70%);
    pointer-events: none
}

.reward-tile img {
    width: 42px;
    height: 42px;
    object-fit: contain;
    margin-bottom: 6px;
    filter: drop-shadow(0 4px 6px rgba(0,0,0,.3))
}

.reward-name {
    font-size: 11px;
    color: #fff;
    font-weight: 600;
    line-height: 1.1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px
}

.reward-name svg {
    width: 12px;
    height: 12px;
    flex-shrink: 0
}

.reward-name svg path {
    stroke: #fff
}

.reward-value {
    font-size: .8rem;
    color: #fbb03b;
    font-weight: 800;
    text-shadow: 0 1px 4px rgba(0,0,0,.5);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 3px
}

.roulette-cell.winner .roulette-cell-icon {
    transform: rotate(180deg) scale(1.3)!important;
    filter: drop-shadow(0 0 15px rgba(255,255,255,.9))
}

.roulette-cell.dimmed {
    opacity: .2;
    filter: blur(1px) grayscale(.5);
    transition: opacity .5s,filter .5s
}

body.page-friends {
    margin: 0;
    height: 100%;
    background: var(--new-year-bg);
    background-attachment: fixed;
    background-color: var(--background);
    color: var(--text-color);
    overflow-x: hidden;
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none
}

body.page-friends::-webkit-scrollbar {
    display: none
}

.page-friends main {
    padding-top: calc(var(--tg-content-safe-area-inset-top) + var(--tg-safe-area-inset-top) + 76px);
    padding-bottom: calc(6rem + 10px);
    padding-left: 0;
    padding-right: 0;
    width: 92%;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    opacity: 0;
    transition: opacity .4s ease;
    box-sizing: border-box
}

.page-friends .main-container {
    width: 92%;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: flex-start
}

.page-friends .page-title {
    font-size: 32px;
    font-weight: 800;
    margin: 0 0 10px;
    text-transform: uppercase;
    color: var(--text-primary);
    text-align: left;
    width: 100%
}

.page-friends .referral-link-section {
    width: 100%;
    margin-bottom: 16px
}

.page-friends .total-stats {
    width: 100%;
    justify-content: flex-start;
    margin-bottom: 24px
}

.page-friends .info-card {
    background: var(--card-bg);
    border-radius: 16px;
    padding: 20px;
    width: 100%;
    box-sizing: border-box;
    margin-bottom: 5px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    position: relative;
    overflow: hidden
}

.page-friends .info-text-wrapper {
    position: relative;
    z-index: 2;
    max-width: 65%;
    display: flex;
    flex-direction: column;
    gap: 8px
}

.page-friends .info-bg-image {
    position: absolute;
    top: 5px;
    right: -10px;
    height: 130px;
    width: auto;
    object-fit: contain;
    z-index: 1;
    opacity: 1
}

.page-friends .info-title {
    font-size: 18px;
    font-weight: 700;
    color: var(--text-primary);
    text-transform: uppercase;
    margin: 0
}

.page-friends .info-subtitle {
    font-size: 12px;
    color: var(--text-secondary);
    font-weight: 500;
    margin: 0;
    text-transform: uppercase;
    opacity: .9;
    line-height: 1.4
}

.page-friends .rewards-section-title {
    font-size: 13px;
    font-weight: 700;
    color: var(--text-primary);
    text-transform: uppercase;
    position: relative;
    z-index: 3
}

body.ui-hidden-top .tg-app-header-island,body.ui-hidden-all .tg-app-header-island {
    transform: translate(-50%,-250%) translateY(calc(0px - (var(--tg-actual-header-height) / 2)));
    opacity: 0;
    pointer-events: none
}

.page-friends .rewards-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    width: 100%;
    position: relative;
    z-index: 3
}

.page-friends .reward-box {
    background: #00000080;
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    border-radius: 12px;
    padding: 10px 12px;
    display: flex;
    align-items: center;
    border: 1px solid rgba(255,255,255,.1);
    position: relative;
    overflow: hidden;
    min-height: 42px
}

.page-friends .reward-box span {
    font-size: 10px;
    font-weight: 700;
    color: var(--text-primary);
    line-height: 1.2;
    text-transform: uppercase;
    text-align: left;
    position: relative;
    z-index: 2;
    max-width: 65%
}

.page-friends .reward-box img {
    width: 52px;
    height: 52px;
    object-fit: contain;
    position: absolute;
    bottom: -2px;
    right: 0;
    z-index: 1;
    margin: 0
}

.page-friends .reward-box-wheel {
    background: #00000080;
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    border-radius: 12px;
    padding: 10px 12px;
    display: flex;
    align-items: center;
    border: 1px solid rgba(255,255,255,.1);
    position: relative;
    overflow: hidden;
    min-height: 42px
}

.page-friends .reward-box-wheel span {
    font-size: 10px;
    font-weight: 700;
    color: var(--text-primary);
    line-height: 1.2;
    text-transform: uppercase;
    text-align: left;
    position: relative;
    z-index: 2;
    max-width: 65%
}

.page-friends .reward-box-wheel img {
    width: 65px;
    height: 65px;
    object-fit: contain;
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: 1;
    margin: 0
}

.page-friends .friends-list-container {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding-bottom: 20px
}

.page-friends .invite-item {
    background: var(--element-bg);
    border-radius: 12px;
    padding: 12px;
    display: flex;
    align-items: center;
    gap: 12px;
    width: 100%;
    box-sizing: border-box
}

.page-friends .invite-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
    border: 1px solid rgba(255,255,255,.05)
}

.page-friends .invite-info {
    flex-grow: 1;
    min-width: 0
}

.page-friends .invite-name {
    color: var(--text-primary);
    font-size: 15px;
    font-weight: 700;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis
}

.page-friends .invite-details {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 4px
}

.page-friends .invite-tag,.page-friends .invite-date {
    color: var(--text-secondary);
    font-size: 13px
}

.page-friends .invite-reward {
    display: flex;
    align-items: center;
    gap: 4px;
    color: var(--text-primary);
    font-weight: 700;
    font-size: 15px;
    background-color: #ffffff1a;
    padding: 6px 10px;
    border-radius: 8px;
    white-space: nowrap
}

.page-friends .invite-reward--pending {
    background: none;
    padding: 6px;
    justify-content: center
}

.page-friends .invite-spinner {
    width: 20px;
    height: 20px;
    animation: invite-spin 1s linear infinite;
    color: currentColor
}

@keyframes invite-spin {
    100% { transform: rotate(360deg) }
}

.page-friends .invite-reward--rejected {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    background: none;
    padding: 6px;
    position: relative
}

.page-friends .invite-info-icon {
    position: relative;
    display: flex;
    align-items: center;
    cursor: pointer
}

.page-friends .invite-tooltip {
    visibility: hidden;
    opacity: 0;
    background-color: #2a2a2a;
    color: #fff;
    text-align: center;
    border-radius: 6px;
    padding: 6px 10px;
    position: absolute;
    z-index: 100;
    bottom: 140%;
    left: 50%;
    transform: translateX(-50%);
    width: max-content;
    max-width: 140px;
    font-size: 11px;
    font-family: sans-serif;
    box-shadow: 0 4px 6px #0000004d;
    transition: opacity .2s ease-in-out,visibility .2s;
    pointer-events: none
}

.page-friends .invite-tooltip-arrow {
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -5px;
    border-width: 5px;
    border-style: solid;
    border-color: #2a2a2a transparent transparent transparent
}

.page-friends .invite-info-icon:hover .invite-tooltip {
    visibility: visible;
    opacity: 1
}

.page-friends .empty-state {
    text-align: center;
    padding: 40px 20px;
    color: var(--text-secondary)
}

@media (max-width: 360px) {
    .page-friends .info-bg-image {
        height:100px;
        right: -15px
    }

    .page-friends .reward-box span {
        font-size: 9px
    }
}

.profile-access-status {
    width: 100%;
    padding: 12px 16px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: transform .2s,background-color .2s;
    margin-bottom: 12px;
    box-sizing: border-box;
    text-decoration: none;
    border: 1px solid transparent
}

.profile-access-status:active {
    transform: scale(.98)
}

.access-status-warning {
    background: #ffa5001a;
    color: #ffb340;
    border-color: #ffa50033
}

.access-status-warning .status-icon {
    color: #ffb340
}

.access-status-success {
    background: #4aa6571a;
    color: #4aa657;
    border-color: #4aa65733;
    cursor: default
}

.access-status-success:active {
    transform: none
}

.access-status-success .status-icon {
    color: #4aa657
}

.access-status-error {
    background: #c8313e1a;
    color: #ff6060;
    border-color: #c8313e33
}

.access-status-error .status-icon {
    color: #ff6060
}

.status-icon {
    width: 24px;
    height: 24px;
    flex-shrink: 0
}

.smart-access-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #000000b3;
    z-index: 2000;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: all .3s ease;
    -webkit-backdrop-filter: blur(5px);
    backdrop-filter: blur(5px)
}

.smart-access-overlay.show {
    opacity: 1;
    visibility: visible
}

.smart-access-modal {
    background: var(--profile-modal-bg);
    border: var(--profile-border);
    border-radius: 24px;
    padding: 30px 24px;
    width: 90%;
    max-width: 380px;
    text-align: center;
    transform: scale(.9);
    transition: transform .3s cubic-bezier(.34,1.56,.64,1);
    position: relative;
    box-shadow: 0 10px 40px #00000080
}

.smart-icon-wrapper {
    margin-bottom: 20px
}

.smart-icon-wrapper svg {
    width: 60px;
    height: 60px
}

.smart-icon-wrapper.warning svg {
    color: #ffb340
}

.smart-icon-wrapper.sad svg {
    color: #ff6060
}

.smart-title {
    font-size: 20px;
    font-weight: 800;
    color: var(--text-primary);
    margin-bottom: 12px;
    line-height: 1.3
}

.smart-text {
    font-size: 15px;
    color: var(--text-secondary);
    margin-bottom: 24px;
    line-height: 1.5
}

.smart-subtext {
    font-size: 13px;
    color: var(--text-tertiary);
    margin-bottom: 20px;
    margin-top: -10px
}

.reward-promo-block {
    background: #ffffff0d;
    border-radius: 16px;
    padding: 15px;
    margin-bottom: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    border: 1px solid rgba(255,215,0,.2)
}

.reward-value-anim {
    font-size: 28px;
    font-weight: 800;
    color: gold;
    display: flex;
    align-items: center;
    gap: 6px;
    background: linear-gradient(90deg,gold,#fff,gold);
    background-size: 200% auto;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    animation: goldShine 3s linear infinite
}

.reward-coin-icon {
    width: 28px;
    height: 28px;
    fill: gold;
    filter: drop-shadow(0 0 10px rgba(255,215,0,.5))
}

.reward-info-btn {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--text-secondary);
    opacity: .7;
    padding: 5px;
    display: flex
}

.reward-info-btn:hover {
    opacity: 1;
    color: var(--text-primary)
}

.smart-btn {
    width: 100%;
    padding: 16px;
    border-radius: 14px;
    font-weight: 700;
    font-size: 16px;
    cursor: pointer;
    border: none;
    transition: transform .1s
}

.smart-btn.primary {
    background: var(--info-color);
    color: #fff;
    box-shadow: 0 4px 15px #0a84ff4d
}

.smart-btn:active {
    transform: scale(.97)
}

.smart-tooltip {
    position: absolute;
    background: #141414f2;
    padding: 12px;
    border-radius: 8px;
    font-size: 12px;
    color: #fff;
    width: 200px;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    pointer-events: none;
    opacity: 0;
    transition: opacity .2s;
    z-index: 10;
    border: 1px solid rgba(255,255,255,.1);
    box-shadow: 0 10px 30px #00000080
}

.smart-tooltip.show {
    opacity: 1
}

.smart-access-modal {
    background: #1e1e1e99!important;
    backdrop-filter: blur(20px)!important;
    -webkit-backdrop-filter: blur(20px)!important;
    border: 1px solid rgba(255,255,255,.08)!important;
    border-radius: 24px!important;
    padding: 32px 24px!important;
    width: 82%;
    max-width: 360px;
    box-shadow: 0 20px 50px #00000080!important;
    text-align: center;
    position: relative;
    overflow: hidden;
    transform: scale(.95);
    transition: transform .3s cubic-bezier(.175,.885,.32,1.275)
}

.smart-access-overlay.show .smart-access-modal {
    transform: scale(1)
}

.smart-icon-container {
    margin-bottom: 20px;
    display: inline-flex;
    padding: 15px;
    border-radius: 50%;
    background: #ffffff08;
    box-shadow: inset 0 0 20px #ffffff05
}

.smart-icon-container svg {
    filter: drop-shadow(0 0 10px currentColor)
}

.smart-title {
    font-size: 22px;
    font-weight: 800;
    color: #fff;
    margin: 0 0 12px;
    letter-spacing: -.5px
}

.smart-text {
    font-size: 15px;
    color: #9ca3af;
    line-height: 1.5;
    margin: 0 0 24px
}

.smart-text b {
    color: #fff
}

.smart-reward-box {
    background: linear-gradient(145deg,#ffd7000d,#0003);
    border: 1px solid rgba(255,215,0,.3);
    border-radius: 16px;
    padding: 16px;
    margin-bottom: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    position: relative;
    box-shadow: 0 4px 20px #ffd7000d
}

.golden-anim {
    font-size: 28px;
    font-weight: 800;
    text-transform: uppercase;
    background: linear-gradient(90deg,gold,#fff,gold);
    background-size: 200% auto;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    animation: goldShine 3s linear infinite;
    display: flex;
    align-items: center;
    gap: 8px
}

.golden-anim svg {
    filter: drop-shadow(0 0 5px rgba(255,215,0,.5))
}

.smart-btn {
    width: 100%;
    padding: 16px;
    border-radius: 14px;
    font-size: 16px;
    font-weight: 700;
    border: none;
    cursor: pointer;
    transition: all .2s ease;
    background: #0a84ff;
    color: #fff;
    box-shadow: 0 4px 15px #0a84ff4d
}

.smart-btn:active {
    transform: scale(.97);
    box-shadow: 0 2px 10px #0a84ff33
}

@keyframes pearlFlow {
    0% {
        background-position: 0% 50%
    }

    50% {
        background-position: 100% 50%
    }

    to {
        background-position: 0% 50%
    }
}

.site-notification-bar.x2-booster {
    background: #141423f2;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: none;
    border-radius: 99px;
    position: fixed;
    z-index: 95;
    height: 32px;
    padding: 0 16px 0 6px;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 10px;
    box-shadow: 0 8px 30px #0006;
    transition: all .5s cubic-bezier(.25,.8,.25,1);
    max-width: 95%
}

.site-notification-bar.x2-booster:before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    border-radius: 99px;
    padding: 1px;
    background: linear-gradient(90deg,#a855f7,#ec4899,#fff,#a855f7);
    background-size: 300% 100%;
    animation: pearlFlow 3s linear infinite;
    -webkit-mask: linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    pointer-events: none
}

.x2-booster-content {
    display: flex;
    align-items: center;
    gap: 8px;
    width: auto
}

.x2-booster-icon {
    width: 22px;
    height: 22px;
    border-radius: 50%;
    object-fit: cover;
    filter: drop-shadow(0 0 5px rgba(168,85,247,.6))
}

.x2-booster-text {
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .5px;
    text-transform: uppercase;
    white-space: nowrap;
    background: linear-gradient(90deg,#fff,#fbcfe8,#fff);
    background-size: 200% auto;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: #fff;
    text-shadow: 0 0 15px rgba(236,72,153,.5);
    animation: pearlFlow 4s ease infinite
}

.x2-booster-timer {
    font-size: 11px;
    color: #fff9;
    font-weight: 600;
    font-family: monospace;
    margin-top: 1px;
    padding-left: 8px;
    border-left: 1px solid rgba(255,255,255,.15)
}

.site-notification-bar.x2-booster.collapsed {
    width: 32px!important;
    padding: 0!important;
    gap: 0;
    left: 100%!important;
    transform: translate(calc(-100% - 16px))!important;
    justify-content: center;
    background: #1e1e28f2
}

.site-notification-bar.x2-booster.collapsed .x2-booster-text,.site-notification-bar.x2-booster.collapsed .x2-booster-timer {
    display: none;
    opacity: 0;
    width: 0
}

.site-notification-bar.x2-booster.collapsed .x2-booster-content {
    justify-content: center;
    padding: 0;
    margin: 0
}

.site-notification-bar.x2-booster.collapsed .x2-booster-icon {
    margin: 0;
    width: 22px;
    height: 22px
}

@keyframes pearlTextFlow {
    0% {
        background-position: 0% 50%
    }

    50% {
        background-position: 100% 50%
    }

    to {
        background-position: 0% 50%
    }
}

.purple-pearl-text {
    background: linear-gradient(90deg,#a855f7,#da7dff,#fff,#da7dff,#a855f7);
    background-size: 200% auto;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    animation: shine-bg 3s linear infinite;
    font-weight: 800!important
}

.purple-pearl-icon {
    filter: drop-shadow(0 0 4px rgba(168,85,247,.6))
}

.pages-container {
    z-index: 1
}

.modal,.overlay,.site-notification-bar {
    z-index: 2000
}

.settings-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #000000b3;
    z-index: 5000;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: opacity .3s ease,visibility .3s ease;
    -webkit-backdrop-filter: blur(5px);
    backdrop-filter: blur(5px)
}

.settings-overlay.show {
    opacity: 1;
    visibility: visible
}

.settings-modal {
    position: fixed;
    background: #1a1a1af2;
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 24px;
    padding: 24px;
    width: 82%;
    max-width: 400px;
    z-index: 10001;
    opacity: 0;
    pointer-events: none;
    box-shadow: 0 20px 50px #00000080
}

.settings-overlay.show .settings-modal {
    transform: translate(-50%,-50%) scale(1);
    opacity: 1;
    pointer-events: auto
}

body.no-gradients * {
    transition: none!important;
    animation: none!important
}

body.no-gradients #pearlGradient animate {
    display: none!important
}

body.no-gradients .pearl-text,body.no-gradients [style*="url(#pearlGradient)"] {
    fill: #fff!important;
    background: transparent!important;
    -webkit-text-fill-color: #ffffff!important;
    stroke: none!important
}

.settings-overlay.show .settings-modal {
    transform: scale(1)
}

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

.settings-header h3 {
    margin: 0;
    font-size: 20px;
    font-weight: 800;
    color: var(--text-primary)
}

.settings-close-btn {
    background: var(--button-bg);
    border: none;
    color: var(--text-secondary);
    width: 32px;
    height: 32px;
    border-radius: 50%;
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center
}

.settings-list {
    display: flex;
    flex-direction: column;
    gap: 16px
}

.setting-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px;
    background: #ffffff08;
    border-radius: 12px
}

.setting-item span {
    font-size: 15px;
    font-weight: 600;
    color: var(--text-primary)
}

.settings-hint {
    margin-top: 20px;
    font-size: 12px;
    color: var(--text-tertiary);
    text-align: center
}

.toggle-switch {
    position: relative;
    display: inline-block;
    width: 44px;
    height: 24px
}

.toggle-switch input {
    opacity: 0;
    width: 0;
    height: 0
}

.toggle-slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #fff3;
    transition: .4s;
    border-radius: 34px
}

.toggle-slider:before {
    position: absolute;
    content: "";
    height: 18px;
    width: 18px;
    left: 3px;
    bottom: 3px;
    background-color: #fff;
    transition: .4s;
    border-radius: 50%
}

input:checked+.toggle-slider {
    background-color: var(--success-color)
}

input:checked+.toggle-slider:before {
    transform: translate(20px)
}

body.no-transitions *,body.no-transitions *:before,body.no-transitions *:after {
    transition-property: none!important;
    transition-duration: 0s!important
}

body.no-wheel-spin .roulette-wheel,body.no-wheel-spin .roulette-wheel.idle-spin {
    animation-play-state: paused!important;
    -webkit-animation-play-state: paused!important
}

body.no-gradients .purple-pearl-text,body.no-gradients .golden-anim,body.no-gradients .x2-booster-text,body.no-gradients .reward-value-anim,body.no-gradients .site-notification-bar.x2-booster:before,body.no-gradients .smart-reward-box:before,body.no-gradients .award-item.can-claim {
    animation-play-state: paused!important;
    -webkit-animation-play-state: paused!important
}

body.no-gradients .purple-pearl-icon,body.no-gradients .purple-pearl-icon path,body.no-gradients .x2-booster-icon path {
    stroke: #a855f7!important;
    fill: none;
    filter: none!important
}

body.no-gradients svg [fill="url(#pearlGradient)"],body.no-gradients svg [fill="url(#goldGradientAnim)"] {
    fill: #a855f7!important
}

body.no-gradients .right-glow-indicator.visible {
    animation: none!important;
    opacity: .8!important
}

.quick-nav-section {
    display: flex;
    justify-content: center;
    gap: 4%;
    width: 100%;
    margin-top: 1.5rem;
    box-sizing: border-box
}

.quick-nav-btn {
    width: 48%;
    height: auto;
    aspect-ratio: 600 / 429;
    border-radius: 16px;
    overflow: hidden;
    cursor: pointer;
    position: relative;
    box-shadow: 0 4px 15px #ffffff4d;
    transition: transform .2s cubic-bezier(.25,.8,.25,1)
}

.quick-nav-btn:active {
    transform: scale(.96)
}

.quick-nav-btn img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block
}

body.ui-hidden .top-header {
    transform: translate(-50%,-200%)!important;
    pointer-events: none
}

body.ui-hidden .tg-app-header {
    transform: translateY(-200%)!important;
    pointer-events: none
}

body.ui-hidden .bottom-nav {
    transform: translate(-50%) translateY(200%)!important;
    pointer-events: none
}

.referral-actions-container {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    margin-top: 8px
}

.invite-friend-button {
    flex-grow: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 12px 16px;
    background: #22c55e;
    color: #fff;
    border: none;
    border-radius: 12px;
    font-size: 16px;
    font-weight: 700;
    cursor: pointer;
    height: 48px;
    box-shadow: 0 4px 15px #22c55e4d;
    transition: transform .1s ease,background .2s
}

.invite-friend-button:active {
    transform: scale(.97)
}

.invite-friend-button .btn-icon {
    width: 24px;
    height: 24px
}

.referral-link__copy-button {
    background-color: var(--card-background-color);
    border: 1px solid var(--border-color);
    border-radius: .5rem;
    cursor: pointer;
    color: var(--text-color);
    width: 44px;
    height: 44px;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    -webkit-tap-highlight-color: transparent;
    position: relative;
    overflow: hidden;
    transition: background-color .3s,border-color .3s
}

body.ui-hidden-all .top-header,body.ui-hidden-all .tg-app-header {
    transform: translateY(-200%)!important;
    pointer-events: none
}

body.ui-hidden-all .bottom-nav {
    transform: translate(-50%) translateY(200%)!important;
    pointer-events: none
}

body.ui-hidden-top .top-header,body.ui-hidden-top .tg-app-header {
    transform: translateY(-200%)!important;
    pointer-events: none
}

body.ui-hidden-bottom .bottom-nav {
    transform: translate(-50%) translateY(200%)!important;
    pointer-events: none
}

body.hide-tg-header .tg-app-header {
    display: none!important
}

body.platform-pc .top-header {
    top: 10px!important
}

body.platform-pc .pages-container {
    padding-top: 0!important
}

#orientation-lock-overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #0f1521;
    z-index: 999999;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    text-align: center
}

.orientation-lock-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 20px
}

.orientation-lock-content svg {
    animation: rotatePhone 2s infinite ease-in-out
}

.orientation-lock-content p {
    color: #fff;
    font-size: 18px;
    font-weight: 600;
    padding: 0 20px
}

@keyframes rotatePhone {
    0% {
        transform: rotate(0)
    }

    50% {
        transform: rotate(-90deg)
    }

    to {
        transform: rotate(0)
    }
}

@media screen and (orientation: landscape) and (max-height: 500px) and (pointer: coarse) {
    #orientation-lock-overlay {
        display:flex!important
    }

    body {
        overflow: hidden!important
    }
}

#userBalance {
    transition: color .3s ease,transform .2s ease;
    display: inline-block
}

.balance-up {
    color: #4aa657!important;
    transform: scale(1.1)
}

.balance-down {
    color: #c8313e!important;
    transform: scale(.95)
}

@keyframes spinIcon {
    0% {
        transform: rotate(0)
    }

    to {
        transform: rotate(360deg)
    }
}

.spin-icon-anim {
    animation: spinIcon 2s linear infinite;
    width: 18px;
    height: 18px;
    vertical-align: middle
}

.event-reward-modal {
    padding: 32px 24px!important;
    text-align: center;
    background: #1e1e28f2!important;
    border: 1px solid rgba(255,255,255,.1)!important;
    box-shadow: 0 20px 60px #0009!important
}

.event-reward-title {
    font-size: 22px!important;
    font-weight: 800!important;
    text-transform: uppercase;
    letter-spacing: .5px;
    background: linear-gradient(90deg,#fff,#a5a5a5);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    margin-bottom: 24px!important
}

.event-reward-visual {
    width: 120px;
    height: 120px;
    margin: 0 auto 16px;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center
}

.event-reward-visual:before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: radial-gradient(circle,rgba(255,215,0,.3) 0%,transparent 70%);
    filter: blur(20px);
    z-index: 0
}

.er-reward-img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    position: relative;
    z-index: 1;
    filter: drop-shadow(0 10px 20px rgba(0,0,0,.5))
}

.er-balance-display {
    font-size: 32px;
    font-weight: 800;
    color: gold;
    display: flex;
    align-items: center;
    gap: 8px;
    z-index: 1;
    text-shadow: 0 0 20px rgba(255,215,0,.5)
}

.event-reward-subtitle {
    font-size: 16px;
    font-weight: 700;
    color: #fff;
    margin: 0 0 24px
}

.event-reward-stats-container {
    display: flex;
    align-items: center;
    justify-content: center;
    background: #ffffff0d;
    border-radius: 16px;
    padding: 12px;
    margin-bottom: 24px;
    border: 1px solid rgba(255,255,255,.05);
    width: 100%;
    box-sizing: border-box
}

.er-stat-box {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px
}

.er-stat-divider {
    width: 1px;
    height: 30px;
    background: #ffffff1a
}

.er-stat-label {
    font-size: 11px;
    color: var(--text-secondary);
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: .5px
}

.er-stat-value {
    font-size: 18px;
    font-weight: 800;
    color: #fff
}

.er-stat-value.gold-text {
    color: gold
}

.event-reward-claim-button {
    background: linear-gradient(135deg,#0a84ff,#0056b3)!important;
    box-shadow: 0 4px 15px #0a84ff66!important;
    border: none!important;
    font-size: 16px!important;
    padding: 16px!important;
    border-radius: 14px!important;
    transition: transform .2s ease,box-shadow .2s ease!important;
    margin-top: 0!important
}

.event-reward-claim-button:active {
    transform: scale(.97)!important
}

.spin-btn.is-free-spin {
    background: linear-gradient(90deg,#fbb03b,#ffdf7a);
    color: #3e2810;
    font-weight: 800;
    box-shadow: 0 4px 15px #ffd70066
}

.personalization-grid {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 15px;
    margin-top: 20px;
    justify-items: center
}

.color-option-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    width: 100%
}

.color-preview-square {
    width: 60px;
    height: 60px;
    border-radius: 14px;
    border: 2px solid rgba(255,255,255,.1);
    transition: all .2s ease;
    position: relative;
    box-shadow: 0 4px 10px #0003
}

.color-option-card.active .color-preview-square {
    border-color: #fff;
    transform: scale(1.05);
    box-shadow: 0 0 15px #ffffff4d
}

.color-option-card.active .color-preview-square:after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 24px;
    opacity: .8
}

.color-name {
    font-size: 12px;
    color: #888;
    font-weight: 600
}

.color-option-card.active .color-name {
    color: #fff
}

.bg-nick-none {
    background: #333
}

.bg-nick-red {
    background: #ff4757
}

.bg-nick-green {
    background: #2ed573
}

.bg-nick-gold {
    background: linear-gradient(to bottom,gold,#fdb931)
}

.bg-nick-premium {
    background: linear-gradient(120deg,#ffcb66,#ffcb66 48%,#fff,#ffcb66 52%,#ffcb66);
    background-size: 300% auto;
    animation: shine-premium 12s linear infinite
}

.bg-nick-winter {
    background: linear-gradient(90deg,#028fd2,#5a58fe,#9934fe,#5a58fe,#028fd2);
    background-size: 200% auto;
    animation: shine-bg 4s linear infinite
}

.nick-red {
    color: #ff4757!important
}

.nick-green {
    color: #2ed573!important
}

.nick-gold {
    background: linear-gradient(to bottom,gold,#fdb931);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    font-weight: 800
}

.nick-premium {
    background: linear-gradient(120deg,#ffcb66,#ffcb66 48%,#fff,#ffcb66 52%,#ffcb66);
    background-size: 300% auto;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    animation: shine-premium 12s linear infinite;
    font-weight: 800
}

.nick-winter {
    background: linear-gradient(90deg,#028fd2,#5a58fe,#9934fe,#5a58fe,#028fd2);
    background-size: 200% auto;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    animation: shine-bg 4s linear infinite;
    font-weight: 800
}

@keyframes shine-bg {
    0% {
        background-position: 0% center
    }

    to {
        background-position: 200% center
    }
}

@keyframes gradientMove-bg {
    0% {
        background-position: 0% 50%
    }

    to {
        background-position: 100% 50%
    }
}

body.page-events.platform-pc .events-container {
    padding-top: calc(96px + var(--tg-content-safe-area-inset-top, 0px))!important
}

body.page-friends.platform-pc main {
    padding-top: calc(var(--tg-viewport-safe-area-inset-top, 0px) + 92px)!important
}

body.platform-pc .scroll-container {
    padding-top: calc(var(--tg-viewport-safe-area-inset-top, 0px) + 72px)!important
}

body.page-ggpass.platform-pc main {
    padding-top: calc(var(--tg-viewport-safe-area-inset-top, 0px) + 92px)!important
}

body.page-tasks.platform-pc main {
    padding-top: calc(var(--tg-viewport-safe-area-inset-top, 0px) + 66px)!important
}

.deposit-bonus-banner {
    position: absolute;
    top: 3px;
    width: 200px;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,.15);
    border-radius: 12px;
    padding: 6px;
    z-index: 10000;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: opacity .5s ease,transform .5s ease,visibility .5s;
    pointer-events: none
}

.deposit-bonus-banner.visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto
}

.bonus-header {
    font-weight: 800;
    font-size: 14px;
    color: #fff;
    margin-bottom: 2px;
    text-transform: uppercase;
    letter-spacing: .5px
}

.bonus-desc {
    font-size: 10px;
    font-weight: 600;
    color: #ffa800;
    margin-bottom: 8px;
    line-height: 1.2
}

.bonus-code {
    font-size: 18px;
    margin-bottom: 8px;
    letter-spacing: 1px;
    background: linear-gradient(120deg,#ffcb66,#ffcb66 48%,#fff,#ffcb66 52%,#ffcb66);
    background-size: 300% auto;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    animation: shine-premium 12s linear infinite;
    font-weight: 800
}

.bonus-btn {
    background: #6d74ff;
    color: #fff;
    border: none;
    text-decoration: none;
    font-weight: 700;
    font-size: 11px;
    padding: 8px 0;
    width: 100%;
    border-radius: 8px;
    text-transform: uppercase;
    cursor: pointer;
    transition: transform .1s,opacity .2s;
    box-shadow: 0 4px 10px #6d74ff4d
}

.bonus-btn:active {
    transform: scale(.96);
    opacity: .9
}

@keyframes shine-premium {
    0% {
        background-position: 300% center
    }

    to {
        background-position: 0% center
    }
}

.promo-spoiler {
    position: relative;
    display: inline-block;
    color: transparent!important;
    background-color: #2f2f2f;
    border-radius: 6px;
    cursor: pointer;
    overflow: hidden;
    padding: 2px 6px;
    margin: 0 2px;
    vertical-align: middle;
    line-height: 1.2;
    -webkit-user-select: none;
    user-select: none;
    transition: transform .1s;
    -webkit-mask-image: -webkit-radial-gradient(white,black)
}

.promo-spoiler:active {
    transform: scale(.95)
}

.spoiler-canvas {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 1;
    opacity: .6
}

.terms-link {
    display: block;
    margin-top: 15px;
    font-size: 13px;
    color: var(--text-secondary);
    text-decoration: underline;
    cursor: pointer;
    background: none;
    border: none;
    width: 100%;
    text-align: center;
    padding: 5px;
    transition: color .2s
}

.terms-link:hover {
    color: var(--text-primary)
}

.nick-neon {
    color: #fff!important;
    font-weight: 800;
    text-shadow: 0 0 2px #ff9d00,0 0 5px #ff6600,0 0 7px #ff4500;
    animation: neon-flicker 3s infinite alternate
}

@keyframes neon-flicker {
    0%,19%,21%,23%,25%,54%,56%,to {
        text-shadow: 0 0 2px #ff9d00,0 0 5px #ff6600,0 0 7px #ff4500;
        opacity: 1
    }

    20%,24%,55% {
        text-shadow: none;
        opacity: .8
    }
}

.nick-sunset {
    background: linear-gradient(90deg,#8a2be2,#ff69b4,gold);
    -webkit-background-clip: text!important;
    -webkit-text-fill-color: transparent!important;
    font-weight: 800
}

.nick-ice {
    background: linear-gradient(180deg,#fff 10%,#00bfff 60%,#1e90ff);
    -webkit-background-clip: text!important;
    -webkit-text-fill-color: transparent!important;
    font-weight: 800;
    text-shadow: 0 0 2px rgba(0,191,255,.3)
}

.nick-matrix {
    color: #00ff41!important;
    font-weight: 800;
    text-shadow: 0 0 3px #008F11;
    font-family: Courier New,monospace;
    letter-spacing: -.5px
}

.nick-magma {
    background: linear-gradient(to top,maroon,red,#ff0);
    -webkit-background-clip: text!important;
    -webkit-text-fill-color: transparent!important;
    font-weight: 800;
    filter: drop-shadow(0 1px 0px rgba(0,0,0,.5))
}

.nick-dynamic-neon {
    color: #fff!important;
    font-weight: 800;
    display: inline-block;
    padding: 2px 8px;
    border-radius: 6px;
    border: 1px solid var(--user-neon-color);
    text-shadow: 0 0 2px var(--user-neon-color),0 0 5px var(--user-neon-color);
    box-shadow: 0 0 5px var(--user-neon-color),inset 0 0 10px var(--user-neon-color);
    animation: neon-flicker-dynamic 3s infinite alternate
}

@keyframes neon-flicker-dynamic {
    0%,19%,21%,23%,25%,54%,56%,to {
        text-shadow: 0 0 2px var(--user-neon-color),0 0 5px var(--user-neon-color);
        box-shadow: 0 0 8px var(--user-neon-color),inset 0 0 15px var(--user-neon-color);
        border-color: var(--user-neon-color);
        opacity: 1
    }

    20%,24%,55% {
        text-shadow: none;
        box-shadow: none;
        border-color: #ffffff1a;
        opacity: .7
    }
}

.color-edit-btn {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 24px;
    height: 24px;
    background: #0009;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 10;
    transition: transform .2s,background .2s;
    border: 1px solid rgba(255,255,255,.2)
}

.color-edit-btn:active {
    transform: scale(.9)
}

.color-edit-btn svg {
    width: 14px;
    height: 14px;
    color: #fff
}

#neonColorPicker {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
    pointer-events: none
}

.bg-nick-neon {
    --user-neon-color: #ff9d00;
    background-color: #1a1a1a;
    border-radius: 8px;
    border: 1px solid var(--user-neon-color);
    box-shadow: 0 0 5px var(--user-neon-color),inset 0 0 10px var(--user-neon-color);
    animation: neon-box-flicker 3s infinite alternate;
    transition: border-color .2s,box-shadow .2s
}

@keyframes neon-box-flicker {
    0%,19%,21%,23%,25%,54%,56%,to {
        box-shadow: 0 0 8px var(--user-neon-color),inset 0 0 15px var(--user-neon-color);
        border-color: var(--user-neon-color);
        opacity: 1
    }

    20%,24%,55% {
        box-shadow: none;
        border-color: #ffffff1a;
        opacity: .7
    }
}

.bg-nick-sunset {
    background: linear-gradient(135deg,#8a2be2,#ff69b4)
}

.bg-nick-ice {
    background: linear-gradient(135deg,#fff,#00bfff)
}

.nick-matrix {
    position: relative;
    color: #00ff41!important;
    font-family: Courier New,monospace;
    font-weight: 800;
    letter-spacing: -.5px;
    text-transform: uppercase;
    text-shadow: 0 0 5px rgba(0,255,65,.5)
}

.nick-matrix:before,.nick-matrix:after {
    content: attr(data-text);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #1a1a1a
}

.nick-matrix:before {
    left: 2px;
    text-shadow: -1px 0 #ccffcc;
    clip-path: inset(0 0 0 0);
    animation: matrix-glitch-anim-1 2s infinite linear alternate-reverse
}

.nick-matrix:after {
    left: -2px;
    text-shadow: -1px 0 #003300;
    clip-path: inset(0 0 0 0);
    animation: matrix-glitch-anim-2 3s infinite linear alternate-reverse
}

@keyframes matrix-glitch-anim-1 {
    0% {
        clip-path: inset(20% 0 80% 0)
    }

    20% {
        clip-path: inset(60% 0 10% 0)
    }

    40% {
        clip-path: inset(40% 0 50% 0)
    }

    60% {
        clip-path: inset(80% 0 5% 0)
    }

    80% {
        clip-path: inset(10% 0 70% 0)
    }

    to {
        clip-path: inset(30% 0 20% 0)
    }
}

@keyframes matrix-glitch-anim-2 {
    0% {
        clip-path: inset(10% 0 60% 0)
    }

    20% {
        clip-path: inset(30% 0 20% 0)
    }

    40% {
        clip-path: inset(70% 0 10% 0)
    }

    60% {
        clip-path: inset(20% 0 50% 0)
    }

    80% {
        clip-path: inset(50% 0 30% 0)
    }

    to {
        clip-path: inset(0% 0 90% 0)
    }
}

.bg-nick-matrix {
    background-color: #000;
    border: 1px solid #00FF41;
    box-shadow: 0 0 5px #00ff41 inset;
    position: relative;
    overflow: hidden
}

.bg-nick-matrix:after {
    content: "";
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: repeating-linear-gradient(0deg,transparent,transparent 2px,#00FF41 3px,#00FF41 3px);
    opacity: .1;
    animation: matrix-scan 5s linear infinite
}

@keyframes matrix-scan {
    0% {
        transform: translateY(0)
    }

    to {
        transform: translateY(20px)
    }
}

.bg-nick-magma {
    background: linear-gradient(135deg,maroon,red)
}

.compensation-visual {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 15px;
    margin-bottom: 20px;
    width: 100%
}

.comp-item {
    position: relative;
    width: 80px;
    height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #ffffff0d;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,.1)
}

.comp-item img {
    width: 60px;
    height: 60px;
    object-fit: contain
}

.comp-item.crossed {
    filter: grayscale(100%);
    opacity: .7
}

.comp-item.crossed:after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100%;
    height: 3px;
    background: #ff4d4d;
    transform: translate(-50%,-50%) rotate(-45deg);
    box-shadow: 0 0 5px #ff000080
}

.comp-arrow {
    color: var(--text-secondary);
    animation: pulseArrow 1.5s infinite
}

@keyframes pulseArrow {
    0%,to {
        transform: translate(0);
        opacity: .5
    }

    50% {
        transform: translate(5px);
        opacity: 1
    }
}

.comp-text {
    font-size: 14px;
    color: var(--text-secondary);
    line-height: 1.5;
    margin-bottom: 20px;
    text-align: center
}

.comp-amount {
    color: gold;
    font-weight: 800
}

.comp-amount-box {
    background: linear-gradient(145deg,#ffd7000d,#0003);
    border: 1px solid rgba(255,215,0,.3);
    border-radius: 16px;
    padding: 12px 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    box-shadow: 0 4px 15px #ffd7000d
}

.comp-amount-value {
    font-size: 26px;
    font-weight: 800;
    background: linear-gradient(90deg,gold,#fff,gold);
    background-size: 200% auto;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    animation: goldShine 3s linear infinite
}

@keyframes goldShine {
    to {
        background-position: 200% center
    }
}

.capsule-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #000c;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: .3s
}

.capsule-overlay.active {
    opacity: 1;
    visibility: visible
}

.capsule-modal {
    width: 82%;
    max-width: 400px;
    text-align: center;
    background: var(--profile-modal-bg);
    border: var(--profile-border);
    border-radius: 24px;
    padding: 30px 20px;
    box-shadow: 0 20px 50px #00000080;
    display: flex;
    flex-direction: column;
    align-items: center
}

.capsule-title {
    color: var(--text-primary);
    font-weight: 800;
    font-size: 22px;
    margin: 0 0 30px;
    text-transform: uppercase;
    letter-spacing: 1px
}

.capsule-scratch-area {
    display: flex;
    gap: 15px;
    justify-content: center;
    margin-bottom: 30px;
    width: 100%
}

.scratch-card {
    width: 130px;
    height: 130px;
    position: relative;
    border-radius: 16px;
    overflow: hidden;
    border: 2px solid rgba(255,255,255,.1);
    background: #222;
    transition: transform .3s,opacity .3s,border-color .3s;
    box-shadow: 0 4px 15px #0000004d;
    flex-shrink: 0
}

.scratch-card.selected {
    border-color: var(--success-color);
    transform: scale(1.05);
    box-shadow: 0 0 20px #4aa65766;
    z-index: 2
}

.scratch-card.locked {
    opacity: .8;
    transform: scale(.95);
    pointer-events: none
}

.scratch-result {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    z-index: 10;
    background: radial-gradient(circle,#ffffff1a,#0000 70%)
}

.scratch-img {
    width: 70%;
    height: 70%;
    object-fit: contain;
    filter: drop-shadow(0 5px 10px rgba(0,0,0,.5))
}

.scratch-percent {
    position: absolute;
    bottom: 8px;
    font-size: 14px;
    font-weight: 800;
    color: #fff;
    background: #0009;
    padding: 4px 8px;
    border-radius: 6px;
    opacity: 0;
    transition: opacity .5s;
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px)
}

.scratch-canvas {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 20;
    cursor: crosshair;
    touch-action: none
}

.capsule-colors-list-wrapper {
    width: 100%;
    overflow-x: auto;
    padding-bottom: 10px
}

.capsule-colors-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: center
}

.capsule-color-item {
    width: 48px;
    height: 48px;
    background: var(--button-bg);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 10px;
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent
}

.capsule-color-item img {
    width: 80%;
    height: 80%;
    object-fit: contain
}

.color-percent-blur {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: #000000b3;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 700;
    font-size: 14px;
    opacity: 0;
    transition: opacity .1s ease-out;
    border-radius: 10px
}

.capsule-color-item.blur-active .color-percent-blur {
    opacity: 1
}

.capsule-status-text {
    margin-top: 20px;
    color: var(--text-secondary);
    font-size: 14px;
    font-weight: 500;
    min-height: 20px
}

.personalization-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #00000080;
    z-index: 10001;
    opacity: 0;
    visibility: hidden;
    transition: opacity .3s ease,visibility .3s ease;
    display: flex;
    align-items: flex-end
}

.personalization-overlay.show {
    opacity: 1;
    visibility: visible
}

.personalization-modal {
    background: var(--header-bg);
    backdrop-filter: var(--blur-effect);
    -webkit-backdrop-filter: blur(20px);
    border-top-left-radius: 20px;
    border-top-right-radius: 20px;
    width: 100%;
    box-sizing: border-box;
    max-height: 85vh;
    overflow-y: auto;
    transform: translateY(100%);
    transition: transform .4s cubic-bezier(.4,0,.2,1);
    padding: 24px;
    display: flex;
    flex-direction: column
}

.personalization-overlay.show .personalization-modal {
    transform: translateY(0)
}

.personalization-header {
    margin-bottom: 20px;
    text-align: center
}

.personalization-title {
    font-size: 20px;
    font-weight: 800;
    color: var(--text-primary);
    margin: 0 0 8px
}

.personalization-desc {
    font-size: 14px;
    color: var(--text-secondary);
    margin: 0;
    line-height: 1.4
}

.personalization-grid {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 12px;
    margin-bottom: 20px
}

.color-option-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    position: relative
}

.color-preview-square {
    width: 100%;
    aspect-ratio: 1;
    border-radius: 16px;
    border: 2px solid rgba(255,255,255,.1);
    background-color: #222;
    position: relative;
    overflow: hidden;
    transition: all .2s ease;
    display: flex;
    align-items: center;
    justify-content: center
}

.color-preview-img {
    width: 80%;
    height: 80%;
    object-fit: contain;
    filter: drop-shadow(0 4px 8px rgba(0,0,0,.5));
    transition: transform .2s
}

.color-option-card.active .color-preview-square {
    border-color: var(--success-color);
    box-shadow: 0 0 0 4px #4aa65733
}

.color-option-card.active .color-preview-img {
    transform: scale(1.1)
}

.bg-nick-neon {
    background: #1a1a1a;
    border: 1px solid var(--user-neon-color);
    box-shadow: inset 0 0 20px var(--user-neon-color)
}

.personalization-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 40px 0;
    color: var(--text-secondary)
}

.personalization-empty svg {
    width: 64px;
    height: 64px;
    margin-bottom: 16px;
    opacity: .5
}

.page-tasks main {
    width: 90%;
    margin: 0 auto;
    padding-top: calc(var(--tg-content-safe-area-inset-top) + var(--tg-safe-area-inset-top) + 68px);
    opacity: 0;
    transition: opacity .3s ease
}

.tasks-grid {
    display: grid;
    grid-template-columns: minmax(0,1fr);
    gap: 12px;
    width: 100%;
    box-sizing: border-box
}

.task-card {
    background: var(--card-bg);
    border-radius: 100px;
    padding: 4px 12px 4px 4px;
    display: flex;
    align-items: center;
    gap: 12px;
    border: 1px solid rgba(255,255,255,.05);
    position: relative;
    min-height: 60px;
    transition: all .5s ease
}

.task-card-img {
    width: 60px;
    height: 60px;
    border-radius: 100px;
    object-fit: cover;
    flex-shrink: 0
}

.task-card-info {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    gap: 4px;
    position: relative;
    justify-content: center;
    min-width: 0
}

.task-card-title {
    font-weight: 700;
    font-size: 14px;
    color: #fff;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block
}

.task-card-reward {
    font-size: 12px;
    color: var(--success-color);
    font-weight: 600;
    display: flex;
    align-items: center
}

.task-card-btn {
    width: 40px;
    height: 40px;
    min-width: 40px;
    flex-shrink: 0;
    border-radius: 100px;
    background: var(--button-bg);
    color: #fff;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer
}

.task-card-btn svg {
    width: 20px
}

.task-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #000c;
    z-index: 10000;
    opacity: 0;
    visibility: hidden;
    transition: .3s;
    display: flex;
    align-items: flex-end
}

.task-modal-overlay.active {
    opacity: 1;
    visibility: visible
}

.task-modal {
    width: 100%;
    background: #1a1a1a;
    border-radius: 24px 24px 0 0;
    padding: 24px;
    box-sizing: border-box;
    position: relative;
    overflow: hidden;
    transform: translateY(100%);
    transition: transform .3s cubic-bezier(.4,0,.2,1)
}

.task-modal-overlay.active .task-modal {
    transform: translateY(0)
}

.task-modal-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    opacity: .1
}

.task-modal-content {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    text-align: left
}

.task-modal-title {
    font-size: 24px;
    font-weight: 700;
    margin: 0 0 4px;
    text-transform: uppercase;
    text-align: left;
    width: 100%
}

.task-modal-desc {
    font-size: 14px;
    color: #888;
    margin: 0 0 10px;
    text-align: left;
    max-width: 75%;
    line-height: 1.4
}

.task-channel-card {
    background: #40404066;
    border-radius: 100px;
    padding: 3px;
    display: flex;
    align-items: center;
    gap: 7px;
    width: 100%;
    box-sizing: border-box;
    margin-bottom: 24px;
    -webkit-backdrop-filter: blur(7px);
    backdrop-filter: blur(7px)
}

.task-channel-avatar {
    width: 55px;
    height: 55px;
    border-radius: 50%
}

.task-channel-info {
    flex-grow: 1;
    text-align: left;
    min-width: 0;
    padding-right: 10px
}

.task-channel-name {
    font-weight: 700;
    font-size: 14px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block
}

.task-channel-tag {
    font-size: 12px;
    color: #ffffffbd;
    font-weight: 300
}

.task-reward-badge {
    color: gold;
    font-weight: 800;
    font-size: 16px;
    display: flex;
    align-items: center;
    gap: 4px;
    padding-right: 15px;
    justify-content: flex-end
}

.task-action-btn {
    padding: 16px 32px;
    background: #40404066;
    color: #fff;
    border: none;
    border-radius: 100px;
    font-weight: 600;
    font-size: 16px;
    cursor: pointer;
    -webkit-backdrop-filter: blur(14px);
    backdrop-filter: blur(7px);
    margin: 0 auto;
    display: block
}

.empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 40px 20px;
    text-align: center;
    color: var(--text-secondary);
    width: 100%;
    box-sizing: border-box
}

.empty-state-icon {
    width: 64px;
    height: 64px;
    margin-bottom: 16px;
    opacity: .5;
    stroke: currentColor
}

.empty-state p {
    font-size: 15px;
    margin: 0;
    max-width: 280px;
    line-height: 1.4;
    font-weight: 500
}

.task-reward-badge.vertical {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px
}

.task-reward-img {
    width: 40px;
    height: 40px;
    object-fit: contain;
    filter: drop-shadow(0 0 10px rgba(255,255,255,.2))
}

.task-reward-name {
    font-size: 11px;
    font-weight: 600;
    color: var(--text-secondary);
    text-align: center;
    white-space: nowrap
}

.task-limit-badge {
    position: absolute;
    top: -23px;
    left: 0;
    right: auto;
    background: #fcc4551a;
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-radius: 100px;
    padding: 3px 6px;
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 11px;
    font-weight: 700;
    color: #fcc455;
    z-index: 2;
    white-space: nowrap
}

.task-limit-badge svg {
    width: 12px;
    height: 12px;
    fill: #fcc455
}

.task-card.grayed-out {
    filter: grayscale(1);
    opacity: .7
}

.task-card.grayed-out .task-card-title,.task-card.grayed-out .task-card-reward {
    opacity: .6
}

.task-card-btn.completed {
    background: #4aa65766!important;
    color: #fff!important;
    cursor: default!important;
    pointer-events: none;
    border: 1px solid rgba(74,166,87,.2)
}

.task-card-btn.unavailable {
    background: #ffffff1a!important;
    color: #888!important;
    cursor: default!important;
    pointer-events: none
}

.task-modal-limit {
    margin-bottom: 8px;
    background: #fcc4551a;
    -webkit-backdrop-filter: blur(14px);
    backdrop-filter: blur(14px);
    border-radius: 100px;
    padding: 6px 12px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    font-weight: 700;
    color: #fcc455;
    align-self: flex-end;
    margin-left: auto
}

.task-modal.gray-mode .task-channel-avatar,.task-modal.gray-mode .task-modal-bg {
    filter: grayscale(1)
}

.task-modal.gray-mode .task-channel-name,.task-modal.gray-mode .task-channel-tag,.task-modal.gray-mode .task-reward-badge {
    opacity: .6
}

.task-action-btn.completed {
    background: #4aa65766!important;
    color: #fff!important;
    cursor: default;
    pointer-events: none;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px
}

.task-action-btn.unavailable {
    background: #ffffff1a!important;
    color: #888!important;
    cursor: default;
    pointer-events: none
}

.task-meta-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    width: 100%;
    margin-bottom: 24px;
    gap: 10px
}

.withdraw-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #000c;
    z-index: 2000;
    opacity: 0;
    visibility: hidden;
    transition: opacity .3s ease,visibility .3s ease;
    display: flex;
    align-items: flex-end
}

.withdraw-overlay.show {
    opacity: 1;
    visibility: visible
}

.withdraw-modal {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: var(--header-bg);
    border-radius: 20px 20px 0 0;
    z-index: 1001;
    display: flex;
    flex-direction: column;
    height: 85vh;
    max-height: 85vh;
    overflow: hidden;
    -webkit-backdrop-filter: var(--blur-effect);
    backdrop-filter: var(--blur-effect);
    transform: translateY(100%);
    transition: transform .3s cubic-bezier(.2,.8,.2,1)
}

.withdraw-header,.withdraw-tabs {
    flex-shrink: 0;
    padding: 0 20px
}

.withdraw-overlay.show .withdraw-modal {
    transform: translateY(0)
}

.withdraw-header {
    padding-top: 20px;
    padding-bottom: 10px
}

.withdraw-header h3 {
    font-size: 20px;
    font-weight: 800;
    color: var(--text-primary);
    margin: 10px 0 0
}

.withdraw-drag-handle {
    width: 40px;
    height: 4px;
    background: #fff3;
    border-radius: 2px;
    position: absolute;
    top: -10px
}

.withdraw-form .form-group {
    margin-bottom: 20px
}

.withdraw-form label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--text-secondary);
    margin-bottom: 8px
}

.custom-input-wrapper {
    background: var(--button-bg);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 12px;
    display: flex;
    align-items: center;
    padding: 0 12px;
    transition: border-color .2s;
    margin-bottom: 3px;
    position: relative
}

.custom-input-wrapper:focus-within {
    border-color: var(--info-color);
    background: #ffffff0d
}

.custom-input {
    background: transparent;
    border: none;
    color: var(--text-primary);
    font-size: 16px;
    font-weight: 600;
    width: 100%;
    padding: 14px 0;
    outline: none
}

.input-suffix {
    color: var(--text-secondary);
    font-weight: 700;
    margin-left: 8px
}

.input-icon {
    color: var(--text-secondary);
    margin-right: 10px;
    display: flex;
    align-items: center;
    width: 100%
}

.input-icon svg {
    margin-right: 8px;
    flex-shrink: 0
}

.input-icon input {
    flex: 1;
    background: transparent;
    border: none;
    color: #fff;
    outline: none;
    font-weight: 600
}

.custom-file-upload {
    background: var(--button-bg);
    border: 1px dashed rgba(255,255,255,.2);
    border-radius: 12px;
    padding: 0 12px;
    height: 50px;
    position: relative;
    display: flex;
    align-items: center;
    cursor: pointer;
    transition: all .3s ease;
    box-sizing: border-box;
    overflow: hidden
}

.custom-file-upload:hover {
    background: #ffffff1a
}

custom-file-upload span {
    font-size: 14px;
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    width: 100%;
    padding-right: 40px;
    text-align: left
}

.upload-preview-container {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    width: 0;
    height: 36px;
    border-radius: 6px;
    overflow: hidden;
    opacity: 0;
    transition: width .3s ease,opacity .3s ease;
    background: #000;
    z-index: 10
}

.upload-preview-container img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block
}

.upload-icon {
    color: var(--info-color);
    flex-shrink: 0
}

.custom-file-upload.has-file .upload-preview-container {
    width: 36px;
    opacity: 1
}

.custom-file-upload.has-file {
    border-color: var(--success-color);
    background: #4aa6571a
}

.custom-file-upload.has-file span {
    flex-grow: 1
}

.custom-file-upload span {
    font-size: 12px;
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: flex;
    align-items: center;
    height: 100%;
    width: 100%;
    padding-right: 40px
}

.skin-price-box {
    background: linear-gradient(90deg,#ffd7001a,#0000);
    border: 1px solid rgba(255,215,0,.3);
    border-radius: 12px;
    padding: 12px 16px;
    display: flex;
    align-items: center;
    margin-bottom: 12px
}

.skin-price-box span {
    font-size: 20px;
    font-weight: 800;
    color: gold
}

.skin-price-box .currency {
    margin-left: 4px;
    font-size: 20px
}

.copy-icon-btn {
    margin-left: auto;
    background: none;
    border: none;
    color: #ffffff80;
    cursor: pointer;
    margin-bottom: -5px
}

.copy-icon-btn:active {
    color: #fff;
    transform: scale(.9)
}

.skin-card {
    display: flex;
    align-items: center;
    gap: 12px;
    background: #0003;
    padding: 10px;
    border-radius: 12px
}

.skin-card img {
    width: 70px;
    height: 40px;
    object-fit: contain
}

.skin-details {
    display: flex;
    flex-direction: column
}

.skin-title {
    font-size: 14px;
    font-weight: 700;
    color: #fff
}

.skin-subtitle {
    font-size: 11px;
    color: #888
}

.info-note {
    font-size: 11px;
    color: #666;
    margin-top: 6px;
    line-height: 1.3
}

.error-text {
    color: #ff6b6b
}

.withdraw-submit-btn {
    width: 100%;
    padding: 16px;
    background: var(--success-color);
    color: #fff;
    border: none;
    border-radius: 14px;
    font-size: 16px;
    font-weight: 700;
    cursor: pointer;
    margin-top: 10px;
    box-shadow: 0 1px 2px #4aa6574d;
    transition: transform .1s
}

.withdraw-submit-btn:active {
    transform: scale(.98)
}

.withdraw-submit-btn:disabled {
    opacity: .6;
    cursor: not-allowed
}

.withdraw-footer-note {
    text-align: center;
    font-size: 11px;
    color: #666;
    margin-top: 12px
}

.icon-suffix {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-left: 8px
}

.icon-suffix svg {
    color: var(--text-secondary);
    opacity: .8
}

.custom-input.error-input-text {
    color: #ff4e4e!important
}

.amount-warning-overlay {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: #c8313ef2;
    color: #fff;
    padding: 4px 8px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 700;
    pointer-events: none;
    opacity: 0;
    visibility: hidden;
    transition: opacity .2s ease,visibility .2s ease,left .1s ease;
    z-index: 10;
    box-shadow: 0 4px 10px #0000004d;
    white-space: nowrap
}

.amount-warning-overlay.show {
    opacity: 1;
    visibility: visible
}

@keyframes popIn {
    0% {
        transform: translateY(-50%) scale(.8);
        opacity: 0
    }

    to {
        transform: translateY(-50%) scale(1);
        opacity: 1
    }
}

.withdraw-tabs {
    display: flex;
    background: #7676801f;
    border-radius: 12px;
    padding: 4px;
    margin-bottom: 20px;
    position: relative;
    margin-left: 20px;
    margin-right: 20px;
    width: auto;
    box-sizing: border-box
}

.withdraw-tab {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 8px;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 600;
    color: var(--text-secondary);
    cursor: pointer;
    transition: all .2s ease;
    -webkit-user-select: none;
    user-select: none
}

.withdraw-tab svg {
    width: 16px;
    height: 16px;
    opacity: .7
}

.withdraw-tab.active {
    background: #fff;
    color: #000;
    box-shadow: 0 2px 8px #00000026
}

.withdraw-tab.active svg {
    opacity: 1
}

.withdraw-content-viewport {
    flex: 1;
    width: 100%;
    position: relative;
    overflow: hidden
}

.withdraw-content-slider {
    display: flex;
    width: 200%;
    height: 100%;
    transition: transform .3s cubic-bezier(.25,1,.5,1)
}

.withdraw-view {
    width: 50%;
    height: 100%;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 0 20px 20px;
    box-sizing: border-box;
    -webkit-overflow-scrolling: touch
}

.withdraw-history-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding-bottom: 20px
}

.withdraw-history-list::-webkit-scrollbar {
    display: none
}

.history-item {
    background: var(--button-bg);
    border: 1px solid rgba(255,255,255,.05);
    border-radius: 14px;
    padding: 12px;
    display: flex;
    flex-direction: column;
    gap: 8px
}

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

.history-avatar {
    width: 40px;
    height: 40px;
    border-radius: 8px;
    object-fit: cover;
    background: #000
}

.history-info {
    flex: 1
}

.history-id {
    font-size: 12px;
    color: var(--text-secondary);
    margin-bottom: 2px
}

.history-amount {
    font-size: 16px;
    font-weight: 700;
    color: var(--text-primary)
}

.history-status {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 600;
    padding-top: 6px;
    border-top: 1px solid rgba(255,255,255,.05)
}

.status-icon {
    width: 16px;
    height: 16px
}

.history-status.pending {
    color: #fbb03b
}

.history-status.success {
    color: #4aa657
}

.history-status.canceled {
    color: #ff4e4e
}

.history-reason {
    font-size: 11px;
    color: #ff4e4e;
    background: #ff4e4e1a;
    padding: 6px 10px;
    border-radius: 6px;
    margin-top: 4px;
    line-height: 1.3
}

.field-error {
    color: #ff4e4e;
    font-size: 11px;
    font-weight: 600;
    margin-top: 6px;
    display: none;
    line-height: 1.2;
    animation: fadeInError .2s ease-out
}

.field-error.show {
    display: block
}

.custom-input-wrapper.has-error,.custom-file-upload.has-error {
    border-color: #ff4e4e!important;
    background: #ff4e4e0d
}

@keyframes fadeInError {
    0% {
        opacity: 0;
        transform: translateY(-5px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

.history-date {
    font-size: 11px;
    color: var(--text-secondary);
    opacity: .7;
    margin-bottom: 2px
}

.page-ggpass main {
    padding-top: calc(var(--tg-viewport-safe-area-inset-top, 0px) + 152px)!important;
    width: 100%;
    max-width: 100%;
    display: block;
    overflow-x: hidden;
    overflow-y: visible;
    padding-bottom: calc(6rem + 10px)
}

.ggpass-timer-container {
    position: absolute;
    top: 5px;
    left: 50%;
    transform: translate(-50%);
    background: #1a1a1a33;
    backdrop-filter: blur(30px);
    -webkit-backdrop-filter: blur(30px);
    border-radius: 15px;
    padding: 10px 20px;
    text-align: center;
    z-index: 10;
    width: max-content
}

.ggpass-timer-label {
    font-weight: 500;
    font-size: 11px;
    color: #fff;
    margin-bottom: 4px
}

.ggpass-timer-value {
    font-weight: 800;
    font-size: 20px;
    color: #fff;
    letter-spacing: 1px
}

.ggpass-timer-sublabels {
    display: flex;
    justify-content: space-between;
    width: 100%;
    margin-top: -2px
}

.ggpass-timer-sublabels span {
    font-weight: 500;
    font-size: 7px;
    color: #ffffff8c
}

.ggpass-header-image {
    width: 100%;
    height: auto;
    aspect-ratio: 390 / 363;
    overflow: hidden;
    border-top-left-radius: 25px;
    border-top-right-radius: 25px;
    position: relative;
    z-index: 1
}

.ggpass-header-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block
}

.ggpass-sticky-wrapper {
    position: -webkit-sticky;
    position: sticky;
    top: calc(var(--tg-content-safe-area-inset-top) + var(--tg-safe-area-inset-top) + 92px);
    z-index: 20;
    padding: 0 20px;
    margin-top: -110px;
    margin-bottom: 20px;
    pointer-events: none
}

.ggpass-sticky-wrapper>* {
    pointer-events: auto
}

body.platform-pc .ggpass-sticky-wrapper {
    top: calc(var(--tg-viewport-safe-area-inset-top, 0px) + 102px)!important
}

.ggpass-title {
    font-weight: 800;
    font-size: 32px;
    color: #fff;
    text-align: center;
    margin: -150px 0 110px;
    text-shadow: 0 4px 20px rgba(0,0,0,.5);
    position: relative;
    z-index: 5;
    pointer-events: none
}

.ggpass-progress-card {
    background: #1a1a1a66;
    backdrop-filter: blur(40px);
    -webkit-backdrop-filter: blur(40px);
    border-radius: 30px;
    padding: 15px 20px 10px;
    width: 100%;
    box-sizing: border-box
}

.ggpass-progress-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px
}

.ggpass-level-text {
    font-weight: 800;
    font-size: 22px;
    color: #fff
}

.ggpass-how-to {
    display: flex;
    align-items: center;
    gap: 5px;
    font-weight: 600;
    font-size: 12px;
    color: #868b92;
    cursor: pointer
}

.ggpass-progress-track {
    background: #ffffff14;
    border-radius: 26px;
    height: 32px;
    width: 100%;
    position: relative;
    overflow: hidden
}

.ggpass-progress-fill {
    background: #539ab3c2;
    height: 100%;
    border-radius: 26px;
    transition: width .5s ease
}

.ggpass-progress-text {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    font-weight: 600;
    font-size: 16px;
    color: #fff
}

.ggpass-rewards-grid {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding: 0 20px;
    position: relative;
    z-index: 5
}

.ggpass-row {
    display: flex;
    align-items: stretch;
    position: relative;
    margin-bottom: 0;
    min-height: 180px
}

.ggpass-timeline-col {
    width: 60px;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    flex-shrink: 0
}

.ggpass-line {
    width: 10px;
    background: #ffffff14;
    border-radius: 100px;
    flex-grow: 1;
    position: relative;
    overflow: hidden
}

.ggpass-line.top {
    margin-bottom: -17.5px
}

.ggpass-line.bottom {
    margin-top: -17.5px
}

.ggpass-line.active {
    background: #539ab3;
    box-shadow: 0 0 10px #539ab366
}

.ggpass-timeline-icon {
    width: 35px;
    height: 35px;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0
}

.ggpass-timeline-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain
}

.ggpass-card-col {
    flex-grow: 1;
    padding-left: 15px;
    padding-bottom: 20px
}

.ggpass-card {
    background: #1a1a1a66;
    border-radius: 30px;
    padding: 15px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 90%;
    position: relative
}

.ggpass-card-img {
    width: 125px;
    height: 125px;
    object-fit: contain;
    margin-bottom: 10px;
    filter: drop-shadow(0 5px 15px rgba(0,0,0,.5))
}

.ggpass-btn {
    width: 100%;
    padding: 10px;
    border-radius: 100px;
    border: none;
    font-weight: 600;
    font-size: 11px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    cursor: default;
    transition: transform .1s
}

.ggpass-btn.locked {
    background: #ffffff14;
    color: #868b92
}

.ggpass-btn.claim {
    background: #fff;
    color: #000;
    cursor: pointer;
    box-shadow: 0 4px 15px #ffffff4d
}

.ggpass-btn.claim:active {
    transform: scale(.95)
}

.ggpass-btn.claimed {
    background: #ffffff14;
    color: #868b92
}

.ggpass-line.top,.ggpass-line.bottom {
    border-radius: 0
}

.ggpass-row.first-item .ggpass-line.top {
    border-top-left-radius: 100px;
    border-top-right-radius: 100px
}

.ggpass-row.last-item .ggpass-line.bottom {
    border-bottom-left-radius: 100px;
    border-bottom-right-radius: 100px;
    visibility: hidden
}

.info-modal-content {
    background: #1a1a1aad!important;
    border-radius: 30px!important;
    padding: 30px 20px!important;
    text-align: center;
    position: relative;
    border: none!important
}

.close-btn-circle {
    position: absolute;
    top: 15px;
    right: 15px;
    width: 30px;
    height: 30px;
    background: #ffffff1a;
    border-radius: 50%;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer
}

.info-modal-title {
    font-weight: 800;
    font-size: 22px;
    color: #fff;
    margin: 10px 0 5px;
    line-height: 1.2
}

.info-modal-subtitle {
    font-weight: 500;
    font-size: 13px;
    color: #868b92;
    margin: 0 0 25px
}

.info-card-inner {
    background: #252525ba;
    border-radius: 24px;
    padding: 20px;
    display: flex;
    flex-direction: column;
    align-items: center
}

.golden-ticket {
    width: 100px;
    height: auto;
    margin-bottom: 15px;
    filter: drop-shadow(0 0 15px rgba(155,207,212,.3))
}

.info-card-inner h3 {
    font-weight: 700;
    font-size: 16px;
    color: #fff;
    margin: 0 0 8px
}

.info-card-inner p {
    font-weight: 500;
    font-size: 12px;
    color: #868b92;
    line-height: 1.4;
    margin: 0;
    max-width: 250px
}

.ggpass-header-image {
    position: relative
}

.ggpass-timer-overlay {
    position: absolute;
    top: 4px;
    left: 50%;
    transform: translate(-50%);
    background: #1a1a1a47;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-radius: 20px;
    padding: 6px 15px;
    width: 90%;
    max-width: 170px;
    z-index: 5
}

.ggpass-timer-title {
    font-size: 10px;
    color: #fffc;
    text-align: center;
    margin-bottom: 4px;
    letter-spacing: .5px
}

.ggpass-timer-grid {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 5px
}

.timer-block {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 45px
}

.timer-val {
    font-weight: 800;
    font-size: 18px;
    color: #fff;
    line-height: 1
}

.timer-lbl {
    font-weight: 600;
    font-size: 8px;
    color: #ffffff80;
    margin-top: 3px
}

.timer-sep {
    font-weight: 700;
    font-size: 18px;
    color: #ffffff4d;
    margin-bottom: 10px
}

.gg-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #000c;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: all .3s cubic-bezier(.4,0,.2,1)
}

.gg-modal-overlay.active {
    opacity: 1;
    visibility: visible
}

.gg-modal-card {
    background: linear-gradient(145deg,#1e1e1e,#141414);
    border-radius: 24px;
    padding: 32px 24px;
    width: 82%;
    max-width: 380px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    box-shadow: 0 20px 60px #0009;
    transform: scale(.9) translateY(20px);
    transition: all .4s cubic-bezier(.34,1.56,.64,1);
    position: relative;
    overflow: hidden
}

.gg-modal-overlay.active .gg-modal-card {
    transform: scale(1) translateY(0)
}

.gg-modal-glow {
    position: absolute;
    top: 30%;
    left: 50%;
    transform: translate(-50%,-50%);
    width: 300px;
    height: 300px;
    background: radial-gradient(circle,#c7e3ff1a,#0000 70%);
    pointer-events: none;
    z-index: 0
}

.gg-modal-card.error-mode .gg-modal-glow {
    background: radial-gradient(circle,rgba(200,49,62,.2) 0%,transparent 70%)
}

.gg-modal-card.gold-mode .gg-modal-glow {
    background: radial-gradient(circle,rgba(255,215,0,.15) 0%,transparent 70%)
}

.gg-modal-content {
    position: relative;
    z-index: 2;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center
}

.gg-reward-img-wrapper {
    width: 100px;
    height: 100px;
    margin-bottom: 20px;
    position: relative
}

.gg-reward-img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    filter: drop-shadow(0 10px 20px rgba(0,0,0,.3))
}

.gg-modal-subtitle {
    font-size: 12px;
    color: #fff;
    font-weight: 600
}

.gg-modal-title {
    font-size: 22px;
    font-weight: 800;
    color: var(--text-primary);
    margin: 0 0 24px;
    line-height: 1.2
}

.gg-promo-box {
    background: #ffffff0d;
    border: 1px dashed rgba(255,255,255,.2);
    border-radius: 14px;
    padding: 16px;
    width: 100%;
    box-sizing: border-box;
    margin-bottom: 24px;
    cursor: pointer;
    transition: all .2s ease;
    position: relative
}

.gg-promo-box:active {
    background: #ffffff1a;
    transform: scale(.98)
}

.gg-promo-code {
    font-size: 18px;
    font-weight: 700;
    color: #fff;
    letter-spacing: 1px
}

.gg-copy-hint {
    font-size: 10px;
    color: var(--text-secondary);
    margin-top: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px
}

.gg-copy-feedback {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: #4aa657e6;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 700;
    font-size: 14px;
    opacity: 0;
    transition: opacity .2s;
    pointer-events: none
}

.gg-copy-feedback.visible {
    opacity: 1
}

.gg-btn {
    width: 100%;
    padding: 16px;
    border-radius: 14px;
    border: none;
    font-size: 16px;
    font-weight: 700;
    cursor: pointer;
    transition: transform .1s
}

.gg-btn:active {
    transform: scale(.96)
}

.gg-btn-primary {
    background: var(--text-primary);
    color: #000
}

.gg-btn-secondary {
    background: #ffffff05;
    color: #868b92
}

.oos-icon {
    width: 64px;
    height: 64px;
    color: var(--danger-color);
    margin-bottom: 16px;
    background: #c8313e1a;
    padding: 16px;
    border-radius: 50%
}

.oos-text {
    font-size: 14px;
    color: var(--text-secondary);
    line-height: 1.5;
    margin-bottom: 24px
}

.gg-modal-close-icon {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 32px;
    height: 32px;
    background: #ffffff1a;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: #fff;
    transition: background .2s;
    z-index: 10
}

.gg-modal-close-icon:hover {
    background: #fff3
}

.gg-modal-close-icon svg {
    width: 18px;
    height: 18px;
    stroke-width: 2.5
}

.gg-locked-badge {
    background: #f5f5fa05;
    border-radius: 12px;
    padding: 8px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #4f535a;
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 24px;
    justify-content: center;
    box-sizing: border-box
}

.gg-locked-badge svg {
    width: 16px;
    height: 16px;
    fill: currentColor;
    margin-top: 1
}

.gg-capsule-grid {
    display: grid;
    grid-template-columns: repeat(4,1fr);
    gap: 10px;
    width: 100%;
    margin-top: 10px;
    max-height: 300px
}

.gg-capsule-grid::-webkit-scrollbar {
    width: 4px
}

.gg-capsule-grid::-webkit-scrollbar-track {
    background: #ffffff0d;
    border-radius: 4px
}

.gg-capsule-grid::-webkit-scrollbar-thumb {
    background: #fff3;
    border-radius: 4px
}

.gg-capsule-item {
    background: linear-gradient(0deg,#4d505c33,#d4325d33 53.65%,#ff004233);
    border-radius: 16px;
    aspect-ratio: 1.5 / 1;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
    cursor: help;
    transition: transform .2s ease
}

.gg-capsule-item:active {
    transform: scale(.98)
}

.gg-capsule-item img {
    width: 60%;
    height: 80%;
    object-fit: contain;
    filter: drop-shadow(0 5px 15px rgba(0,0,0,.4));
    transition: filter .3s ease
}

.gg-capsule-overlay {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    -webkit-backdrop-filter: blur(4px);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity .2s ease;
    pointer-events: none;
    z-index: 0
}

.gg-capsule-percent {
    font-size: 12px;
    font-weight: 700;
    color: #b9bac1
}

.gg-capsule-item:hover .gg-capsule-overlay,.gg-capsule-item.active .gg-capsule-overlay {
    opacity: 1
}

.gg-capsule-item:hover img,.gg-capsule-item.active img {
    filter: blur(5px)
}

.gg-btn {
    position: relative;
    overflow: hidden
}

.gg-btn.is-loading {
    color: transparent!important;
    pointer-events: none
}

.gg-btn.is-loading:after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 20px;
    height: 20px;
    margin-top: -10px;
    margin-left: -10px;
    border: 2px solid rgba(255,255,255,.3);
    border-top-color: #fff;
    border-radius: 50%;
    animation: gg-spin .8s linear infinite
}

@keyframes gg-spin {
    to {
        transform: rotate(360deg)
    }
}

.gg-reward-img-wrapper {
    width: 120px;
    height: 120px;
    margin-bottom: 15px
}

.gg-modal-title {
    font-size: 20px;
    margin-bottom: 6px
}

.avatar-container {
    position: relative
}

.online-badge {
    position: absolute;
    top: 50%;
    left: 90%;
    transform: translateY(-50%);
    margin-left: 12px;
    background: var(--element-bg);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    border-radius: 12px;
    padding: 4px;
    display: flex;
    align-items: center;
    gap: 5px;
    z-index: 5;
    min-width: 40px;
    justify-content: center;
    white-space: nowrap
}

.online-dot {
    width: 6px;
    height: 6px;
    background-color: #4aa657;
    border-radius: 50%;
    box-shadow: 0 0 5px #4aa657;
    animation: onlinePulse 2s infinite ease-in-out
}

#onlineCount {
    font-size: 11px;
    font-weight: 700;
    color: #fff;
    line-height: 1
}

@keyframes onlinePulse {
    0% {
        opacity: 1;
        transform: scale(1);
        box-shadow: 0 0 #4aa657b3
    }

    50% {
        opacity: .6;
        transform: scale(.9);
        box-shadow: 0 0 0 2px #4aa65700
    }

    to {
        opacity: 1;
        transform: scale(1);
        box-shadow: 0 0 #4aa65700
    }
}

.gg-modal-card.capsule-mode {
    padding: 0;
    background: #141414;
    overflow: hidden;
    max-width: 400px;
    width: 95%;
    border: none
}

.gg-capsule-header-section {
    padding: 40px 20px 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    background: radial-gradient(circle at center,rgba(168,85,247,.15) 0%,transparent 40%);
    position: relative
}

.gg-capsule-img-big {
    width: 100px;
    height: 100px;
    object-fit: contain;
    filter: drop-shadow(0 0 30px rgba(168,85,247,.4));
    animation: floatCapsule 3s ease-in-out infinite
}

@keyframes floatCapsule {
    0%,to {
        transform: translateY(0)
    }

    50% {
        transform: translateY(-10px)
    }
}

.gg-capsule-body-section {
    background: #1c1c1c8f;
    padding: 24px 20px;
    border-top-left-radius: 24px;
    border-top-right-radius: 24px;
    width: 100%;
    box-sizing: border-box
}

.gg-capsule-content-title {
    font-size: 16px;
    font-weight: 700;
    color: #fff;
    margin-bottom: 16px;
    text-align: left;
    padding-left: 4px
}

.gg-capsule-close-btn {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 32px;
    height: 32px;
    background: #ffffff1a;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: #fff;
    z-index: 20
}

body.support-banned .promo-report-button,body.support-banned #reportPromoSubmitButton {
    display: none!important;
    pointer-events: none;
    opacity: .5
}
