:root {
    --base-bg: #0f1521;
    --bg: linear-gradient(to right, #1f2937 0%, #111827 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
}

body, html {
    margin: 0;
    padding: 0;
    width: 100%;
    height: 100vh;
    height: var(--tg-viewport-stable-height, 100vh);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    background: var(--bg, linear-gradient(to right, #1f2937 0%, #111827 100%));
    background-color: var(--background, #111);
}

.pages-container {
    width: 100%;
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
    position: relative;
    overflow-x: hidden;
    overflow-y: auto;
    -ms-overflow-style: none;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
}

.pages-container::-webkit-scrollbar {
    display: none;
}

.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 {
    font-size: .8rem;
    opacity: .7;
    text-transform: uppercase;
    margin-bottom: 4px
}

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

#rewardModalTitle .currency-icon {
    display: inline-block;
    width: 1em;
    height: auto;
    vertical-align: middle;
    margin-left: 2px
}

#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: 18px;
    height: 15px;
    flex-shrink: 0;
    margin-top: 1px;
}

.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: 99;
    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(--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
}

.page-wrapper--hidden {
    display: none !important;
    visibility: hidden !important;
    position: absolute !important;
    left: -9999px !important;
    width: 100% !important;
    pointer-events: none !important;
    z-index: 0 !important;
}

/* Ð‘Ð»Ð¾ÐºÐ¸Ñ€Ð¾Ð²ÐºÐ° ÑÐºÑ€Ð¾Ð»Ð»Ð° ÑÑ‚Ñ€Ð°Ð½Ð¸Ñ†Ñ‹ Ð¿Ñ€Ð¸ Ð¾Ñ‚ÐºÑ€Ñ‹Ñ‚Ð¾Ð¹ Ð¼Ð¾Ð´Ð°Ð»ÐºÐµ â€” Ð¼Ð¾Ð´Ð°Ð»ÐºÐ° Ð½Ðµ Â«ÐºÑ€ÑƒÑ‚Ð¸Ñ‚ÑÑÂ» ÑÐ¾ ÑÐºÑ€Ð¾Ð»Ð»Ð¾Ð¼ */
body:has(.gg-modal-overlay.active),
body:has(.task-modal-overlay.active),
body:has(.modal-overlay.visible),
body:has([class*="modal-overlay"].active),
body:has([class*="-overlay"].show) {
    overflow: hidden !important
}

body:has(.gg-modal-overlay.active) .page-wrapper,
body:has(.task-modal-overlay.active) .page-wrapper,
body:has(.modal-overlay.visible) .page-wrapper,
body:has([class*="modal-overlay"].active) .page-wrapper,
body:has([class*="-overlay"].show) .page-wrapper {
    overflow: hidden !important;
    touch-action: none
}

.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: 20%;
    background: #ffffff14;
    border-radius: 4px;
    align-self: center;
}

.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 {
    background: transparent
}

.page-index .pc-sidebar .nav-link:hover {
    background: transparent
}

.page-index .pc-sidebar .nav-link.active {
    background: transparent;
    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
    }
}

.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
}

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

.nav-item {
    flex: 1;
    min-width: 0;
    background: transparent
}

.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;
    background: transparent;
    border: none;
    border-radius: 0
}

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

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

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

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

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



.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: 100;
    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-container {
    position: relative;
    display: inline-block;
    margin-bottom: 16px
}

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

.partner-verified-badge {
    display: inline-flex;
    align-items: center;
    margin-left: 2px;
    vertical-align: middle;
    margin-top: -1px;
    position: relative;
    cursor: pointer;
    overflow: visible;
}
.partner-verified-badge svg {
    width: 14px;
    height: 14px;
}
.partner-verified-badge .badge-tooltip {
    visibility: hidden;
    opacity: 0;
    position: absolute;
    top: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%);
    background-color: #2a2a2a;
    color: #fff;
    font-size: 11px;
    font-weight: 500;
    padding: 6px 10px;
    border-radius: 6px;
    white-space: nowrap;
    pointer-events: none;
    z-index: 10000;
    box-shadow: 0 4px 6px rgba(0,0,0,0.3);
    transition: opacity 0.2s ease-in-out, visibility 0.2s;
    width: max-content;
}
.partner-verified-badge .badge-tooltip::before {
    content: '';
    position: absolute;
    bottom: 100%;
    left: 50%;
    margin-left: -5px;
    border-width: 5px;
    border-style: solid;
    border-color: transparent transparent #2a2a2a transparent;
}
.partner-verified-badge:hover .badge-tooltip,
.partner-verified-badge:active .badge-tooltip,
.partner-verified-badge .badge-tooltip.show {
    visibility: visible;
    opacity: 1;
}

.partner-dashboard-block {
    margin-bottom: 20px;
    padding: 16px;
    background: var(--element-bg, rgba(255,255,255,0.06));
    border-radius: 12px;
    border: 1px solid var(--profile-border, rgba(255,255,255,0.1));
}
.partner-dashboard-title { font-size: 1.1rem; margin-bottom: 12px; }
.partner-dashboard-stats p { margin: 6px 0; }
.partner-dashboard-copy { margin-top: 12px; }

.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;
    flex-wrap: wrap;
    gap: 8px 16px;
    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 .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: 92%;
        z-index: 100
    }

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

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

    .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(--bg, linear-gradient(to right, #1f2937 0%, #111827 100%));
    background-attachment: fixed;
    background-color: var(--background, #111);
    color: var(--text-color, #fff);
    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: 92%;
    margin: 0 auto !important;
    padding-bottom: 13vh;
    opacity: 0;
    transition: opacity .4s ease, max-width .3s ease, padding-top .3s ease;
    box-sizing: border-box;
}

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

.page.friends main.space-y-6 > * + *,
.page.friends main > * + * {
    margin-top: 0
}

.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;
    margin-top: 0;
}

.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: #1a1a1a66;
    border-radius: var(--card-radius);
    margin-top: 1.5rem;
    transition: background-color .3s ease
}

.awards-header {
    font-weight: 700;
    font-size: 1rem;
    margin-bottom: 10px;
    padding: 16px 1rem 0;
    letter-spacing: .01em;
    display: flex;
    align-items: center;
    gap: 8px
}

.awards-header::before {
    content: '';
    width: 3px;
    height: 16px;
    background: linear-gradient(180deg, #fbbf24 0%, #f59e0b 100%);
    border-radius: 3px;
    flex-shrink: 0
}

.awards-list-container {
    padding: 0 12px 16px;
    overflow: visible
}

.awards-list {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 8px
}

/* --- Card wrapper --- */
.award-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px
}

/* --- Card --- */
.award-item {
    width: 100%;
    background: rgba(255, 255, 255, .04);
    border: 1px solid rgba(255, 255, 255, .07);
    border-radius: 14px;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 10px 4px 8px;
    box-sizing: border-box;
    transition: background .3s ease, transform .3s ease, border-color .3s ease, box-shadow .3s ease;
    gap: 5px;
    position: relative;
    overflow: hidden
}

/* Wide card (span 3-4) â€” horizontal layout */
.award-item-wide {
    flex-direction: row;
    padding: 10px 14px;
    gap: 12px;
    align-items: center
}

.award-item-wide .award-day-badge {
    position: absolute;
    top: 6px;
    right: 8px;
    font-size: .5rem
}

.award-item-wide .award-item-icon {
    width: 42px;
    height: 42px;
    flex-shrink: 0
}

.award-item-wide .award-item-icon img {
    width: 38px;
    height: 38px
}

.award-item-wide .award-item-info {
    align-items: flex-start;
    text-align: left;
    flex: 1;
    min-height: auto
}

.award-item-wide .award-item-name {
    font-size: .72rem;
    font-weight: 600;
    max-width: none
}

.award-item-wide .award-mystery-icon {
    width: 42px;
    height: 42px;
    font-size: 1.4rem
}

/* --- Day badge --- */
.award-day-badge {
    font-size: .55rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: rgba(255, 255, 255, .45);
    background: rgba(255, 255, 255, .06);
    padding: 2px 8px;
    border-radius: 20px;
    line-height: 1.4;
    transition: color .3s, background .3s
}

/* --- Icon area --- */
.award-item-icon {
    position: relative;
    width: 38px;
    height: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0
}

.award-item-icon img {
    width: 36px;
    height: 36px;
    object-fit: contain;
    border-radius: 8px;
    transition: transform .3s ease, opacity .3s ease, filter .3s ease;
    filter: drop-shadow(0 2px 5px rgba(0, 0, 0, .25))
}

/* --- Mystery icon for hidden rewards --- */
.award-mystery-icon {
    width: 38px;
    height: 38px;
    border-radius: 10px;
    background: linear-gradient(135deg, rgba(251, 191, 36, .08) 0%, rgba(245, 158, 11, .04) 100%);
    border: 1px solid rgba(251, 191, 36, .12);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    font-weight: 800;
    color: rgba(251, 191, 36, .4);
    position: relative;
    overflow: hidden
}

.award-mystery-icon::after {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: linear-gradient(
        105deg,
        transparent 40%,
        rgba(251, 191, 36, .06) 45%,
        rgba(251, 191, 36, .12) 50%,
        rgba(251, 191, 36, .06) 55%,
        transparent 60%
    );
    animation: adventShimmer 3s infinite linear;
    pointer-events: none
}

@keyframes adventShimmer {
    0% { transform: translateX(-100%) rotate(25deg) }
    100% { transform: translateX(100%) rotate(25deg) }
}

/* --- Check overlay for claimed --- */
.award-check-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, .45);
    border-radius: 8px;
    z-index: 2
}

