        * { margin: 0; padding: 0; box-sizing: border-box; }
        html { overflow-y: auto; overflow-x: hidden; overflow-x: clip; width: 100%; max-width: 100%; }

        :root {
            --bg: #030305;
            --bg-card: #0a0a10;
            --bg-elevated: #101018;
            --bg-hover: #15151f;
            --border: rgba(212, 175, 55, 0.12);
            --border-bright: rgba(212, 175, 55, 0.35);
            --text: #ffffff;
            --text-dim: #5a5a6a;
            --text-muted: #8a8a9a;
            --gold: #d4af37;
            --gold-light: #f0d060;
            --gold-dark: #a08020;
            --cyan: #00d4ff;
            --cyan-glow: rgba(0, 212, 255, 0.4);
            --pink: #ff6b9d;
            --red: #ef4444;
            --green: #22c55e;
            --blue: #3b82f6;
            --purple: #a855f7;
        }

        body {
            font-family: 'Exo 2', sans-serif;
            background: var(--bg);
            color: var(--text);
            min-height: 100vh;
            overflow-x: hidden;
            overflow-x: clip;
            width: 100%;
            max-width: 100%;
        }

        /* ========== CYBER NEON BACKGROUND ========== */

        /* Pulsing Cyber Grid */
        .cyber-grid {
            position: fixed;
            top: 0; left: 0; right: 0; bottom: 0;
            background-image:
                linear-gradient(rgba(0, 212, 255, 0.03) 1px, transparent 1px),
                linear-gradient(90deg, rgba(0, 212, 255, 0.03) 1px, transparent 1px);
            background-size: 50px 50px;
            z-index: 0;
            pointer-events: none;
            animation: gridPulse 4s ease-in-out infinite;
        }
        @keyframes gridPulse {
            0%, 100% { opacity: 0.4; }
            50% { opacity: 0.8; }
        }

        .bg-effects {
            position: fixed;
            top: 0; left: 0; right: 0; bottom: 0;
            pointer-events: none;
            z-index: 0;
            overflow: hidden;
            contain: strict;
        }

        /* Colorful Mesh Orbs - Cyan, Purple, Pink, Gold */
        .bg-orb {
            position: absolute;
            border-radius: 50%;
            filter: blur(120px);
            opacity: 0.25;
            animation: orbFloat 20s ease-in-out infinite;
            will-change: transform;
            transform: translateZ(0);
        }
        .bg-orb-1 {
            width: 700px; height: 700px;
            background: #00d4ff; /* Cyan */
            top: -300px; left: -200px;
            animation-delay: 0s;
        }
        .bg-orb-2 {
            width: 600px; height: 600px;
            background: #a855f7; /* Purple */
            top: 30%; right: -200px;
            animation-delay: -5s;
        }
        .bg-orb-3 {
            width: 500px; height: 500px;
            background: #ff6b9d; /* Pink */
            bottom: -200px; left: 20%;
            animation-delay: -10s;
        }
        .bg-orb-4 {
            width: 450px; height: 450px;
            background: var(--gold); /* Gold */
            top: 50%; left: -150px;
            animation-delay: -15s;
        }
        @keyframes orbFloat {
            0%, 100% { transform: translate(0, 0) scale(1) rotate(0deg); }
            25% { transform: translate(60px, -60px) scale(1.1) rotate(90deg); }
            50% { transform: translate(-40px, 40px) scale(0.9) rotate(180deg); }
            75% { transform: translate(30px, -30px) scale(1.05) rotate(270deg); }
        }

        /* Floating Particles - Multi-colored */
        .particles-container {
            position: fixed;
            inset: 0;
            pointer-events: none;
            z-index: 1;
            overflow: hidden;
        }
        @media (max-width: 768px) {
            .cyber-grid { animation: none !important; }
            .bg-effects .orb { animation: none !important; }
        }
        .particle {
            position: absolute;
            width: 4px;
            height: 4px;
            border-radius: 50%;
            opacity: 0;
            animation: particleFloat 15s linear infinite;
        }
        .particle:nth-child(1) { left: 10%; background: #00d4ff; animation-delay: 0s; }
        .particle:nth-child(2) { left: 20%; background: var(--gold); animation-delay: 2s; }
        .particle:nth-child(3) { left: 30%; background: #a855f7; animation-delay: 4s; }
        .particle:nth-child(4) { left: 40%; background: #ff6b9d; animation-delay: 6s; }
        .particle:nth-child(5) { left: 50%; background: #00d4ff; animation-delay: 8s; }
        .particle:nth-child(6) { left: 60%; background: var(--gold); animation-delay: 10s; }
        .particle:nth-child(7) { left: 70%; background: #a855f7; animation-delay: 1s; }
        .particle:nth-child(8) { left: 80%; background: #ff6b9d; animation-delay: 3s; }
        .particle:nth-child(9) { left: 90%; background: #00d4ff; animation-delay: 5s; }
        .particle:nth-child(10) { left: 95%; background: var(--gold); animation-delay: 7s; }
        @keyframes particleFloat {
            0% { transform: translateY(100vh) scale(0); opacity: 0; }
            10% { opacity: 0.7; }
            90% { opacity: 0.7; }
            100% { transform: translateY(-100px) scale(1); opacity: 0; }
        }

        /* ========== ADVANCED CARD EFFECTS ========== */
        /* 3D Tilt Effect */
        .tilt-card {
            transform-style: preserve-3d;
            transition: transform 0.3s ease;
        }
        .tilt-card:hover {
            transform: perspective(1000px) rotateX(var(--rotateX, 0deg)) rotateY(var(--rotateY, 0deg)) scale(1.02);
        }

        /* Game Card Glow Effect */
        .game-card {
            transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
            position: relative;
        }
        .game-card::before {
            content: '';
            position: absolute;
            inset: -2px;
            border-radius: 18px;
            background: linear-gradient(135deg, var(--gold), #8b5cf6, var(--gold));
            opacity: 0;
            z-index: -1;
            transition: opacity 0.4s;
            filter: blur(8px);
        }
        .game-card:hover {
            transform: translateY(-4px) scale(1.02) !important;
            border-color: var(--gold) !important;
            opacity: 1 !important;
        }
        .game-card:hover::before {
            opacity: 0.5;
        }
        .game-card.active::before {
            opacity: 0.7;
            animation: glowPulse 2s ease-in-out infinite;
        }
        @keyframes glowPulse {
            0%, 100% { opacity: 0.5; filter: blur(8px); }
            50% { opacity: 0.8; filter: blur(12px); }
        }

        /* Type Chip Animations */
        .type-chip {
            transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
            position: relative;
            overflow: hidden;
        }
        .type-chip::after {
            content: '';
            position: absolute;
            inset: 0;
            background: linear-gradient(135deg, rgba(255,255,255,0.2), transparent);
            opacity: 0;
            transition: opacity 0.3s;
        }
        .type-chip:hover {
            transform: translateY(-2px) scale(1.05);
            box-shadow: 0 4px 15px rgba(0,0,0,0.3);
            opacity: 1 !important;
        }
        .type-chip:hover::after {
            opacity: 1;
        }
        .type-chip.active {
            animation: chipPulse 2s ease-in-out infinite;
        }
        @keyframes chipPulse {
            0%, 100% { box-shadow: 0 0 0 0 rgba(212, 175, 55, 0.4); }
            50% { box-shadow: 0 0 0 8px rgba(212, 175, 55, 0); }
        }

        /* Pokemon Card Advanced Effects */
        .poke-card {
            transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
        }
        @media (min-width: 769px) {
            .poke-card { transform-style: preserve-3d; }
        }
        .poke-card::after {
            content: '';
            position: absolute;
            inset: 0;
            border-radius: 20px;
            background: linear-gradient(135deg, rgba(212, 175, 55, 0.1), transparent);
            opacity: 0;
            transition: opacity 0.3s;
            pointer-events: none;
        }
        .poke-card:hover::after {
            opacity: 1;
        }
        .poke-card:hover {
            transform: translateY(-8px) scale(1.03) !important;
            box-shadow: 0 20px 40px rgba(0, 0, 0, 0.4), 0 0 30px rgba(212, 175, 55, 0.15) !important;
        }
        .poke-card:hover .poke-img {
            transform: scale(1.15) translateY(-5px);
            filter: drop-shadow(0 10px 20px rgba(0,0,0,0.3));
        }

        /* Type Glow on Cards */
        .poke-card[data-type="fire"]:hover { box-shadow: 0 20px 40px rgba(0,0,0,0.4), 0 0 30px rgba(240, 128, 48, 0.3) !important; }
        .poke-card[data-type="water"]:hover { box-shadow: 0 20px 40px rgba(0,0,0,0.4), 0 0 30px rgba(104, 144, 240, 0.3) !important; }
        .poke-card[data-type="grass"]:hover { box-shadow: 0 20px 40px rgba(0,0,0,0.4), 0 0 30px rgba(120, 200, 80, 0.3) !important; }
        .poke-card[data-type="electric"]:hover { box-shadow: 0 20px 40px rgba(0,0,0,0.4), 0 0 30px rgba(248, 208, 48, 0.3) !important; }
        .poke-card[data-type="psychic"]:hover { box-shadow: 0 20px 40px rgba(0,0,0,0.4), 0 0 30px rgba(248, 88, 136, 0.3) !important; }
        .poke-card[data-type="dragon"]:hover { box-shadow: 0 20px 40px rgba(0,0,0,0.4), 0 0 30px rgba(112, 56, 248, 0.3) !important; }
        .poke-card[data-type="dark"]:hover { box-shadow: 0 20px 40px rgba(0,0,0,0.4), 0 0 30px rgba(112, 88, 72, 0.3) !important; }
        .poke-card[data-type="fairy"]:hover { box-shadow: 0 20px 40px rgba(0,0,0,0.4), 0 0 30px rgba(238, 153, 172, 0.3) !important; }
        .poke-card[data-type="ghost"]:hover { box-shadow: 0 20px 40px rgba(0,0,0,0.4), 0 0 30px rgba(112, 88, 152, 0.3) !important; }
        .poke-card[data-type="fighting"]:hover { box-shadow: 0 20px 40px rgba(0,0,0,0.4), 0 0 30px rgba(192, 48, 40, 0.3) !important; }
        .poke-card[data-type="steel"]:hover { box-shadow: 0 20px 40px rgba(0,0,0,0.4), 0 0 30px rgba(184, 184, 208, 0.3) !important; }
        .poke-card[data-type="ice"]:hover { box-shadow: 0 20px 40px rgba(0,0,0,0.4), 0 0 30px rgba(152, 216, 216, 0.3) !important; }

        /* Shiny Card Sparkle Effect */
        .poke-card.shiny-card {
            position: relative;
        }
        .poke-card.shiny-card::before {
            content: '';
            position: absolute;
            top: 10px; right: 10px;
            width: 20px;
            height: 20px;
            background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23fbbf24'%3E%3Cpath d='M12 2L15.09 8.26L22 9.27L17 14.14L18.18 21.02L12 17.77L5.82 21.02L7 14.14L2 9.27L8.91 8.26L12 2Z'/%3E%3C/svg%3E") center/contain no-repeat;
            animation: shinyStar 1.5s ease-in-out infinite;
            z-index: 10;
        }
        @keyframes shinyStar {
            0%, 100% { transform: scale(1) rotate(0deg); opacity: 1; }
            50% { transform: scale(1.2) rotate(15deg); opacity: 0.8; }
        }

        /* Glass Morphism Enhancement */
        .glass-card {
            background: rgba(10, 10, 16, 0.7) !important;
            backdrop-filter: blur(20px) saturate(180%);
            -webkit-backdrop-filter: blur(20px) saturate(180%);
            border: 1px solid rgba(212, 175, 55, 0.15) !important;
        }

        /* Premium Toggle Switch Animation */
        .premium-toggle {
            transition: all 0.3s ease !important;
        }
        .premium-toggle:hover {
            transform: translateY(-2px);
            box-shadow: 0 8px 25px rgba(0,0,0,0.3);
            border-color: var(--gold) !important;
        }
        .premium-toggle.active {
            border-color: var(--gold) !important;
            background: rgba(212, 175, 55, 0.1) !important;
        }

        /* Keyboard Shortcut Hints */
        .kbd-hint {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            min-width: 20px;
            height: 20px;
            padding: 0 6px;
            background: rgba(255,255,255,0.1);
            border: 1px solid rgba(255,255,255,0.2);
            border-radius: 4px;
            font-size: 10px;
            font-family: 'JetBrains Mono', monospace;
            color: var(--text-dim);
            margin-left: 8px;
        }

        /* Skeleton Loading */
        .skeleton {
            background: linear-gradient(90deg, var(--bg-card) 25%, var(--bg-elevated) 50%, var(--bg-card) 75%);
            background-size: 200% 100%;
            animation: skeleton 1.5s ease-in-out infinite;
            border-radius: 12px;
        }
        @keyframes skeleton {
            0% { background-position: 200% 0; }
            100% { background-position: -200% 0; }
        }

        /* Sound Toggle Active State */
        .sound-active {
            color: var(--gold) !important;
        }
        .sound-active svg {
            animation: soundPulse 1s ease-in-out infinite;
        }
        @keyframes soundPulse {
            0%, 100% { transform: scale(1); }
            50% { transform: scale(1.1); }
        }

        /* Header - HIDDEN (using new nav instead) */
        .header {
            display: none;
        }
        .logo {
            font-family: 'Rajdhani', sans-serif;
            font-size: 22px;
            font-weight: 700;
            color: var(--gold);
            text-decoration: none;
            letter-spacing: 2px;
        }
        .search-box {
            flex: 1;
            max-width: 400px;
            position: relative;
        }
        .search-box input {
            width: 100%;
            padding: 10px 16px 10px 42px;
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 10px;
            color: var(--text);
            font-size: 14px;
            outline: none;
            transition: all 0.2s;
        }
        .search-box input:focus {
            border-color: var(--gold);
            box-shadow: 0 0 20px rgba(212, 175, 55, 0.1);
        }
        .search-box input::placeholder { color: var(--text-dim); }
        .search-box svg {
            position: absolute;
            left: 14px;
            top: 50%;
            transform: translateY(-50%);
            color: var(--text-dim);
            width: 16px;
            height: 16px;
        }
        .header-actions {
            display: flex;
            align-items: center;
            gap: 10px;
            margin-left: auto;
        }
        .header-btn {
            padding: 8px 14px;
            background: transparent;
            border: 1px solid var(--border);
            border-radius: 8px;
            color: var(--text-muted);
            font-size: 12px;
            font-weight: 600;
            cursor: pointer;
            display: flex;
            align-items: center;
            gap: 6px;
            transition: all 0.2s;
            white-space: nowrap;
        }
        .header-btn:hover {
            border-color: var(--gold);
            color: var(--gold);
        }
        .header-btn.active {
            background: var(--gold);
            border-color: var(--gold);
            color: #000;
        }
        .header-btn.random-btn {
            background: linear-gradient(135deg, var(--purple), #6366f1);
            border: none;
            color: #fff;
        }
        .header-btn.random-btn:hover {
            box-shadow: 0 0 20px rgba(139, 92, 246, 0.4);
        }
        .header-btn.history-btn {
            background: linear-gradient(135deg, #059669, #10b981);
            border: none;
            color: #fff;
        }
        .team-count {
            background: var(--red);
            color: #fff;
            font-size: 10px;
            padding: 2px 6px;
            border-radius: 10px;
            font-weight: 700;
        }

        /* Main Layout */
        .main-layout {
            display: flex;
            padding-top: 80px;
            min-height: 100vh;
            position: relative;
            z-index: 1;
            max-width: 100%;
            overflow-x: hidden;
        }

        /* Sidebar - Hidden for new layout */
        .sidebar {
            display: none;
        }
        .sidebar.collapsed { display: none; }
        .filter-section { margin-bottom: 20px; }
        .filter-title {
            font-size: 11px;
            font-weight: 700;
            color: var(--text-dim);
            text-transform: uppercase;
            letter-spacing: 1px;
            margin-bottom: 10px;
            display: flex;
            align-items: center;
            justify-content: space-between;
        }
        .filter-title button {
            background: none;
            border: none;
            color: var(--gold);
            font-size: 10px;
            cursor: pointer;
        }

        /* Mode Toggle Bars */
        .mode-bar {
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 12px 16px;
            background: #1e2a35;
            border: 1px solid #2a3845;
            border-radius: 10px;
            margin-bottom: 12px;
        }
        .mode-bar .mode-icon {
            width: 32px;
            height: 32px;
            flex-shrink: 0;
            display: flex;
            align-items: center;
            justify-content: center;
        }
        .mode-bar .mode-icon img { width: 100%; height: 100%; object-fit: contain; }
        .mode-bar .mode-toggle {
            width: 46px;
            height: 24px;
            background: #2a3845;
            border: none;
            border-radius: 12px;
            cursor: pointer;
            position: relative;
            transition: all 0.25s ease;
        }
        .mode-bar .mode-toggle::after {
            content: '';
            position: absolute;
            width: 20px;
            height: 20px;
            background: #4a5a6a;
            border-radius: 50%;
            top: 2px;
            left: 2px;
            transition: all 0.25s ease;
        }
        .mode-bar.active .mode-toggle { background: #4a8a58; }
        .mode-bar.active .mode-toggle::after { background: #fff; left: 24px; }
        .mode-bar.shiny-bar.active .mode-toggle { background: linear-gradient(135deg, #fbbf24, #f59e0b); }
        .mode-bar .mode-label {
            font-size: 12px;
            font-weight: 600;
            letter-spacing: 1px;
            color: #6a7a8a;
            text-transform: uppercase;
        }
        .mode-bar.active .mode-label { color: #7cb788; }
        .mode-bar.shiny-bar.active .mode-label { color: #fbbf24; }

        /* Shiny Star Icon */
        .shiny-star {
            width: 32px;
            height: 32px;
            background: linear-gradient(135deg, #fbbf24, #f59e0b);
            -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='currentColor'%3E%3Cpath d='M12 2L15.09 8.26L22 9.27L17 14.14L18.18 21.02L12 17.77L5.82 21.02L7 14.14L2 9.27L8.91 8.26L12 2Z'/%3E%3C/svg%3E") center/contain no-repeat;
            mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='currentColor'%3E%3Cpath d='M12 2L15.09 8.26L22 9.27L17 14.14L18.18 21.02L12 17.77L5.82 21.02L7 14.14L2 9.27L8.91 8.26L12 2Z'/%3E%3C/svg%3E") center/contain no-repeat;
        }

        /* Quick Filters */
        .quick-filters {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
            margin-bottom: 16px;
        }
        .quick-filter-btn {
            padding: 6px 12px;
            background: var(--bg-elevated);
            border: 1px solid var(--border);
            border-radius: 20px;
            color: var(--text-muted);
            font-size: 11px;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.15s;
        }
        .quick-filter-btn:hover { border-color: var(--border-bright); color: var(--text); }
        .quick-filter-btn.active { border-color: var(--gold); color: var(--gold); background: rgba(212, 175, 55, 0.1); }

        /* Game Selector */
        .game-select {
            width: 100%;
            padding: 12px 14px;
            background: var(--bg-elevated);
            border: 1px solid var(--border);
            border-radius: 10px;
            color: var(--text);
            font-size: 13px;
            cursor: pointer;
            outline: none;
            appearance: none;
            background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23d4af37' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
            background-repeat: no-repeat;
            background-position: right 12px center;
        }
        .game-select option { background: var(--bg-elevated); }

        /* Type Grid */
        .type-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 6px;
        }
        .type-btn {
            padding: 6px 4px;
            background: var(--bg-elevated);
            border: 1px solid var(--border);
            border-radius: 6px;
            color: var(--text-muted);
            font-size: 10px;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.15s;
            text-transform: capitalize;
        }
        .type-btn:hover { border-color: var(--border-bright); color: var(--text); }
        .type-btn.active { border-color: var(--gold); color: var(--gold); background: rgba(212, 175, 55, 0.1); }

        /* Generation Buttons */
        .gen-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 6px;
        }
        .gen-btn {
            padding: 8px;
            background: var(--bg-elevated);
            border: 1px solid var(--border);
            border-radius: 6px;
            color: var(--text-muted);
            font-size: 11px;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.15s;
        }
        .gen-btn:hover { border-color: var(--border-bright); color: var(--text); }
        .gen-btn.active { border-color: var(--gold); color: var(--gold); background: rgba(212, 175, 55, 0.1); }

        /* Toggles */
        .toggle-row {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: 8px 0;
            border-bottom: 1px solid var(--border);
        }
        .toggle-row:last-child { border-bottom: none; }
        .toggle-label { font-size: 12px; color: var(--text-muted); }
        .toggle-switch {
            width: 38px;
            height: 20px;
            background: var(--bg-elevated);
            border: 1px solid var(--border);
            border-radius: 10px;
            cursor: pointer;
            position: relative;
            transition: all 0.2s;
        }
        .toggle-switch::after {
            content: '';
            position: absolute;
            width: 14px;
            height: 14px;
            background: var(--text-dim);
            border-radius: 50%;
            top: 2px;
            left: 2px;
            transition: all 0.2s;
        }
        .toggle-switch.active { background: var(--gold); border-color: var(--gold); }
        .toggle-switch.active::after { background: #000; left: 20px; }

        /* Sound Toggle */
        .sound-toggle {
            display: flex;
            align-items: center;
            gap: 8px;
            padding: 10px 14px;
            background: var(--bg-elevated);
            border: 1px solid var(--border);
            border-radius: 8px;
            cursor: pointer;
            margin-top: 12px;
        }
        .sound-toggle svg { width: 18px; height: 18px; color: var(--text-dim); }
        .sound-toggle.active svg { color: var(--gold); }
        .sound-toggle span { font-size: 12px; color: var(--text-muted); }

        /* Content */
        .content {
            flex: 1;
            margin-left: 0;
            padding: clamp(52px, 10vw, 100px) clamp(12px, 4vw, 60px) 32px clamp(12px, 4vw, 60px);
            max-width: 100%;
            width: 100%;
            margin: 0 auto;
            transition: margin 0.3s;
        }
        .content.expanded { margin-left: 0; padding: clamp(52px, 10vw, 100px) clamp(12px, 4vw, 60px) 32px clamp(12px, 4vw, 60px); }

        /* Stats Bar */
        .stats-bar {
            display: flex;
            gap: 12px;
            margin-bottom: 16px;
            flex-wrap: wrap;
        }
        .stat-pill {
            display: flex;
            align-items: center;
            gap: 8px;
            padding: 10px 16px;
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 10px;
        }
        .stat-pill .value {
            font-family: 'Rajdhani', sans-serif;
            font-size: 20px;
            font-weight: 700;
            color: var(--gold);
        }
        .stat-pill .label { font-size: 12px; color: var(--text-dim); }

        /* View Controls */
        .view-controls {
            display: flex;
            align-items: center;
            gap: 10px;
            margin-bottom: 16px;
            flex-wrap: wrap;
        }
        .view-btn {
            padding: 8px 12px;
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 8px;
            color: var(--text-muted);
            font-size: 11px;
            cursor: pointer;
            display: flex;
            align-items: center;
            gap: 6px;
            transition: all 0.15s;
        }
        .view-btn:hover { border-color: var(--border-bright); color: var(--text); }
        .view-btn.active { border-color: var(--gold); color: var(--gold); }
        .sort-select {
            padding: 8px 32px 8px 12px;
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 8px;
            color: var(--text-muted);
            font-size: 11px;
            cursor: pointer;
            outline: none;
            appearance: none;
            background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23d4af37' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
            background-repeat: no-repeat;
            background-position: right 10px center;
        }
        .results-count { margin-left: auto; font-size: 12px; color: var(--text-dim); }

        /* Top Section - normal scroll */
        .sticky-top-section {
            /* Not sticky - scrolls with page */
            max-width: 100%;
            overflow: hidden;
        }
        /* Make hero section responsive in base CSS - no reliance on media queries */
        .sticky-top-section > div:first-child {
            margin-bottom: clamp(10px, 4vw, 50px) !important;
            padding: clamp(4px, 1.5vw, 20px) 0 !important;
        }
        .sticky-top-section h1 {
            font-size: clamp(24px, 6vw, 80px) !important;
            letter-spacing: clamp(1px, 0.3vw, 4px) !important;
        }

        /* Command Center Dashboard */
        .command-center {
            display: none;
        }
        .command-center.active {
            display: block;
        }
        .classic-view.hidden {
            display: none;
        }

        .dashboard-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
            gap: 20px;
            margin-bottom: 24px;
        }

        .dashboard-card {
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 16px;
            padding: 20px;
            transition: all 0.3s;
        }
        .dashboard-card:hover {
            border-color: var(--cyan);
            box-shadow: 0 0 20px rgba(0, 212, 255, 0.1);
        }
        .dashboard-card-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            margin-bottom: 16px;
        }
        .dashboard-card-title {
            font-family: 'Rajdhani', sans-serif;
            font-size: 14px;
            font-weight: 700;
            color: var(--text-muted);
            letter-spacing: 2px;
            display: flex;
            align-items: center;
            gap: 8px;
        }
        .dashboard-card-title svg {
            color: var(--cyan);
        }

        .bot-status-list {
            display: flex;
            flex-direction: column;
            gap: 12px;
        }
        .bot-status-item {
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 12px;
            background: var(--bg-elevated);
            border-radius: 10px;
        }
        .bot-status-item img {
            width: 40px;
            height: 40px;
            object-fit: contain;
        }
        .bot-status-info {
            flex: 1;
        }
        .bot-status-name {
            font-size: 14px;
            font-weight: 600;
            color: var(--text);
        }
        .bot-status-game {
            font-size: 11px;
            color: var(--text-dim);
        }
        .bot-status-badge {
            padding: 4px 10px;
            border-radius: 20px;
            font-size: 11px;
            font-weight: 600;
        }
        .bot-status-badge.online {
            background: rgba(34, 197, 94, 0.15);
            color: #22c55e;
        }
        .bot-status-badge.busy {
            background: rgba(251, 191, 36, 0.15);
            color: #fbbf24;
        }
        .bot-status-badge.offline {
            background: rgba(239, 68, 68, 0.15);
            color: #ef4444;
        }

        .quick-trade-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 12px;
        }
        .quick-trade-item {
            background: var(--bg-elevated);
            border: 1px solid var(--border);
            border-radius: 12px;
            padding: 16px;
            text-align: center;
            cursor: pointer;
            transition: all 0.2s;
        }
        .quick-trade-item:hover {
            border-color: var(--gold);
            transform: translateY(-2px);
        }
        .quick-trade-item img {
            width: 50px;
            height: 50px;
            object-fit: contain;
            margin-bottom: 8px;
        }
        .quick-trade-item .name {
            font-size: 12px;
            color: var(--text);
            font-weight: 600;
        }
        .quick-trade-item .time {
            font-size: 10px;
            color: var(--text-dim);
        }

        .activity-feed {
            display: flex;
            flex-direction: column;
            gap: 10px;
            max-height: 300px;
            overflow-y: auto;
        }
        .activity-item {
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 10px;
            background: var(--bg-elevated);
            border-radius: 8px;
        }
        .activity-item img {
            width: 32px;
            height: 32px;
        }
        .activity-text {
            flex: 1;
            font-size: 13px;
            color: var(--text-muted);
        }
        .activity-text strong {
            color: var(--text);
        }
        .activity-time {
            font-size: 11px;
            color: var(--text-dim);
        }

        .queue-position {
            text-align: center;
            padding: 30px;
        }
        .queue-number {
            font-family: 'Orbitron', sans-serif;
            font-size: 64px;
            font-weight: 700;
            color: var(--cyan);
            line-height: 1;
        }
        .queue-label {
            font-size: 14px;
            color: var(--text-dim);
            margin-top: 8px;
        }
        .queue-empty {
            color: var(--text-muted);
            font-size: 14px;
        }

        /* Mode Toggle Tabs */
        .mode-tab {
            position: relative;
            overflow: visible;
        }
        .mode-tab::before {
            content: '';
            position: absolute;
            top: 0;
            left: -100%;
            width: 100%;
            height: 100%;
            background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
            transition: left 0.5s;
        }
        .mode-tab:hover::before {
            left: 100%;
        }
        .mode-tab.active {
            box-shadow: 0 4px 20px rgba(168, 85, 247, 0.4);
        }
        .mode-tab:not(.active):hover {
            background: var(--bg-elevated) !important;
            color: var(--text) !important;
            border-color: var(--border-bright) !important;
        }

        /* Showdown Input Textarea */
        #showdownInput:focus {
            border-color: var(--purple);
            box-shadow: 0 0 0 3px rgba(168, 85, 247, 0.2);
            outline: none;
        }
        #showdownInput::placeholder {
            color: var(--text-dim);
            opacity: 0.6;
        }

        /* Type Badges */
        .type-badge {
            display: inline-block;
            padding: 4px 12px;
            border-radius: 20px;
            font-size: 11px;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.5px;
        }
        .type-fire { background: linear-gradient(135deg, #F08030, #dd6610); color: #fff; }
        .type-water { background: linear-gradient(135deg, #6890F0, #4a6fc4); color: #fff; }
        .type-grass { background: linear-gradient(135deg, #78C850, #5ca935); color: #fff; }
        .type-electric { background: linear-gradient(135deg, #F8D030, #d4a800); color: #000; }
        .type-psychic { background: linear-gradient(135deg, #F85888, #d63a6a); color: #fff; }
        .type-ice { background: linear-gradient(135deg, #98D8D8, #6cc4c4); color: #000; }
        .type-dragon { background: linear-gradient(135deg, #7038F8, #5a1ed6); color: #fff; }
        .type-dark { background: linear-gradient(135deg, #705848, #4d3c32); color: #fff; }
        .type-fairy { background: linear-gradient(135deg, #EE99AC, #e06f8a); color: #000; }
        .type-normal { background: linear-gradient(135deg, #A8A878, #8a8a5c); color: #000; }
        .type-fighting { background: linear-gradient(135deg, #C03028, #9c201a); color: #fff; }
        .type-flying { background: linear-gradient(135deg, #A890F0, #8468e0); color: #fff; }
        .type-poison { background: linear-gradient(135deg, #A040A0, #7c2e7c); color: #fff; }
        .type-ground { background: linear-gradient(135deg, #E0C068, #c9a445); color: #000; }
        .type-rock { background: linear-gradient(135deg, #B8A038, #96811f); color: #fff; }
        .type-bug { background: linear-gradient(135deg, #A8B820, #889410); color: #fff; }
        .type-ghost { background: linear-gradient(135deg, #705898, #554374); color: #fff; }
        .type-steel { background: linear-gradient(135deg, #B8B8D0, #9494ac); color: #000; }

        /* Batch Item */
        .batch-item {
            display: flex;
            align-items: center;
            gap: 12px;
            background: var(--bg-elevated);
            border: 1px solid var(--border);
            border-radius: 12px;
            padding: 12px;
            transition: all 0.3s;
        }
        .batch-item:hover {
            border-color: var(--purple);
            transform: translateY(-2px);
        }
        .batch-item img {
            width: 50px;
            height: 50px;
            object-fit: contain;
        }
        .batch-item-info {
            flex: 1;
        }
        .batch-item-name {
            font-weight: 600;
            color: var(--text);
            font-size: 14px;
        }
        .batch-item-details {
            font-size: 11px;
            color: var(--text-dim);
        }

        /* Step Indicator Sections */
        .step-section {
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 16px;
            padding: 24px;
            margin-bottom: 20px;
        }
        .step-header {
            display: flex;
            align-items: center;
            gap: 16px;
            margin-bottom: 20px;
        }
        .step-number {
            width: 36px;
            height: 36px;
            background: linear-gradient(135deg, var(--cyan), #0891b2);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-family: 'Rajdhani', sans-serif;
            font-size: 18px;
            font-weight: 700;
            color: #000;
            flex-shrink: 0;
        }
        .step-title {
            font-family: 'Rajdhani', sans-serif;
            font-size: 16px;
            font-weight: 700;
            color: var(--text);
            letter-spacing: 2px;
            text-transform: uppercase;
        }

        /* Pokemon Grid - Performance Optimized */
        .pokemon-grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
            gap: 20px;
            contain: layout style;
        }
        .pokemon-grid.list-view { grid-template-columns: 1fr; gap: 12px; }
        .pokemon-grid.compact-view { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 12px; }

        /* Pokemon Card - GPU Optimized */
        .poke-card {
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 20px;
            padding: 24px 20px;
            cursor: pointer;
            transition: border-color 0.2s, transform 0.2s, box-shadow 0.2s;
            text-align: center;
            position: relative;
            overflow: hidden;
            contain: layout style paint;
            content-visibility: auto;
            contain-intrinsic-size: 200px 240px;
            will-change: transform;
            transform: translateZ(0);
        }
        .poke-card::before {
            content: '';
            position: absolute;
            top: 0; left: 0; right: 0; bottom: 0;
            opacity: 0;
            transition: opacity 0.3s;
            pointer-events: none;
        }
        .poke-card.type-glow::before { opacity: 0.15; }
        .poke-card:hover {
            border-color: var(--gold);
            transform: translateY(-4px) translateZ(0);
            box-shadow: 0 12px 30px rgba(0, 0, 0, 0.4), 0 0 15px rgba(212, 175, 55, 0.1);
        }
        .poke-card.in-team {
            border-color: var(--green);
            box-shadow: 0 0 15px rgba(34, 197, 94, 0.2);
        }
        .poke-card .favorite-btn {
            position: absolute;
            top: 8px;
            right: 8px;
            width: 24px;
            height: 24px;
            background: rgba(0,0,0,0.5);
            border: none;
            border-radius: 50%;
            color: var(--text-dim);
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            opacity: 0;
            transition: all 0.2s;
            z-index: 5;
        }
        .poke-card:hover .favorite-btn { opacity: 1; }
        .poke-card .favorite-btn.active { color: var(--red); opacity: 1; }
        .poke-card .favorite-btn svg { width: 14px; height: 14px; }
        .poke-card .badge-container {
            position: absolute;
            top: 8px;
            left: 8px;
            display: flex;
            flex-direction: column;
            gap: 4px;
            z-index: 5;
        }
        .poke-card .badge {
            width: 24px;
            height: 24px;
            display: none;
            filter: drop-shadow(0 2px 4px rgba(0,0,0,0.3));
            animation: badgePop 0.3s ease;
        }
        .poke-card .badge.visible { display: block; }
        .poke-card .badge img { width: 100%; height: 100%; object-fit: contain; }
        .poke-card .shiny-badge {
            width: 24px;
            height: 24px;
            background: linear-gradient(135deg, #fbbf24, #f59e0b);
            -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='currentColor'%3E%3Cpath d='M12 2L15.09 8.26L22 9.27L17 14.14L18.18 21.02L12 17.77L5.82 21.02L7 14.14L2 9.27L8.91 8.26L12 2Z'/%3E%3C/svg%3E") center/contain no-repeat;
            mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='currentColor'%3E%3Cpath d='M12 2L15.09 8.26L22 9.27L17 14.14L18.18 21.02L12 17.77L5.82 21.02L7 14.14L2 9.27L8.91 8.26L12 2Z'/%3E%3C/svg%3E") center/contain no-repeat;
        }
        @keyframes badgePop {
            0% { transform: scale(0); opacity: 0; }
            50% { transform: scale(1.2); }
            100% { transform: scale(1); opacity: 1; }
        }
        /* Shiny sparkle effect - Subtle twinkle */
        .poke-card .sparkles {
            position: absolute;
            top: 0; left: 0; right: 0; bottom: 0;
            pointer-events: none;
            display: none;
            contain: strict;
        }
        .poke-card .sparkles.visible { display: block; }
        .sparkle {
            position: absolute;
            width: 4px;
            height: 4px;
            background: #ffd700;
            border-radius: 50%;
            animation: twinkle 1.5s ease-in-out infinite;
            opacity: 0;
        }
        .poke-card .sparkles.visible .sparkle { animation-play-state: running; }
        .sparkle:nth-child(1) { top: 15%; left: 20%; animation-delay: 0s; }
        .sparkle:nth-child(2) { top: 25%; right: 25%; animation-delay: 0.4s; }
        .sparkle:nth-child(3) { bottom: 40%; left: 30%; animation-delay: 0.8s; }
        .sparkle:nth-child(4) { bottom: 30%; right: 20%; animation-delay: 1.2s; }
        @keyframes twinkle {
            0%, 100% { opacity: 0; transform: scale(0.5); }
            50% { opacity: 1; transform: scale(1); }
        }
        .poke-card .poke-img {
            width: 120px;
            height: 120px;
            object-fit: contain;
            transition: transform 0.2s;
            position: relative;
            z-index: 2;
        }
        .poke-card:hover .poke-img { transform: scale(1.1); }
        .poke-card .name {
            font-weight: 700;
            font-size: 16px;
            margin: 12px 0 4px;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            position: relative;
            z-index: 2;
        }
        .poke-card .number {
            font-size: 13px;
            color: var(--text-dim);
            position: relative;
            z-index: 2;
        }
        .poke-card .types {
            display: flex;
            gap: 6px;
            justify-content: center;
            margin-top: 12px;
            flex-wrap: wrap;
            position: relative;
            z-index: 2;
        }
        .type-tag {
            padding: 4px 12px;
            border-radius: 12px;
            font-size: 10px;
            font-weight: 700;
            text-transform: uppercase;
        }

        /* List View Card */
        .poke-card.list-card {
            display: flex;
            align-items: center;
            padding: 16px 24px;
            text-align: left;
            gap: 20px;
        }
        .poke-card.list-card .poke-img { width: 70px; height: 70px; }
        .poke-card.list-card .info { flex: 1; }
        .poke-card.list-card .name { margin: 0; font-size: 18px; }
        .poke-card.list-card .types { justify-content: flex-start; margin-top: 6px; }
        .poke-card.list-card .favorite-btn { position: static; opacity: 1; }
        .poke-card.list-card .badge-container { position: static; flex-direction: row; }

        /* Compact View */
        .poke-card.compact-card { padding: 16px 12px; }
        .poke-card.compact-card .poke-img { width: 70px; height: 70px; }
        .poke-card.compact-card .name { font-size: 12px; }
        .poke-card.compact-card .number { font-size: 10px; }
        .poke-card.compact-card .types { display: none; }

        /* Type Colors */
        .type-normal { background: #a8a878; color: #000; }
        .type-fire { background: #f08030; color: #000; }
        .type-water { background: #6890f0; color: #fff; }
        .type-electric { background: #f8d030; color: #000; }
        .type-grass { background: #78c850; color: #000; }
        .type-ice { background: #98d8d8; color: #000; }
        .type-fighting { background: #c03028; color: #fff; }
        .type-poison { background: #a040a0; color: #fff; }
        .type-ground { background: #e0c068; color: #000; }
        .type-flying { background: #a890f0; color: #000; }
        .type-psychic { background: #f85888; color: #000; }
        .type-bug { background: #a8b820; color: #000; }
        .type-rock { background: #b8a038; color: #000; }
        .type-ghost { background: #705898; color: #fff; }
        .type-dragon { background: #7038f8; color: #fff; }
        .type-dark { background: #705848; color: #fff; }
        .type-steel { background: #b8b8d0; color: #000; }
        .type-fairy { background: #ee99ac; color: #000; }

        /* Type Glow Colors */
        .glow-fire { background: radial-gradient(circle at center, #f08030 0%, transparent 70%); }
        .glow-water { background: radial-gradient(circle at center, #6890f0 0%, transparent 70%); }
        .glow-grass { background: radial-gradient(circle at center, #78c850 0%, transparent 70%); }
        .glow-electric { background: radial-gradient(circle at center, #f8d030 0%, transparent 70%); }
        .glow-psychic { background: radial-gradient(circle at center, #f85888 0%, transparent 70%); }
        .glow-ice { background: radial-gradient(circle at center, #98d8d8 0%, transparent 70%); }
        .glow-dragon { background: radial-gradient(circle at center, #7038f8 0%, transparent 70%); }
        .glow-dark { background: radial-gradient(circle at center, #705848 0%, transparent 70%); }
        .glow-fairy { background: radial-gradient(circle at center, #ee99ac 0%, transparent 70%); }
        .glow-fighting { background: radial-gradient(circle at center, #c03028 0%, transparent 70%); }
        .glow-poison { background: radial-gradient(circle at center, #a040a0 0%, transparent 70%); }
        .glow-ground { background: radial-gradient(circle at center, #e0c068 0%, transparent 70%); }
        .glow-flying { background: radial-gradient(circle at center, #a890f0 0%, transparent 70%); }
        .glow-bug { background: radial-gradient(circle at center, #a8b820 0%, transparent 70%); }
        .glow-rock { background: radial-gradient(circle at center, #b8a038 0%, transparent 70%); }
        .glow-ghost { background: radial-gradient(circle at center, #705898 0%, transparent 70%); }
        .glow-steel { background: radial-gradient(circle at center, #b8b8d0 0%, transparent 70%); }
        .glow-normal { background: radial-gradient(circle at center, #a8a878 0%, transparent 70%); }

        /* Type Glow on Hover */
        .poke-card.type-glow-hover:hover {
            box-shadow: 0 0 30px var(--type-glow-color, rgba(212, 175, 55, 0.3));
        }

        /* Keyboard Shortcuts Help Panel */
        .shortcuts-help-btn {
            position: fixed;
            bottom: 24px;
            right: 24px;
            width: 48px;
            height: 48px;
            background: var(--bg-card);
            border: 2px solid var(--gold);
            border-radius: 50%;
            color: var(--gold);
            font-size: 24px;
            font-weight: bold;
            cursor: pointer;
            z-index: 200;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: all 0.3s;
            box-shadow: 0 4px 20px rgba(212, 175, 55, 0.2);
        }
        .shortcuts-help-btn:hover {
            background: var(--gold);
            color: #000;
            transform: scale(1.1);
        }

        .shortcuts-panel {
            position: fixed;
            bottom: 84px;
            right: 24px;
            width: 320px;
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 16px;
            padding: 20px;
            z-index: 199;
            opacity: 0;
            visibility: hidden;
            transform: translateY(10px);
            transition: all 0.3s;
            box-shadow: 0 10px 40px rgba(0, 0, 0, 0.5);
        }
        .shortcuts-panel.visible {
            opacity: 1;
            visibility: visible;
            transform: translateY(0);
        }
        .shortcuts-panel h3 {
            font-family: 'Rajdhani', sans-serif;
            font-size: 16px;
            color: var(--gold);
            margin-bottom: 16px;
            letter-spacing: 1px;
        }
        .shortcut-item {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 8px 0;
            border-bottom: 1px solid var(--border);
        }
        .shortcut-item:last-child { border-bottom: none; }
        .shortcut-key {
            background: var(--bg-elevated);
            border: 1px solid var(--border);
            padding: 4px 10px;
            border-radius: 6px;
            font-family: 'JetBrains Mono', monospace;
            font-size: 12px;
            color: var(--gold);
        }
        .shortcut-desc {
            font-size: 13px;
            color: var(--text-muted);
        }

        /* Recently Viewed Section */
        .recently-viewed {
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 16px;
            padding: 20px;
            margin-bottom: 24px;
        }
        .recently-viewed h3 {
            font-family: 'Rajdhani', sans-serif;
            font-size: 14px;
            color: var(--gold);
            letter-spacing: 2px;
            margin-bottom: 16px;
            display: flex;
            align-items: center;
            gap: 8px;
        }
        .recently-viewed-grid {
            display: flex;
            gap: 12px;
            overflow-x: auto;
            padding-bottom: 8px;
        }
        .recent-pokemon {
            flex-shrink: 0;
            width: 80px;
            background: var(--bg-elevated);
            border: 1px solid var(--border);
            border-radius: 12px;
            padding: 12px;
            text-align: center;
            cursor: pointer;
            transition: all 0.2s;
        }
        .recent-pokemon:hover {
            border-color: var(--gold);
            transform: translateY(-2px);
        }
        .recent-pokemon img {
            width: 50px;
            height: 50px;
            object-fit: contain;
        }
        .recent-pokemon .name {
            font-size: 10px;
            color: var(--text-muted);
            margin-top: 4px;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
        }

        /* Team Panel */
        .team-panel {
            position: fixed;
            bottom: 0;
            left: 280px;
            right: 0;
            background: var(--bg-card);
            border-top: 1px solid var(--border);
            padding: 16px 24px;
            transform: translateY(100%);
            transition: all 0.3s;
            z-index: 50;
        }
        .team-panel.visible { transform: translateY(0); }
        .team-panel.expanded-left { left: 0; }
        .team-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            margin-bottom: 12px;
        }
        .team-header h3 {
            font-family: 'Rajdhani', sans-serif;
            font-size: 18px;
            color: var(--gold);
        }
        .team-slots { display: flex; gap: 12px; }
        .team-slot {
            width: 70px;
            height: 70px;
            background: var(--bg-elevated);
            border: 2px dashed var(--border);
            border-radius: 12px;
            display: flex;
            align-items: center;
            justify-content: center;
            position: relative;
        }
        .team-slot.filled { border-style: solid; border-color: var(--gold); }
        .team-slot img { width: 55px; height: 55px; }
        .team-slot .remove-btn {
            position: absolute;
            top: -8px;
            right: -8px;
            width: 20px;
            height: 20px;
            background: var(--red);
            border: none;
            border-radius: 50%;
            color: #fff;
            font-size: 14px;
            cursor: pointer;
            display: none;
        }
        .team-slot.filled:hover .remove-btn { display: flex; align-items: center; justify-content: center; }
        .team-actions { display: flex; gap: 10px; margin-left: auto; }
        .team-btn {
            padding: 10px 18px;
            border-radius: 8px;
            font-size: 12px;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.2s;
        }
        .team-btn.secondary {
            background: transparent;
            border: 1px solid var(--border);
            color: var(--text-muted);
        }
        .team-btn.primary {
            background: linear-gradient(135deg, var(--gold), var(--gold-dark));
            border: none;
            color: #000;
        }
        .team-btn.export-btn {
            background: linear-gradient(135deg, var(--blue), #2563eb);
            border: none;
            color: #fff;
        }

        /* Modal - Performance Optimized */
        .modal-overlay {
            position: fixed;
            top: 0; left: 0; right: 0; bottom: 0;
            background: rgba(0, 0, 0, 0.92);
            backdrop-filter: blur(6px);
            -webkit-backdrop-filter: blur(6px);
            display: none;
            align-items: center;
            justify-content: center;
            z-index: 10000;
            padding: 20px;
            will-change: opacity;
        }
        .modal-overlay.active { display: flex; }
        .modal {
            background: var(--bg-elevated);
            border: 1px solid var(--border);
            border-radius: 20px;
            width: 100%;
            max-width: 700px;
            max-height: 90vh;
            overflow-y: auto;
            position: relative;
        }
        .modal-close {
            position: absolute;
            top: 16px;
            right: 16px;
            width: 36px;
            height: 36px;
            background: rgba(255,255,255,0.05);
            border: 1px solid var(--border);
            border-radius: 10px;
            color: var(--text-dim);
            font-size: 20px;
            cursor: pointer;
            z-index: 10;
        }
        .modal-close:hover { color: var(--text); }

        /* Modal Header */
        .modal-hero {
            padding: 24px;
            background: linear-gradient(135deg, var(--bg-card), rgba(212, 175, 55, 0.05));
            border-bottom: 1px solid var(--border);
            display: flex;
            align-items: center;
            gap: 20px;
        }
        .modal-pokemon-container {
            position: relative;
        }
        .modal-pokemon-img {
            width: 120px;
            height: 120px;
            object-fit: contain;
            filter: drop-shadow(0 0 30px rgba(212, 175, 55, 0.3));
        }
        .modal-sparkles {
            position: absolute;
            top: 0; left: 0; right: 0; bottom: 0;
            pointer-events: none;
            display: none;
        }
        .modal-sparkles.visible { display: block; }
        .modal-sparkles .sparkle { width: 6px; height: 6px; }
        .modal-sparkles .sparkle:nth-child(1) { top: 10%; left: 10%; }
        .modal-sparkles .sparkle:nth-child(2) { top: 15%; right: 15%; }
        .modal-sparkles .sparkle:nth-child(3) { bottom: 25%; left: 20%; }
        .modal-sparkles .sparkle:nth-child(4) { bottom: 20%; right: 10%; }
        .modal-pokemon-info { flex: 1; }
        .modal-pokemon-info h2 {
            font-family: 'Rajdhani', sans-serif;
            font-size: 28px;
            font-weight: 700;
        }
        .modal-pokemon-info .meta {
            color: var(--text-dim);
            font-size: 13px;
            margin-bottom: 6px;
        }
        .modal-pokemon-info .types { display: flex; gap: 6px; }
        .modal-pokemon-info .type-tag { padding: 4px 12px; font-size: 11px; }

        /* Evolution Chain */
        .evo-chain {
            display: flex;
            align-items: center;
            gap: 8px;
            margin-top: 12px;
            padding: 10px;
            background: var(--bg-card);
            border-radius: 8px;
            overflow-x: auto;
        }
        .evo-pokemon {
            display: flex;
            flex-direction: column;
            align-items: center;
            cursor: pointer;
            padding: 6px;
            border-radius: 8px;
            transition: all 0.2s;
            min-width: 60px;
        }
        .evo-pokemon:hover { background: var(--bg-hover); }
        .evo-pokemon.current { background: rgba(212, 175, 55, 0.2); border: 1px solid var(--gold); }
        .evo-pokemon img { width: 40px; height: 40px; }
        .evo-pokemon span { font-size: 9px; color: var(--text-muted); margin-top: 2px; }
        .evo-arrow { color: var(--text-dim); font-size: 16px; }

        /* Base Stats */
        .base-stats {
            display: flex;
            flex-direction: column;
            gap: 8px;
            margin-top: 12px;
            padding: 12px;
            background: var(--bg-card);
            border-radius: 8px;
        }
        .stat-row {
            display: flex;
            align-items: center;
            gap: 10px;
        }
        .stat-name {
            width: 40px;
            font-size: 10px;
            font-weight: 700;
            color: var(--text-dim);
        }
        .stat-bar-container {
            flex: 1;
            height: 8px;
            background: var(--bg-elevated);
            border-radius: 4px;
            overflow: hidden;
        }
        .stat-bar {
            height: 100%;
            border-radius: 4px;
            transition: width 0.5s ease;
        }
        .stat-bar.hp { background: #ff5959; }
        .stat-bar.atk { background: #f5ac78; }
        .stat-bar.def { background: #fae078; }
        .stat-bar.spa { background: #9db7f5; }
        .stat-bar.spd { background: #a7db8d; }
        .stat-bar.spe { background: #fa92b2; }
        .stat-value {
            width: 30px;
            font-size: 11px;
            font-weight: 700;
            text-align: right;
        }

        /* Modal Tabs */
        .modal-tabs {
            display: flex;
            border-bottom: 1px solid var(--border);
            padding: 0 16px;
            overflow-x: auto;
        }
        .modal-tab {
            padding: 12px 16px;
            background: none;
            border: none;
            color: var(--text-dim);
            font-size: 12px;
            font-weight: 600;
            cursor: pointer;
            border-bottom: 2px solid transparent;
            margin-bottom: -1px;
            transition: all 0.2s;
            white-space: nowrap;
        }
        .modal-tab:hover { color: var(--text); }
        .modal-tab.active { color: var(--gold); border-bottom-color: var(--gold); }

        /* Tab Content */
        .tab-content { display: none; padding: 20px; }
        .tab-content.active { display: block; }

        /* Mode Indicator */
        .mode-indicator {
            display: none;
            align-items: center;
            gap: 10px;
            padding: 10px 14px;
            border-radius: 8px;
            margin-bottom: 14px;
        }
        .mode-indicator.visible { display: flex; }
        .mode-indicator.egg-indicator {
            background: linear-gradient(135deg, rgba(118, 171, 130, 0.15), rgba(136, 201, 153, 0.1));
            border: 1px solid rgba(118, 171, 130, 0.4);
        }
        .mode-indicator.shiny-indicator {
            background: linear-gradient(135deg, rgba(251, 191, 36, 0.15), rgba(245, 158, 11, 0.1));
            border: 1px solid rgba(251, 191, 36, 0.4);
        }
        .mode-indicator .indicator-icon {
            width: 24px;
            height: 24px;
            flex-shrink: 0;
        }
        .mode-indicator .indicator-icon img { width: 100%; height: 100%; object-fit: contain; }
        .mode-indicator span { font-size: 11px; font-weight: 600; }
        .mode-indicator.egg-indicator span { color: #88c999; }
        .mode-indicator.shiny-indicator span { color: #fbbf24; }

        /* Form */
        .form-grid {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 14px;
        }
        .form-group { margin-bottom: 14px; }
        .form-group.full-width { grid-column: span 2; }
        .form-label {
            display: block;
            font-size: 10px;
            font-weight: 700;
            color: var(--text-dim);
            text-transform: uppercase;
            letter-spacing: 1px;
            margin-bottom: 6px;
        }
        .form-select, .form-input {
            width: 100%;
            padding: 10px 12px;
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 8px;
            color: var(--text);
            font-size: 13px;
            outline: none;
            transition: all 0.2s;
        }
        .form-select:focus, .form-input:focus { border-color: var(--gold); }
        .form-select {
            cursor: pointer;
            appearance: none;
            background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23d4af37' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
            background-repeat: no-repeat;
            background-position: right 12px center;
        }
        .form-select option { background: var(--bg-elevated); }

        /* Searchable Dropdown */
        .searchable-dropdown { position: relative; width: 100%; }
        .searchable-dropdown .sd-input {
            width: 100%; padding: 10px 32px 10px 12px; background: var(--bg-card);
            border: 1px solid var(--border); border-radius: 8px; color: var(--text);
            font-size: 13px; outline: none; transition: all 0.2s; box-sizing: border-box;
        }
        .searchable-dropdown .sd-input:focus { border-color: var(--gold); }
        .searchable-dropdown .sd-input::placeholder { color: var(--text-dim); }
        .searchable-dropdown .sd-clear {
            position: absolute; right: 8px; top: 50%; transform: translateY(-50%);
            background: none; border: none; color: var(--text-dim); cursor: pointer;
            font-size: 16px; padding: 2px 6px; display: none; line-height: 1; z-index: 2;
        }
        .searchable-dropdown .sd-clear:hover { color: #ef4444; }
        .searchable-dropdown.has-value .sd-clear { display: block; }
        .searchable-dropdown .sd-list {
            position: absolute; top: 100%; left: 0; right: 0; max-height: 200px;
            overflow-y: auto; background: var(--bg-elevated); border: 1px solid var(--border-bright, var(--border));
            border-top: none; border-radius: 0 0 8px 8px; z-index: 9999;
            display: none; box-shadow: 0 8px 24px rgba(0,0,0,0.5);
        }
        .searchable-dropdown.open .sd-list { display: block; }
        .searchable-dropdown .sd-option {
            padding: 8px 12px; cursor: pointer; font-size: 12px; color: var(--text-muted);
            transition: background 0.15s; border-bottom: 1px solid rgba(255,255,255,0.03);
        }
        .searchable-dropdown .sd-option:hover,
        .searchable-dropdown .sd-option.highlighted { background: rgba(212,175,55,0.1); color: var(--text); }
        .searchable-dropdown .sd-option.selected { color: var(--gold); font-weight: 600; }
        .searchable-dropdown .sd-empty {
            padding: 12px; text-align: center; color: var(--text-dim); font-size: 12px; font-style: italic;
        }
        .searchable-dropdown .sd-list::-webkit-scrollbar { width: 6px; }
        .searchable-dropdown .sd-list::-webkit-scrollbar-track { background: transparent; }
        .searchable-dropdown .sd-list::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }

        /* Toggle Group */
        .toggle-group {
            display: flex;
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 8px;
            overflow: hidden;
        }
        .toggle-opt {
            flex: 1;
            padding: 10px;
            background: none;
            border: none;
            color: var(--text-dim);
            font-size: 11px;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.2s;
        }
        .toggle-opt:not(:last-child) { border-right: 1px solid var(--border); }
        .toggle-opt.active { background: var(--gold); color: #000; }

        /* Slider */
        .slider-container { margin-bottom: 14px; }
        .slider-header { display: flex; justify-content: space-between; margin-bottom: 6px; }
        .slider-value {
            font-family: 'Rajdhani', sans-serif;
            font-size: 18px;
            font-weight: 700;
            color: var(--gold);
        }
        .slider {
            width: 100%;
            height: 6px;
            background: var(--bg-card);
            border-radius: 3px;
            appearance: none;
            cursor: pointer;
        }
        .slider::-webkit-slider-thumb {
            appearance: none;
            width: 18px;
            height: 18px;
            background: linear-gradient(135deg, var(--gold), var(--gold-dark));
            border-radius: 50%;
            cursor: pointer;
        }

        /* Stats Grid */
        .stats-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 10px;
        }
        .stat-box {
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 8px;
            padding: 10px;
            text-align: center;
        }
        .stat-box .name {
            font-size: 10px;
            color: var(--text-dim);
            text-transform: uppercase;
            margin-bottom: 4px;
        }
        .stat-box input {
            width: 55px;
            padding: 6px;
            background: var(--bg-elevated);
            border: 1px solid var(--border);
            border-radius: 4px;
            color: var(--text);
            font-size: 13px;
            text-align: center;
            outline: none;
        }
        .stat-box input:focus { border-color: var(--gold); }

        /* Presets */
        .preset-btns {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
            margin-bottom: 10px;
        }
        .preset-btn {
            padding: 6px 10px;
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 6px;
            color: var(--text-muted);
            font-size: 10px;
            cursor: pointer;
            transition: all 0.15s;
        }
        .preset-btn:hover { border-color: var(--gold); color: var(--gold); }

        /* Showdown Import */
        .showdown-import {
            margin-bottom: 14px;
        }
        .showdown-textarea {
            width: 100%;
            height: 120px;
            padding: 12px;
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 8px;
            color: var(--text);
            font-family: monospace;
            font-size: 12px;
            resize: vertical;
            outline: none;
        }
        .showdown-textarea:focus { border-color: var(--gold); }
        .showdown-textarea::placeholder { color: var(--text-dim); }
        .import-btn {
            margin-top: 8px;
            padding: 10px 20px;
            background: linear-gradient(135deg, var(--purple), #6366f1);
            border: none;
            border-radius: 8px;
            color: #fff;
            font-size: 12px;
            font-weight: 600;
            cursor: pointer;
        }

        /* Type Calculator */
        .type-calc {
            background: var(--bg-card);
            border-radius: 10px;
            padding: 14px;
        }
        .type-calc h4 {
            font-size: 12px;
            color: var(--gold);
            margin-bottom: 10px;
        }
        .weakness-grid {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
        }
        .weakness-item {
            padding: 4px 10px;
            border-radius: 6px;
            font-size: 10px;
            font-weight: 700;
        }
        .weakness-item.weak { background: rgba(239, 68, 68, 0.2); color: #ef4444; }
        .weakness-item.resist { background: rgba(34, 197, 94, 0.2); color: #22c55e; }
        .weakness-item.immune { background: rgba(107, 114, 128, 0.2); color: #6b7280; }

        /* Bot Selector */
        .bot-selector {
            padding: 16px 20px;
            border-top: 1px solid var(--border);
            background: var(--bg-elevated);
        }
        .bot-selector-label {
            font-size: 11px;
            font-weight: 700;
            color: var(--text-dim);
            text-transform: uppercase;
            letter-spacing: 1px;
            margin-bottom: 10px;
        }
        .game-tabs {
            display: flex;
            gap: 6px;
            margin-bottom: 12px;
            flex-wrap: wrap;
        }
        .game-tab {
            padding: 8px 14px;
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 8px;
            color: var(--text-muted);
            font-size: 11px;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.2s;
        }
        .game-tab:hover {
            border-color: var(--gold);
            color: var(--gold);
        }
        .game-tab.active {
            background: var(--gold);
            border-color: var(--gold);
            color: #000;
        }
        .bot-cards {
            display: flex;
            gap: 8px;
            flex-wrap: wrap;
        }
        .bot-card {
            display: flex;
            align-items: center;
            gap: 8px;
            padding: 10px 14px;
            background: var(--bg-card);
            border: 2px solid var(--border);
            border-radius: 10px;
            cursor: pointer;
            transition: all 0.2s;
            flex: 1;
            min-width: 140px;
        }
        .bot-card:hover {
            border-color: var(--gold);
            background: var(--bg-hover);
        }
        .bot-card.selected {
            border-color: var(--gold);
            background: rgba(212, 175, 55, 0.1);
            box-shadow: 0 0 15px rgba(212, 175, 55, 0.2);
        }
        .bot-card img {
            width: 36px;
            height: 36px;
            object-fit: contain;
        }
        .bot-card-info {
            flex: 1;
        }
        .bot-card-name {
            font-size: 13px;
            font-weight: 600;
            color: var(--text);
        }
        .bot-card-status {
            font-size: 10px;
            color: var(--green);
            display: flex;
            align-items: center;
            gap: 4px;
        }
        .bot-card-status::before {
            content: '';
            width: 6px;
            height: 6px;
            background: var(--green);
            border-radius: 50%;
        }
        .bot-status-indicator {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            margin-top: 8px;
            font-size: 12px;
            color: var(--text-muted);
        }
        .bot-status-dot {
            width: 8px;
            height: 8px;
            border-radius: 50%;
            background: var(--green);
            animation: pulse 2s infinite;
        }
        .bot-status-dot.offline {
            background: var(--red);
            animation: none;
        }
        @keyframes pulse {
            0%, 100% { opacity: 1; }
            50% { opacity: 0.5; }
        }

        /* Modal Footer */
        .modal-footer {
            padding: 16px 20px;
            border-top: 1px solid var(--border);
            display: flex;
            gap: 10px;
        }
        .btn {
            flex: 1;
            padding: 12px 16px;
            border-radius: 10px;
            font-size: 13px;
            font-weight: 700;
            cursor: pointer;
            transition: all 0.2s;
        }
        .btn-secondary {
            background: transparent;
            border: 1px solid var(--border);
            color: var(--text-muted);
        }
        .btn-primary {
            background: linear-gradient(135deg, var(--gold), var(--gold-dark));
            border: none;
            color: #000;
            flex: 2;
        }
        .btn-team { background: var(--green); border: none; color: #fff; }

        /* History Panel */
        .history-panel {
            position: fixed;
            top: 64px;
            right: 0;
            width: 320px;
            height: calc(100vh - 64px);
            background: var(--bg-card);
            border-left: 1px solid var(--border);
            transform: translateX(100%);
            transition: transform 0.3s;
            z-index: 90;
            display: flex;
            flex-direction: column;
        }
        .history-panel.visible { transform: translateX(0); }
        .history-header {
            padding: 16px;
            border-bottom: 1px solid var(--border);
            display: flex;
            align-items: center;
            justify-content: space-between;
        }
        .history-header h3 {
            font-family: 'Rajdhani', sans-serif;
            font-size: 18px;
            color: var(--gold);
        }
        .history-close {
            background: none;
            border: none;
            color: var(--text-dim);
            font-size: 20px;
            cursor: pointer;
        }
        .history-list {
            flex: 1;
            overflow-y: auto;
            padding: 12px;
        }
        .history-item {
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 12px;
            background: var(--bg-elevated);
            border: 1px solid var(--border);
            border-radius: 10px;
            margin-bottom: 8px;
            cursor: pointer;
            transition: all 0.2s;
        }
        .history-item:hover { border-color: var(--gold); }
        .history-item img { width: 45px; height: 45px; }
        .history-item .info { flex: 1; }
        .history-item .name { font-weight: 600; font-size: 13px; }
        .history-item .details { font-size: 10px; color: var(--text-dim); }
        .history-item .time { font-size: 9px; color: var(--text-dim); }
        .history-item .retrade-btn {
            padding: 6px 12px;
            background: var(--gold);
            border: none;
            border-radius: 6px;
            color: #000;
            font-size: 10px;
            font-weight: 600;
            cursor: pointer;
        }
        .history-empty {
            text-align: center;
            padding: 40px 20px;
            color: var(--text-dim);
            font-size: 13px;
        }

        /* Share Modal */
        .share-modal {
            position: fixed;
            top: 0; left: 0; right: 0; bottom: 0;
            background: rgba(0,0,0,0.8);
            display: none;
            align-items: center;
            justify-content: center;
            z-index: 250;
        }
        .share-modal.active { display: flex; }
        .share-content {
            background: var(--bg-elevated);
            border: 1px solid var(--border);
            border-radius: 16px;
            padding: 24px;
            width: 90%;
            max-width: 400px;
            text-align: center;
        }
        .share-content h3 {
            font-family: 'Rajdhani', sans-serif;
            font-size: 22px;
            color: var(--gold);
            margin-bottom: 16px;
        }
        .share-code {
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 8px;
            padding: 16px;
            font-family: monospace;
            font-size: 14px;
            word-break: break-all;
            margin-bottom: 16px;
        }
        .share-actions { display: flex; gap: 10px; }
        .share-actions button {
            flex: 1;
            padding: 12px;
            border-radius: 8px;
            font-size: 13px;
            font-weight: 600;
            cursor: pointer;
        }
        .share-actions .copy-btn {
            background: var(--gold);
            border: none;
            color: #000;
        }
        .share-actions .close-btn {
            background: transparent;
            border: 1px solid var(--border);
            color: var(--text-muted);
        }

        /* Toast */
        .toast-container {
            position: fixed;
            bottom: 100px;
            right: 24px;
            z-index: 300;
        }
        .toast {
            background: var(--bg-elevated);
            border: 1px solid var(--gold);
            border-radius: 10px;
            padding: 12px 18px;
            display: flex;
            align-items: center;
            gap: 10px;
            box-shadow: 0 10px 40px rgba(0,0,0,0.5);
            animation: toastIn 0.3s ease;
            margin-top: 8px;
        }
        @keyframes toastIn {
            from { transform: translateX(100%); opacity: 0; }
            to { transform: translateX(0); opacity: 1; }
        }

        /* Trade Confirmation Modal */
        .trade-confirmation-overlay {
            position: fixed;
            top: 0; left: 0; right: 0; bottom: 0;
            background: rgba(0,0,0,0.92);
            display: flex;
            align-items: center;
            justify-content: center;
            z-index: 10001;
            animation: fadeIn 0.2s ease;
            overflow-y: auto;
            padding: 20px;
        }
        @keyframes fadeIn {
            from { opacity: 0; }
            to { opacity: 1; }
        }
        .trade-confirmation {
            background: var(--bg-card);
            border: 1px solid var(--gold);
            border-radius: 16px;
            padding: 28px;
            max-width: 420px;
            width: 90%;
            text-align: center;
            box-shadow: 0 20px 60px rgba(212, 175, 55, 0.2);
            animation: scaleIn 0.3s ease;
        }
        @keyframes scaleIn {
            from { transform: scale(0.9); opacity: 0; }
            to { transform: scale(1); opacity: 1; }
        }
        .trade-conf-header {
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 10px;
            margin-bottom: 20px;
        }
        .trade-conf-header h3 {
            color: var(--green);
            font-size: 22px;
            font-weight: 700;
        }
        .trade-conf-pokemon {
            display: flex;
            align-items: center;
            gap: 16px;
            background: var(--bg-elevated);
            border-radius: 12px;
            padding: 16px;
            margin-bottom: 20px;
        }
        .trade-conf-pokemon img {
            width: 80px;
            height: 80px;
            object-fit: contain;
        }
        .trade-conf-pokemon .pokemon-details {
            text-align: left;
        }
        .trade-conf-pokemon h4 {
            font-size: 18px;
            color: var(--gold);
            margin-bottom: 4px;
        }
        .trade-conf-pokemon p {
            font-size: 13px;
            color: var(--text-muted);
        }
        .trade-conf-info {
            background: var(--bg-elevated);
            border-radius: 12px;
            padding: 16px;
            margin-bottom: 16px;
        }
        .trade-conf-info .info-row {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 8px 0;
            border-bottom: 1px solid var(--border);
        }
        .trade-conf-info .info-row:last-child {
            border-bottom: none;
        }
        .trade-conf-info .label {
            color: var(--text-muted);
            font-size: 13px;
        }
        .trade-conf-info .value {
            color: var(--text);
            font-weight: 600;
        }
        .link-code-row {
            padding: 12px 0 !important;
        }
        .link-code {
            font-family: 'JetBrains Mono', monospace;
            font-size: 20px;
            color: var(--gold) !important;
            letter-spacing: 3px;
        }
        .copy-btn {
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 6px;
            padding: 6px 8px;
            cursor: pointer;
            color: var(--text-muted);
            transition: all 0.2s;
            margin-left: 10px;
        }
        .copy-btn:hover {
            border-color: var(--gold);
            color: var(--gold);
        }
        .trade-conf-note {
            font-size: 13px;
            color: var(--text-muted);
            margin-bottom: 20px;
            line-height: 1.5;
        }
        .trade-conf-close {
            width: 100%;
            padding: 14px 24px;
            background: linear-gradient(135deg, var(--gold), var(--gold-dark));
            border: none;
            border-radius: 10px;
            color: #000;
            font-size: 15px;
            font-weight: 700;
            cursor: pointer;
            transition: all 0.2s;
        }
        .trade-conf-close:hover {
            box-shadow: 0 0 30px rgba(212, 175, 55, 0.4);
            transform: translateY(-2px);
        }

        /* Loading */
        .loading {
            display: flex;
            align-items: center;
            justify-content: center;
            padding: 60px;
        }
        .spinner {
            width: 40px;
            height: 40px;
            border: 3px solid var(--border);
            border-top-color: var(--gold);
            border-radius: 50%;
            animation: spin 1s linear infinite;
        }
        @keyframes spin { to { transform: rotate(360deg); } }

        /* Reduced motion preference - improves accessibility and performance */
        @media (prefers-reduced-motion: reduce) {
            .bg-orb, .sparkle, .spinner { animation: none; }
            .poke-card, .header-btn, .type-btn, .gen-btn, .toggle-switch { transition: none; }
        }

        /* Mobile */
        @media (max-width: 1024px) {
            .sidebar { transform: translateX(-280px); }
            .sidebar.visible { transform: translateX(0); }
            .content { margin-left: 0; }
            .team-panel { left: 0; }
            .history-panel { width: 100%; }
        }
        @media (max-width: 768px) {
            .header { padding: 0 12px; gap: 8px; }
            .search-box { display: none; }
            .header-btn { padding: 6px 10px; font-size: 11px; }
            .content { padding: 12px; }
            .form-grid { grid-template-columns: 1fr; }
            .form-group.full-width { grid-column: span 1; }
            .stats-grid { grid-template-columns: repeat(2, 1fr); }
            .modal-hero { flex-direction: column; text-align: center; }
            .team-slots { flex-wrap: wrap; justify-content: center; }
            .team-slot { width: 60px; height: 60px; }
        }

        /* ========== MOBILE RESPONSIVE - CREATE MODE ========== */
        @media (max-width: 900px) {
            /* Mode tabs responsive */
            #browseTab, #createTab, #importTab {
                padding: 10px 16px !important;
                font-size: 12px !important;
            }

            /* Create mode main grid - stack vertically (was nth-child(3), fixed to use ID) */
            #creatorMainGrid {
                display: flex !important;
                flex-direction: column !important;
            }

            /* Pokemon selector becomes full width */
            #creatorMainGrid > div:first-child {
                width: 100% !important;
                max-height: 350px !important;
                border-right: none !important;
                border-bottom: 1px solid var(--border) !important;
            }

            /* Pokemon grid 4 columns on tablet */
            #creatorPokemonGrid {
                grid-template-columns: repeat(4, 1fr) !important;
                max-height: 280px !important;
            }

            /* Right panel full width */
            #creatorMainGrid > div:last-child {
                width: 100% !important;
            }

            /* Preview + Game selection stack */
            #creatorMainGrid > div:last-child > div:first-child {
                grid-template-columns: 1fr !important;
                gap: 16px !important;
            }
        }

        @media (max-width: 600px) {
            /* Mode tabs smaller */
            #browseTab, #createTab, #importTab {
                padding: 8px 12px !important;
                font-size: 11px !important;
            }

            /* Pokemon grid 3 columns on mobile */
            #creatorPokemonGrid {
                grid-template-columns: repeat(3, 1fr) !important;
                gap: 8px !important;
            }

            /* Smaller pokemon cards */
            .creator-pokemon-card {
                padding: 8px 4px !important;
            }
            .creator-pokemon-card img {
                width: 48px !important;
                height: 48px !important;
            }

            /* Type filters scroll horizontally */
            #creatorTypeFilters {
                flex-wrap: nowrap !important;
                overflow-x: auto !important;
                padding-bottom: 8px !important;
                -webkit-overflow-scrolling: touch;
            }
            #creatorTypeFilters::-webkit-scrollbar { height: 4px; }
            #creatorTypeFilters::-webkit-scrollbar-thumb { background: var(--green); border-radius: 2px; }

            /* Gen filters smaller */
            .gen-btn {
                padding: 4px 8px !important;
                font-size: 9px !important;
            }

            /* Stack preview + game selection vertically on mobile */
            #creatorMainGrid > div:last-child > div:first-child,
            [style*="grid-template-columns: 1fr 1fr; gap: 20px"] {
                grid-template-columns: 1fr !important;
                gap: 16px !important;
            }

            /* Preview card smaller */
            #creatorPreviewCard {
                padding: 16px !important;
            }
            #creatorSprite {
                width: 120px !important;
                height: 120px !important;
            }
            #creatorPokeName {
                font-size: 20px !important;
            }

            /* Toggle buttons stack */
            #creatorPreviewCard > div:last-child {
                flex-wrap: wrap !important;
            }
            #creatorShinyBtn, #creatorSquareBtn {
                padding: 8px 14px !important;
                font-size: 12px !important;
            }

            /* Game grid 3 columns */
            #creatorGameGrid {
                grid-template-columns: repeat(3, 1fr) !important;
            }

            /* Stats tab grids */
            #creatorIVSliders, #creatorEVSliders {
                grid-template-columns: 1fr !important;
            }

            /* Ball grid 4 columns */
            #creatorBallGrid {
                grid-template-columns: repeat(4, 1fr) !important;
            }

            /* Tera type grid 6 columns */
            #creatorTeraGrid {
                grid-template-columns: repeat(6, 1fr) !important;
            }

            /* Trade button full width */
            #creatorTradeBtn {
                width: 100% !important;
            }
        }

        @media (max-width: 400px) {
            /* Extra small phones */
            #creatorPokemonGrid {
                grid-template-columns: repeat(2, 1fr) !important;
            }

            .creator-pokemon-card img {
                width: 40px !important;
                height: 40px !important;
            }

            #creatorSprite {
                width: 100px !important;
                height: 100px !important;
            }

            #creatorGameGrid {
                grid-template-columns: repeat(2, 1fr) !important;
            }

            #creatorTeraGrid {
                grid-template-columns: repeat(4, 1fr) !important;
            }
        }

        /* Touch-friendly improvements */
        @media (hover: none) and (pointer: coarse) {
            .creator-pokemon-card {
                min-height: 90px;
            }
            button, .creator-pokemon-card {
                -webkit-tap-highlight-color: transparent;
            }
            #creatorSearch {
                font-size: 16px !important; /* Prevents zoom on iOS */
            }
        }

        /* PKM Universe Navigation */
        .nav-container {
            position: fixed;
            top: 20px;
            left: 50%;
            transform: translateX(-50%);
            z-index: 1000;
            width: auto;
            max-width: 95%;
        }

        .nav {
            background: rgba(10, 10, 15, 0.95);
            backdrop-filter: blur(20px);
            border: 1px solid rgba(212, 175, 55, 0.2);
            border-radius: 50px;
            padding: 10px 24px;
            display: flex;
            align-items: center;
            gap: 8px;
            box-shadow: 0 4px 30px rgba(0, 0, 0, 0.5);
        }

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

        .pokeball-logo {
            width: 36px;
            height: 36px;
            background: linear-gradient(180deg, #ff1a1a 50%, #fff 50%);
            border-radius: 50%;
            position: relative;
            box-shadow: 0 0 20px rgba(212, 175, 55, 0.5);
        }

        .pokeball-logo::before {
            content: '';
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            width: 12px;
            height: 12px;
            background: #fff;
            border: 3px solid #333;
            border-radius: 50%;
        }

        .pokeball-logo::after {
            content: '';
            position: absolute;
            top: 50%;
            left: 0;
            right: 0;
            height: 4px;
            background: #333;
            transform: translateY(-50%);
        }

        .nav-brand {
            font-family: 'Orbitron', sans-serif;
            font-size: 18px;
            font-weight: 900;
            background: linear-gradient(135deg, #f0d875, #d4af37, #b8941f);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
            letter-spacing: 2px;
        }

        .nav-links {
            display: flex;
            gap: 10px;
            align-items: center;
        }

        .nav-link {
            color: #888;
            text-decoration: none;
            padding: 8px 16px;
            border-radius: 25px;
            font-weight: 600;
            font-size: 14px;
            transition: all 0.3s;
            position: relative;
        }

        .nav-link:hover {
            color: var(--gold);
            background: rgba(212, 175, 55, 0.1);
        }

        /* Dropdown Menu */
        .nav-dropdown {
            position: relative;
        }

        .nav-dropdown-menu {
            position: absolute;
            top: 100%;
            left: 50%;
            transform: translateX(-50%);
            min-width: 220px;
            max-height: 70vh;
            overflow-y: auto;
            background: rgba(10, 10, 15, 0.98);
            backdrop-filter: blur(20px);
            border: 1px solid var(--border);
            border-radius: 16px;
            padding: 12px;
            margin-top: 10px;
            opacity: 0;
            visibility: hidden;
            transition: all 0.3s;
            z-index: 1001;
            box-shadow: 0 10px 40px rgba(0, 0, 0, 0.5);
            display: grid;
            grid-template-columns: 1fr;
            gap: 2px;
        }
        .mega-item-simple {
            display: block;
            padding: 8px 12px;
            text-decoration: none;
            border-radius: 8px;
            transition: all 0.2s;
            color: inherit;
        }
        .mega-item-simple:hover {
            background: rgba(212, 175, 55, 0.06);
        }
        .mega-item-simple h4 {
            color: #d4af37;
            font-size: .75rem;
            font-weight: 600;
            margin: 0;
        }
        .mega-item-simple p {
            color: #666;
            font-size: .6rem;
            margin: 2px 0 0;
        }

        .nav-dropdown:hover .nav-dropdown-menu {
            opacity: 1;
            visibility: visible;
        }

        .nav-dropdown-menu::before {
            content: '';
            position: absolute;
            top: -8px;
            left: 50%;
            transform: translateX(-50%);
            border-left: 8px solid transparent;
            border-right: 8px solid transparent;
            border-bottom: 8px solid var(--border);
        }

        .dropdown-item {
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 12px 16px;
            color: var(--text-muted);
            text-decoration: none;
            border-radius: 10px;
            font-size: 14px;
            transition: all 0.2s;
        }

        .dropdown-item:hover {
            background: rgba(212, 175, 55, 0.1);
            color: var(--gold);
        }

        .dropdown-item svg {
            width: 18px;
            height: 18px;
            opacity: 0.7;
        }

        .dropdown-item:hover svg {
            opacity: 1;
            color: var(--cyan);
        }

        .dropdown-item-badge {
            margin-left: auto;
            padding: 2px 8px;
            background: var(--cyan);
            color: #000;
            font-size: 10px;
            font-weight: 700;
            border-radius: 10px;
        }

        .dropdown-divider {
            height: 1px;
            background: var(--border);
            margin: 8px 0;
        }

        .nav-divider {
            color: #333;
            margin: 0 5px;
        }

        .nav-notifications {
            position: relative;
            width: 40px;
            height: 40px;
            display: flex;
            align-items: center;
            justify-content: center;
            cursor: pointer;
            border-radius: 50%;
            transition: all 0.3s;
            color: #888;
        }

        .nav-notifications:hover {
            background: rgba(212, 175, 55, 0.1);
            color: var(--gold);
        }

        .notification-badge {
            position: absolute;
            top: 5px;
            right: 5px;
            width: 16px;
            height: 16px;
            background: #ef4444;
            border-radius: 50%;
            font-size: 10px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-weight: 700;
            color: #fff;
        }

        /* Dropdown Arrow */
        .dropdown-arrow {
            font-size: 10px;
            margin-left: 4px;
            opacity: 0.6;
        }

        .nav-link.has-dropdown:hover .dropdown-arrow {
            opacity: 1;
        }

        /* Theme Circles */
        .theme-circles {
            display: flex;
            gap: 8px;
            margin-left: 8px;
        }

        .theme-circle {
            width: 28px;
            height: 28px;
            border-radius: 50%;
            cursor: pointer;
            transition: all 0.3s;
            box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
        }

        .theme-circle:hover {
            transform: scale(1.15);
            box-shadow: 0 4px 15px rgba(0, 0, 0, 0.4);
        }

        .theme-gold { background: linear-gradient(135deg, #d4af37, #b8941f); }
        .theme-cyan { background: linear-gradient(135deg, #06b6d4, #0891b2); }
        .theme-purple { background: linear-gradient(135deg, #a855f7, #7c3aed); }

        /* Mobile Navigation */
        .hamburger-btn { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: 8px; border: none; background: none; z-index: 10001; }
        .hamburger-btn span { display: block; width: 24px; height: 2px; background: var(--gold, #d4af37); border-radius: 2px; transition: all 0.3s; }
        .hamburger-btn.active span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
        .hamburger-btn.active span:nth-child(2) { opacity: 0; }
        .hamburger-btn.active span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }
        .mobile-nav-overlay { display: none; position: fixed; inset: 0; background: rgba(10, 10, 15, 0.98); z-index: 9998; padding: 80px 30px 30px; overflow-y: auto; }
        .mobile-nav-overlay.active { display: block; }
        .mobile-nav-overlay a { display: block; color: #fff; text-decoration: none; padding: 16px 20px; font-size: 18px; font-weight: 600; border-bottom: 1px solid rgba(212, 175, 55, 0.1); transition: all 0.2s; }
        .mobile-nav-overlay a:hover { color: #d4af37; background: rgba(212, 175, 55, 0.05); }
        .mobile-nav-overlay .mobile-nav-section { display: block; color: #d4af37; font-size: 12px; text-transform: uppercase; letter-spacing: 2px; padding: 20px 20px 8px; }
        @media (max-width: 768px) {
            .hamburger-btn { display: flex !important; }
            .nav-notifications { display: none !important; }
            .theme-circles { display: none !important; }
            .theme-switcher { display: none !important; }
            .nav-container { top: 0; left: 0; right: 0; transform: none; width: 100%; max-width: 100%; z-index: 9999; padding: 0; }
            .nav { border-radius: 0; padding: 6px 12px; gap: 4px; width: 100%; flex-wrap: wrap; box-sizing: border-box; }
            .nav-brand { display: block !important; font-size: 12px; }
            .nav-logo { gap: 5px; width: auto; flex-shrink: 0; }
            .pokeball-logo { width: 20px; height: 20px; }
            .nav-links { display: flex !important; flex-wrap: nowrap; gap: 2px; width: 100%; order: 10; overflow: visible; justify-content: space-around; }
            .nav-links .nav-link { font-size: 10px; padding: 4px 6px; white-space: nowrap; cursor: pointer; }
            .nav-dropdown-menu { position: fixed !important; top: 70px !important; left: 8px !important; right: 8px !important; transform: none !important; min-width: 0 !important; width: auto !important; z-index: 99999 !important; }
            .nav-links > .nav-divider { display: none !important; }
            .nav-desktop-only { display: none !important; }
            /* Mobile Performance */
            .cyber-grid { display: none !important; }
            .bg-orb { filter: blur(20px) !important; opacity: 0.1 !important; animation: none !important; }
            .particles-container { display: none !important; }
            .glow-line { display: none !important; }
            /* Fix horizontal overflow */
            .sticky-top-section, .content, .main-container, section, footer {
                max-width: 100vw !important;
                overflow-x: hidden !important;
                box-sizing: border-box !important;
            }
            .sticky-top-section h1 {
                font-size: clamp(24px, 6vw, 48px) !important;
                word-break: break-word !important;
            }
            .sticky-top-section [style*="display: flex"] {
                flex-wrap: wrap !important;
                justify-content: center !important;
            }
        }
        @media (max-width: 480px) {
            .bg-effects { display: none !important; }
        }

        /* ========== COMPREHENSIVE MOBILE RESPONSIVE ========== */
        @media (max-width: 768px) {
            /* CRITICAL: Prevent horizontal scroll (clip works on iOS, hidden does not) */
            html, body {
                overflow-x: clip !important;
                max-width: 100vw !important;
                width: 100% !important;
            }

            /* Force all direct children to respect viewport */
            .main-layout {
                max-width: 100vw !important;
                overflow-x: clip !important;
                width: 100% !important;
            }

            /* Main content - reduce padding */
            .content {
                padding: 60px 12px 24px 12px !important;
                max-width: 100vw !important;
                width: 100% !important;
                overflow-x: clip !important;
            }
            .content.expanded {
                padding: 100px 12px 20px 12px !important;
            }

            .sticky-top-section { padding-top: 70px !important; }

            /* Hero container - compress vertical space */
            .sticky-top-section > div:first-child {
                margin-bottom: 12px !important;
                padding: 8px 0 !important;
            }
            /* LIVE TRADING badge */
            .sticky-top-section [style*="margin-bottom: 24px"] {
                margin-bottom: 8px !important;
                padding: 5px 14px !important;
            }
            /* TRADE HUB title */
            .sticky-top-section h1 {
                font-size: clamp(28px, 6vw, 48px) !important;
                margin-bottom: 8px !important;
                letter-spacing: 2px !important;
            }
            /* Subtitle */
            .sticky-top-section p[style*="margin: 0 auto 32px"] {
                margin-bottom: 12px !important;
                font-size: 14px !important;
            }
            /* Hero stat cards row */
            .sticky-top-section [style*="margin-bottom: 32px"] {
                margin-bottom: 10px !important;
            }
            .sticky-top-section [style*="padding: 24px 40px"] {
                padding: 12px 16px !important;
            }
            .sticky-top-section [style*="font-size: 36px"] {
                font-size: 20px !important;
            }
            .sticky-top-section [style*="gap: 24px"] {
                gap: 8px !important;
            }
            /* View mode buttons */
            .sticky-top-section [style*="gap: 16px; flex-wrap"] {
                gap: 8px !important;
            }
            .sticky-top-section [style*="padding: 14px 28px"] {
                padding: 8px 14px !important;
                font-size: 12px !important;
            }
            /* Mode tabs container - reduce top margin */
            #modeTabsContainer {
                margin-top: 12px !important;
                padding-top: 6px !important;
            }
            /* Mode tab buttons - smaller on mobile */
            #browseTab, #createTab, #importTab {
                padding: 10px 14px !important;
                font-size: 12px !important;
            }

            /* Pokemon grid - 2 columns on mobile */
            .pokemon-grid {
                grid-template-columns: repeat(2, 1fr) !important;
                gap: 10px !important;
            }
            .pokemon-grid.compact-view {
                grid-template-columns: repeat(3, 1fr) !important;
                gap: 8px !important;
            }

            /* Pokemon cards smaller */
            .poke-card {
                padding: 16px 12px !important;
            }
            .poke-card .poke-img {
                width: 80px !important;
                height: 80px !important;
            }
            .poke-card .name {
                font-size: 13px !important;
            }
            .poke-card .number {
                font-size: 11px !important;
            }
            .type-tag {
                padding: 3px 8px !important;
                font-size: 9px !important;
            }

            /* Game cards - 2 columns, override inline style */
            .game-cards {
                grid-template-columns: repeat(2, 1fr) !important;
                gap: 10px !important;
            }
            .game-card {
                padding: 14px !important;
            }

            /* Dashboard grid - single column */
            .dashboard-grid {
                grid-template-columns: 1fr !important;
                gap: 12px !important;
            }

            /* Quick trade grid - 2 columns */
            .quick-trade-grid {
                grid-template-columns: repeat(2, 1fr) !important;
                gap: 8px !important;
            }

            /* Stats bar - wrap properly */
            .stats-bar {
                gap: 8px !important;
            }
            .stat-pill {
                padding: 8px 12px !important;
                flex: 1 1 auto !important;
                min-width: 0 !important;
            }
            .stat-pill .value {
                font-size: 16px !important;
            }
            .stat-pill .label {
                font-size: 10px !important;
            }

            /* View controls */
            .view-controls {
                gap: 6px !important;
            }

            /* Premium toggles - wrap and full width */
            .premium-toggle {
                padding: 10px 14px !important;
            }
            [style*="flex-wrap: wrap; gap: 20px; padding-top: 20px"] {
                gap: 8px !important;
            }

            /* Create mode - CRITICAL: stack 320px sidebar (ID + attribute for reliability) */
            #creatorMainGrid,
            [style*="grid-template-columns: 320px 1fr"] {
                display: flex !important;
                flex-direction: column !important;
                min-height: auto !important;
            }
            /* Create mode left panel */
            #creatorMainGrid > div:first-child,
            [style*="grid-template-columns: 320px 1fr"] > div:first-child {
                max-height: 350px !important;
                border-right: none !important;
                border-bottom: 1px solid var(--border) !important;
                width: 100% !important;
            }

            /* Import mode grid - stack columns */
            [style*="grid-template-columns: 1fr 1fr; gap: 24px"] {
                grid-template-columns: 1fr !important;
                gap: 16px !important;
            }

            /* Import game cards */
            #importGameCards {
                grid-template-columns: repeat(2, 1fr) !important;
            }

            /* Batch list */
            #batchList {
                grid-template-columns: 1fr !important;
            }

            /* Create mode inner grids */
            [style*="grid-template-columns: 1fr 1fr; gap: 20px"] {
                grid-template-columns: 1fr !important;
                gap: 12px !important;
            }
            [style*="grid-template-columns: 2fr 1fr; gap: 12px"] {
                grid-template-columns: 1fr !important;
            }
            [style*="grid-template-columns: repeat(3, 1fr); gap: 8px"] {
                grid-template-columns: repeat(2, 1fr) !important;
            }

            /* Create mode IV/EV grids */
            #creatorIVs {
                grid-template-columns: repeat(2, 1fr) !important;
            }
            #creatorEVs {
                grid-template-columns: repeat(3, 1fr) !important;
            }
            #evBars {
                grid-template-columns: repeat(3, 1fr) !important;
            }

            /* Ball/item/tera grids */
            #ballGrid {
                grid-template-columns: repeat(5, 1fr) !important;
            }
            #teraGrid {
                grid-template-columns: repeat(6, 1fr) !important;
            }

            /* Showdown textarea */
            #showdownInput, #quickShowdownInput {
                font-size: 12px !important;
                height: 250px !important;
            }

            /* Showdown preview section */
            [style*="grid-template-columns: 1fr 1fr; gap: 16px"] {
                grid-template-columns: 1fr !important;
                gap: 10px !important;
            }

            /* Move inputs */
            [style*="grid-template-columns: repeat(2, 1fr); gap: 12px"] {
                grid-template-columns: 1fr !important;
                gap: 8px !important;
            }

            /* Sprite in creator */
            #creatorSprite {
                width: 120px !important;
                height: 120px !important;
            }

            /* Team panel - full width */
            .team-panel {
                left: 0 !important;
                padding: 12px !important;
            }
            .team-slots {
                flex-wrap: wrap !important;
                justify-content: center !important;
                gap: 8px !important;
            }
            .team-slot {
                width: 55px !important;
                height: 55px !important;
            }
            .team-slot img {
                width: 42px !important;
                height: 42px !important;
            }

            /* Modal - full width on mobile */
            .modal-overlay {
                padding: 10px !important;
            }
            .modal {
                max-width: 100% !important;
                border-radius: 14px !important;
            }
            .modal-hero {
                padding: 16px !important;
                gap: 14px !important;
            }
            .modal-pokemon-img {
                width: 100px !important;
                height: 100px !important;
            }

            /* History panel - full width */
            .history-panel {
                width: 100% !important;
                top: 0 !important;
                height: 100vh !important;
            }

            /* Step sections */
            .step-section {
                padding: 16px !important;
                border-radius: 12px !important;
                overflow: hidden !important;
            }
            .step-header {
                gap: 10px !important;
            }
            .step-title {
                font-size: 13px !important;
            }

            /* Mode bars */
            .mode-bar {
                padding: 10px 12px !important;
                gap: 8px !important;
            }

            /* Quick filter buttons */
            .quick-filters {
                overflow-x: auto !important;
                flex-wrap: nowrap !important;
                -webkit-overflow-scrolling: touch;
                padding-bottom: 6px !important;
            }
            .quick-filter-btn {
                white-space: nowrap !important;
                flex-shrink: 0 !important;
            }

            /* Type scroll */
            .type-scroll {
                -webkit-overflow-scrolling: touch !important;
            }

            /* Shortcuts help - hide on mobile */
            .shortcuts-help-btn {
                display: none !important;
            }

            /* Keyboard hints - hide on mobile */
            .kbd-hint {
                display: none !important;
            }

            /* Pokedex iframe container */
            [style*="height: calc(100vh - 200px)"] {
                min-height: 400px !important;
            }

            /* === ADDITIONAL MOBILE FIXES === */

            /* Explicit game grid 2 columns (replace fragile attribute selector) */
            #creatorGameGrid {
                grid-template-columns: repeat(2, 1fr) !important;
            }

            /* Hide mode bar on mobile (match showdown-trader) */
            .mode-bar {
                display: none !important;
            }

            /* Step sections overflow protection */
            .step-section {
                overflow: hidden !important;
            }

            /* Creator action buttons - wrap on tablet */
            #createMode [style*="display: flex; gap: 12px; justify-content: center"] {
                flex-wrap: wrap !important;
            }
            #createMode [style*="display: flex; gap: 12px; justify-content: center"] button {
                flex: 1 1 auto !important;
                min-width: 140px !important;
            }

            /* Advanced tab checkboxes - smaller on mobile */
            #contentAdvanced [style*="display: flex; flex-wrap: wrap; gap: 8px"] label {
                font-size: 11px !important;
                padding: 6px 10px !important;
            }
        }

        @media (max-width: 480px) {
            /* Extra small phones */
            .content {
                padding: 52px 8px 16px 8px !important;
            }
            .content.expanded {
                padding: 52px 8px 16px 8px !important;
            }

            /* Hide subtitle and stats on small phones - save space */
            .sticky-top-section p[style*="margin: 0 auto 32px"] {
                display: none !important;
            }
            .sticky-top-section > div:first-child > div[style*="margin-bottom: 32px"] {
                display: none !important;
            }

            /* Hero even more compact */
            .sticky-top-section > div:first-child {
                margin-bottom: 8px !important;
                padding: 4px 0 !important;
            }
            .sticky-top-section h1 {
                font-size: 24px !important;
                margin-bottom: 6px !important;
            }
            .sticky-top-section [style*="padding: 24px 40px"] {
                padding: 10px 12px !important;
            }
            .sticky-top-section [style*="font-size: 36px"] {
                font-size: 18px !important;
            }

            /* View buttons smaller */
            .sticky-top-section [style*="padding: 14px 28px"] {
                padding: 6px 10px !important;
                font-size: 11px !important;
            }

            /* Mode tabs even smaller */
            #modeTabsContainer {
                margin-top: 8px !important;
            }
            #browseTab, #createTab, #importTab {
                padding: 8px 10px !important;
                font-size: 11px !important;
                gap: 6px !important;
            }

            /* Pokemon grid - still 2 columns but tighter */
            .pokemon-grid {
                gap: 8px !important;
            }
            .poke-card {
                padding: 12px 8px !important;
            }
            .poke-card .poke-img {
                width: 65px !important;
                height: 65px !important;
            }
            .poke-card .name {
                font-size: 12px !important;
            }

            /* Game cards */
            .game-cards {
                grid-template-columns: 1fr 1fr !important;
            }
            .game-card {
                padding: 12px !important;
            }

            /* Stat pills smaller */
            .stat-pill {
                padding: 6px 8px !important;
            }
            .stat-pill .value {
                font-size: 14px !important;
            }

            /* Queue number */
            .queue-number {
                font-size: 40px !important;
            }

            /* Batch items */
            .batch-item img {
                width: 36px !important;
                height: 36px !important;
            }
            .batch-item-name {
                font-size: 12px !important;
            }

            /* Quick trade items */
            .quick-trade-item {
                padding: 10px !important;
            }
            .quick-trade-item img {
                width: 36px !important;
                height: 36px !important;
            }

            /* Creator pokemon grid */
            #creatorPokemonGrid {
                grid-template-columns: repeat(3, 1fr) !important;
            }

            /* Creator EV grid */
            #creatorEVs {
                grid-template-columns: repeat(2, 1fr) !important;
            }

            /* Step sections tighter on small phones */
            .step-section {
                padding: 12px !important;
            }

            /* Creator game grid 2 columns */
            #creatorGameGrid {
                grid-template-columns: repeat(2, 1fr) !important;
            }

            /* Creator tabs smaller on small phones */
            .creator-tab {
                padding: 10px 6px !important;
                font-size: 10px !important;
            }

            /* Creator action buttons - stack vertically */
            #createMode [style*="display: flex; gap: 12px; justify-content: center"] {
                flex-direction: column !important;
                gap: 8px !important;
            }
            #createMode [style*="display: flex; gap: 12px; justify-content: center"] button {
                width: 100% !important;
            }

            /* EV preset buttons wrap */
            #contentStats [style*="display: flex; gap: 6px"] {
                flex-wrap: wrap !important;
            }

            /* Gen filter buttons wrap */
            [style*="display: flex; gap: 4px; margin-bottom: 12px"] {
                flex-wrap: wrap !important;
            }
            .gen-btn {
                padding: 4px 7px !important;
                font-size: 9px !important;
            }
        }

        @media (max-width: 360px) {
            /* Tiny phones */
            .pokemon-grid {
                grid-template-columns: repeat(2, 1fr) !important;
            }
            .poke-card .poke-img {
                width: 55px !important;
                height: 55px !important;
            }
            .game-cards {
                grid-template-columns: 1fr !important;
            }
            #browseTab, #createTab, #importTab {
                padding: 8px 10px !important;
                font-size: 10px !important;
            }

            /* Creator tabs even smaller on tiny phones */
            .creator-tab {
                padding: 8px 4px !important;
                font-size: 9px !important;
                letter-spacing: -0.3px !important;
            }
        }

        /* ========== TOUCH DEVICE FIXES (iOS + Android) ========== */
        @media (hover: none) and (pointer: coarse) {
            /* Disable hover effects that get stuck on touch */
            .poke-card:hover {
                transform: none !important;
                box-shadow: none !important;
            }
            .poke-card:hover .poke-img {
                transform: none !important;
            }
            .game-card:hover {
                transform: none !important;
            }
            .tilt-card:hover {
                transform: none !important;
            }

            /* Make tap targets bigger */
            .type-btn, .gen-btn, .quick-filter-btn {
                min-height: 40px !important;
            }

            /* Smooth scrolling for iOS */
            .content, .modal, .history-panel, .type-scroll {
                -webkit-overflow-scrolling: touch !important;
            }

            /* Hide cursor-related effects */
            .cyber-grid {
                display: none !important;
            }

            /* Fix iOS input zoom (font-size < 16px causes zoom) */
            input, select, textarea {
                font-size: 16px !important;
            }

            /* Prevent iOS rubber-band bounce causing layout issues */
            .main-layout {
                overflow-x: hidden !important;
            }
        }

/* ========== BANNER SHARED ========== */
.pkm-banner-close {
  position: absolute; top: 12px; right: 16px;
  background: none; border: none; color: #555; font-size: 20px; cursor: pointer; padding: 4px; z-index: 10;
}
.pkm-banner-close:hover { color: #fff; }
@keyframes gradientShift {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}
.gradient-text {
  background: linear-gradient(90deg, #d4af37, #f0d875, #fff, #f0d875, #d4af37);
  background-size: 300% 100%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: gradientShift 4s ease infinite;
}

/* ========== OPTION 9: Upgraded Hero Banner ========== */
@keyframes gradientShift {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}
.gradient-text {
  background: linear-gradient(90deg, #d4af37, #f0d875, #fff, #f0d875, #d4af37);
  background-size: 300% 100%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: gradientShift 4s ease infinite;
}

.banner-9 {
  position: relative;
  max-width: 1200px;
  margin: 100px auto 30px;
  padding: 0;
  background: linear-gradient(135deg, #0f0f20 0%, #1a1435 25%, #0d1025 50%, #141028 75%, #12121f 100%);
  border: 1px solid rgba(212, 175, 55, 0.25);
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 8px 40px rgba(0, 0, 0, 0.5), 0 0 60px rgba(212, 175, 55, 0.05);
}
.b9-particles {
  position: absolute;
  top: 0; left: 0; width: 100%; height: 100%;
  pointer-events: none;
  z-index: 0;
}
.b9-particle {
  position: absolute;
  border-radius: 50%;
  animation: b9Float linear infinite;
}
@keyframes b9Float {
  0% { transform: translateY(0) translateX(0); opacity: 0; }
  10% { opacity: var(--p-opacity); }
  90% { opacity: var(--p-opacity); }
  100% { transform: translateY(-100px) translateX(30px); opacity: 0; }
}

.b9-glass-panel {
  position: absolute;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,0.03);
  background: rgba(255,255,255,0.01);
  backdrop-filter: blur(2px);
  pointer-events: none;
  z-index: 0;
}
.b9-glass-1 { width: 300px; height: 200px; top: -40px; right: -30px; transform: rotate(15deg); }
.b9-glass-2 { width: 200px; height: 150px; bottom: -30px; left: 10%; transform: rotate(-10deg); }

.b9-inner {
  position: relative;
  z-index: 1;
  padding: 32px 50px 32px 32px;
  display: flex;
  align-items: center;
  gap: 28px;
  transition: transform 0.15s ease;
}

/* Pokeball CSS icon */
.b9-pokeball-wrap { position: relative; width: 64px; height: 64px; flex-shrink: 0; }
.b9-pokeball {
  width: 56px; height: 56px;
  border-radius: 50%;
  position: relative;
  overflow: hidden;
  border: 3px solid rgba(212,175,55,0.5);
  box-shadow: 0 0 20px rgba(212,175,55,0.2);
}
.b9-pokeball-top {
  position: absolute; top: 0; left: 0; width: 100%; height: 50%;
  background: linear-gradient(135deg, #ee1515, #cc0000);
}
.b9-pokeball-bottom {
  position: absolute; bottom: 0; left: 0; width: 100%; height: 50%;
  background: linear-gradient(135deg, #f0f0f0, #ddd);
}
.b9-pokeball-center {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  width: 16px; height: 16px; border-radius: 50%;
  background: #fff; border: 3px solid rgba(212,175,55,0.6);
  z-index: 2;
  box-shadow: 0 0 10px rgba(212,175,55,0.4);
}
.b9-pokeball-glow {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  width: 80px; height: 80px; border-radius: 50%;
  background: radial-gradient(circle, rgba(212,175,55,0.2), transparent 70%);
  animation: b9PulseGlow 2.5s ease-in-out infinite;
  pointer-events: none;
}
@keyframes b9PulseGlow {
  0%, 100% { transform: translate(-50%, -50%) scale(1); opacity: 0.5; }
  50% { transform: translate(-50%, -50%) scale(1.3); opacity: 1; }
}

.b9-content { flex: 1; }

.b9-live-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 12px;
  background: rgba(16, 185, 129, 0.1);
  border: 1px solid rgba(16, 185, 129, 0.3);
  border-radius: 20px;
  font-size: 0.65rem; font-weight: 800; color: #10b981;
  letter-spacing: 2px; text-transform: uppercase;
  font-family: 'Orbitron', sans-serif;
  margin-bottom: 12px;
}
.b9-live-dot {
  width: 8px; height: 8px; border-radius: 50%; background: #10b981;
  animation: b9LivePulse 1.5s ease-in-out infinite;
}
@keyframes b9LivePulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(16,185,129,0.5); }
  50% { box-shadow: 0 0 0 5px rgba(16,185,129,0); }
}

.b9-title {
  font-family: 'Orbitron', sans-serif;
  font-size: 1.5rem;
  font-weight: 800;
  margin-bottom: 10px;
  line-height: 1.3;
}
.b9-desc {
  font-size: 0.88rem; color: #999; line-height: 1.6;
  margin-bottom: 16px; max-width: 600px;
}

.b9-tags { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 14px; }
.b9-tag {
  padding: 5px 12px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 20px;
  font-size: 0.72rem; color: #bbb;
  display: flex; align-items: center; gap: 6px;
  transition: all 0.3s;
}
.b9-tag:hover {
  border-color: rgba(212,175,55,0.3);
  background: rgba(212,175,55,0.06);
}
.b9-tag .tag-dot { width: 6px; height: 6px; border-radius: 50%; }

@keyframes b9TagFadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
.b9-tag-anim {
  opacity: 0;
  animation: b9TagFadeIn 0.5s ease forwards;
}

.b9-user-cluster {
  display: flex; align-items: center; gap: 14px;
  margin-top: 4px;
}
.b9-avatars { display: flex; align-items: center; }
.b9-avatar {
  width: 36px; height: 36px; border-radius: 50%;
  border: 2.5px solid rgba(212, 175, 55, 0.4);
  margin-left: -10px;
  background: linear-gradient(135deg, #1a1a2e, #12121f);
  object-fit: cover;
  transition: all 0.3s;
  box-shadow: 0 2px 8px rgba(0,0,0,0.4);
}
.b9-avatar:first-child { margin-left: 0; }
.b9-avatar:hover { transform: translateY(-3px) scale(1.15); z-index: 10 !important; border-color: #d4af37; }
.b9-avatar-more {
  width: 36px; height: 36px; border-radius: 50%;
  border: 2.5px solid rgba(212, 175, 55, 0.2);
  margin-left: -10px;
  background: rgba(212, 175, 55, 0.1);
  display: flex; align-items: center; justify-content: center;
  font-size: 0.75rem; color: #d4af37; font-weight: 700;
}
.b9-active-text {
  font-size: 0.82rem; color: #ccc; font-weight: 500;
}

.b9-actions {
  display: flex; flex-direction: column; gap: 10px; flex-shrink: 0;
}
.b9-btn-primary {
  padding: 12px 28px;
  background: linear-gradient(135deg, #d4af37, #b8941f);
  color: #000; border: none; border-radius: 12px;
  font-weight: 800; font-size: 0.85rem;
  cursor: pointer; text-decoration: none; text-align: center;
  font-family: 'Orbitron', sans-serif;
  letter-spacing: 0.5px;
  transition: all 0.3s;
  box-shadow: 0 4px 20px rgba(212,175,55,0.25);
  position: relative; overflow: hidden;
}
.b9-btn-primary:hover { transform: translateY(-2px); box-shadow: 0 6px 30px rgba(212,175,55,0.45); }
.b9-btn-secondary {
  padding: 10px 24px;
  background: transparent;
  border: 1px solid rgba(212,175,55,0.3);
  color: #d4af37; border-radius: 12px;
  font-size: 0.8rem; font-weight: 600;
  cursor: pointer; text-decoration: none; text-align: center;
  transition: all 0.3s;
}
.b9-btn-secondary:hover { border-color: #d4af37; background: rgba(212,175,55,0.08); }

/* ========== OPTION 10: Upgraded Bottom CTA ========== */
.cta-10 {
  position: relative;
  max-width: 1200px;
  margin: 0 auto 40px;
  padding: 0;
  background: linear-gradient(180deg, #0d0d1a 0%, #111125 50%, #0f0f20 100%);
  border: 1px solid rgba(212, 175, 55, 0.2);
  border-radius: 24px;
  text-align: center;
  overflow: hidden;
  animation: c10BorderSweep 4s ease-in-out infinite;
  box-shadow: 0 8px 40px rgba(0,0,0,0.5);
}
@keyframes c10BorderSweep {
  0% { border-color: rgba(212,175,55,0.1); box-shadow: 0 8px 40px rgba(0,0,0,0.5), 0 0 0 rgba(212,175,55,0); }
  50% { border-color: rgba(212,175,55,0.4); box-shadow: 0 8px 40px rgba(0,0,0,0.5), 0 0 40px rgba(212,175,55,0.08); }
  100% { border-color: rgba(212,175,55,0.1); box-shadow: 0 8px 40px rgba(0,0,0,0.5), 0 0 0 rgba(212,175,55,0); }
}

/* Floating orbs */
.c10-orb {
  position: absolute; border-radius: 50%; pointer-events: none;
  filter: blur(80px);
}
.c10-orb-1 {
  width: 250px; height: 250px; background: rgba(212,175,55,0.08);
  top: -60px; right: 10%; animation: c10OrbMove1 12s ease-in-out infinite;
}
.c10-orb-2 {
  width: 200px; height: 200px; background: rgba(168,85,247,0.06);
  bottom: -40px; left: 5%; animation: c10OrbMove2 15s ease-in-out infinite;
}
.c10-orb-3 {
  width: 180px; height: 180px; background: rgba(212,175,55,0.05);
  top: 30%; left: 60%; animation: c10OrbMove3 10s ease-in-out infinite;
}
.c10-orb-4 {
  width: 220px; height: 220px; background: rgba(168,85,247,0.04);
  top: 10%; right: 30%; animation: c10OrbMove4 18s ease-in-out infinite;
}
@keyframes c10OrbMove1 { 0%,100% { transform: translate(0,0); } 50% { transform: translate(-30px, 20px); } }
@keyframes c10OrbMove2 { 0%,100% { transform: translate(0,0); } 50% { transform: translate(40px, -15px); } }
@keyframes c10OrbMove3 { 0%,100% { transform: translate(0,0); } 50% { transform: translate(-20px, -25px); } }
@keyframes c10OrbMove4 { 0%,100% { transform: translate(0,0); } 50% { transform: translate(25px, 30px); } }

/* Mesh gradient */
.c10-mesh {
  position: absolute; top: 0; left: 0; width: 100%; height: 100%;
  background:
    radial-gradient(ellipse at 20% 50%, rgba(212,175,55,0.04), transparent 50%),
    radial-gradient(ellipse at 80% 20%, rgba(168,85,247,0.03), transparent 50%),
    radial-gradient(ellipse at 50% 80%, rgba(59,130,246,0.02), transparent 50%);
  animation: c10MeshShift 8s ease-in-out infinite alternate;
  pointer-events: none;
}
@keyframes c10MeshShift {
  0% { opacity: 0.6; }
  100% { opacity: 1; }
}

.c10-inner {
  position: relative; z-index: 1;
  padding: 55px 40px;
}

/* Staggered fade-in */
@keyframes c10FadeInUp {
  from { opacity: 0; transform: translateY(25px); }
  to { opacity: 1; transform: translateY(0); }
}
.c10-fade-up {
  opacity: 0;
  animation: c10FadeInUp 0.7s ease forwards;
}

/* Icon with glow ring */
.c10-icon-wrap {
  position: relative; display: inline-block; margin-bottom: 16px;
}
.c10-glow-ring {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  width: 80px; height: 80px; border-radius: 50%;
  border: 2px solid rgba(212,175,55,0.2);
  animation: c10RingPulse 3s ease-in-out infinite;
}
@keyframes c10RingPulse {
  0%,100% { transform: translate(-50%,-50%) scale(1); opacity: 0.5; border-color: rgba(212,175,55,0.15); }
  50% { transform: translate(-50%,-50%) scale(1.2); opacity: 1; border-color: rgba(212,175,55,0.35); }
}
.c10-icon { font-size: 2.8rem; position: relative; z-index: 1; }

.c10-title {
  font-family: 'Orbitron', sans-serif;
  font-size: 2rem; font-weight: 800;
  margin-bottom: 14px;
  line-height: 1.3;
}

.c10-subtitle {
  color: #999; font-size: 1rem; line-height: 1.7;
  max-width: 600px; margin: 0 auto 30px;
  min-height: 1.7em;
  border-right: 2px solid rgba(212,175,55,0.6);
  display: inline-block;
  padding-right: 4px;
  animation: c10Cursor 0.8s step-end infinite;
}
@keyframes c10Cursor {
  0%, 100% { border-right-color: rgba(212,175,55,0.6); }
  50% { border-right-color: transparent; }
}

/* Stats */
.c10-stats {
  display: flex; justify-content: center; gap: 48px;
  margin-bottom: 30px;
}
.c10-stat { text-align: center; }
.c10-stat-num {
  display: block;
  font-family: 'Orbitron', sans-serif;
  font-size: 1.8rem; color: #d4af37; font-weight: 700;
}
.c10-stat-label {
  font-size: 0.72rem; color: #666;
  text-transform: uppercase; letter-spacing: 1.5px;
}

/* Feature pills */
.c10-pills {
  display: flex; gap: 10px; justify-content: center;
  flex-wrap: wrap; margin-bottom: 30px;
}
.c10-pill {
  padding: 6px 16px;
  background: rgba(212,175,55,0.06);
  border: 1px solid rgba(212,175,55,0.15);
  border-radius: 24px;
  font-size: 0.78rem; color: #ccc;
  transition: all 0.3s;
  animation: c10PillPulse 3s ease-in-out infinite;
}
.c10-pill:nth-child(2) { animation-delay: 0.5s; }
.c10-pill:nth-child(3) { animation-delay: 1s; }
.c10-pill:nth-child(4) { animation-delay: 1.5s; }
@keyframes c10PillPulse {
  0%,100% { border-color: rgba(212,175,55,0.15); }
  50% { border-color: rgba(212,175,55,0.35); }
}
.c10-pill:hover { background: rgba(212,175,55,0.1); border-color: rgba(212,175,55,0.4); }

/* Buttons */
.c10-actions { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }
.c10-btn-gold {
  padding: 14px 36px;
  background: linear-gradient(135deg, #d4af37, #b8941f);
  color: #000; border: none; border-radius: 14px;
  font-weight: 800; font-size: 0.95rem;
  cursor: pointer; text-decoration: none;
  font-family: 'Orbitron', sans-serif;
  letter-spacing: 1px; text-transform: uppercase;
  transition: all 0.3s;
  box-shadow: 0 4px 25px rgba(212,175,55,0.3);
  position: relative; overflow: hidden;
}
.c10-btn-gold:hover { transform: translateY(-2px); box-shadow: 0 6px 35px rgba(212,175,55,0.5); }
/* Ripple effect on click */
.c10-btn-gold .ripple, .b9-btn-primary .ripple {
  position: absolute;
  border-radius: 50%;
  background: rgba(255,255,255,0.4);
  transform: scale(0);
  animation: c10Ripple 0.6s ease-out forwards;
  pointer-events: none;
}
@keyframes c10Ripple {
  to { transform: scale(4); opacity: 0; }
}
.c10-btn-outline {
  padding: 14px 36px;
  background: transparent;
  border: 1px solid rgba(212,175,55,0.3);
  color: #d4af37; border-radius: 14px;
  font-weight: 700; font-size: 0.9rem;
  cursor: pointer; text-decoration: none;
  transition: all 0.3s;
}
.c10-btn-outline:hover { background: rgba(212,175,55,0.08); border-color: #d4af37; }

/* ========== Responsive for Options 9 & 10 ========== */
@media (max-width: 768px) {
  .b9-inner { flex-direction: column; text-align: center; padding: 24px 20px; }
  .b9-tags { justify-content: center; }
  .b9-user-cluster { justify-content: center; }
  .b9-actions { flex-direction: row; }
  .b9-title { font-size: 1.2rem; }
  .b9-desc { font-size: 0.82rem; }
  .c10-inner { padding: 35px 20px; }
  .c10-title { font-size: 1.4rem; }
  .c10-stats { gap: 20px; flex-wrap: wrap; }
  .c10-stat-num { font-size: 1.3rem; }
  .c10-pills { gap: 6px; }
  .c10-btn-gold, .c10-btn-outline { padding: 12px 24px; font-size: 0.82rem; }
}


/* ===== V4 AMBIENT EFFECTS ===== */
.v4-ambient-orbs{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.v4-ambient-orb{position:absolute;border-radius:50%;filter:blur(140px);opacity:0.08;animation:v4orbFloat 25s ease-in-out infinite}
.v4-ambient-orb.v4-orb-1{width:700px;height:700px;background:radial-gradient(circle,#d4af37,transparent);top:-15%;left:-10%}
.v4-ambient-orb.v4-orb-2{width:600px;height:600px;background:radial-gradient(circle,#5b21b6,transparent);bottom:-20%;right:-10%;animation-delay:-9s}
.v4-ambient-orb.v4-orb-3{width:550px;height:550px;background:radial-gradient(circle,#ea580c,transparent);top:35%;left:45%;animation-delay:-16s}
@keyframes v4orbFloat{0%,100%{transform:translate(0,0) scale(1)}25%{transform:translate(80px,-50px) scale(1.12)}50%{transform:translate(-40px,60px) scale(0.88)}75%{transform:translate(-60px,-30px) scale(1.06)}}

/* ===== V4 DOT GRID OVERLAY ===== */
body::before{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:radial-gradient(rgba(212,175,55,0.06) 1px,transparent 1px);background-size:28px 28px}

/* ===== V4 VIGNETTE ===== */
body::after{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(ellipse at center,transparent 50%,rgba(0,0,0,0.35) 100%)}

/* ===== V4 GLASS CARD ===== */
.glass-card{position:relative;background:rgba(15,15,30,0.6);backdrop-filter:blur(20px);border-radius:20px;
  border:1px solid rgba(212,175,55,0.12);box-shadow:inset 0 1px 0 rgba(255,255,255,0.05),0 8px 32px rgba(0,0,0,0.3);
  transition:transform 0.35s ease,box-shadow 0.35s ease;overflow:visible !important}
.glass-card::before{content:'';position:absolute;inset:-1px;border-radius:20px;padding:1px;
  background:linear-gradient(135deg,rgba(212,175,55,0.25),transparent 40%,transparent 60%,rgba(212,175,55,0.15));
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;z-index:0}
.glass-card:hover{transform:translateY(-4px) scale(1.005);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.05),0 12px 40px rgba(212,175,55,0.08),0 0 60px rgba(212,175,55,0.04)}

/* ===== V4 SECTION TITLE ===== */
.section-title-v4{font-family:'Orbitron',sans-serif;font-size:0.7rem;color:#d4af37;letter-spacing:2px;
  text-transform:uppercase;display:flex;align-items:center;gap:12px;margin-bottom:14px}
.section-title-v4::after{content:'';flex:1;height:1px;
  background:linear-gradient(90deg,rgba(212,175,55,0.4),transparent)}

/* ===== V4 ENHANCED STAT BARS ===== */
.v4-stat-bar-wrap{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.v4-stat-label{font-family:'Orbitron',sans-serif;font-size:0.55rem;color:#8888aa;width:32px;text-align:right;letter-spacing:0.5px}
.v4-stat-track{flex:1;height:10px;background:rgba(255,255,255,0.04);border-radius:5px;overflow:hidden;position:relative}
.v4-stat-fill{height:100%;border-radius:5px;transition:width 0.6s ease;position:relative}
.v4-stat-fill.hp{background:linear-gradient(90deg,#ff4444,#ff6666);box-shadow:0 0 8px rgba(255,68,68,0.3)}
.v4-stat-fill.atk{background:linear-gradient(90deg,#ff8844,#ffaa66);box-shadow:0 0 8px rgba(255,136,68,0.3)}
.v4-stat-fill.def{background:linear-gradient(90deg,#ffcc44,#ffdd66);box-shadow:0 0 8px rgba(255,204,68,0.3)}
.v4-stat-fill.spa{background:linear-gradient(90deg,#4488ff,#66aaff);box-shadow:0 0 8px rgba(68,136,255,0.3)}
.v4-stat-fill.spd{background:linear-gradient(90deg,#44cc66,#66ee88);box-shadow:0 0 8px rgba(68,204,102,0.3)}
.v4-stat-fill.spe{background:linear-gradient(90deg,#ff66aa,#ff88cc);box-shadow:0 0 8px rgba(255,102,170,0.3)}
.v4-stat-val{font-family:'JetBrains Mono',monospace;font-size:0.6rem;color:#e8e8f0;width:28px;text-align:left}

/* ===== V4 COVERAGE CHART ===== */
.v4-coverage-wrap{margin-top:16px;padding:14px;background:rgba(255,255,255,0.02);border:1px solid rgba(212,175,55,0.1);border-radius:12px}
.v4-coverage-title{font-family:'Orbitron',sans-serif;font-size:0.65rem;color:#d4af37;letter-spacing:1.5px;margin-bottom:10px;text-transform:uppercase}
.v4-coverage-grid{display:flex;flex-wrap:wrap;gap:5px}
.v4-coverage-chip{font-family:'Orbitron',sans-serif;font-size:0.5rem;font-weight:700;padding:3px 8px;border-radius:4px;color:#fff;letter-spacing:0.5px;text-transform:uppercase;transition:all 0.3s}
.v4-coverage-chip.covered{opacity:1;box-shadow:0 0 8px currentColor}
.v4-coverage-chip.uncovered{opacity:0.15;filter:grayscale(0.8)}

/* ===== V4 TIER BADGE ===== */
.v4-tier-badge{font-family:'Orbitron',sans-serif;font-size:0.55rem;font-weight:800;padding:3px 10px;border-radius:4px;letter-spacing:1.5px;display:inline-flex;align-items:center;gap:4px;margin-top:6px}
.v4-tier-ou{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}
.v4-tier-uber{background:linear-gradient(135deg,#9333ea,#7c3aed);color:#fff}
.v4-tier-uu{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}
.v4-tier-ru{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff}
.v4-tier-nu{background:linear-gradient(135deg,#84cc16,#65a30d);color:#fff}
.v4-tier-pu{background:linear-gradient(135deg,#a8a29e,#78716c);color:#fff}
.v4-tier-lc{background:linear-gradient(135deg,#f472b6,#ec4899);color:#fff}
.v4-tier-mythical{background:linear-gradient(135deg,#d4af37,#b8941e);color:#000}

/* ===== V4 SUGGESTED SETS ===== */
.v4-suggested-sets{margin-top:14px}
.v4-suggested-set{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:10px;background:rgba(255,255,255,0.02);border:1px solid rgba(212,175,55,0.1);cursor:pointer;transition:all 0.3s;margin-bottom:6px}
.v4-suggested-set:hover{border-color:#d4af37;background:rgba(212,175,55,0.05);transform:translateY(-1px)}
.v4-suggested-set-name{font-family:'Orbitron',sans-serif;font-size:0.65rem;color:#d4af37;font-weight:600;flex-shrink:0;min-width:100px}
.v4-suggested-set-moves{font-size:0.6rem;color:#8888aa;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}

/* ===== V4 TRADE LAUNCH ===== */
.v4-trade-steps{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:20px;flex-wrap:wrap}
.v4-trade-step{display:flex;align-items:center;gap:6px;font-family:'Orbitron',sans-serif;font-size:0.55rem;letter-spacing:1px;color:#5a5a6a;padding:5px 12px;border-radius:20px;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.05)}
.v4-trade-step.complete{color:#22c55e;border-color:rgba(34,197,94,0.25);background:rgba(34,197,94,0.06)}
.v4-trade-step .step-dot{width:14px;height:14px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.5rem;background:rgba(34,197,94,0.2);color:#22c55e}
.v4-trade-arrow{color:rgba(255,255,255,0.15);font-size:0.6rem}

/* ===== V4 FOOTER ===== */
.v4-footer{position:relative;z-index:1;margin-top:40px;padding:30px 24px 20px;text-align:center}
.v4-footer-brand{font-family:'Orbitron',sans-serif;font-size:1rem;color:#d4af37;letter-spacing:4px;font-weight:700;margin-bottom:8px}
.v4-footer-links{display:flex;align-items:center;justify-content:center;gap:12px;font-size:0.7rem;color:#5a5a6a;flex-wrap:wrap}
.v4-footer-dot{width:3px;height:3px;border-radius:50%;background:rgba(212,175,55,0.2);display:inline-block}
.v4-footer-line{margin-top:20px;height:1px;background:linear-gradient(90deg,transparent,rgba(212,175,55,0.2),transparent)}

/* ===== V4 MOVE SLOT NUMBER INDICATORS ===== */
.v4-move-num{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;
  font-family:'Orbitron',sans-serif;font-size:0.5rem;font-weight:800;color:#fff;margin-right:6px;vertical-align:middle;
  background:linear-gradient(135deg,rgba(212,175,55,0.6),rgba(212,175,55,0.3))}

/* ===== TRADE STATUS MODAL ===== */
.trade-modal-overlay{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,0.85);
  backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;
  opacity:0;transition:opacity 0.4s}
.trade-modal-overlay.active{display:flex;opacity:1}
.trade-modal-close{position:fixed;top:20px;right:24px;z-index:10001;width:40px;height:40px;
  border-radius:50%;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);
  color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:all 0.3s}
.trade-modal-close:hover{background:rgba(255,68,68,0.3);border-color:rgba(255,68,68,0.5)}
.trade-modal-content{width:100%;max-width:560px;padding:20px;position:relative}

.trade-steps-indicator{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:24px}
.trade-step-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:0.7rem;font-weight:700;font-family:'Orbitron',sans-serif;border:2px solid rgba(255,255,255,0.1);
  background:rgba(255,255,255,0.03);color:rgba(255,255,255,0.3);transition:all 0.4s}
.trade-step-dot.done{background:rgba(34,197,94,0.2);border-color:#22c55e;color:#22c55e}
.trade-step-dot.active{background:rgba(212,175,55,0.2);border-color:#d4af37;color:#d4af37;
  box-shadow:0 0 16px rgba(212,175,55,0.3);animation:tradeStepPulse 2s ease-in-out infinite}
@keyframes tradeStepPulse{0%,100%{box-shadow:0 0 12px rgba(212,175,55,0.2)}50%{box-shadow:0 0 24px rgba(212,175,55,0.4)}}
.trade-step-line{width:40px;height:2px;background:rgba(255,255,255,0.1);transition:background 0.4s}
.trade-step-line.done{background:linear-gradient(90deg,#22c55e,#22c55e)}
.trade-step-label{font-size:0.5rem;color:rgba(255,255,255,0.3);margin-top:4px;font-family:'Orbitron',sans-serif;letter-spacing:0.5px}

.trade-status-card{background:rgba(15,15,30,0.8);backdrop-filter:blur(20px);border:1px solid rgba(212,175,55,0.15);
  border-radius:18px;padding:32px;text-align:center;position:relative;overflow:hidden;
  box-shadow:0 24px 80px rgba(0,0,0,0.5)}
.trade-status-card .status-icon{width:64px;height:64px;margin:0 auto 16px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:1.8rem}
.trade-status-card .status-title{font-family:'Orbitron',sans-serif;font-size:1.2rem;font-weight:700;
  margin-bottom:8px;letter-spacing:1px}
.trade-status-card .status-desc{font-size:0.85rem;color:rgba(255,255,255,0.6);margin-bottom:20px}

.trade-code-digits{display:flex;align-items:center;justify-content:center;gap:6px;margin:20px 0}
.trade-code-digit{width:44px;height:52px;background:rgba(0,0,0,0.4);border:2px solid rgba(212,175,55,0.3);
  border-radius:8px;display:flex;align-items:center;justify-content:center;
  font-family:'JetBrains Mono','Courier New',monospace;font-size:1.4rem;font-weight:700;color:#d4af37;
  box-shadow:0 0 12px rgba(212,175,55,0.1)}
.trade-code-dash{font-size:1.4rem;color:rgba(212,175,55,0.4);margin:0 4px}

.trade-queue-pos{font-family:'Orbitron',sans-serif;font-size:2.5rem;font-weight:800;color:#d4af37;
  text-shadow:0 0 20px rgba(212,175,55,0.3)}

.trade-modal-sprite{width:120px;height:120px;object-fit:contain;
  filter:drop-shadow(0 8px 24px rgba(0,0,0,0.5));margin:0 auto 12px;display:block}

.trade-progress-bar{width:100%;height:6px;background:rgba(255,255,255,0.05);border-radius:3px;
  margin:16px 0;overflow:hidden}
.trade-progress-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,#22c55e,#10b981);
  transition:width 1s ease;box-shadow:0 0 8px rgba(34,197,94,0.3)}

/* Progress Ring */
.trade-progress-ring{width:100px;height:100px;margin:0 auto 12px;position:relative}
.trade-progress-ring svg{transform:rotate(-90deg)}
.trade-progress-ring .ring-bg{fill:none;stroke:rgba(255,255,255,0.06);stroke-width:5}
.trade-progress-ring .ring-fill{fill:none;stroke:#22c55e;stroke-width:5;stroke-linecap:round;
  transition:stroke-dashoffset 1.5s ease,stroke 0.5s;filter:drop-shadow(0 0 6px rgba(34,197,94,0.4))}
.trade-progress-ring .ring-pct{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:'Orbitron',sans-serif;font-size:0.9rem;font-weight:700;color:#22c55e}

/* Countdown Timer */
.trade-countdown{font-family:'JetBrains Mono',monospace;font-size:0.75rem;color:rgba(255,255,255,0.4);margin-top:6px}

/* Bot Log Feed */
.trade-log-feed{max-height:80px;overflow-y:auto;margin:10px 0;text-align:left;padding:8px 12px;
  background:rgba(0,0,0,0.3);border:1px solid rgba(255,255,255,0.05);border-radius:8px}
.trade-log-line{font-family:'JetBrains Mono',monospace;font-size:0.6rem;color:rgba(255,255,255,0.35);
  padding:2px 0;border-bottom:1px solid rgba(255,255,255,0.03);animation:logFadeIn 0.3s ease}
.trade-log-line:last-child{border-bottom:none;color:rgba(212,175,55,0.7)}
@keyframes logFadeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}

/* Pokemon Entrance Animation */
@keyframes pokemonEntrance{0%{transform:scale(0) rotate(-15deg);opacity:0}
  50%{transform:scale(1.2) rotate(5deg);opacity:1}100%{transform:scale(1) rotate(0deg);opacity:1}}
@keyframes pokemonShine{0%{filter:drop-shadow(0 8px 24px rgba(0,0,0,0.5)) brightness(1)}
  50%{filter:drop-shadow(0 8px 30px rgba(212,175,55,0.4)) brightness(1.3)}
  100%{filter:drop-shadow(0 8px 24px rgba(0,0,0,0.5)) brightness(1)}}
.trade-entrance-sprite{animation:pokemonEntrance 0.8s cubic-bezier(0.34,1.56,0.64,1) forwards,
  pokemonShine 2s ease-in-out 0.8s infinite}
.trade-sparkle-burst{position:absolute;width:200px;height:200px;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}

/* Trade Receipt */
.trade-receipt{background:linear-gradient(135deg,rgba(15,15,30,0.95),rgba(20,20,40,0.95));
  border:1px solid rgba(212,175,55,0.2);border-radius:14px;padding:20px;margin-top:12px;text-align:center;
  position:relative;overflow:hidden}
.trade-receipt::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,#d4af37,#22c55e,#06b6d4,#a855f7)}
.trade-receipt-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;
  font-size:0.75rem;border-bottom:1px solid rgba(255,255,255,0.04)}
.trade-receipt-row:last-child{border-bottom:none}
.trade-receipt-label{color:rgba(255,255,255,0.4);font-weight:500}
.trade-receipt-value{color:#fff;font-weight:600;font-family:'JetBrains Mono',monospace}
.trade-receipt-actions{display:flex;gap:6px;justify-content:center;margin-top:10px}
.trade-receipt-btn{padding:6px 14px;border-radius:8px;border:none;font-size:0.7rem;font-weight:600;
  cursor:pointer;font-family:inherit;transition:all 0.2s}
.trade-receipt-share{background:rgba(99,102,241,0.15);color:#6366f1;border:1px solid rgba(99,102,241,0.3)}
.trade-receipt-share:hover{background:rgba(99,102,241,0.25)}
.trade-receipt-save{background:rgba(34,197,94,0.15);color:#22c55e;border:1px solid rgba(34,197,94,0.3)}
.trade-receipt-save:hover{background:rgba(34,197,94,0.25)}

/* Reconnecting */
.trade-reconnect{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;
  background:rgba(245,158,11,0.1);border:1px solid rgba(245,158,11,0.25);border-radius:20px;
  font-size:0.7rem;color:#f59e0b;margin-top:8px;animation:reconnectPulse 1.5s ease-in-out infinite}
@keyframes reconnectPulse{0%,100%{opacity:1}50%{opacity:0.5}}

/* ===== TRADE MODAL COSMETIC UPGRADES (from demo-trade-status-v3) ===== */

/* UPGRADE #1: Hexagonal Step Indicator Gems */
.trade-modal-hex-dot{
  width:34px;height:34px;
  clip-path:polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
  border:none;
  background:rgba(255,255,255,0.08);
  display:flex;align-items:center;justify-content:center;
  font-family:'Orbitron',sans-serif;font-size:0.65rem;font-weight:600;
  color:rgba(255,255,255,0.3);transition:all .5s cubic-bezier(.4,0,.2,1);
  position:relative;flex-shrink:0;
}
.trade-modal-hex-dot::before{
  content:'';position:absolute;inset:-2px;
  clip-path:polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
  background:rgba(255,255,255,0.06);z-index:-1;
}
.trade-modal-hex-dot.active{
  background:rgba(212,175,55,0.25);color:#d4af37;
  box-shadow:0 0 20px rgba(212,175,55,0.3),0 0 40px rgba(212,175,55,0.1);
  animation:tradeModalHexPulse 2s ease-in-out infinite;
}
.trade-modal-hex-dot.active::before{background:#d4af37;}
@keyframes tradeModalHexPulse{
  0%,100%{box-shadow:0 0 20px rgba(212,175,55,0.3);filter:brightness(1)}
  50%{box-shadow:0 0 30px rgba(212,175,55,0.4),0 0 50px rgba(212,175,55,0.15);filter:brightness(1.2)}
}
.trade-modal-hex-dot.done{background:rgba(34,197,94,0.25);color:#22c55e;}
.trade-modal-hex-dot.done::before{background:#22c55e;}
.trade-modal-hex-line{width:36px;height:3px;background:rgba(255,255,255,0.06);transition:background .5s;position:relative;overflow:hidden;flex-shrink:0}
.trade-modal-hex-line.done{background:linear-gradient(90deg,#22c55e,#d4af37)}
.trade-modal-hex-line.done::after{
  content:'';position:absolute;top:0;left:0;width:20px;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.8),transparent);
  animation:tradeModalLineTrail 1.5s linear infinite;
}
@keyframes tradeModalLineTrail{0%{left:-20px}100%{left:calc(100% + 20px)}}
.trade-modal-step-label{font-size:0.45rem;color:rgba(255,255,255,0.3);margin-top:3px;font-family:'Orbitron',sans-serif;letter-spacing:0.5px;white-space:nowrap}

/* UPGRADE #2: Scan-Line Trade Code Digits */
.trade-modal-code-digit{
  width:44px;height:52px;
  background:rgba(0,0,0,0.4);
  border:1.5px solid rgba(212,175,55,0.35);border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-family:'JetBrains Mono','Courier New',monospace;font-size:1.3rem;font-weight:700;
  color:#c0d037;
  box-shadow:0 0 12px rgba(212,175,55,0.08),inset 0 0 10px rgba(0,0,0,0.5);
  position:relative;overflow:hidden;
  opacity:0;transform:translateY(8px);transition:all .15s;
}
.trade-modal-code-digit::after{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(0deg, transparent 0px, transparent 2px, rgba(0,255,0,0.03) 2px, rgba(0,255,0,0.03) 3px);
  animation:tradeModalScanScroll 2s linear infinite;
  pointer-events:none;z-index:1;
}
@keyframes tradeModalScanScroll{0%{transform:translateY(0)}100%{transform:translateY(3px)}}
@keyframes tradeModalDigitFlicker{0%,100%{opacity:1}50%{opacity:0.95}75%{opacity:0.98}}
.trade-modal-code-digit.revealed{opacity:1;transform:translateY(0);animation:tradeModalDigitFlicker 0.15s linear infinite}
.trade-modal-code-dash{font-size:1.3rem;color:rgba(212,175,55,0.4);margin:0 4px;opacity:0;transition:opacity .15s}
.trade-modal-code-dash.revealed{opacity:1}
@keyframes tradeModalCodePulse{0%,100%{box-shadow:0 0 12px rgba(212,175,55,0.08),inset 0 0 10px rgba(0,0,0,0.5)}50%{box-shadow:0 0 20px rgba(212,175,55,0.2),inset 0 0 10px rgba(0,0,0,0.5)}}
.trade-modal-code-digit.pulse-glow{animation:tradeModalCodePulse 2s ease-in-out infinite,tradeModalDigitFlicker 0.15s linear infinite}

/* UPGRADE #4: Per-Step Card Backgrounds */
.trade-modal-step-bg{position:absolute;inset:0;pointer-events:none;z-index:0;opacity:0;transition:opacity 0.8s ease;border-radius:18px;overflow:hidden}
.trade-modal-step-bg.active{opacity:1}
.trade-modal-step-bg-0{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='40'%3E%3Cpath d='M0 20 Q50 5 100 20 T200 20' stroke='rgba(255,255,255,0.03)' fill='none' stroke-width='1'/%3E%3C/svg%3E");
  background-size:200px 40px;
}
.trade-modal-step-bg-1{
  background-image:radial-gradient(circle, rgba(255,255,255,0.03) 1px, transparent 1px);
  background-size:20px 20px;
}
.trade-modal-step-bg-2{
  background-image:repeating-linear-gradient(45deg, transparent, transparent 14px, rgba(255,255,255,0.025) 14px, rgba(255,255,255,0.025) 15px);
}
.trade-modal-step-bg-3{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Crect x='10' y='10' width='6' height='6' fill='none' stroke='rgba(255,255,255,0.03)' stroke-width='0.5'/%3E%3Crect x='44' y='44' width='6' height='6' fill='none' stroke='rgba(255,255,255,0.03)' stroke-width='0.5'/%3E%3Cline x1='16' y1='13' x2='44' y2='47' stroke='rgba(255,255,255,0.02)' stroke-width='0.5'/%3E%3C/svg%3E");
  background-size:60px 60px;
}
.trade-modal-step-bg-4{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cline x1='100' y1='100' x2='100' y2='0' stroke='rgba(255,255,255,0.02)' stroke-width='0.5'/%3E%3Cline x1='100' y1='100' x2='200' y2='50' stroke='rgba(255,255,255,0.02)' stroke-width='0.5'/%3E%3Cline x1='100' y1='100' x2='200' y2='150' stroke='rgba(255,255,255,0.02)' stroke-width='0.5'/%3E%3Cline x1='100' y1='100' x2='100' y2='200' stroke='rgba(255,255,255,0.02)' stroke-width='0.5'/%3E%3Cline x1='100' y1='100' x2='0' y2='150' stroke='rgba(255,255,255,0.02)' stroke-width='0.5'/%3E%3Cline x1='100' y1='100' x2='0' y2='50' stroke='rgba(255,255,255,0.02)' stroke-width='0.5'/%3E%3C/svg%3E");
  background-size:200px 200px;background-position:center;
}

/* UPGRADE #5: Pokeball Confetti */
.trade-modal-confetti-pokeball{
  position:absolute;width:10px;height:10px;border-radius:50%;
  background:linear-gradient(180deg, #ef4444 0%, #ef4444 45%, #1a1a2e 45%, #1a1a2e 55%, #ffffff 55%, #ffffff 100%);
  border:1px solid rgba(0,0,0,0.6);opacity:0;
}
.trade-modal-confetti-pokeball::after{
  content:'';position:absolute;top:50%;left:50%;width:4px;height:4px;
  border-radius:50%;background:#1a1a2e;border:1px solid rgba(0,0,0,0.5);
  transform:translate(-50%,-50%);
}
.trade-modal-confetti-container{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:10}

/* UPGRADE #6: Chrome/Metallic TRADE COMPLETE text */
.trade-modal-chrome-title{
  font-family:'Orbitron',sans-serif;font-size:1.3rem;font-weight:800;
  background:linear-gradient(180deg, #ffffff 0%, #22c55e 30%, #0f5132 50%, #22c55e 70%, #ffffff 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  position:relative;display:inline-block;
  filter:drop-shadow(0 2px 4px rgba(0,0,0,0.3)) drop-shadow(0 0 20px rgba(34,197,94,0.3));
}
.trade-modal-chrome-shine{
  position:absolute;inset:0;
  background:linear-gradient(90deg, transparent 0%, transparent 35%, rgba(255,255,255,0.6) 50%, transparent 65%, transparent 100%);
  background-size:200% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:tradeModalChromeShine 3s linear infinite;
  pointer-events:none;
}
@keyframes tradeModalChromeShine{0%{background-position:200% center}100%{background-position:-200% center}}

/* UPGRADE #7: Holographic Shimmer */
.trade-modal-holo-shimmer{
  position:absolute;inset:0;z-index:5;pointer-events:none;border-radius:18px;
  background:linear-gradient(135deg, transparent 20%, rgba(255,0,0,0.04) 30%, rgba(255,165,0,0.04) 35%, rgba(255,255,0,0.04) 40%, rgba(0,255,0,0.04) 45%, rgba(0,0,255,0.04) 50%, rgba(128,0,255,0.04) 55%, transparent 65%);
  background-size:300% 300%;
  opacity:0;transition:opacity 0.4s;
  animation:tradeModalHoloAuto 6s ease-in-out infinite;
}
.trade-modal-holo-shimmer.active{opacity:1}
@keyframes tradeModalHoloAuto{
  0%{background-position:0% 0%}25%{background-position:100% 0%}
  50%{background-position:100% 100%}75%{background-position:0% 100%}100%{background-position:0% 0%}
}

/* UPGRADE #8: Button Ripple */
.trade-modal-btn-ripple{
  position:absolute;border-radius:50%;
  background:rgba(255,255,255,0.3);
  transform:scale(0);
  animation:tradeModalRippleExpand 0.6s ease-out forwards;
  pointer-events:none;
}
@keyframes tradeModalRippleExpand{0%{transform:scale(0);opacity:1}100%{transform:scale(1);opacity:0}}

/* Responsive adjustments for trade modal upgrades */
@media(max-width:600px){
  .trade-modal-hex-dot{width:28px;height:28px;font-size:0.55rem}
  .trade-modal-hex-line{width:24px}
  .trade-modal-code-digit{width:36px;height:44px;font-size:1.1rem}
  .trade-modal-step-label{font-size:0.4rem}
}

/* ===== TRADE MODAL COSMETIC UPGRADES ===== */
/* Hexagonal step dots */
.trade-step-dot{clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);width:38px;height:38px}
.trade-step-dot.active{animation:tradeHexPulse 2s ease-in-out infinite}
@keyframes tradeHexPulse{0%,100%{box-shadow:0 0 12px rgba(212,175,55,0.3)}50%{box-shadow:0 0 24px rgba(212,175,55,0.6)}}
.trade-step-line.done{background:linear-gradient(90deg,#22c55e,#22c55e);position:relative;overflow:hidden}
.trade-step-line.done::after{content:'';position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.6),transparent);animation:tradeLineTrail 1.5s ease-in-out infinite}
@keyframes tradeLineTrail{0%{left:-50%}100%{left:150%}}

/* Scan-line trade code digits */
.trade-code-digit{position:relative;color:#c0d037;box-shadow:inset 0 0 10px rgba(0,0,0,0.5);animation:tradeDigitFlicker 0.1s steps(2) infinite}
.trade-code-digit::after{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent 0px,transparent 2px,rgba(0,255,0,0.03) 2px,rgba(0,255,0,0.03) 3px);animation:tradeScanLine 2s linear infinite;pointer-events:none;border-radius:8px}
@keyframes tradeScanLine{0%{transform:translateY(0)}100%{transform:translateY(20px)}}
@keyframes tradeDigitFlicker{0%,100%{opacity:1}50%{opacity:0.95}}

/* Per-step card backgrounds */
.trade-card-bg{position:absolute;inset:0;pointer-events:none;opacity:0;transition:opacity 0.5s;border-radius:18px}
.trade-card-bg.active{opacity:1}
.trade-card-bg.bg-waves{background:repeating-linear-gradient(0deg,transparent,transparent 10px,rgba(212,175,55,0.015) 10px,rgba(212,175,55,0.015) 11px);opacity:0.03}
.trade-card-bg.bg-grid{background:radial-gradient(rgba(212,175,55,0.03) 1px,transparent 1px);background-size:16px 16px}
.trade-card-bg.bg-diag{background:repeating-linear-gradient(45deg,transparent,transparent 8px,rgba(212,175,55,0.02) 8px,rgba(212,175,55,0.02) 9px)}
.trade-card-bg.bg-circuit{background:linear-gradient(90deg,rgba(212,175,55,0.015) 1px,transparent 1px),linear-gradient(0deg,rgba(212,175,55,0.015) 1px,transparent 1px);background-size:20px 20px}
.trade-card-bg.bg-starburst{background:conic-gradient(from 0deg,transparent 0deg,rgba(34,197,94,0.02) 10deg,transparent 20deg);background-size:100% 100%}

/* Chrome metallic text */
.trade-chrome-text{background:linear-gradient(180deg,#ffffff 0%,#22c55e 30%,#0f5132 50%,#22c55e 70%,#ffffff 100%);-webkit-background-clip:text;background-clip:text;color:transparent;font-size:1.4rem;position:relative;filter:drop-shadow(0 2px 4px rgba(0,0,0,0.3))}
.trade-chrome-text::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent 30%,rgba(255,255,255,0.3) 50%,transparent 70%);animation:tradeChromeShine 3s ease-in-out infinite}
@keyframes tradeChromeShine{0%,100%{transform:translateX(-100%)}50%{transform:translateX(100%)}}

/* Pokeball confetti */
.trade-confetti-pokeball{width:10px;height:10px;border-radius:50%;background:linear-gradient(180deg,#ef4444 0%,#ef4444 45%,#333 45%,#333 55%,#fff 55%,#fff 100%);position:fixed;pointer-events:none;z-index:10001}
.trade-confetti-pokeball::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:4px;height:4px;border-radius:50%;background:#333;border:1px solid #fff}

/* Holographic shimmer */
.trade-holo-shimmer{position:absolute;inset:0;border-radius:16px;pointer-events:none;opacity:0.06;background:linear-gradient(135deg,transparent 20%,rgba(255,0,0,0.15) 30%,rgba(255,165,0,0.15) 35%,rgba(255,255,0,0.15) 40%,rgba(0,255,0,0.15) 45%,rgba(0,0,255,0.15) 50%,rgba(128,0,255,0.15) 55%,transparent 65%);background-size:200% 200%;transition:background-position 0.1s}

/* Button ripple */
.trade-btn-ripple{position:absolute;border-radius:50%;background:rgba(255,255,255,0.3);transform:scale(0);animation:tradeRipple 0.6s ease-out forwards;pointer-events:none}
@keyframes tradeRipple{to{transform:scale(4);opacity:0}}

