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

        :root {
            --tg-bg: var(--tg-theme-bg-color, #f4f7fe);
            --tg-text: var(--tg-theme-text-color, #1e2a4a);
            --tg-hint: var(--tg-theme-hint-color, #7b8ab0);
            --tg-link: var(--tg-theme-link-color, #2563eb);
            --tg-btn: var(--tg-theme-button-color, #2563eb);
            --tg-btn-text: var(--tg-theme-button-text-color, #ffffff);
            --tg-secondary-bg: var(--tg-theme-secondary-bg-color, #edf1fb);
            --tg-header-bg: var(--tg-theme-header-bg-color, #ffffff);
            --tg-section-bg: var(--tg-theme-section-bg-color, #ffffff);
            --tg-section-header: var(--tg-theme-section-header-text-color, #5a6a96);
            --tg-subtitle: var(--tg-theme-subtitle-text-color, #7b8ab0);
            --tg-destructive: var(--tg-theme-destructive-text-color, #ef4444);

            /* Glassmorphism */
            --glass-bg: rgba(255, 255, 255, 0.55);
            --glass-bg-strong: rgba(255, 255, 255, 0.8);
            --glass-border: rgba(200, 215, 255, 0.45);
            --glass-border-subtle: rgba(200, 215, 255, 0.2);
            --glass-shadow: 0 8px 32px rgba(31, 56, 135, 0.1);
            --glass-shadow-sm: 0 4px 16px rgba(31, 56, 135, 0.06);
            --glass-blur: 18px;

            /* Primary blue palette */
            --primary: #2563eb;
            --primary-light: #60a5fa;
            --primary-dark: #1d4ed8;
            --primary-50: #eff6ff;
            --primary-100: #dbeafe;
            --primary-200: #bfdbfe;
            --primary-glow: rgba(37, 99, 235, 0.2);
            --gradient-blue: linear-gradient(135deg, #2563eb 0%, #1d4ed8 100%);
            --gradient-blue-light: linear-gradient(135deg, #60a5fa 0%, #3b82f6 100%);

            /* Text colors */
            --text-heading: #1e2a4a;
            --text-body: #334872;
            --text-muted: #7b8ab0;
            --text-accent: #2563eb;

            --radius: 18px;
            --radius-sm: 12px;
            --radius-xs: 8px;
            --gap: 12px;
            --bottom-nav-height: 68px;
        }

        @media (prefers-color-scheme: dark) {
            :root {
                --glass-bg: rgba(22, 28, 50, 0.7);
                --glass-bg-strong: rgba(22, 28, 50, 0.88);
                --glass-border: rgba(100, 130, 220, 0.12);
                --glass-border-subtle: rgba(100, 130, 220, 0.06);
                --glass-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
                --glass-shadow-sm: 0 4px 16px rgba(0, 0, 0, 0.2);
                --text-heading: #e2e8f0;
                --text-body: #b0bdd6;
                --text-muted: #6b7ba0;
            }
        }

        body {
            font-family: -apple-system, 'SF Pro Display', 'SF Pro Text', system-ui, 'Helvetica Neue', Helvetica, Arial, sans-serif;
            font-size: 15px;
            line-height: 1.5;
            color: var(--text-body);
            background: linear-gradient(145deg, #e0e8ff 0%, #edf1fc 25%, #f4f0ff 50%, #eef3ff 75%, #e8edff 100%);
            background-attachment: fixed;
            -webkit-font-smoothing: antialiased;
            padding-bottom: calc(var(--bottom-nav-height) + 20px);
            min-height: 100vh;
            overflow-x: hidden;
        }

        @media (prefers-color-scheme: dark) {
            body { background: linear-gradient(145deg, #0c0f1e 0%, #121830 40%, #171e38 70%, #0e1225 100%); }
        }

        /* === SVG ICONS === */
        .icon { width: 28px; height: 28px; display: inline-block; vertical-align: middle; flex-shrink: 0; }
        .icon-sm { width: 20px; height: 20px; }
        .icon-lg { width: 36px; height: 36px; }
        .icon-xl { width: 48px; height: 48px; }
        .icon-nav { width: 24px; height: 24px; }

        .menu-item .icon { width: 40px; height: 40px; margin-bottom: 8px; color: var(--primary); }
        .list-item .icon { margin-right: 14px; color: var(--primary); }

        /* === CONTAINER === */
        .container { padding: 0 16px; max-width: 100%; box-sizing: border-box; min-width: 0; overflow: hidden; }

        /* === CARDS (Glassmorphism) === */
        .card {
            background: var(--glass-bg);
            backdrop-filter: blur(var(--glass-blur));
            -webkit-backdrop-filter: blur(var(--glass-blur));
            border-radius: var(--radius);
            padding: 16px;
            margin-bottom: var(--gap);
            border: 1px solid var(--glass-border);
            box-shadow: var(--glass-shadow-sm);
        }

        .card-header {
            font-size: 13px;
            font-weight: 700;
            text-transform: uppercase;
            color: var(--text-accent);
            letter-spacing: 0.8px;
            margin-bottom: 12px;
            padding: 0 4px;
        }

        /* === MENU GRID === */
        .menu-grid {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: var(--gap);
        }

        .menu-item {
            background: var(--glass-bg);
            backdrop-filter: blur(var(--glass-blur));
            -webkit-backdrop-filter: blur(var(--glass-blur));
            border-radius: var(--radius);
            padding: 22px 16px;
            text-align: center;
            text-decoration: none;
            color: var(--text-heading);
            cursor: pointer;
            transition: all 0.25s ease;
            border: 1px solid var(--glass-border);
            box-shadow: var(--glass-shadow-sm);
            font-family: inherit;
            width: 100%;
        }
        .menu-item:active { transform: scale(0.96); box-shadow: var(--glass-shadow); border-color: var(--primary-200); }

        .menu-item-title { font-size: 14px; font-weight: 700; display: block; color: var(--text-heading); }
        .menu-item-desc { font-size: 12px; color: var(--text-muted); margin-top: 4px; display: block; }

        .menu-item-wide {
            grid-column: 1 / -1;
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 16px 20px;
            text-align: left;
        }
        .menu-item-wide .icon { margin-bottom: 0; }
        .menu-item-wide .menu-item-info { flex: 1; }
        .menu-item-wide .menu-item-value {
            font-size: 16px;
            font-weight: 700;
            color: var(--tg-link);
        }

        /* === LIST === */
        .list { background: var(--glass-bg); backdrop-filter: blur(var(--glass-blur)); -webkit-backdrop-filter: blur(var(--glass-blur)); border-radius: var(--radius); overflow: hidden; border: 1px solid var(--glass-border); box-shadow: var(--glass-shadow-sm); }

        .list-item {
            display: flex;
            align-items: center;
            padding: 14px 16px;
            text-decoration: none;
            color: var(--tg-text);
            cursor: pointer;
            transition: background 0.2s, transform 0.15s;
            border: none;
            background: none;
            width: 100%;
            font-family: inherit;
            font-size: 15px;
            text-align: left;
        }
        .list-item:active { background: rgba(0,0,0,0.05); transform: scale(0.98); }
        .list-item + .list-item { border-top: 0.5px solid rgba(128,128,128,0.15); }

        .list-item-content { flex: 1; min-width: 0; }
        .list-item-title { font-weight: 600; color: var(--text-heading); }
        .list-item-subtitle { font-size: 13px; color: var(--text-muted); margin-top: 2px; }
        .list-item-chevron { color: var(--text-muted); margin-left: 8px; font-size: 18px; transition: transform 0.2s; }
        .list-item:active .list-item-chevron { transform: translateX(2px); }
        .list-item-value { font-weight: 700; color: var(--primary); margin-left: 8px; white-space: nowrap; }

        /* === FORMS === */
        .form-group { margin-bottom: 16px; }

        .form-label {
            display: block;
            font-size: 13px;
            font-weight: 700;
            text-transform: uppercase;
            color: var(--text-accent);
            letter-spacing: 0.6px;
            margin-bottom: 8px;
            padding: 0 4px;
        }

        .form-input {
            width: 100%;
            padding: 14px 16px;
            font-size: 16px;
            border: 1.5px solid var(--glass-border);
            border-radius: var(--radius-sm);
            background: var(--glass-bg);
            backdrop-filter: blur(8px);
            -webkit-backdrop-filter: blur(8px);
            color: var(--primary);
            outline: none;
            font-family: inherit;
            -webkit-appearance: none;
            transition: border-color 0.2s, box-shadow 0.2s;
        }
        .form-input::placeholder { color: var(--tg-hint); }
        .form-input:focus {
            border-color: var(--primary);
            box-shadow: 0 0 0 3px var(--primary-glow);
        }

        .form-select {
            width: 100%;
            padding: 14px 16px;
            font-size: 16px;
            border: 1.5px solid var(--glass-border);
            border-radius: var(--radius-sm);
            background: var(--glass-bg);
            backdrop-filter: blur(8px);
            -webkit-backdrop-filter: blur(8px);
            color: var(--tg-text);
            outline: none;
            font-family: inherit;
            -webkit-appearance: none;
            cursor: pointer;
            transition: border-color 0.2s, box-shadow 0.2s;
        }
        .form-select:focus {
            border-color: var(--primary);
            box-shadow: 0 0 0 3px var(--primary-glow);
        }

        /* === BUTTONS === */
        .btn {
            display: block;
            width: 100%;
            padding: 15px 24px;
            border: 1.5px solid transparent;
            border-radius: var(--radius);
            font-size: 16px;
            font-weight: 700;
            font-family: inherit;
            cursor: pointer;
            text-align: center;
            text-decoration: none;
            transition: transform 0.2s, box-shadow 0.2s, opacity 0.2s;
        }
        .btn:active { transform: scale(0.97); }
        .btn:disabled { opacity: 0.4; pointer-events: none; cursor: not-allowed; }

        .btn-primary {
            background: var(--gradient-blue);
            color: #ffffff;
            border-color: transparent;
            box-shadow: 0 6px 20px var(--primary-glow);
            letter-spacing: 0.2px;
        }
        .btn-primary:active { box-shadow: 0 2px 10px var(--primary-glow); transform: scale(0.97); }

        .btn-secondary {
            background: var(--primary-50);
            backdrop-filter: blur(var(--glass-blur));
            -webkit-backdrop-filter: blur(var(--glass-blur));
            color: var(--primary);
            border-color: var(--primary-200);
        }
        .btn-secondary:active { background: var(--primary-100); }

        .btn-danger { background: none; color: var(--tg-destructive); border-color: transparent; }
        .btn-sm { padding: 10px 16px; font-size: 14px; }

        /* === CHIPS === */
        .chips { display: flex; gap: 8px; flex-wrap: wrap; }
        .chip {
            padding: 10px 18px;
            border-radius: 24px;
            background: var(--primary-50);
            color: var(--primary);
            font-size: 14px;
            font-weight: 600;
            border: 1.5px solid var(--primary-200);
            cursor: pointer;
            font-family: inherit;
            transition: all 0.25s;
        }
        .chip:active { transform: scale(0.95); }
        .chip.active {
            background: var(--gradient-blue);
            color: #ffffff;
            border-color: transparent;
            box-shadow: 0 3px 14px var(--primary-glow);
        }

        /* === BALANCE BANNER === */
        .balance-banner {
            background: var(--gradient-blue);
            color: #ffffff;
            border-radius: var(--radius);
            padding: 22px;
            margin-bottom: var(--gap);
            box-shadow: 0 8px 24px var(--primary-glow);
            position: relative;
            overflow: hidden;
        }
        .balance-banner::before {
            content: '';
            position: absolute;
            top: -50%;
            right: -30%;
            width: 200px;
            height: 200px;
            background: radial-gradient(circle, rgba(255,255,255,0.15) 0%, transparent 70%);
            border-radius: 50%;
        }
        .balance-label { font-size: 13px; opacity: 0.8; font-weight: 500; }
        .balance-amount { font-size: 34px; font-weight: 800; margin-top: 4px; letter-spacing: -0.5px; }
        .balance-sub { font-size: 13px; opacity: 0.7; margin-top: 8px; }

        /* === AMOUNT INPUT === */
        .amount-input-wrap {
            display: flex;
            align-items: center;
            background: var(--tg-section-bg);
            border-radius: var(--radius);
            padding: 4px;
            border: 1.5px solid rgba(128,128,128,0.15);
            transition: border-color 0.2s, box-shadow 0.2s;
        }
        .amount-input-wrap:focus-within {
            border-color: var(--tg-btn);
            box-shadow: 0 0 0 3px color-mix(in srgb, var(--tg-btn) 20%, transparent);
        }
        .amount-input-wrap .form-input { text-align: center; font-size: 24px; font-weight: 700; border: none; }
        .amount-input-wrap .form-input:focus { box-shadow: none; }
        .amount-input-wrap .currency-badge {
            padding: 8px 16px;
            font-weight: 700;
            color: var(--tg-hint);
            font-size: 18px;
            background: rgba(128,128,128,0.08);
            border-radius: var(--radius-sm);
        }

        /* === QUICK AMOUNTS === */
        .quick-amounts { display: flex; gap: 8px; margin-top: 8px; }
        .quick-amount {
            flex: 1;
            padding: 11px;
            border-radius: var(--radius-sm);
            background: var(--primary-50);
            border: 1.5px solid var(--primary-200);
            font-size: 14px;
            font-weight: 600;
            color: var(--primary);
            cursor: pointer;
            font-family: inherit;
            text-align: center;
            transition: all 0.2s;
        }
        .quick-amount:active { transform: scale(0.95); background: var(--primary-100); }

        /* === SUMMARY === */
        .summary {
            background: var(--glass-bg);
            backdrop-filter: blur(var(--glass-blur));
            -webkit-backdrop-filter: blur(var(--glass-blur));
            border-radius: var(--radius);
            padding: 16px;
            margin-bottom: var(--gap);
            border: 1px solid var(--glass-border);
            box-shadow: var(--glass-shadow-sm);
        }
        .summary-row { display: flex; justify-content: space-between; padding: 8px 0; }
        .summary-row-label { color: var(--tg-hint); }
        .summary-row-value { font-weight: 600; }
        .summary-row-total { border-top: 0.5px solid rgba(128,128,128,0.15); padding-top: 12px; margin-top: 4px; }
        .summary-row-total .summary-row-value { font-size: 20px; font-weight: 800; color: var(--primary); letter-spacing: -0.3px; }

        /* === STATUS === */
        .status-badge { display: inline-flex; align-items: center; gap: 5px; padding: 5px 12px; border-radius: 20px; font-size: 12px; font-weight: 600; }
        .status-new { background: #fef3c7; color: #92400e; }
        .status-processing { background: #dbeafe; color: #1e40af; }
        .status-success { background: #d1fae5; color: #065f46; }
        .status-failed { background: #fee2e2; color: #991b1b; }

        /* === SKELETON LOADING === */
        .skeleton {
            background: linear-gradient(90deg, var(--tg-secondary-bg) 25%, rgba(128,128,128,0.08) 50%, var(--tg-secondary-bg) 75%);
            background-size: 200% 100%;
            animation: shimmer 1.8s ease-in-out infinite;
            border-radius: var(--radius);
        }
        @keyframes shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

        /* === BOTTOM NAV (Glassmorphism) === */
        .bottom-nav {
            position: fixed;
            bottom: 0; left: 0; right: 0;
            height: var(--bottom-nav-height);
            background: var(--glass-bg-strong);
            border-top: 1px solid var(--glass-border);
            display: flex;
            align-items: center;
            justify-content: space-around;
            padding-bottom: env(safe-area-inset-bottom, 0px);
            z-index: 100;
            backdrop-filter: blur(20px) saturate(1.2);
            -webkit-backdrop-filter: blur(20px) saturate(1.2);
            box-shadow: 0 -4px 24px rgba(31, 38, 135, 0.06);
        }
        .nav-item {
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 4px;
            text-decoration: none;
            color: var(--text-muted);
            font-size: 10px;
            font-weight: 600;
            padding: 6px 12px;
            cursor: pointer;
            border: none;
            background: none;
            font-family: inherit;
            transition: all 0.2s;
            position: relative;
        }
        .nav-item.active { color: var(--primary); }
        .nav-item.active::after {
            content: '';
            position: absolute;
            top: 0;
            left: 50%;
            transform: translateX(-50%);
            width: 20px;
            height: 3px;
            background: var(--primary);
            border-radius: 2px;
        }
        .nav-item .icon-nav { fill: var(--text-muted); transition: fill 0.2s; }
        .nav-item.active .icon-nav { fill: var(--primary); }

        /* === CART BADGE === */
        .cart-badge {
            position: absolute;
            top: 2px;
            right: 4px;
            background: var(--tg-destructive);
            color: #fff;
            font-size: 10px;
            font-weight: 700;
            min-width: 16px;
            height: 16px;
            line-height: 16px;
            border-radius: 8px;
            text-align: center;
            padding: 0 4px;
        }

        /* === PAGE HEADER === */
        .page-header { padding: 20px 16px 14px; }
        .page-title { font-size: 28px; font-weight: 800; display: flex; align-items: center; gap: 10px; letter-spacing: -0.5px; color: var(--text-heading); }
        .page-title .icon { width: 32px; height: 32px; color: var(--primary); }
        .page-subtitle { font-size: 14px; color: var(--text-muted); margin-top: 4px; }

        /* === TOAST === */
        .toast {
            position: fixed; top: 16px; left: 16px; right: 16px;
            padding: 14px 18px; border-radius: var(--radius);
            font-size: 14px; font-weight: 600; z-index: 200;
            transform: translateY(-120%); transition: transform 0.35s cubic-bezier(0.32, 0.72, 0, 1);
            box-shadow: 0 4px 20px rgba(0,0,0,0.15);
        }
        .toast.show { transform: translateY(0); }
        .toast-success { background: #d1fae5; color: #065f46; }
        .toast-error { background: #fee2e2; color: #991b1b; }

        /* === EMPTY STATE === */
        .empty-state { text-align: center; padding: 60px 24px; color: var(--text-muted); }
        .empty-state .icon { width: 56px; height: 56px; margin-bottom: 16px; fill: var(--primary-light); opacity: 0.4; }
        .empty-state-icon { margin-bottom: 4px; }
        .empty-state-text { font-size: 15px; font-weight: 500; }

        /* === SPINNER === */
        .spinner {
            width: 24px; height: 24px;
            border: 3px solid var(--primary-100);
            border-top-color: var(--primary);
            border-radius: 50%;
            animation: spin 0.7s linear infinite;
            margin: 0 auto;
        }
        @keyframes spin { to { transform: rotate(360deg); } }

        .loading-overlay {
            position: fixed; inset: 0;
            background: rgba(0,0,0,0.35);
            backdrop-filter: blur(4px);
            -webkit-backdrop-filter: blur(4px);
            display: flex; align-items: center; justify-content: center;
            z-index: 300;
        }
        .loading-box {
            background: var(--glass-bg-strong);
            backdrop-filter: blur(24px);
            -webkit-backdrop-filter: blur(24px);
            border-radius: 20px;
            padding: 28px 36px;
            text-align: center;
            box-shadow: 0 8px 40px rgba(31, 56, 135, 0.15);
            border: 1px solid var(--glass-border);
        }
        .loading-box .spinner { width: 32px; height: 32px; margin-bottom: 14px; }
        .loading-box p { font-size: 14px; color: var(--text-muted); font-weight: 500; }

        /* === SPA TRANSITION === */
        #app { transition: opacity 0.2s ease; }
        #app.loading { opacity: 0.3; pointer-events: none; }

        /* === UTILITIES === */
        .mt-1 { margin-top: 8px; }
        .mt-2 { margin-top: 16px; }
        .mt-3 { margin-top: 24px; }
        .mb-1 { margin-bottom: 8px; }
        .mb-2 { margin-bottom: 16px; }
        .text-center { text-align: center; }
        .text-hint { color: var(--text-muted); font-size: 13px; }
        .text-link { color: var(--primary); }
        .text-destructive { color: var(--tg-destructive); }
        .hidden { display: none !important; }

        /* === ANIMATIONS === */
        @keyframes fadeInUp {
            from { opacity: 0; transform: translateY(12px); }
            to { opacity: 1; transform: translateY(0); }
        }
        .animate-in { animation: fadeInUp 0.35s ease-out both; }

        /* === LIST ICON STYLING === */
        .list-item-icon {
            display: flex;
            align-items: center;
            justify-content: center;
            width: 40px;
            height: 40px;
            border-radius: 12px;
            background: var(--primary-100);
            margin-right: 12px;
            flex-shrink: 0;
            font-size: 18px;
        }
        .list-item-icon .icon { width: 22px; height: 22px; color: var(--primary); margin-right: 0; }

        /* === MENU ITEM ICON (PlayStation index grid) === */
        .menu-item .menu-item-icon {
            display: flex;
            align-items: center;
            justify-content: center;
            margin: 0 auto 8px;
            width: 46px;
            height: 46px;
            border-radius: 14px;
            background: var(--primary-100);
        }
        .menu-item .menu-item-icon .icon { width: 26px; height: 26px; color: var(--primary); margin-bottom: 0; margin-right: 0; }

        /* === SECTION DIVIDER === */
        .section-title {
            font-size: 14px;
            font-weight: 700;
            text-transform: uppercase;
            color: var(--text-accent);
            letter-spacing: 0.8px;
            padding: 18px 4px 10px;
        }

        /* === INFO NOTICE === */
        .notice {
            display: flex;
            align-items: flex-start;
            gap: 10px;
            padding: 14px;
            border-radius: var(--radius);
            font-size: 13px;
            line-height: 1.5;
            margin-bottom: var(--gap);
        }
        .notice-info {
            background: color-mix(in srgb, var(--tg-link) 8%, transparent);
            color: var(--tg-text);
        }
        .notice-warning {
            background: #fef3c7;
            color: #92400e;
        }
        .notice-icon { font-size: 18px; flex-shrink: 0; }

        /* === CAROUSEL === */
        .carousel {
            position: relative;
            overflow: hidden;
            border-radius: var(--radius);
            margin-bottom: var(--gap);
            box-shadow: var(--glass-shadow);
        }
        .carousel-track {
            display: flex;
            transition: transform 0.5s cubic-bezier(0.32, 0.72, 0, 1);
        }
        .carousel-slide {
            min-width: 100%;
            position: relative;
            aspect-ratio: 16/8;
            overflow: hidden;
        }
        .carousel-slide img {
            width: 100%;
            height: 100%;
            object-fit: cover;
        }
        .carousel-slide-overlay {
            position: absolute;
            bottom: 0;
            left: 0;
            right: 0;
            padding: 16px 20px;
            background: linear-gradient(transparent, rgba(0,0,0,0.6));
            color: #fff;
        }
        .carousel-slide-title { font-size: 18px; font-weight: 700; }
        .carousel-slide-subtitle { font-size: 13px; opacity: 0.85; margin-top: 2px; }
        .carousel-dots {
            display: flex;
            justify-content: center;
            gap: 6px;
            padding: 10px 0;
        }
        .carousel-dot {
            width: 8px;
            height: 8px;
            border-radius: 50%;
            background: var(--tg-hint);
            opacity: 0.3;
            transition: all 0.3s;
            cursor: pointer;
            border: none;
            padding: 0;
        }
        .carousel-dot.active {
            opacity: 1;
            background: var(--primary);
            width: 20px;
            border-radius: 4px;
        }

        /* === HORIZONTAL SCROLL === */
        .scroll-row {
            display: flex;
            overflow-x: auto;
            overflow-y: hidden;
            scroll-snap-type: x proximity;
            -webkit-overflow-scrolling: touch;
            gap: var(--gap);
            padding: 0 0 8px;
            scrollbar-width: none;
            max-width: 100%;
            width: 100%;
            box-sizing: border-box;
        }
        .scroll-row::-webkit-scrollbar { display: none; }
        .scroll-row > * { flex-shrink: 0; scroll-snap-align: start; }
        .container .scroll-row, .donate-section-bg .scroll-row { padding: 0 0 8px; }

        /* === GAME CARD === */
        .game-card {
            scroll-snap-align: start;
            min-width: 170px;
            max-width: 170px;
            background: var(--glass-bg);
            backdrop-filter: blur(var(--glass-blur));
            -webkit-backdrop-filter: blur(var(--glass-blur));
            border-radius: var(--radius);
            border: 1px solid var(--glass-border);
            box-shadow: var(--glass-shadow-sm);
            overflow: hidden;
            cursor: pointer;
            transition: transform 0.2s;
        }
        .game-card:active { transform: scale(0.96); }

        /* Компактный вариант для Новинок / Предзаказов — узкие, влезает ~3 на экран */
        .game-card.game-card-compact {
            min-width: 118px;
            max-width: 118px;
            border-radius: 12px;
        }
        .game-card.game-card-compact .game-card-body { padding: 8px 10px; }
        .game-card.game-card-compact .game-card-title { font-size: 12px; line-height: 1.25; }
        .game-card.game-card-compact .game-card-price { font-size: 13px; margin-top: 4px; }
        .game-card.game-card-compact .game-card-badge { font-size: 10px; padding: 1px 5px; }
        .game-card-image {
            width: 100%;
            aspect-ratio: 3/4;
            object-fit: cover;
            background: var(--tg-secondary-bg);
        }
        .game-card-body { padding: 10px 12px; }
        .game-card-title { font-size: 13px; font-weight: 700; line-height: 1.3; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; color: var(--text-heading); }
        .game-card-price { font-size: 14px; font-weight: 800; color: var(--primary); margin-top: 6px; }
        .game-card-price-old { font-size: 12px; color: var(--text-muted); text-decoration: line-through; margin-left: 4px; font-weight: 400; }
        .game-card-badge { font-size: 11px; color: var(--primary-light); font-weight: 600; background: var(--primary-50); padding: 2px 6px; border-radius: 4px; display: inline-block; margin-top: 2px; }

        /* === GAME CARD GRID (for catalog 2-col) === */
        .game-grid {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: var(--gap);
            padding: 0;
        }
        .game-grid .game-card { min-width: unset; max-width: unset; }

        /* === NEWS CARD === */
        .news-card {
            background: var(--glass-bg);
            backdrop-filter: blur(var(--glass-blur));
            -webkit-backdrop-filter: blur(var(--glass-blur));
            border-radius: var(--radius);
            border: 1px solid var(--glass-border);
            box-shadow: var(--glass-shadow-sm);
            overflow: hidden;
            cursor: pointer;
            transition: transform 0.2s;
            margin-bottom: var(--gap);
        }
        .news-card:active { transform: scale(0.98); }
        .news-card-image {
            width: 100%;
            aspect-ratio: 16/9;
            object-fit: cover;
            background: var(--tg-secondary-bg);
        }
        .news-card-body { padding: 12px 14px; }
        .news-card-title { font-size: 15px; font-weight: 700; line-height: 1.3; color: var(--text-heading); }
        .news-card-date { font-size: 12px; color: var(--text-muted); margin-top: 4px; }

        /* === VOUCHER GRID (2-col for Turkey/India) === */
        .voucher-grid {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 10px;
        }
        .voucher-grid-3 {
            display: grid;
            grid-template-columns: 1fr 1fr 1fr;
            gap: 8px;
        }
        .voucher-grid-3 .voucher-card { aspect-ratio: 2/3; }
        .voucher-grid-3 .voucher-card-nominal { font-size: 12px; }
        .voucher-grid-3 .voucher-card-price { font-size: 10px; }

        /* Region selector */
        .region-selector {
            display: flex;
            gap: 4px;
            align-items: center;
        }
        .region-flag {
            min-width: 40px;
            height: 32px;
            padding: 0 6px;
            border-radius: 8px;
            display: flex;
            align-items: center;
            justify-content: center;
            cursor: pointer;
            border: 2px solid transparent;
            background: var(--glass-bg);
            backdrop-filter: blur(var(--glass-blur));
            -webkit-backdrop-filter: blur(var(--glass-blur));
            box-shadow: var(--glass-shadow-sm);
            transition: all 0.25s;
            overflow: hidden;
        }
        .region-flag svg { display: block; border-radius: 3px; }
        .region-flag:active { transform: scale(0.9); }
        .region-flag.active {
            border-color: var(--primary);
            background: var(--primary-100);
            box-shadow: 0 0 0 3px var(--primary-glow);
            box-shadow: 0 0 0 2px var(--primary-glow);
        }

        /* PS Plus dark card */
        .ps-plus-card {
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 14px 16px;
            background: var(--glass-bg);
            backdrop-filter: blur(var(--glass-blur));
            -webkit-backdrop-filter: blur(var(--glass-blur));
            border: 1px solid var(--glass-border);
            border-radius: var(--radius-sm);
            box-shadow: var(--glass-shadow-sm);
            cursor: pointer;
            transition: all 0.2s;
            margin-bottom: 8px;
        }
        .ps-plus-card:active { transform: scale(0.98); box-shadow: var(--glass-shadow); }

        /* === PS PLUS SQUARE CARD (grid 2x2) === */
        .ps-plus-square {
            position: relative;
            border-radius: var(--radius);
            padding: 18px 16px;
            aspect-ratio: 1;
            display: flex;
            flex-direction: column;
            justify-content: space-between;
            cursor: pointer;
            overflow: hidden;
            box-shadow: 0 6px 20px rgba(31, 56, 135, 0.15);
            transition: all 0.25s cubic-bezier(0.34, 1.56, 0.64, 1);
            color: #fff;
        }
        .ps-plus-square:active { transform: scale(0.95); }
        .ps-plus-square-badge {
            font-size: 10px;
            font-weight: 800;
            letter-spacing: 1px;
            background: rgba(255,255,255,0.2);
            padding: 3px 8px;
            border-radius: 6px;
            backdrop-filter: blur(4px);
            -webkit-backdrop-filter: blur(4px);
            align-self: flex-start;
            z-index: 2;
            position: relative;
        }
        .ps-plus-square-emoji {
            font-size: 38px;
            line-height: 1;
            text-align: center;
            flex: 1;
            display: flex;
            align-items: center;
            justify-content: center;
            z-index: 2;
            position: relative;
            filter: drop-shadow(0 2px 8px rgba(0,0,0,0.3));
        }
        .ps-plus-square-name {
            font-size: 18px;
            font-weight: 800;
            letter-spacing: -0.3px;
            z-index: 2;
            position: relative;
        }
        .ps-plus-square-cta {
            font-size: 11px;
            font-weight: 600;
            opacity: 0.8;
            margin-top: 3px;
            z-index: 2;
            position: relative;
        }
        .ps-plus-square-deco {
            position: absolute;
            top: -30px;
            right: -30px;
            width: 100px;
            height: 100px;
            background: rgba(255,255,255,0.1);
            border-radius: 50%;
            pointer-events: none;
        }
        .ps-plus-square-deco::after {
            content: '';
            position: absolute;
            top: 110px;
            left: -80px;
            width: 70px;
            height: 70px;
            background: rgba(255,255,255,0.06);
            border-radius: 50%;
        }

        /* === CREATIVE EFFECTS === */

        /* Shimmer (glossy) overlay on cards */
        .shimmer-overlay {
            position: relative;
            overflow: hidden;
        }
        .shimmer-overlay::after {
            content: '';
            position: absolute;
            top: -50%;
            left: -100%;
            width: 50%;
            height: 200%;
            background: linear-gradient(90deg, transparent, rgba(255,255,255,0.15), transparent);
            transform: skewX(-25deg);
            pointer-events: none;
            animation: shimmerMove 3s infinite;
        }
        @keyframes shimmerMove {
            0%, 60% { left: -100%; }
            100% { left: 200%; }
        }

        /* Floating animation */
        @keyframes float {
            0%, 100% { transform: translateY(0); }
            50% { transform: translateY(-4px); }
        }
        .float { animation: float 3s ease-in-out infinite; }

        /* Glow pulse */
        @keyframes glowPulse {
            0%, 100% { box-shadow: 0 4px 14px rgba(37,99,235,0.2); }
            50% { box-shadow: 0 6px 24px rgba(37,99,235,0.4); }
        }
        .glow { animation: glowPulse 2.5s ease-in-out infinite; }

        /* Section title with accent line */
        .section-title-fancy {
            display: flex;
            align-items: center;
            gap: 10px;
            font-size: 14px;
            font-weight: 800;
            color: var(--text-heading);
            padding: 18px 4px 10px;
            letter-spacing: -0.2px;
        }
        .section-title-fancy::before {
            content: '';
            width: 4px;
            height: 18px;
            background: linear-gradient(180deg, var(--primary), #7c3aed);
            border-radius: 2px;
            flex-shrink: 0;
        }
        .section-title-fancy-badge {
            background: var(--primary-100);
            color: var(--primary);
            font-size: 11px;
            font-weight: 700;
            padding: 2px 8px;
            border-radius: 6px;
            margin-left: auto;
        }

        /* Hover-lift on desktop */
        @media (hover: hover) {
            .voucher-card:hover,
            .game-card:hover,
            .ps-plus-card:hover,
            .news-card:hover,
            .service-btn:hover,
            .cart-card:hover {
                transform: translateY(-2px);
                box-shadow: 0 8px 24px rgba(31, 56, 135, 0.15);
            }
            .region-flag:hover { transform: translateY(-1px); }

            .carousel-monolith-viewport {
                scroll-snap-type: none;
                scroll-behavior: auto;
            }

            .carousel-monolith .carousel-slide {
                scroll-snap-align: none;
            }
        }

        /* Service btn subtle hover tilt */
        .service-btn { transition: all 0.25s cubic-bezier(0.34, 1.56, 0.64, 1); }

        /* Gradient text */
        .gradient-text {
            background: linear-gradient(135deg, var(--primary), #7c3aed);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
        }

        /* Skeleton pulse better */
        .skeleton {
            animation: skeletonPulse 1.4s ease-in-out infinite;
        }
        @keyframes skeletonPulse {
            0%, 100% { opacity: 1; }
            50% { opacity: 0.5; }
        }

        /* Sparkle (for featured items) */
        .sparkle::before {
            content: '✦';
            position: absolute;
            top: 6px;
            right: 8px;
            color: #fbbf24;
            font-size: 14px;
            animation: sparkleRotate 4s linear infinite;
            z-index: 3;
            text-shadow: 0 0 8px rgba(251,191,36,0.6);
        }
        @keyframes sparkleRotate {
            0%, 100% { transform: rotate(0) scale(1); opacity: 1; }
            50% { transform: rotate(180deg) scale(1.2); opacity: 0.7; }
        }
        .ps-plus-card-icon {
            width: 44px;
            height: 44px;
            border-radius: 12px;
            display: flex;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
            color: #fff;
            font-size: 11px;
            font-weight: 800;
            line-height: 1.1;
            text-align: center;
        }
        .ps-plus-card-body { flex: 1; }
        .ps-plus-card-price { font-size: 18px; font-weight: 800; color: var(--text-heading); }
        .ps-plus-card-name { font-size: 13px; color: var(--text-muted); margin-top: 2px; }

        /* Donate section background */
        .donate-section-bg {
            background: var(--glass-bg);
            backdrop-filter: blur(var(--glass-blur));
            -webkit-backdrop-filter: blur(var(--glass-blur));
            border: 1px solid var(--glass-border);
            border-radius: var(--radius);
            padding: 16px;
            margin-top: 8px;
            box-shadow: var(--glass-shadow-sm);
        }
        .voucher-card {
            position: relative;
            border-radius: var(--radius-sm);
            border: none;
            padding: 0;
            cursor: pointer;
            transition: all 0.25s;
            overflow: hidden;
            aspect-ratio: 3/4;
        }
        .voucher-card:active { transform: scale(0.96); }
        .voucher-card-overlay {
            position: absolute;
            bottom: 0;
            left: 0;
            right: 0;
            padding: 12px;
            background: linear-gradient(transparent 0%, rgba(0,0,0,0.6) 100%);
            text-align: left;
        }
        .voucher-card-nominal { font-size: 17px; font-weight: 800; color: #fff; }
        .voucher-card-price { font-size: 13px; color: rgba(255,255,255,0.85); margin-top: 2px; font-weight: 600; }

        /* === GAME DETAIL === */
        .game-detail-cover {
            width: 100%;
            aspect-ratio: 16/9;
            object-fit: cover;
            border-radius: var(--radius);
            box-shadow: var(--glass-shadow);
        }
        .game-detail-header { padding: 16px 0 8px; }
        .game-detail-title { font-size: 22px; font-weight: 800; letter-spacing: -0.3px; }
        .game-detail-meta { display: flex; gap: 12px; align-items: center; margin-top: 6px; color: var(--tg-hint); font-size: 13px; }
        .game-detail-rating { display: flex; align-items: center; gap: 4px; color: #f59e0b; font-weight: 600; }
        .game-detail-price-row { display: flex; align-items: center; gap: 10px; margin: 12px 0; }
        .game-detail-price { font-size: 24px; font-weight: 800; color: var(--primary); }
        .game-detail-price-old { font-size: 16px; color: var(--tg-hint); text-decoration: line-through; }
        .game-detail-info { margin: 8px 0; }
        .game-detail-info-row { display: flex; justify-content: space-between; padding: 10px 0; border-bottom: 0.5px solid var(--glass-border-subtle); font-size: 14px; }
        .game-detail-info-label { color: var(--tg-hint); }
        .game-detail-info-value { font-weight: 600; }

        /* === SCREENSHOTS GALLERY === */
        .screenshots-row {
            display: flex;
            overflow-x: auto;
            overflow-y: hidden;
            gap: 8px;
            scrollbar-width: none;
            -webkit-overflow-scrolling: touch;
            touch-action: pan-x;
            scroll-snap-type: x proximity;
            padding-bottom: 4px;
        }
        .screenshots-row::-webkit-scrollbar { display: none; }
        .screenshot-thumb {
            flex: 0 0 auto;
            width: 220px;
            height: 124px;
            border-radius: var(--radius-sm);
            object-fit: cover;
            cursor: pointer;
            scroll-snap-align: start;
        }

        /* === CATALOG TABS === */
        .catalog-tabs {
            display: flex;
            gap: 8px;
            overflow-x: auto;
            padding: 0 16px 12px;
            scrollbar-width: none;
        }
        .catalog-tabs::-webkit-scrollbar { display: none; }
        .catalog-tab {
            padding: 9px 18px;
            border-radius: 22px;
            background: var(--primary-50);
            color: var(--primary);
            font-size: 14px;
            font-weight: 600;
            border: 1.5px solid var(--primary-200);
            cursor: pointer;
            white-space: nowrap;
            transition: all 0.2s;
        }
        .catalog-tab.active {
            background: var(--gradient-blue);
            color: #fff;
            border-color: transparent;
            box-shadow: 0 3px 14px var(--primary-glow);
        }

        /* === SERVICE GRID (квадратные кнопки каталога) === */
        .service-grid {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 10px;
            padding: 0 16px 14px;
        }
        .service-btn {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: 6px;
            padding: 10px 4px;
            border-radius: var(--radius-sm);
            background: var(--glass-bg);
            backdrop-filter: blur(var(--glass-blur));
            -webkit-backdrop-filter: blur(var(--glass-blur));
            border: 1px solid var(--glass-border);
            box-shadow: var(--glass-shadow-sm);
            color: #fff;
            cursor: pointer;
            transition: all 0.25s;
            font-family: inherit;
            font-size: 11px;
            overflow: hidden;
            font-weight: 700;
            text-align: center;
            position: relative;
        }
        .service-btn .svc-icon {
            width: 48px;
            height: 48px;
            border-radius: 12px;
            display: flex;
            align-items: center;
            justify-content: center;
            margin-bottom: 2px;
        }
        .service-btn .svc-icon svg { width: 26px; height: 26px; fill: #fff; }
        .service-btn .svc-label { color: var(--text-heading); font-size: 11px; font-weight: 700; }
        .service-btn:active { transform: scale(0.93); box-shadow: var(--glass-shadow); }
        .service-btn.active {
            background: var(--gradient-blue);
            color: #fff;
            border-color: transparent;
            box-shadow: 0 3px 14px var(--primary-glow);
        }
        .service-btn.active svg { fill: #fff; }

        /* === VOUCHER CARD IMAGE (full background) === */
        .voucher-card-img {
            position: absolute;
            inset: 0;
            width: 100%;
            height: 100%;
            object-fit: cover;
            display: block;
        }

        /* === ANIMATIONS === */
        @keyframes fadeUp {
            from { opacity: 0; transform: translateY(18px); }
            to { opacity: 1; transform: translateY(0); }
        }
        @keyframes scaleIn {
            from { opacity: 0; transform: scale(0.92); }
            to { opacity: 1; transform: scale(1); }
        }
        @keyframes slideRight {
            from { opacity: 0; transform: translateX(-16px); }
            to { opacity: 1; transform: translateX(0); }
        }
        @keyframes pulseGlow {
            0%, 100% { box-shadow: 0 0 0 0 var(--primary-glow); }
            50% { box-shadow: 0 0 0 8px transparent; }
        }

        .anim-fade-up { animation: fadeUp 0.45s ease-out both; }
        .anim-scale-in { animation: scaleIn 0.35s ease-out both; }
        .anim-slide-right { animation: slideRight 0.4s ease-out both; }
        .anim-pulse { animation: pulseGlow 2s ease-in-out infinite; }

        .stagger-1 { animation-delay: 0.05s; }
        .stagger-2 { animation-delay: 0.1s; }
        .stagger-3 { animation-delay: 0.15s; }
        .stagger-4 { animation-delay: 0.2s; }
        .stagger-5 { animation-delay: 0.25s; }
        .stagger-6 { animation-delay: 0.3s; }

        /* === GLASS NOTICE (for Steam SBP warning) === */
        .glass-notice {
            display: flex;
            align-items: center;
            gap: 10px;
            padding: 14px 16px;
            background: var(--glass-bg);
            backdrop-filter: blur(var(--glass-blur));
            -webkit-backdrop-filter: blur(var(--glass-blur));
            border: 1px solid var(--glass-border);
            border-radius: var(--radius-sm);
            font-size: 13px;
            color: var(--text-body);
            line-height: 1.5;
            margin-bottom: var(--gap);
        }

        /* === SMOOTH CAROUSEL (no dots, monolith) === */
        /* === HORIZONTAL SCROLL CAROUSEL с подглядыванием соседей по краям === */
        .carousel-monolith {
            position: relative;
            margin: 0 auto 12px;
            max-width: 360px;            /* шире — чтобы влезли соседи */
            user-select: none;
            -webkit-user-select: none;
        }
        .carousel-monolith-viewport {
            overflow-x: auto;
            overflow-y: hidden;
            scroll-snap-type: x proximity;
            scroll-behavior: smooth;        /* плавный программный scrollTo */
            -webkit-overflow-scrolling: touch;
            scrollbar-width: none;
            cursor: grab;
            padding: 8px 0;
            scroll-padding: 0 18%;         /* помогает snap правильно центровать */
        }
        .carousel-monolith-viewport::-webkit-scrollbar { display: none; }
        .carousel-monolith.dragging .carousel-monolith-viewport {
            cursor: grabbing;
            scroll-snap-type: none;        /* во время драга snap отключён → нет дрожи */
            scroll-behavior: auto;
        }
        .carousel-monolith .carousel-track {
            display: flex;
            gap: 10px;
            padding: 0 18%;
        }
        .carousel-monolith .carousel-slide {
            flex: 0 0 64%;
            width: 64%;
            scroll-snap-align: center;
            aspect-ratio: 3/4;
            overflow: hidden;
            position: relative;
            cursor: pointer;
            display: block;
            border-radius: 16px;
            box-shadow: var(--glass-shadow);
            transition: transform 0.3s cubic-bezier(0.25, 0.8, 0.25, 1), opacity 0.3s ease;
        }
        /* Соседние слайды чуть меньше и приглушены */
        .carousel-monolith .carousel-slide:not(.is-active) {
            transform: scale(0.92);
            opacity: 0.7;
        }
        /* Глянцевая накладка для глубины */
        .carousel-monolith .carousel-slide::after {
            content: '';
            position: absolute;
            inset: 0;
            background: linear-gradient(180deg, rgba(255,255,255,0.06) 0%, transparent 35%, transparent 65%, rgba(0,0,0,0.12) 100%);
            pointer-events: none;
            border-radius: inherit;
        }

        /* Dots-индикатор */
        .carousel-dots {
            display: flex;
            justify-content: center;
            gap: 6px;
            margin-top: -10px;
            margin-bottom: 4px;
        }
        .carousel-dot {
            width: 6px;
            height: 6px;
            border-radius: 50%;
            background: var(--glass-border);
            transition: all 0.25s ease;
            cursor: pointer;
            border: none;
            padding: 0;
        }
        .carousel-dot.is-active {
            width: 22px;
            border-radius: 4px;
            background: var(--primary);
            box-shadow: 0 2px 6px var(--primary-glow);
        }
        .carousel-progress {
            position: absolute;
            bottom: 0;
            left: 0;
            height: 3px;
            background: rgba(255,255,255,0.6);
            border-radius: 2px;
            transition: width 0.3s linear;
        }