.award-check-overlay svg {
    width: 20px;
    height: 20px;
    color: #fbbf24;
    filter: drop-shadow(0 0 4px rgba(251, 191, 36, .4))
}

/* --- Info area --- */
.award-item-info {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1px;
    text-align: center;
    min-height: 22px;
    justify-content: center
}

.award-item-name {
    font-size: .62rem;
    font-weight: 500;
    color: rgba(255, 255, 255, .75);
    line-height: 1.2;
    word-break: break-word;
    max-width: 72px
}

.award-item-name-hidden {
    color: rgba(251, 191, 36, .3);
    font-style: italic;
    font-size: .58rem
}

.award-item-amount {
    display: flex;
    align-items: center;
    gap: 3px;
    font-size: .55rem;
    font-weight: 600;
    color: rgba(255, 255, 255, .4)
}

.award-item-amount .currency-icon {
    width: 11px;
    height: 8px
}

/* --- Claim button --- */
.award-claim-btn {
    font-size: .65rem;
    font-weight: 700;
    color: #000;
    background: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);
    padding: 5px 14px;
    border-radius: 10px;
    text-align: center;
    letter-spacing: .03em;
    box-shadow: 0 2px 10px rgba(251, 191, 36, .3);
    cursor: pointer;
    transition: transform .15s ease, box-shadow .15s ease;
    white-space: nowrap
}

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

/* ===== STATES ===== */

/* -- Claimed -- */
.award-item.claimed {
    background: rgba(255, 255, 255, .025);
    border-color: rgba(255, 255, 255, .04)
}

.award-item.claimed .award-day-badge {
    color: rgba(251, 191, 36, .5);
    background: rgba(251, 191, 36, .07)
}

.award-item.claimed .award-item-name {
    color: rgba(255, 255, 255, .35);
    font-size: .58rem
}

.award-item.claimed .award-item-icon img {
    opacity: .5;
    filter: saturate(.4) drop-shadow(0 1px 3px rgba(0, 0, 0, .15))
}

/* -- Can claim (active) -- */
.award-item.can-claim {
    cursor: pointer;
    background: rgba(251, 191, 36, .06);
    border-color: rgba(251, 191, 36, .25);
    animation: claimCardPulse 2.5s infinite ease-in-out
}

.award-item.can-claim:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 20px rgba(251, 191, 36, .15)
}

.award-item.can-claim .award-day-badge {
    color: #fbbf24;
    background: rgba(251, 191, 36, .15);
    font-weight: 800
}

.award-item.can-claim .award-item-icon img,
.award-item.can-claim .award-mystery-icon {
    animation: rewardFloat 3s ease-in-out infinite
}

.award-item.can-claim .award-mystery-icon {
    color: rgba(251, 191, 36, .7);
    border-color: rgba(251, 191, 36, .3);
    background: linear-gradient(135deg, rgba(251, 191, 36, .15) 0%, rgba(245, 158, 11, .08) 100%)
}

.award-item.can-claim .award-item-name {
    color: rgba(255, 255, 255, .9);
    font-weight: 600
}

@keyframes claimCardPulse {
    0%, 100% {
        box-shadow: 0 0 6px rgba(251, 191, 36, .08);
        border-color: rgba(251, 191, 36, .2)
    }
    50% {
        box-shadow: 0 0 16px rgba(251, 191, 36, .18);
        border-color: rgba(251, 191, 36, .4)
    }
}

@keyframes rewardFloat {
    0%, 100% { transform: translateY(0) }
    50% { transform: translateY(-3px) }
}

/* -- Future (hidden / locked) -- */
.award-item.future {
    opacity: .6
}

.award-item.future .award-item-icon img {
    filter: saturate(.3) brightness(.8) drop-shadow(0 1px 3px rgba(0, 0, 0, .15))
}

.award-item.future .award-day-badge {
    color: rgba(255, 255, 255, .3)
}

.award-item.future .award-item-name {
    color: rgba(255, 255, 255, .3)
}

.award-item.future .award-mystery-icon {
    color: rgba(255, 255, 255, .2);
    border-color: rgba(255, 255, 255, .06);
    background: rgba(255, 255, 255, .02)
}



























.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 !important;
    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)
}

@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,
.page.ggpass {
    margin: 0;
    height: 100%;
    background-attachment: fixed;
    color: var(--text-color);
    overflow-x: hidden;
    transition: background .3s ease, color .3s ease
}

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

.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: 100%;
    margin: 0;
    padding-left: 0 !important;
    padding-right: 0 !important;
    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 {
    fill: var(--text-color)
}

.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-attachment: fixed;
    background-color: var(--background);
    color: var(--text-color);
    overflow: hidden;
    transition: background .3s ease, color .3s ease;
    -webkit-user-select: none;
    user-select: none
}

/* ÐžÐ´Ð¸Ð½ ÑÐºÑ€Ð¾Ð»Ð» Ð½Ð° Ð¸Ð²ÐµÐ½Ñ‚Ð°Ñ…: Ñ‚Ð¾Ð»ÑŒÐºÐ¾ events-scroll-wrap, Ð½Ðµ page-wrapper */
.page-wrapper.page.events {
    overflow: hidden !important;
    height: 100% !important;
    min-height: 100% !important;
    overflow-y: hidden !important
}

/* ÐžÐ´Ð¸Ð½ ÑÐºÑ€Ð¾Ð»Ð» Ð½Ð° Ð·Ð°Ð´Ð°Ð½Ð¸ÑÑ…: Ñ‚Ð¾Ð»ÑŒÐºÐ¾ page-wrapper; pages-container Ð½Ðµ ÑÐºÑ€Ð¾Ð»Ð»Ð¸Ñ‚ */
.pages-container:has(.page-wrapper.page.tasks) {
    overflow: hidden !important;
}

.page-wrapper.page.tasks {
    min-height: 0 !important;
    flex: 1 !important;
    height: 100% !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch
}

.page-wrapper.page.tasks:not(:has(.tasks-grid .task-card:nth-last-child(2))) {
    overflow-y: visible !important;
    height: auto !important;
    max-height: 100% !important
}

.page-wrapper.page.tasks .yx-steps-scroll {
    overscroll-behavior: contain
}

/* ============================================ */
/* === FULL-PAGE SCROLL WRAPPER             === */
/* ============================================ */

.events-scroll-wrap {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none
}

.events-scroll-wrap::-webkit-scrollbar {
    display: none
}

.events-container {
    width: 100%;
    min-height: 100vh;
    box-sizing: border-box;
    padding-top: calc(var(--tg-content-safe-area-inset-top) + var(--tg-safe-area-inset-top) + 86px);
    padding-bottom: calc(140px + 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
}

/* ============================================ */
/* === STATUS BADGE                         === */
/* ============================================ */

.event-status-badge {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 5px 14px;
    border-radius: 100px;
    background: rgba(255, 255, 255, 0.06);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.08);
    align-self: center;
    margin-bottom: 8px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--text-color);
    animation: badgeFadeIn 0.5s ease forwards
}

@keyframes badgeFadeIn {
    from {
        opacity: 0;
        transform: translateY(-6px)
    }

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

.status-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: #4ade80;
    flex-shrink: 0
}

.event-status-badge[data-status="live"] .status-dot {
    background: #4ade80;
    box-shadow: 0 0 8px #4ade80;
    animation: statusPulse 1.5s ease-in-out infinite
}

.event-status-badge[data-status="starting"] .status-dot {
    background: #facc15;
    box-shadow: 0 0 6px #facc15;
    animation: statusPulse 2s ease-in-out infinite
}

.event-status-badge[data-status="completed"] .status-dot {
    background: #888;
    box-shadow: none;
    animation: none
}

@keyframes statusPulse {

    0%,
    100% {
        opacity: 1;
        transform: scale(1)
    }

    50% {
        opacity: 0.5;
        transform: scale(0.7)
    }
}

/* ============================================ */
/* === SEGMENTED TIMER                      === */
/* ============================================ */

.event-timer-redesign {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    margin-bottom: 10px;
    width: 100%;
    box-sizing: border-box
}

.timer-label {
    font-size: 11px;
    font-weight: 600;
    color: var(--text-secondary);
    text-align: center;
    letter-spacing: 0.5px
}

.timer-digits {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    gap: 5px
}

.digit-group {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px
}

.digit-blocks {
    display: flex;
    gap: 3px
}

.digit {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 34px;
    background: rgba(255, 255, 255, 0.06);
    border-radius: 7px;
    font-size: 18px;
    font-weight: 800;
    color: var(--text-color);
    font-variant-numeric: tabular-nums;
    border: 1px solid rgba(255, 255, 255, 0.06);
    transition: color 0.3s ease, background 0.3s ease, box-shadow 0.3s ease
}

.digit-label {
    font-size: 8px;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px
}

.digit-sep {
    font-size: 16px;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.25);
    margin-top: 6px;
    line-height: 1
}

.event-timer-redesign.timer-urgent .digit {
    color: #ff6b6b;
    background: rgba(255, 107, 107, 0.08);
    border-color: rgba(255, 107, 107, 0.15);
    box-shadow: 0 0 12px rgba(255, 107, 107, 0.1)
}

.event-timer-redesign.timer-urgent .digit-sep {
    color: rgba(255, 107, 107, 0.4);
    animation: sepBlink 1s ease-in-out infinite
}

@keyframes sepBlink {

    0%,
    100% {
        opacity: 1
    }

    50% {
        opacity: 0.3
    }
}

/* ============================================ */
/* === TITLE                                === */
/* ============================================ */

.top-list-title {
    font-size: 17px;
    font-weight: 700;
    color: var(--text-color);
    margin-bottom: 6px;
    padding-left: 4px
}

/* ============================================ */
/* === PODIUM SECTION (TOP 3)               === */
/* ============================================ */

.podium-section {
    width: 100%;
    margin-bottom: 10px
}

.podium-real {
    display: flex;
    justify-content: center;
    align-items: flex-end;
    gap: 6px;
    padding: 4px 0 0;
    animation: podiumReveal 0.6s cubic-bezier(0.4, 0, 0.2, 1) forwards
}

@keyframes podiumReveal {
    from {
        opacity: 0;
        transform: translateY(12px)
    }

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

.podium-slot {
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    flex: 1;
    max-width: 120px
}

.podium-avatar-wrap {
    position: relative;
    margin-bottom: 4px
}

.podium-slot.podium-1 .podium-avatar-wrap {
    width: 56px;
    height: 56px
}

.podium-slot.podium-2 .podium-avatar-wrap,
.podium-slot.podium-3 .podium-avatar-wrap {
    width: 40px;
    height: 40px
}

.podium-avatar-wrap img {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid transparent
}

.podium-1 .podium-avatar-wrap img {
    border-color: var(--gradient-gold)
}

.podium-2 .podium-avatar-wrap img {
    border-color: var(--gradient-silver)
}

.podium-3 .podium-avatar-wrap img {
    border-color: var(--gradient-bronze)
}

.podium-parallax-reward {
    position: absolute;
    top: -32px;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 10;
    will-change: transform, opacity;
    pointer-events: none;
}

.podium-parallax-reward .reward-case img {
    width: 26px;
    height: 26px;
    object-fit: contain;
}

.podium-parallax-reward .reward-case-name {
    display: none;
    /* Keep podium clean, name hides */
}

.podium-parallax-reward .reward-balance {
    font-size: 11px;
    font-weight: 800;
    color: #fff;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
}

.podium-parallax-reward .reward-nothing {
    display: none;
}

.podium-medal {
    position: absolute;
    top: -4px;
    right: -3px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 5;
    border: none;
    background: transparent;
    line-height: 0
}

.podium-1 .podium-medal {
    background: transparent;
    filter: drop-shadow(0 0 4px rgba(255, 215, 0, 0.5))
}

.podium-2 .podium-medal,
.podium-3 .podium-medal {
    background: transparent
}

.podium-name {
    font-size: 11px;
    font-weight: 700;
    color: var(--text-color);
    text-align: center;
    max-width: 80px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-bottom: 1px
}

.podium-invites {
    font-size: 8px;
    color: var(--text-secondary);
    margin-bottom: 3px
}

/* Pedestal bars */
.podium-bar {
    width: 100%;
    border-radius: 10px 10px 0 0
}

.podium-1 .podium-bar {
    height: 36px;
    background: linear-gradient(180deg, rgba(255, 215, 0, 0.15) 0%, rgba(255, 215, 0, 0.03) 100%);
    border: 1px solid rgba(255, 215, 0, 0.2);
    border-bottom: none
}

.podium-2 .podium-bar {
    height: 24px;
    background: linear-gradient(180deg, rgba(192, 192, 192, 0.12) 0%, rgba(192, 192, 192, 0.02) 100%);
    border: 1px solid rgba(192, 192, 192, 0.15);
    border-bottom: none
}

.podium-3 .podium-bar {
    height: 16px;
    background: linear-gradient(180deg, rgba(205, 127, 50, 0.12) 0%, rgba(205, 127, 50, 0.02) 100%);
    border: 1px solid rgba(205, 127, 50, 0.15);
    border-bottom: none
}

/* ============================================ */
/* === LEADERBOARD HEADER                   === */
/* ============================================ */

.leaderboard-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 4px;
    margin-bottom: 8px
}

.leaderboard-label {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-secondary)
}

.leaderboard-count {
    font-size: 11px;
    font-weight: 600;
    color: var(--text-tertiary);
    background: rgba(255, 255, 255, 0.06);
    padding: 2px 8px;
    border-radius: 8px
}

/* ============================================ */
/* === LEADERBOARD LIST (4-100)             === */
/* ============================================ */

.leaderboard-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
    width: 100%
}

/* ============================================ */
/* === TOP ITEM (list row)                  === */
/* ============================================ */

.top-item {
    display: flex;
    align-items: center;
    gap: 10px;
    background: rgba(255, 255, 255, 0.03);
    border-radius: 14px;
    padding: 8px 10px;
    position: relative;
    overflow: visible;
    border: 1px solid rgba(255, 255, 255, 0.04);
    transition: background .3s ease, border-color .3s ease, transform 0.3s ease, opacity 0.3s ease;
    flex-shrink: 0
}

/* Scroll-triggered animation: items start invisible */
.top-item.scroll-reveal {
    opacity: 0;
    transform: translateY(20px) scale(0.97)
}

.top-item.scroll-reveal.revealed {
    opacity: 1;
    transform: translateY(0) scale(1)
}

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

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

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

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

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

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

.top-reward {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 6px;
    min-width: 70px;
    min-height: 40px;
    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: 32px;
    height: 32px;
    object-fit: contain
}

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

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

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

.reward-balance .currency-icon {
    width: 16px;
    height: 13px
}

.reward-balance .currency-icon path {
    transition: fill .3s ease
}

/* ============================================ */
/* === HOW TO PARTICIPATE (Floating)        === */
/* ============================================ */

.how-to-participate {
    position: fixed;
    bottom: calc(160px + var(--tg-content-safe-area-inset-bottom, env(safe-area-inset-bottom, 0px)));
    right: 4%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    color: #ffffff;
    font-size: 12px;
    font-weight: 700;
    padding: 8px 10px;
    border-radius: 100px;
    cursor: pointer;
    z-index: 60;
}

.how-to-participate:active {
    transform: scale(0.95);
    background: linear-gradient(135deg, rgb(255 255 255 / 10%), rgb(255 255 255 / 8%))
}

@media (min-width: 544px) {
    .how-to-participate {
        right: calc(50vw - 250px);
    }
}

/* PC: ÐºÐ½Ð¾Ð¿ÐºÐ° Â«ÐšÐ°Ðº ÑƒÑ‡Ð°ÑÑ‚Ð²Ð¾Ð²Ð°Ñ‚ÑŒÂ» Ð¿Ñ€Ð¸Ð¶Ð°Ñ‚Ð° Ðº Ð¿Ñ€Ð°Ð²Ð¾Ð¼Ñƒ ÐºÑ€Ð°ÑŽ user-top-bar (Ð±Ð°Ñ€ Ñ†ÐµÐ½Ñ‚Ñ€Ð¸Ñ€Ð¾Ð²Ð°Ð½, 92% / max 500px) */
body.platform-pc .how-to-participate {
    right: calc(50vw - min(250px, 46vw));
}

.how-to-participate.empty-mode {
    position: relative;
    top: auto;
    bottom: auto;
    right: auto;
    margin: 24px auto 0;
    width: fit-content;
}

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

/* ============================================ */
/* === USER BAR (bottom fixed)              === */
/* ============================================ */

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

.user-top-bar .top-item {
    width: 100%;
    left: 50%;
    box-sizing: border-box;
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    --gradient-color: rgb(255 255 255 / 15%);
    border-color: rgb(255 255 255 / 25%);
    box-shadow: 0 -4px 24px rgb(0 0 0 / 30%), 0 0 0 1px rgb(255 255 255 / 8%);
    padding: 10px 12px;
    border-radius: 16px;
    animation: userBarSlideUp 0.5s cubic-bezier(0.4, 0, 0.2, 1) forwards;
    opacity: 1
}

@keyframes userBarSlideUp {
    from {
        opacity: 0;
        transform: translate(-50%, 20px)
    }

    to {
        opacity: 1;
        transform: translate(-50%, 0)
    }
}

/* ============================================ */
/* === EMPTY STATE                          === */
/* ============================================ */

.top-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 40px 20px;
    text-align: center;
    color: var(--text-secondary);
    animation: emptyFadeIn 0.6s ease forwards
}

@keyframes emptyFadeIn {
    from {
        opacity: 0;
        transform: scale(0.95)
    }

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

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

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

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

/* ============================================ */
/* === COMPLETED STATE                      === */
/* ============================================ */

.events-container[data-state="completed"] .podium-real {
    opacity: 0.7
}

.events-container[data-state="completed"] .leaderboard-list {
    opacity: 0.5
}

.events-container[data-state="completed"] .event-status-badge {
    background: rgba(255, 255, 255, 0.04);
    border-color: rgba(255, 255, 255, 0.06)
}

/* ============================================ */
/* === MODAL (how-to) â€” Bottom sheet        === */
/* ============================================ */

.page.events .modal-overlay {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: rgba(0, 0, 0, 0.6);
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
    display: flex;
    align-items: flex-end;
    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: rgba(30, 30, 30, 0.95);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-radius: 24px 24px 0 0;
    padding: 28px 24px;
    padding-bottom: calc(110px + env(safe-area-inset-bottom));
    width: 100%;
    max-width: 500px;
    box-shadow: 0 -5px 40px rgba(0, 0, 0, 0.4);
    transform: translateY(calc(100% + 50px));
    transition: transform .35s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    box-sizing: border-box;
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-bottom: none
}

.page.events .modal-overlay.visible .modal-content {
    transform: translateY(0)
}

.page.events .modal-close {
    position: absolute;
    top: 12px;
    right: 18px;
    font-size: 26px;
    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 14px
}

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

.page.events .modal-content p strong {
    color: var(--text-color);
    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;
    color: #ffffff !important;
    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)
    }
}




.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
    }
}


.pages-container,
.page.ggpass main,
.page-events .events-container,
.page-home main,
.scroll-container {
    z-index: 1
}

body,
body.page-index,
.page.ggpass,
body.page-events {
    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, #ffffff0f, #191d2791);
    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-preview-btn .skeleton-text {
    min-width: 30px;
    min-height: 14px;
    display: inline-block;
    vertical-align: middle;
    border-radius: 4px;
    background: rgba(255, 255, 255, 0.15)
}

.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: 100;
    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-scalable-group::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 70%;
    height: 70%;
    transform: translate(-50%, -50%);
    background: radial-gradient(circle, rgb(255 255 255 / 25%) 0%, transparent 70%);
    filter: blur(50px);
    z-index: -1;
    pointer-events: none;
}

@keyframes floatWheel {
    0%, 100% { transform: scale(.55) translateY(-33%); }
    50% { transform: scale(.55) translateY(-35%); }
}

.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%);
    background: url(https://cdn-1.ggprize.fun/wheel_point.avif) no-repeat center/contain;
    z-index: 20;
    filter: drop-shadow(0 5px 12px rgba(255, 255, 255, 0.26));
    pointer-events: none;
    animation: arrowBounce 2s ease-in-out infinite;
}

@keyframes arrowBounce {
    0%, 100% { transform: translate(-50%) translateY(0); }
    50% { transform: translate(-50%) translateY(-4px); }
}

.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: 1px solid rgba(255, 255, 255, 0.2);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.05));
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    color: #fff;
    font-size: 16px;
    font-weight: 800;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2), inset 0 1px 0 rgba(255, 255, 255, 0.2);
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    box-sizing: border-box;
    position: relative;
    overflow: hidden;
}

.spin-btn::after {
    content: '';
    position: absolute;
    top: 0; left: -100%;
    width: 50%; height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
    transform: skewX(-20deg);
    animation: buttonShine 3s infinite;
}

@keyframes buttonShine {
    0% { left: -100%; }
    20%, 100% { left: 200%; }
}

.spin-btn.is-invite {
    background: linear-gradient(135deg, rgba(10, 132, 255, 0.8), rgba(10, 132, 255, 0.5));
    border-color: rgba(10, 132, 255, 0.4);
    box-shadow: 0 6px 20px rgba(10, 132, 255, 0.3), inset 0 1px 0 rgba(255, 255, 255, 0.2);
    padding: 14px;
}

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

.spin-btn:active {
    transform: scale(0.96) translateY(2px);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2), inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

.spin-btn:disabled {
    opacity: 0.6;
    transform: none;
    pointer-events: none;
}

.idle-spin {
    animation: idleSpin 40s 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;
}

.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 {
    z-index: 10;
}

.roulette-cell.winner .roulette-cell-icon {
    transform: rotate(180deg) scale(1.4) !important;
    filter: drop-shadow(0 0 25px rgba(255, 255, 255, 0.6));
    animation: winnerPulse 1.5s ease-in-out infinite;
}

@keyframes winnerPulse {
    0%, 100% { transform: rotate(180deg) scale(1.3) !important; filter: drop-shadow(0 0 15px rgba(255, 255, 255, 0.4)); }
    50% { transform: rotate(180deg) scale(1.5) !important; filter: drop-shadow(0 0 35px rgb(255, 255, 255, 0.6)); }
}

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

body.page-friends {
    margin: 0;
    height: 100%;
    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,
.page.friends main {
    padding-top: calc(var(--tg-content-safe-area-inset-top) + var(--tg-safe-area-inset-top) + 76px);
    padding-bottom: 80px;
    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,
.page.friends .main-container {
    width: 92%;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: flex-start
}

.page-friends .page-title,
.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,
.page.friends .referral-link-section {
    width: 100%;
    margin-bottom: 16px
}

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

.page-friends .info-card,
.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,
.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,
.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,
.page.friends .info-title {
    font-size: 18px;
    font-weight: 700;
    color: var(--text-primary);
    text-transform: uppercase;
    margin: 0
}

.page-friends .info-subtitle,
.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 .info-subtitle .info-subtitle-uc,
.page.friends .info-subtitle .info-subtitle-uc {
    white-space: normal;
    line-height: 1.35;
}

.page-friends .info-subtitle .currency-icon,
.page.friends .info-subtitle .currency-icon {
    width: 14px;
    height: 10px;
    vertical-align: middle;
    display: inline-block
}

.page-friends .rewards-section-title,
.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,
.page.friends .rewards-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    width: 100%;
    position: relative;
    z-index: 3
}

.page-friends .reward-box,
.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,
.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,
.page.friends .reward-box img {
    width: 45px;
    height: 45px;
    object-fit: contain;
    position: absolute;
    right: 5px;
    z-index: 1;
    margin: 0
}

.page-friends .reward-box-wheel,
.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,
.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,
.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,
.page.friends .friends-list-container {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding-bottom: 20px
}

.page-friends .invite-item,
.page.friends .invite-item {
    background: #1a1a1a66;
    border-radius: 12px;
    padding: 12px;
    display: flex;
    align-items: center;
    gap: 12px;
    width: 100%;
    box-sizing: border-box
}

.page-friends .invite-avatar,
.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,
.page.friends .invite-info {
    flex-grow: 1;
    min-width: 0
}

.page-friends .invite-name,
.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,
.page.friends .invite-details {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 4px
}

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

.page-friends .invite-reward,
.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,
.page.friends .invite-reward--pending {
    background: none;
    padding: 6px;
    justify-content: center
}

.page-friends .invite-spinner,
.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,
.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,
.page.friends .invite-info-icon {
    position: relative;
    display: flex;
    align-items: center;
    cursor: pointer
}

.page-friends .invite-tooltip,
.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,
.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,
.page.friends .invite-info-icon:hover .invite-tooltip {
    visibility: visible;
    opacity: 1
}

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

/* Ð¡ÐºÐµÐ»ÐµÑ‚Ð¾Ð½Ñ‹ Ð²ÐºÐ»Ð°Ð´ÐºÐ¸ Ð”Ñ€ÑƒÐ·ÑŒÑ (Ð´ÑƒÐ±Ð»Ð¸Ñ€ÑƒÐµÐ¼ Ð¸Ð· friends.html Ð´Ð»Ñ Ð½Ð°Ð´Ñ‘Ð¶Ð½Ð¾ÑÑ‚Ð¸) */
.page-friends .invite-item.skeleton,
.page.friends .invite-item.skeleton {
    background: rgba(26, 26, 26, 0.4);
    border-radius: 12px;
    padding: 12px;
    display: flex;
    align-items: center;
    gap: 12px;
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.05);
}

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

.page-friends .sk-avatar,
.page.friends .sk-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.1);
    flex-shrink: 0;
}

.page-friends .sk-info,
.page.friends .sk-info {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.page-friends .sk-line,
.page.friends .sk-line {
    height: 10px;
    border-radius: 4px;
    background: rgba(255, 255, 255, 0.08);
}

.page-friends .sk-line.short,
.page.friends .sk-line.short { width: 40%; }

.page-friends .sk-line.long,
.page.friends .sk-line.long { width: 70%; }

.page-friends .sk-reward,
.page.friends .sk-reward {
    width: 40px;
    height: 20px;
    border-radius: 6px;
    background: rgba(255, 255, 255, 0.05);
}

.page-friends .skeleton-media,
.page.friends .skeleton-media {
    background: rgba(255, 255, 255, 0.05);
    border-radius: 12px;
    position: relative;
    overflow: hidden;
}

.page-friends .skeleton-text,
.page.friends .skeleton-text {
    display: inline-block !important;
    background: rgba(255, 255, 255, 0.1) !important;
    border-radius: 6px;
    position: relative;
    overflow: hidden;
    color: transparent !important;
    -webkit-text-fill-color: transparent !important;
    min-height: 18px;
    pointer-events: none;
}

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

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

    .page-friends .reward-box span,
    .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 0px 10px #ffffff17;
    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,
body.ui-hidden-top .top-header,
body.ui-hidden-top .tg-app-header {
    transform: translateY(-200%) !important;
    pointer-events: none
}

body.ui-hidden-all .bottom-nav,
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;
    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-blue {
    background: linear-gradient(135deg, #3b82f6, #1d4ed8)
}

.bg-nick-purple {
    background: linear-gradient(135deg, #a855f7, #7c3aed)
}

.bg-nick-sunset {
    background: linear-gradient(135deg, #fb923c, #f43f5e)
}

.bg-nick-ice {
    background: linear-gradient(135deg, #e0f2fe, #7dd3fc, #0284c7)
}

.bg-nick-magma {
    background: linear-gradient(135deg, #ef4444, #f97316, #eab308)
}

.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
}

.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;
    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
}

/* Lightweight CSS-only spoiler for hidden nicknames (no canvas, no lag) */
.name-spoiler {
    position: relative;
    display: inline-block;
    color: transparent !important;
    border-radius: 4px;
    padding: 0 2px;
    vertical-align: middle;
    line-height: 1.2;
    -webkit-user-select: none;
    user-select: none;
    background: rgba(255, 255, 255, 0.12);
    overflow: hidden;
}
.name-spoiler::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 4 4' xmlns='http://www.w3.org/2000/svg'%3E%3Crect x='0' y='0' width='1' height='1' fill='%23ffffff' fill-opacity='0.3'/%3E%3Crect x='2' y='1' width='1' height='1' fill='%23ffffff' fill-opacity='0.2'/%3E%3Crect x='1' y='2' width='1' height='1' fill='%23ffffff' fill-opacity='0.25'/%3E%3Crect x='3' y='3' width='1' height='1' fill='%23ffffff' fill-opacity='0.15'/%3E%3C/svg%3E");
    background-size: 4px 4px;
    animation: spoilerShimmer 0.8s linear infinite;
    pointer-events: none;
    z-index: 1;
}
@keyframes spoilerShimmer {
    0% { background-position: 0 0; }
    100% { background-position: 4px 4px; }
}

.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
}

/* ---------- Partner Dashboard Block ---------- */
.partner-dashboard {
    width: 100%;
    box-sizing: border-box;
    margin-bottom: 20px;
    border-radius: 20px;
    position: relative;
    overflow: hidden;
    background: linear-gradient(145deg, rgba(0, 157, 255, 0.12) 0%, rgba(0, 157, 255, 0.03) 50%, rgba(26, 26, 26, 0.6) 100%);
    border: 1px solid rgba(0, 157, 255, 0.2);
    -webkit-backdrop-filter: blur(14px);
    backdrop-filter: blur(14px);
}
.partner-dashboard::before {
    content: "";
    position: absolute;
    top: -50%;
    right: -25%;
    width: 70%;
    height: 120%;
    background: radial-gradient(ellipse, rgba(0, 157, 255, 0.1) 0%, transparent 70%);
    pointer-events: none;
}

.partner-dashboard__header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 18px 18px 0;
    position: relative;
    z-index: 1;
}
.partner-dashboard__icon {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    background: linear-gradient(135deg, rgba(0, 157, 255, 0.3), rgba(0, 157, 255, 0.12));
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.partner-dashboard__icon svg {
    width: 22px;
    height: 22px;
}
.partner-dashboard__title {
    font-size: 16px;
    font-weight: 800;
    color: var(--text-primary, #fff);
    margin: 0;
}
.partner-dashboard__sub {
    font-size: 12px;
    color: var(--text-secondary, rgba(255,255,255,0.55));
    margin: 2px 0 0;
}

/* Stats row */
.partner-dashboard__stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    padding: 14px 18px;
    position: relative;
    z-index: 1;
}
.partner-dashboard__stat {
    background: rgba(0, 0, 0, 0.3);
    border-radius: 12px;
    padding: 12px 10px;
    border: 1px solid rgba(255, 255, 255, 0.05);
    text-align: center;
}
.partner-dashboard__stat-val {
    font-size: 20px;
    font-weight: 800;
    color: var(--text-primary, #fff);
    line-height: 1.2;
}
.partner-dashboard__stat-val--green { color: #4ade80; }
.partner-dashboard__stat-label {
    display: block;
    font-size: 10px;
    font-weight: 600;
    color: var(--text-secondary, rgba(255,255,255,0.5));
    text-transform: uppercase;
    letter-spacing: 0.03em;
    margin-top: 4px;
}

/* Link copy section */
.partner-dashboard__link-section {
    padding: 0 18px 16px;
    position: relative;
    z-index: 1;
}
.partner-dashboard__link-row {
    display: flex;
    align-items: center;
    gap: 8px;
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 12px;
    padding: 10px 12px;
}
.partner-dashboard__link-text {
    flex: 1;
    font-size: 12px;
    color: var(--text-secondary, rgba(255,255,255,0.6));
    word-break: break-all;
    font-family: monospace;
    line-height: 1.3;
}
.partner-dashboard__copy-btn {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 8px 14px;
    background: linear-gradient(180deg, #009dff 0%, #0074c2 100%);
    color: #fff;
    border: none;
    border-radius: 10px;
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    transition: transform 0.15s ease, opacity 0.15s ease;
    -webkit-tap-highlight-color: transparent;
}
.partner-dashboard__copy-btn:active { transform: scale(0.96); }
.partner-dashboard__copy-btn svg { width: 16px; height: 16px; flex-shrink: 0; }

@media (max-width: 380px) {
    .partner-dashboard__stats { grid-template-columns: 1fr 1fr; }
}
#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)
}

/* === COLLAPSE COLOR === */
.nick-collapse {
    opacity: 1;
    background-image: url(https://cdn-1.ggprize.fun/colors/1x.webp);
    background-size: cover;
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    filter: drop-shadow(rgb(0, 148, 255) 1px 1px 0.5px) drop-shadow(rgb(255, 0, 145) 0px 0px 3px);
    font-weight: 800
}

.bg-nick-collapse {
    opacity: 1;
    background-image: url(https://cdn-1.ggprize.fun/colors/1x.webp);
    background-size: cover;
    filter: drop-shadow(rgb(0, 148, 255) 1px 1px 0.5px) drop-shadow(rgb(255, 0, 145) 0px 0px 3px)
}

/* === AVATAR FRAMES (3-layer Lottie) === */
.avatar-frame-wrapper {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center
}

.lottie-layer {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%
}

.lottie-bg {
    transform: scale(1.12);
    filter: drop-shadow(0 0 8px rgba(255, 255, 255, .15))
}

.lottie-border {
    transform: scale(1.04)
}

.lottie-fg {
    filter: drop-shadow(0 2px 4px rgba(0, 0, 0, .25))
}

.avatar-container,
.profile-avatar-container {
    overflow: visible !important;
    position: relative
}

.avatar-container img,
.profile-avatar-container img {
    position: relative;
    z-index: 1
}

.avatar-container {
    position: relative
}

.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 !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100vw !important;
    min-height: 100vh !important;
    min-height: 100dvh !important;
    max-height: 100vh !important;
    max-height: 100dvh !important;
    margin: 0 !important;
    background: #000c;
    z-index: 10000;
    opacity: 0;
    visibility: hidden;
    transition: .3s;
    display: flex !important;
    align-items: flex-end !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch
}

.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);
    flex-shrink: 0;
    margin-top: auto
}

.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
}

/* ===== YANDEX SPECIAL TASK ===== */
.yx-modal {
    background: #17181A;
    padding: 0;
    max-height: 85vh;
    display: flex;
    flex-direction: column
}

.yx-header {
    padding: 17px 17px 0;
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0
}

.yx-title-bar {
    display: flex;
    align-items: center;
    gap: 12px;
    background: rgba(64, 64, 64, .4);
    backdrop-filter: blur(7px);
    -webkit-backdrop-filter: blur(7px);
    border-radius: 37px;
    padding: 3px;
    flex: 1;
    min-width: 0
}

.yx-logo {
    width: 55px;
    height: 55px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0
}

.yx-title-text {
    display: flex;
    flex-direction: column;
    min-width: 0
}

.yx-brand {
    font-weight: 700;
    font-size: 24px;
    line-height: 30px;
    color: #fff
}

.yx-subtitle {
    font-weight: 200;
    font-size: 12px;
    line-height: 15px;
    color: rgba(255, 255, 255, .8);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis
}

.yx-close {
    width: 40px;
    height: 40px;
    min-width: 40px;
    border-radius: 100px;
    background: rgba(255, 255, 255, .1);
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    flex-shrink: 0
}

.yx-reward-header {
    padding: 14px 20px 0;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    flex-shrink: 0
}

.yx-reward-amount {
    font-weight: 700;
    font-size: 32px;
    line-height: 40px;
    color: #fff
}

.yx-uc-icon-big {
    height: 22px;
    width: auto
}

.yx-reward-text {
    font-weight: 700;
    font-size: 20px;
    line-height: 25px;
    color: #fff
}

.yx-steps-scroll {
    flex: 1;
    overflow-y: auto;
    padding: 16px 17px 17px;
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 22px;
    -webkit-overflow-scrolling: touch
}

.yx-fade-top {
    position: sticky;
    top: 0;
    left: 0;
    width: 100%;
    height: 24px;
    background: linear-gradient(180deg, #17181A 0%, rgba(23, 24, 26, 0) 100%);
    z-index: 2;
    margin-bottom: -24px;
    pointer-events: none;
    flex-shrink: 0
}

.yx-step-card {
    position: relative;
    background: rgba(64, 64, 64, .4);
    border-radius: 25px;
    padding: 15px;
    overflow: hidden;
    flex-shrink: 0
}

.yx-step-bg-vector {
    position: absolute;
    right: 0;
    bottom: 0px;
    width: 140px;
    height: auto;
    opacity: 1;
    pointer-events: none;
    transform: rotate(0deg)
}

.yx-step-header {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    position: relative;
    z-index: 1;
    margin-bottom: 12px
}

.yx-step-icon {
    width: 30px;
    height: 30px;
    flex-shrink: 0;
    margin-top: 11px;
}

.yx-step-texts {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0
}

.yx-step-label {
    font-weight: 700;
    font-size: 12px;
    line-height: 15px;
    color: rgba(255, 255, 255, .8)
}

.yx-step-title {
    font-weight: 800;
    font-size: 15px;
    line-height: 19px;
    color: #fff
}

.yx-step-desc {
    font-weight: 400;
    font-size: 10px;
    line-height: 12px;
    color: rgba(255, 255, 255, .5)
}

.yx-step-reward {
    position: relative;
    width: 113px;
    height: 66px;
    background: rgba(26, 26, 26, .6);
    border-radius: 15px;
    margin: 20px 0;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center
}

.yx-step-reward-label {
    position: absolute;
    top: -2px;
    left: 0;
    right: 0;
    font-weight: 400;
    font-size: 10px;
    line-height: 22px;
    color: rgba(255, 255, 255, .8);
    text-align: center
}

.yx-step-reward-glow {
    position: absolute;
    inset: 8px;
    background: radial-gradient(50% 50% at 50% 50%, rgba(255, 255, 255, .1) 0%, rgba(255, 255, 255, 0) 100%);
    pointer-events: none
}

.yx-step-reward-value {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 8px;
    position: relative;
    z-index: 1
}

.yx-step-reward-value span {
    font-weight: 700;
    font-size: 28px;
    line-height: 22px;
    color: #fff;
    text-align: center
}

.yx-uc-icon {
    height: 20px;
    width: auto
}

.yx-step-btn {
    display: block;
    width: 180px;
    height: 40px;
    background: rgba(90, 237, 144, .8);
    border-radius: 15px;
    border: none;
    font-family: 'Geologica', sans-serif;
    font-weight: 700;
    font-size: 16px;
    color: #fff;
    cursor: pointer;
    position: relative;
    z-index: 1;
    transition: opacity .2s
}

.yx-step-btn:active {
    opacity: .7
}

.yx-warning {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    background: #28282A;
    border-radius: 20px;
    padding: 8px 15px;
    flex-shrink: 0
}

.yx-warning-icon {
    width: 30px;
    height: 30px;
    flex-shrink: 0;
    margin-top: 0.6rem;
}

.yx-warning-text {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0
}

.yx-warning-text>span:first-child {
    font-weight: 700;
    font-size: 10px;
    line-height: 12px;
    color: #fff
}

.yx-warning-legal {
    font-weight: 700;
    font-size: 8px;
    line-height: 12px;
    color: rgba(255, 255, 255, .5)
}

.yx-task-card {
    background: linear-gradient(135deg, #2b0b0775, #1a1a1a66);
}

.yx-task-card .task-card-img {
    border-radius: 50%
}

.yx-task-card .task-card-reward {
    color: #5aed90
}

.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;
    padding-left: 1rem;
    padding-right: 1rem;
    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%;
    max-width: 100vw;
    height: auto;
    aspect-ratio: 390 / 363;
    overflow: hidden;
    position: relative;
    z-index: 1;
    margin-left: 0;
    margin-right: 0;
    margin-top: calc(-1rem - var(--header-top-inset));
    border-radius: 20px;
    box-sizing: border-box;
}

@media (min-width: 551px) {
    .ggpass-header-image {
        aspect-ratio: auto;
    }
}

.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) + 82px);
    z-index: 20;
    margin-top: -110px;
    margin-bottom: 20px;
    pointer-events: none;
    width: 92%;
    max-width: 92%;
    margin-left: auto;
    margin-right: auto;
    box-sizing: border-box
}

.ggpass-sticky-wrapper>* {
    pointer-events: auto
}

body.platform-pc .ggpass-sticky-wrapper {
    top: calc(var(--tg-viewport-safe-area-inset-top, 0px) + 82px) !important
}

.ggpass-title {
    font-weight: 800;
    font-size: 32px;
    color: #fff;
    text-align: center;
    margin: -150px auto 110px;
    text-shadow: 0 4px 20px rgba(0, 0, 0, .5);
    position: relative;
    z-index: 5;
    pointer-events: none;
    width: 92%;
    max-width: 92%;
    box-sizing: border-box
}

.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: #fda0b6c4;
    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;
    position: relative;
    z-index: 5;
    width: 92%;
    max-width: 92%;
    margin-left: auto;
    margin-right: auto;
    box-sizing: border-box
}

.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: #fda0b6;
    box-shadow: 0 0 10px #fda0b666
}

.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
}

.page.ggpass .ggpass-skeleton-icon {
    width: 35px;
    height: 35px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.1);
    flex-shrink: 0;
    position: relative;
    overflow: hidden
}

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

@keyframes ggpass-shimmer {
    0% { transform: translateX(-100%); }
    100% { transform: translateX(100%); }
}

.page.ggpass .ggpass-skeleton-card {
    pointer-events: none;
}

.page.ggpass .ggpass-skeleton-img {
    width: 125px;
    height: 125px;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.08);
    margin-bottom: 10px;
    position: relative;
    overflow: hidden
}

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

.page.ggpass .ggpass-skeleton-btn {
    width: 100%;
    height: 36px;
    border-radius: 100px;
    background: rgba(255, 255, 255, 0.08);
    position: relative;
    overflow: hidden
}

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

.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 !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100vw !important;
    min-height: 100vh !important;
    min-height: 100dvh !important;
    max-height: 100vh !important;
    max-height: 100dvh !important;
    margin: 0 !important;
    padding: 16px;
    box-sizing: border-box;
    background: #000c;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    z-index: 10000;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    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);
    margin: auto;
    flex-shrink: 0;
    align-self: center
}

.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
}

.page:not(.shop) > main {
    opacity: 1;
    padding-top: calc(var(--tg-content-safe-area-inset-top) + var(--tg-safe-area-inset-top) + 76px) !important;
    padding-bottom: calc(6rem + var(--tg-content-safe-area-inset-bottom));
}

.page.friends > main, .page.tasks > main {
    opacity: 1 !important;
}

/* Ð”Ñ€ÑƒÐ·ÑŒÑ: Ð±ÐµÐ· rem-Ð¾Ñ‚ÑÑ‚ÑƒÐ¿Ð¾Ð² Ñƒ main, ÐºÐ°Ðº Ñƒ shop */
.page.friends > main,
.page.friends main {
    padding-left: 0 !important;
    padding-right: 0 !important;
    padding-top: calc(var(--tg-content-safe-area-inset-top) + var(--tg-safe-area-inset-top) + 76px) !important;
    padding-bottom: 80px !important;
}

/* Ð—Ð°Ð³Ð¾Ð»Ð¾Ð²Ð¾Ðº ÑÑ‚Ñ€Ð°Ð½Ð¸Ñ†Ñ‹ â€” Ð¾Ð±Ñ‰Ð¸Ð¹ ÑÑ‚Ð¸Ð»ÑŒ Ð´Ð»Ñ Ð²ÐºÐ»Ð°Ð´Ð¾Ðº */
.page .page-title,
.page.friends .page-title,
.page.tasks .page-title {
    font-size: 32px;
    font-weight: 800;
    margin: 0 0 10px;
    text-transform: uppercase;
    color: var(--text-primary);
    text-align: left;
    width: 100%;
}

body.platform-pc .page:not(.shop) > main {
    padding-top: calc(var(--tg-viewport-safe-area-inset-top, 0px) + 102px) !important;
}

/* =============================================
   Inline styles moved from SPA HTML files
   ============================================= */

/* --- FROM home.html --- */
.skeleton-text::after,
.award-item.skeleton::after,
.skeleton-rect::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.1) 50%, transparent 100%);
    transform: translateX(-100%);
    animation: shimmer 1.5s infinite;
}

.award-item.skeleton {
    background: rgba(255, 255, 255, 0.05);
    border-radius: 12px;
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.05);
    min-height: 90px;
    min-width: 80px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.award-item.skeleton .sk-icon {
    width: 32px;
    height: 32px;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 50%;
}

.award-item.skeleton .sk-line {
    height: 8px;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 4px;
    width: 60%;
}

.wheel-preview-btn .skeleton-text {
    width: 40px;
    height: 14px;
    background: rgba(255, 255, 255, 0.15);
}

.page.home #loader {
    display: none !important;
}

.page.home #dailyRewardsLoader {
    display: none !important;
}

.page.home > main {
    opacity: 1 !important;
    padding-top: calc(var(--tg-content-safe-area-inset-top, 0px) + var(--tg-safe-area-inset-top, 0px) + 76px);
    padding-bottom: 90px;
    padding-left: 0;
    padding-right: 0;
}

/* --- FROM friends.html --- */
.page.friends main {
    opacity: 1 !important;
    transition: none !important;
}

.page.friends #loader { display: none !important; }

.page.friends .invite-item.skeleton {
    background: rgba(26, 26, 26, 0.4);
    border-radius: 12px;
    padding: 12px;
    display: flex;
    align-items: center;
    gap: 12px;
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.05);
}

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

.page.friends .sk-avatar {
    width: 40px; height: 40px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.1);
    flex-shrink: 0;
}

.page.friends .sk-info {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.page.friends .sk-line {
    height: 10px;
    border-radius: 4px;
    background: rgba(255, 255, 255, 0.08);
}
.page.friends .sk-line.short { width: 40%; }
.page.friends .sk-line.long { width: 70%; }

.page.friends .sk-reward {
    width: 40px; height: 20px;
    border-radius: 6px;
    background: rgba(255, 255, 255, 0.05);
}

.page.friends .skeleton-media {
    background: rgba(255,255,255,0.05);
    border-radius: 12px;
    position: relative;
    overflow: hidden;
}

.page.friends .skeleton-text {
    display: inline-block !important;
    background: rgba(255, 255, 255, 0.1) !important;
    border-radius: 6px;
    position: relative;
    overflow: hidden;
    color: transparent !important;
    vertical-align: middle;
    -webkit-text-fill-color: unset !important;
    background-clip: border-box !important;
    -webkit-background-clip: border-box !important;
    min-height: 18px;
    pointer-events: none;
}

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

.page.friends img.skeleton-media {
    color: transparent;
    min-height: 48px;
}
.page.friends img.info-bg-image.skeleton-media {
    min-height: 100px;
    min-width: 80px;
}

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

/* --- FROM events.html --- */
.page.events .podium-skeleton {
    display: flex;
    justify-content: center;
    align-items: flex-end;
    gap: 10px;
    padding: 10px 0;
}

.page.events .podium-sk-slot {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    position: relative;
    overflow: hidden;
}

.page.events .podium-sk-slot::after {
    content: "";
    position: absolute;
    top: 0; left: 0; width: 100%; height: 100%;
    background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.04) 50%, transparent 100%);
    transform: translateX(-100%);
    animation: shimmer 1.5s infinite;
}

.page.events .podium-sk-avatar {
    width: 40px;
    height: 40px;
    background: rgba(255, 255, 255, 0.08);
    border-radius: 50%;
}

.page.events .podium-sk-slot.sk-first .podium-sk-avatar {
    width: 56px;
    height: 56px;
}

.page.events .podium-sk-name {
    width: 45px;
    height: 7px;
    background: rgba(255, 255, 255, 0.06);
    border-radius: 4px;
}

.page.events .podium-sk-bar {
    width: 65px;
    background: rgba(255, 255, 255, 0.04);
    border-radius: 8px 8px 0 0;
}

.page.events .podium-sk-slot.sk-second .podium-sk-bar {
    height: 24px;
}

.page.events .podium-sk-slot.sk-first .podium-sk-bar {
    height: 36px;
    width: 75px;
}

.page.events .podium-sk-slot.sk-third .podium-sk-bar {
    height: 16px;
}

.page.events .top-item.skeleton {
    position: relative;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.03);
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.04);
    pointer-events: none;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px;
}

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

.page.events .sk-rank {
    width: 20px;
    height: 20px;
    background: rgba(255, 255, 255, 0.06);
    border-radius: 4px;
}

.page.events .sk-avatar {
    width: 36px;
    height: 36px;
    background: rgba(255, 255, 255, 0.08);
    border-radius: 50%;
    flex-shrink: 0;
}

.page.events .sk-info {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.page.events .sk-line {
    height: 7px;
    background: rgba(255, 255, 255, 0.06);
    border-radius: 4px;
}

.page.events .sk-line.short {
    width: 40%;
}

.page.events .sk-line.long {
    width: 65%;
}

.page.events .sk-reward {
    width: 40px;
    height: 20px;
    background: rgba(255, 255, 255, 0.06);
    border-radius: 5px;
}

.page.events #loader {
    display: none !important;
}

.page.events #eventsContainer {
    opacity: 1 !important;
}

.page.events .user-top-bar.skeleton-bar {
    display: block;
    padding: 0;
}

/* --- FROM shop.html --- */
.shop-skeleton-root .shop-skeleton-card { background: rgba(26,26,26,0.4); border-radius: 12px; padding: 12px; display: flex; flex-direction: column; gap: 10px; aspect-ratio: 160/220; min-height: 200px; position: relative; overflow: hidden; }
.shop-skeleton-root .shop-skeleton-card-img { width: 100%; aspect-ratio: 1; border-radius: 8px; background: rgba(255,255,255,0.08); position: relative; overflow: hidden; }
.shop-skeleton-root .shop-skeleton-card-img::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.06) 50%, transparent 100%); animation: shop-shimmer 1.5s infinite; }
.shop-skeleton-root .shop-skeleton-card-line { height: 10px; border-radius: 4px; background: rgba(255,255,255,0.08); width: 100%; }
.shop-skeleton-root .shop-skeleton-card-line.short { width: 60%; }
.shop-skeleton-root .shop-skeleton-card-price { height: 14px; width: 70px; border-radius: 4px; background: rgba(255,255,255,0.1); margin-top: auto; position: relative; overflow: hidden; }
.shop-skeleton-root .shop-skeleton-card-price::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.06) 50%, transparent 100%); animation: shop-shimmer 1.5s infinite; }
@keyframes shop-shimmer { 0% { transform: translateX(-100%); } 100% { transform: translateX(100%); } }

/* ========== SPIN BATTLES ========== */

.page-spin-battles main,
.page-spin-battles {
    padding-top: 10px;
    padding-bottom: 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
}

.spin-header {
    width: 92%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 5px
}

.spin-title {
    font-family: Geologica, sans-serif;
    font-weight: 600;
    font-size: 35px;
    color: #fff;
    margin: 0
}

.spin-help-btn {
    background: #ffffff14;
    border-radius: 50px;
    padding: 6px 12px;
    display: flex;
    font-size: 11px;
    align-items: center;
    gap: 6px;
    backdrop-filter: blur(10px);
    cursor: pointer;
    text-decoration: none
}

.create-battle-card {
    width: 92%;
    background: #1a1a1a66;
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 25px;
    padding: 16px;
    box-sizing: border-box;
    display: flex;
    backdrop-filter: blur(10px);
    flex-direction: column;
    gap: 15px;
    margin-bottom: 20px
}

.create-header-row {
    display: flex;
    justify-content: space-between;
    align-items: center
}

.create-label {
    font-family: Geologica, sans-serif;
    font-size: 14px;
    color: #fff
}

.battle-type-toggle {
    display: flex;
    background: #ffffff14;
    border-radius: 20px;
    padding: 2px
}

.type-btn {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    border-radius: 20px;
    cursor: pointer;
    opacity: .5;
    transition: opacity .2s, background .2s
}

.type-btn.active {
    opacity: 1;
    background: #ffffff14
}

.type-text {
    font-size: 10px;
    font-family: Geologica
}

.type-text.open {
    color: #5aed90
}

.type-text.private {
    color: #ffa860
}

.create-body-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px
}

.user-mini-profile {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    width: 125px
}

.user-mini-avatar {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    object-fit: cover
}

.user-mini-name {
    font-size: 12px;
    font-weight: 600;
    color: #fff;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%
}

.create-controls {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 12px
}

.bet-input-wrapper {
    background: #1a1a1a66;
    border-radius: 10px;
    padding: 0 12px;
    display: flex;
    align-items: center;
    height: 35px;
    width: 100%;
    max-width: 155px
}

.bet-input {
    background: transparent;
    border: none;
    color: #fff;
    font-size: 12px;
    width: 100%;
    text-align: center;
    font-family: Geologica
}

.bet-input::placeholder {
    color: #fff6;
    font-size: 10px
}

.create-action-btn {
    width: 100%;
    max-width: 180px;
    background: #fffc;
    border-radius: 20px;
    height: 35px;
    border: none;
    font-family: Geologica, sans-serif;
    font-weight: 800;
    font-size: 10px;
    color: #000;
    cursor: pointer
}

.lobby-stats-row {
    width: 92%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px
}

.stats-text {
    font-size: 11px;
    color: #fff9;
    display: flex;
    align-items: center;
    gap: 6px
}

.stats-text b {
    color: #fff
}

.room-id-input-wrapper {
    position: relative;
    width: 150px
}

.search-room-input {
    background: #1a1a1a66;
    border: none;
    border-radius: 8px;
    padding: 8px 30px 8px 12px;
    color: #fff;
    font-size: 10px;
    width: 100%;
    backdrop-filter: blur(10px);
    box-sizing: border-box;
    font-family: Geologica
}

.search-room-input::placeholder {
    color: #fff6
}

.enter-room-btn {
    position: absolute;
    right: 5px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    color: #fff;
    opacity: .5;
    cursor: pointer;
    padding: 0;
    display: flex
}

.battles-list {
    width: 92%;
    display: flex;
    flex-direction: column;
    gap: 12px
}

.battle-item {
    background: #1a1a1a66;
    border-radius: 16px;
    padding: 12px 16px;
    display: flex;
    align-items: center;
    justify-content: space-between
}

.battle-players {
    display: flex;
    align-items: center;
    gap: 15px
}

.b-player {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    width: 50px
}

.b-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover
}

.b-name {
    font-size: 10px;
    color: #fff;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 60px;
    font-family: Geologica
}

.b-vs {
    font-family: Geologica;
    font-weight: 900;
    font-size: 24px;
    color: #fff;
    font-style: italic
}

.b-empty-slot {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: #ffffff14
}

.battle-info {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 8px
}

.b-bet-badge {
    background: #ffc5481a;
    border: 1px solid rgba(255, 197, 72, .3);
    border-radius: 6px;
    padding: 2px 8px;
    display: flex;
    align-items: center;
    gap: 4px;
    color: #ffc548;
    font-weight: 800;
    font-size: 14px
}

.b-action-btn {
    border: none;
    border-radius: 20px;
    padding: 6px 12px;
    color: #fff;
    font-size: 10px;
    display: flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
    font-family: Geologica
}

.b-action-btn.watch {
    background: #ffffff1a
}

.b-action-btn.join-blue {
    background: #539ab399
}

.b-action-row {
    display: flex;
    gap: 6px
}

.icon-only-btn {
    width: 65px;
    height: 26px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    border: none;
    cursor: pointer
}

.icon-only-btn.join {
    background: #539ab399
}

.icon-only-btn.watch {
    background: #ffffff1a
}

.room-back-btn {
    width: 45px;
    height: 45px;
    background: #1a1a1a66;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    cursor: pointer;
    margin-right: 15px
}

.room-id-block {
    display: flex;
    align-items: center;
    gap: 8px
}

.room-id-text {
    color: #fff9;
    font-size: 14px;
    font-weight: 800;
    font-family: Geologica
}

.room-id-val {
    color: #fff
}

.icon-btn {
    width: 20px;
    height: 20px;
    background: #1a1a1a66;
    border-radius: 5px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    border: none
}

.invite-pill {
    background: #1a1a1a66;
    border-radius: 5px;
    padding: 4px 8px;
    display: flex;
    align-items: center;
    gap: 6px;
    cursor: pointer
}

.invite-pill span {
    font-size: 8px;
    font-weight: 600;
    color: #fff;
    font-family: Geologica
}

.room-status-badge {
    background: #ffffff1a;
    border-radius: 10px;
    padding: 3px 10px;
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 10px;
    font-family: Geologica
}

.room-details-card {
    flex-grow: 1;
    width: auto;
    margin: 0;
    height: 82px;
    background: #1a1a1a66;
    border-radius: 15px;
    backdrop-filter: blur(10px);
    padding: 0 13px;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    justify-content: center;
    margin-bottom: 20px;
    position: relative;
    overflow: hidden
}

.rd-title {
    font-family: Geologica;
    font-weight: 700;
    font-size: 14px;
    color: #fff;
    margin-bottom: 4px
}

.rd-row {
    display: flex;
    gap: 30px
}

.rd-col {
    display: flex;
    flex-direction: column;
    gap: 2px
}

.rd-label {
    font-family: Geologica;
    font-weight: 400;
    font-size: 11px;
    color: #868b92
}

.rd-avatars {
    display: flex;
    margin-top: 2px
}

.rd-avatars img {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    margin-right: -10px;
    border: 1px solid #2c2c2c
}

.rd-win-block {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 2px
}

.rd-win-val {
    background: #ffffff14;
    border-radius: 7px;
    padding: 4px 8px;
    display: flex;
    align-items: center;
    gap: 4px;
    color: #ffc548;
    font-family: Geologica;
    font-weight: 800;
    font-size: 14px
}

.rd-fee-block {
    display: flex;
    flex-direction: column;
    align-items: center
}

.rd-fee {
    background: #ffffff14;
    border-radius: 5px;
    padding: 2px 4px;
    font-size: 8px;
    color: #fff;
    font-family: Geologica;
    font-weight: 800
}

.rd-swords-bg {
    position: absolute;
    width: 95px;
    height: 95px;
    right: -5px;
    top: 0;
    opacity: 1
}

.arena-container {
    position: relative;
    width: 92%;
    display: flex;
    flex-direction: column;
    gap: 20px;
    backdrop-filter: blur(10px);
    height: 480px
}

.player-card {
    width: 100%;
    background: #1a1a1a66;
    border-radius: 25px;
    position: absolute;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-top: 55px;
    padding-bottom: 55px;
}

.player-card.p1 {
    top: 0
}

.player-card.p2 {
    bottom: 0
}

.pc-bg {
    position: absolute;
    top: -50%;
    left: 0;
    width: 100%;
    height: 200%;
    background-size: cover;
    background-position: center;
    opacity: .1;
    filter: blur(2.5px);
    z-index: 0
}

.pc-avatar {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    object-fit: cover;
    z-index: 1
}

.pc-name {
    margin-top: 12px;
    font-family: Geologica;
    font-style: normal;
    font-weight: 700;
    font-size: 18px;
    color: #fff;
    z-index: 1
}

.battle-center {
    position: absolute;
    width: 100px;
    height: 100px;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    border: 6px solid rgb(255 255 255 / 24%);
    -webkit-backdrop-filter: blur(7px);
    backdrop-filter: blur(7px);
    border-radius: 50%;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box
}

.battle-swords {
    width: 61px;
    height: 61px;
    z-index: 12
}

.battle-spinner {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 50%;
    z-index: 999;
    background: transparent
}

.spinner-indicator {
    position: absolute;
    width: 15px;
    height: 4px;
    right: -10px;
    top: 50%;
    transform: translateY(-50%);
    background: #fff;
    z-index: 999;
    border-radius: 2px;
    box-shadow: 0 0 5px #fffc
}

.battle-timer {
    font-family: Geologica;
    font-weight: 700;
    font-size: 60px;
    color: #fff;
    z-index: 13
}

.winner-text {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    z-index: 20;
    width: 100%
}

.room-header-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 92%;
    margin-bottom: 20px;
    position: relative
}

.room-sub-header {
    width: 92%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px
}

.currency-svg {
    width: 14px;
    height: 10px;
    display: inline-block;
    vertical-align: middle
}

.swords-wrapper {
    width: 61px;
    height: 61px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 12
}

.copy-btn-room {
    position: relative;
    overflow: hidden
}

.copy-btn-room svg {
    transition: opacity .2s, transform .2s;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%)
}

.copy-btn-room .check-icon {
    opacity: 0;
    transform: translate(-50%, -50%) scale(.5)
}

.copy-btn-room.copied .check-icon {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1)
}

.copy-btn-room.copied svg:not(.check-icon) {
    opacity: 0;
    transform: translate(-50%, -50%) scale(.5)
}

.room-status-badge.open {
    color: #5aed90cc
}

.room-status-badge.private {
    color: #ffa860cc
}

.room-status-badge svg {
    margin-right: 4px
}

.empty-battles {
    color: #fff6;
    font-size: 14px;
    text-align: center;
    padding: 40px 0;
    font-family: Geologica
}

.empty-battles.hidden {
    display: none
}

#confettiCanvas {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 9999
}

.countdown-num {
    font-family: Geologica;
    font-weight: 900;
    font-size: 50px;
    color: #fff;
    z-index: 13;
    text-shadow: 0 0 20px rgba(255,255,255,0.5)
}

.countdown-num.animate-zoom {
    animation: countdownZoom 1s ease forwards
}

@keyframes countdownZoom {
    0% { transform: scale(0.3); opacity: 0 }
    50% { transform: scale(1.2); opacity: 1 }
    100% { transform: scale(1); opacity: 1 }
}

.fade-in {
    animation: fadeIn 0.3s ease
}

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