 /* ========== RESET & VARIABLES ========== */
        * { margin: 0; padding: 0; box-sizing: border-box; font-family: 'Segoe UI', system-ui, sans-serif; }
        :root {
            --bg: #f0f2f5; --card-bg: #ffffff; --primary: #3b4cca; --primary-dark: #00238f;
            --accent: #ffde00; --text-dark: #2d3748; --text-light: #5a6e8a; --border: #e2e8f0;
            --success: #48bb78; --danger: #f56565;
        }
        body { background: var(--bg); min-height: 100vh; color: var(--text-dark); padding: 20px; }
        .hidden { display: none !important; }

        /* ========== BUTTONS ========== */
        .btn { padding: 8px 16px; border: none; border-radius: 40px; cursor: pointer; font-weight: 600; transition: 0.2s; }
        .btn-primary { background: var(--primary); color: white; }
        .btn-primary:hover { background: var(--primary-dark); transform: translateY(-1px); }
        .btn-outline { background: transparent; border: 1px solid var(--border); color: var(--text-light); }
        .btn-danger { background: var(--danger); color: white; }
        .btn-success { background: var(--success); color: white; }
        .btn-sm { padding: 4px 12px; font-size: 0.8rem; }

        /* ========== SHAKE EFFECT ========== */
        .shake-effect { animation: shake 0.5s 1; }
        @keyframes shake {
            0% { transform: translate(1px, 1px) rotate(0deg); }
            10% { transform: translate(-1px, -2px) rotate(-1deg); }
            20% { transform: translate(-3px, 0px) rotate(1deg); }
            30% { transform: translate(3px, 2px) rotate(0deg); }
            40% { transform: translate(1px, -1px) rotate(1deg); }
            50% { transform: translate(-1px, 2px) rotate(-1deg); }
            60% { transform: translate(-3px, 1px) rotate(0deg); }
            70% { transform: translate(3px, 1px) rotate(-1deg); }
            80% { transform: translate(-1px, -1px) rotate(1deg); }
            90% { transform: translate(1px, 2px) rotate(0deg); }
            100% { transform: translate(1px, -2px) rotate(-1deg); }
        }

        /* ========== SANGRE PERENA FIRE EFFECT ========== */
        :root { --glitter: url("https://assets.codepen.io/13471/silver-glitter-background.png"); }
        #battle-container.sangre-fire { position: relative; overflow: hidden; }
        #battle-container.sangre-fire::before,
        #battle-container.sangre-fire::after {
            content: ""; position: absolute; inset: 0; pointer-events: none; z-index: 0;
        }
        #battle-container.sangre-fire::before {
            background-image: var(--glitter), var(--glitter),
                linear-gradient(0deg, white 0px, #ff8951 5px, #dcbc169c 30%, transparent 70%),
                radial-gradient(ellipse at bottom, transparent 30%, black 60%);
            background-size: 350px 500px, 400px 650px, 100% 100%, 100% 100%;
            background-blend-mode: hard-light, color-dodge, multiply;
            background-position: 0px 0px, 0px 0px, var(--gradientPos, 50% 100%);
            background-repeat: repeat, repeat, repeat, no-repeat;
            mix-blend-mode: color-dodge;
            filter: brightness(3.7) blur(7px) contrast(6);
            animation: fireMove 1.75s linear infinite;
            box-shadow: inset 0 -40px 50px -60px #63bbc5;
        }
        #battle-container.sangre-fire::after { background: rgba(0,0,0,0.3); z-index: 1; }
        @keyframes fireMove {
            0% { background-position: center 0px, center 0px, 50% 100%, center center; }
            100% { background-position: center -500px, center -650px, 50% 100%, center center; }
        }
        #battle-container.sangre-fire .battle-ui,
        #battle-container.sangre-fire .battle-header { position: relative; z-index: 2; }

        /* ========== RESPONSIVE MOVES ========== */
        @media (max-width: 400px) {
            #battle-moves { display: flex !important; flex-direction: column !important; gap: 8px; }
            .move-btn { width: 100%; justify-content: space-between; padding: 12px; font-size: 0.9rem; }
            .move-btn .move-power { font-size: 0.75rem; }
        }

        /* ========== CONTAINER & LAYOUT ========== */
        .container { max-width: 1200px; margin: 20px auto; background: var(--card-bg); border-radius: 32px; padding: 30px; box-shadow: 0 10px 30px rgba(0,0,0,0.1); border: 1px solid var(--border); }
        .flex-between { display: flex; justify-content: space-between; align-items: center; gap: 15px; flex-wrap: wrap; }
        .gym-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 20px;
}
.gym-card {
  width: 100%;
  max-width: 360px;
}
        .gym-card:hover {
            transform: translateY(-6px);
            box-shadow: 0 20px 30px -12px rgba(0, 0, 0, 0.25);
            border-color: var(--primary);
        }
        .gym-card::after {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 5px;
            background: linear-gradient(90deg, var(--primary), var(--accent));
            opacity: 0;
            transition: opacity 0.2s;
        }
        .gym-card:hover::after { opacity: 1; }
        .gym-header { display: flex; gap: 15px; align-items: center; margin-bottom: 15px; }
        .gym-img {
            width: 70px;
            height: 70px;
            object-fit: cover;
            border-radius: 20px;
            background: #f0f0f0;
            box-shadow: 0 4px 12px rgba(0,0,0,0.1);
            transition: transform 0.2s;
        }
        .gym-card:hover .gym-img { transform: scale(1.02); }
        .gym-info { flex: 1; }
        .gym-name {
            font-size: 1.3rem;
            font-weight: 800;
            color: var(--primary-dark);
            letter-spacing: -0.3px;
            margin-bottom: 4px;
        }
        .required {
            font-size: 0.75rem;
            font-weight: 600;
            display: inline-block;
            padding: 3px 10px;
            border-radius: 40px;
            background: rgba(0,0,0,0.05);
        }
        .required.unlocked { background: rgba(72,187,120,0.15); color: var(--success); }
        .required.locked { background: rgba(245,101,101,0.1); color: var(--danger); }
        .badge-img {
            width: 48px;
            height: 48px;
            object-fit: contain;
            filter: drop-shadow(0 2px 4px rgba(0,0,0,0.2));
        }
        .defeated-badge {
            background: linear-gradient(135deg, #f6e05e, #ecc94b);
            color: #2d3748;
            padding: 4px 12px;
            border-radius: 40px;
            font-size: 0.7rem;
            font-weight: 800;
            display: inline-block;
            margin-top: 6px;
            box-shadow: 0 2px 6px rgba(0,0,0,0.1);
        }
        .preview-gym {
            width: 100%;
            margin-top: 8px;
            background: var(--primary);
            color: white;
            font-weight: 700;
            border-radius: 40px;
            padding: 10px;
            transition: 0.2s;
            border: none;
            cursor: pointer;
        }
        .preview-gym:hover:not(:disabled) {
            background: var(--primary-dark);
            transform: translateY(-2px);
            box-shadow: 0 8px 18px rgba(59,76,202,0.3);
        }
        .preview-gym:disabled { opacity: 0.5; cursor: not-allowed; }

        @keyframes gentlePulse {
            0% { box-shadow: 0 0 0 0 rgba(59,76,202,0.4); }
            70% { box-shadow: 0 0 0 6px rgba(59,76,202,0); }
            100% { box-shadow: 0 0 0 0 rgba(59,76,202,0); }
        }
        .preview-gym:not(:disabled) { animation: gentlePulse 1.5s infinite; }
        .preview-gym:not(:disabled):hover { animation: none; }

        /* ========== TRAINER CARD ========== */
        .trainer-card {
            margin: 0 auto;
            background: linear-gradient(135deg, var(--primary-dark), var(--primary));
            border-radius: 32px; padding: 20px; color: white;
            display: inline-flex; flex-wrap: wrap; gap: 20px; align-items: center;
            margin-bottom: 30px; width: auto; min-width: 300px;
            position: relative; overflow: hidden;
            box-shadow: 0 10px 20px rgba(0,0,0,0.2);
        }
        #app { text-align: center; }
        .gym-grid { text-align: left; }
        .trainer-card::before {
            content: ''; position: absolute; top: -50%; left: -50%; width: 200%; height: 200%;
            background: radial-gradient(circle, rgba(255,255,255,0.3) 0%, rgba(255,255,255,0) 70%);
            animation: shine 3s infinite;
        }
        @keyframes shine {
            0% { transform: translateX(-100%) translateY(-100%) rotate(45deg); }
            100% { transform: translateX(100%) translateY(100%) rotate(45deg); }
        }
        .trainer-avatar { width: 80px; height: 80px; background: white; border-radius: 50%; display: flex; align-items: center; justify-content: center; z-index: 1; }
        .trainer-avatar img { width: 70px; height: 70px; border-radius: 50%; object-fit: contain; }
        .trainer-stats { flex: 1; z-index: 1; }
        .trainer-name { font-size: 1.5rem; font-weight: bold; }
        .badge-container { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; }
        .badge-icon { width: 40px; height: 40px; object-fit: contain; background: rgba(255,255,255,0.2); border-radius: 50%; padding: 4px; }

        /* ========== BATTLE UI ========== */
        #battle-container {
            background: linear-gradient(145deg, #87CEEB 0%, #c0e0ff 40%, #78c850 100%);
            border-radius: 24px; box-shadow: 0 12px 28px rgba(0,0,0,0.2);
            border: 2px solid rgba(255,255,255,0.5); overflow: hidden;
            max-width: 700px; margin: 0 auto;
        }
        .battle-header { background: var(--primary-dark); color: white; text-align: center; padding: 12px; font-weight: bold; }
        .battle-ui { padding: 20px; display: flex; flex-direction: column; gap: 20px; }
        .side { display: flex; align-items: center; gap: 15px; flex-wrap: wrap; }
        .enemy-side { justify-content: flex-end; }
        .stat-box { background: rgba(255,255,255,0.9); backdrop-filter: blur(4px); padding: 12px 16px; border-radius: 20px; width: 220px; border-left: 4px solid var(--primary); }
        /* Reduce font size for enemy stat box */
.enemy-side .stat-box {
    font-size: 0.75rem;
}

.enemy-side .stat-box strong {
    font-size: 0.65rem;
}

.enemy-side .stat-box small {
    font-size: 0.5rem;
}

/* Keep player stat box at normal/default size */
.player-side .stat-box {
    font-size: 0.85rem;
}

.player-side .stat-box strong {
    font-size: 0.9rem;
}

.player-side .stat-box small {
    font-size: 0.7rem;
}
        .hp-bar { background: #e2e8f0; height: 8px; border-radius: 10px; overflow: hidden; margin-top: 8px; }
        .hp-fill { height: 100%; background: var(--success); width: 100%; transition: width 0.3s; }
        #battle-log { background: rgba(0,0,0,0.7); color: #e0e0e0; padding: 12px; font-family: monospace; height: 80px; overflow-y: auto; border-radius: 16px; margin: 10px 0; }
        #battle-moves { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
        .move-btn {
            display: flex; align-items: center; justify-content: space-between; padding: 12px 16px;
            border: none; border-radius: 32px; cursor: pointer; font-weight: 600; color: white;
            transition: 0.2s; background: #a0aec0;
        }
        .move-btn:hover { transform: translateY(-2px); filter: brightness(0.95); }
        .move-btn .move-power {
            font-size: 0.85rem; font-weight: bold; background: rgba(0,0,0,0.3);
            padding: 4px 8px; border-radius: 20px; margin-left: 8px;
        }
        .catch-area { display: flex; gap: 12px; margin-top: 12px; flex-wrap: wrap; }

        /* ========== BADGES ========== */
        .type-badge, .move-badge {
            display: inline-block; padding: 2px 8px; border-radius: 16px; font-size: 0.7rem;
            font-weight: bold; margin: 0 2px; color: white; text-shadow: 0 1px 1px rgba(0,0,0,0.2);
        }

        /* Smaller type badges inside stat boxes */
.stat-box .type-badge,
.stat-box .move-badge {
    font-size: 0.55rem;
    padding: 1px 5px;
}

/* Even smaller for enemy side */
.enemy-side .stat-box .type-badge {
    font-size: 0.5rem;
    padding: 1px 4px;
}

        /* ========== MODALS & FORMS ========== */
        .overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.85); display: flex; align-items: center; justify-content: center; z-index: 5000; backdrop-filter: blur(4px); }
        .modal { background: var(--card-bg); padding: 30px; border-radius: 32px; max-width: 800px; width: 90%; text-align: center; max-height: 85vh; overflow-y: auto; }
        .back-link { display: inline-block; margin-bottom: 20px; color: var(--primary); text-decoration: none; }
        footer { text-align: center; padding: 20px; font-size: 0.8rem; color: var(--text-light); background: rgba(255,255,255,0.8); margin-top: 40px; border-top: 1px solid var(--border); }

        /* ========== POKEMON SELECTION / TEAM EDITOR ========== */
        .pokemon-select-item {
            display: flex; align-items: center; gap: 15px; padding: 10px;
            background: #f8fafc; border-radius: 20px; margin-bottom: 10px;
            cursor: pointer; transition: 0.2s;
        }
        .pokemon-select-item:hover { background: #eef2ff; transform: translateX(4px); }
        .pokemon-select-item img { width: 60px; height: 60px; object-fit: contain; }
        .pokemon-select-info { flex: 1; text-align: left; }
        .move-list-small { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 6px; }
        .hp-bar-small { width: 100%; height: 6px; background: #e2e8f0; border-radius: 10px; overflow: hidden; margin-top: 4px; }
        .hp-fill-small { height: 100%; background: var(--success); width: 100%; }
        .team-pokemon-card {
            background: #f8fafc; border-radius: 20px; padding: 12px; margin-bottom: 12px;
            display: flex; gap: 15px; align-items: center; transition: 0.2s;
        }
        .team-pokemon-card:hover { background: #eef2ff; }
        .team-pokemon-card img { width: 60px; height: 60px; object-fit: contain; background: white; border-radius: 12px; padding: 4px; }
        .team-pokemon-info { flex: 1; }
        .team-pokemon-actions { display: flex; gap: 8px; }
        .form-group { margin-bottom: 15px; text-align: left; }
        .form-group label { display: block; font-weight: 600; margin-bottom: 5px; }
        .form-group input, .form-group textarea { width: 100%; padding: 8px 12px; border: 1px solid var(--border); border-radius: 16px; }
        .bonus-checkboxes { display: flex; gap: 20px; margin: 10px 0; }
        .bonus-checkboxes label { display: flex; align-items: center; gap: 5px; font-weight: normal; }
        .move-table-container { max-height: 400px; overflow-y: auto; border: 1px solid var(--border); border-radius: 16px; margin: 16px 0; }
        .move-table { width: 100%; border-collapse: collapse; }
        .move-table th, .move-table td { padding: 8px 12px; text-align: left; border-bottom: 1px solid var(--border); }
        .move-table th { position: sticky; top: 0; background: #f8fafc; font-weight: 600; }
        .move-select { cursor: pointer; text-align: center; }
        .move-select input { width: 20px; height: 20px; cursor: pointer; }
        .move-search { margin-bottom: 12px; width: 100%; padding: 8px 12px; border: 1px solid var(--border); border-radius: 40px; }
        .species-preview { display: flex; align-items: center; gap: 15px; margin-top: 10px; flex-wrap: wrap; }
        .species-preview img { width: 80px; height: 80px; object-fit: contain; background: #f8fafc; border-radius: 16px; padding: 8px; }
        .animated-btn { background: var(--primary); color: white; border: none; padding: 4px 12px; border-radius: 40px; cursor: pointer; font-size: 0.7rem; margin-left: auto; }
        .animated-btn:hover { background: var(--primary-dark); }

        /* ========== BONUS ICONS & AURA ========== */
        .bonus-icon { display: inline-block; animation: pulse-glow 1.2s infinite ease-in-out; text-shadow: 0 0 5px currentColor; margin: 0 2px; }
        .bonus-icon.atk { color: #CE1126; text-shadow: 0 0 5px #CE1126, 0 0 10px #FF4444; }
        .bonus-icon.def { color: #0038A8; text-shadow: 0 0 5px #0038A8, 0 0 10px #3366FF; }
        .bonus-icon.spd { color: #FCD116; text-shadow: 0 0 5px #FCD116, 0 0 10px #FFE066; }
        @keyframes pulse-glow {
            0% { opacity: 0.7; transform: scale(1); }
            50% { opacity: 1; transform: scale(1.1); text-shadow: 0 0 12px currentColor; }
            100% { opacity: 0.7; transform: scale(1); }
        }

        /* Fiery aura around Pokémon – Sangre Perena only */
        .fire-aura { position: relative; display: inline-block; }
        .fire-aura::before {
            content: '';
            position: absolute;
            top: -20px; left: -20px; right: -20px; bottom: -20px;
            background: radial-gradient(circle, rgba(255,80,0,0.6), rgba(255,0,0,0.2), transparent);
            border-radius: 50%;
            pointer-events: none;
            z-index: 1;
            animation: auraPulse 1s infinite alternate;
        }
        @keyframes auraPulse {
            0% { opacity: 0.4; transform: scale(0.95); }
            100% { opacity: 1; transform: scale(1.05); }
        }
        .ember {
            position: absolute;
            width: 8px;
            height: 8px;
            background: radial-gradient(circle, #ffcc00, #ff3300);
            border-radius: 50%;
            filter: blur(1px);
            animation: floatUp 2s linear infinite;
            pointer-events: none;
            z-index: 5;
        }
        @keyframes floatUp {
            0% { transform: translateY(0) scale(1); opacity: 0.9; }
            100% { transform: translateY(-100px) scale(0.2); opacity: 0; }
        }
        .fire-particles { position: absolute; inset: 0; pointer-events: none; z-index: 10; overflow: hidden; border-radius: inherit; }
        .fire-particle {
            position: absolute; bottom: 0; width: 6px; height: 6px;
            background: radial-gradient(circle, #ffcc00, #ff3300);
            border-radius: 50% 0 50% 50%;
            opacity: 0;
            animation: flyUp 1.5s ease-out infinite;
            filter: blur(1px);
        }
        @keyframes flyUp {
            0% { transform: translateY(0) scale(1) rotate(0deg); opacity: 0.9; }
            50% { opacity: 0.7; transform: translateY(-150px) scale(0.8) rotate(20deg); }
            100% { transform: translateY(-300px) scale(0.2) rotate(40deg); opacity: 0; }
        }
        .battle-container.gym-sangre {
            background: linear-gradient(145deg, #3a0a0a 0%, #6a1a1a 40%, #2a0a0a 100%);
            position: relative; overflow: hidden;
        }
        .battle-container.gym-sangre::before {
            content: '';
            position: absolute; top: 0; left: 0; width: 100%; height: 100%;
            background: radial-gradient(circle at 20% 30%, rgba(255,80,0,0.4) 0%, rgba(255,50,0,0.1) 70%, transparent 100%);
            pointer-events: none;
            animation: pulseEmber 2s infinite ease-in-out;
        }
        @keyframes pulseEmber {
            0% { opacity: 0.3; transform: scale(1); }
            50% { opacity: 0.8; transform: scale(1.05); }
            100% { opacity: 0.3; transform: scale(1); }
        }

        /* ========== GYM TEAM GRID ========== */
      .gym-team-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 4px;
  margin: 10px 0;
}
        .gym-team-pokemon {
            text-align: center;
            background: rgba(0,0,0,0.02);
            border-radius: 16px;
            padding: 6px;
        }
     .gym-team-pokemon img {
  width: 100%;
  max-width: 48px;
  height: auto;
  image-rendering: pixelated;
}
.badge-effect-pill {
  display: inline-block;
  font-size: 0.65rem;
  background: #fff8e1;
  color: #854F0B;
  border: 1px solid #FAC775;
  border-radius: 20px;
  padding: 2px 8px;
  margin-top: 4px;
  font-weight: 600;
}

.gym-page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 2px solid var(--primary);
  margin-bottom: 20px;
  flex-wrap: wrap;
}

.gym-page-title {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--primary);
}

.gym-page-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.section-heading {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 20px;
  padding: 14px 18px;
  background: linear-gradient(135deg, var(--primary-dark, #00238f), var(--primary, #3b4cca));
  border-radius: 16px;
  color: white;
}

.section-heading-icon {
  font-size: 2rem;
  line-height: 1;
}
.gym-card {
  border: 2px solid transparent;
  transition: border-color 0.2s, transform 0.2s;
}
.gym-card:hover {
  border-color: var(--primary);
  transform: translateY(-3px);
}
@media (max-width: 600px) {
  .gym-page-header { gap: 8px; }
  .gym-page-title span { font-size: 1rem; }
}

        .gym-team-pokemon span {
            font-size: 0.6rem;
            display: block;
            font-weight: 500;
        }

        /* ========== PLAYER TEAM SHOWCASE ========== */
        .player-team-section {
            background: var(--card-bg);
            border-radius: 28px;
            border: 1px solid var(--border);
            padding: 20px;
            margin: 30px auto 20px;
            max-width: 800px;
            text-align: center;
        }
        .player-team-title {
            font-size: 1.2rem;
            font-weight: bold;
            margin-bottom: 15px;
            color: var(--primary-dark);
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 10px;
        }
        .player-team-grid {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 10px;
        }
      
        .player-pokemon-card {
            background: rgba(0,0,0,0.03);
            border-radius: 20px;
            padding: 10px;
            text-align: center;
            transition: transform 0.2s, box-shadow 0.2s;
            cursor: pointer;
            border: 1px solid var(--border);
            max-width: 180px;
            margin: 0 auto;
            width: 100%;
        }
        .player-pokemon-card:hover {
            transform: translateY(-3px);
            box-shadow: 0 6px 12px rgba(0,0,0,0.1);
            border-color: var(--primary);
        }
        .player-pokemon-card img {
  image-rendering: pixelated;
  width: 64px;
  height: 64px;
  object-fit: contain;
}
        .player-pokemon-name {
            font-weight: bold;
            font-size: 0.8rem;
            margin: 5px 0;
        }
        .player-pokemon-level {
            font-size: 0.7rem;
            color: var(--text-light);
        }
        .player-hp-bar {
            background: #e2e8f0;
            height: 6px;
            border-radius: 10px;
            overflow: hidden;
            margin: 6px 0;
        }
        .player-hp-fill {
            background: var(--success);
            height: 100%;
            width: 100%;
        }

        /* ========== BATTLE SIDE LAYOUT ========== */
        .player-side {
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 20px;
            flex-wrap: nowrap;
            position: relative;
        }
        .player-side .btl-sprite {
            width: auto !important;
            height: auto !important;
            margin-right: 0;
            z-index: 10;
            position: relative;
        }
        .player-side .stat-box {
            z-index: 5;
            background: rgba(255,255,255,0.95);
            backdrop-filter: blur(8px);
        }
        @media (max-width: 768px) {
            .player-side {
                flex-direction: column;
                align-items: center;
                justify-content: center;
                gap: 0;
            }
            .player-side .btl-sprite {
                width: auto !important;
                height: auto !important;
                margin-right: 0;
                margin-bottom: -40px;
                z-index: 10;
            }
            .player-side .stat-box {
                width: 90%;
                max-width: 280px;
                margin-top: -30px;
                z-index: 20;
                background: rgba(255,255,255,0.95);
                backdrop-filter: blur(8px);
                border-left: 4px solid var(--primary);
                text-align: center;
            }
            .enemy-side {
                flex-direction: row;
                justify-content: flex-end;
            }
        }

        /* ========== SHAPE-ACCURATE GLOWS (drop-shadow only) ========== */
        .sprite-effect-wrapper {
             position: relative;
             font-size: 0.8rem;
    display: inline-block;
    line-height: 0; /* Prevents extra space below image */
        }
        .sprite-effect-wrapper img {
             display: block;
    width: auto;
    height: auto;
    max-width: 150px;
    max-height: 90px;
    object-fit: contain;
        }
        .fx-legendary-aura img {
            filter: drop-shadow(0 0 4px rgba(255,215,0,0.8))
                    drop-shadow(0 0 8px rgba(255,165,0,0.7))
                    drop-shadow(0 0 16px rgba(255,100,0,0.5))
                    drop-shadow(0 0 30px rgba(255,50,0,0.3));
        }
        .fx-void-aura img {
            filter: drop-shadow(0 0 4px #0af)
                    drop-shadow(0 0 10px #0af)
                    drop-shadow(0 0 20px #00f);
        }
        .fx-mirage-aura img {
            filter: drop-shadow(0 0 4px #ffa)
                    drop-shadow(0 0 12px #fa0)
                    drop-shadow(0 0 25px #f80);
        }
        .fx-blaze-aura img {
            filter: drop-shadow(0 0 4px #f60)
                    drop-shadow(0 0 10px #f30)
                    drop-shadow(0 0 22px #f00);
        }
        .fx-glacial-aura img {
            filter: drop-shadow(0 0 4px #0cf)
                    drop-shadow(0 0 12px #0af)
                    drop-shadow(0 0 28px #06f);
        }
        .fx-shadow-aura img {
            filter: drop-shadow(0 0 4px #c0f)
                    drop-shadow(0 0 12px #80c)
                    drop-shadow(0 0 25px #40a);
        }
        .fx-cosmic-aura img {
            filter: drop-shadow(0 0 5px hsl(var(--rh,0),100%,60%))
                    drop-shadow(0 0 15px hsl(var(--rh,0),100%,55%))
                    drop-shadow(0 0 30px hsl(var(--rh,0),100%,50%));
        }
        .fx-phantom-aura img {
            filter: drop-shadow(0 0 4px #0f8)
                    drop-shadow(0 0 14px #0c6)
                    drop-shadow(0 0 28px #094);
        }
        .fx-rainbow-aura img {
            filter: drop-shadow(0 0 4px hsl(var(--rh,0),100%,60%))
                    drop-shadow(0 0 12px hsl(var(--rh,0),100%,55%))
                    drop-shadow(0 0 25px hsl(var(--rh,0),100%,50%));
        }
        .fx-chrome-aura img {
            filter: drop-shadow(0 0 3px rgba(255,255,255,0.8))
                    drop-shadow(0 0 10px rgba(200,220,255,0.6))
                    drop-shadow(0 0 20px rgba(160,180,200,0.4));
        }
        .fx-electric-aura img {
            filter: drop-shadow(0 0 3px #0ef)
                    drop-shadow(0 0 8px #0cf)
                    drop-shadow(0 0 18px #0af);
            animation: electricFlicker 0.08s steps(2) infinite;
        }
        @keyframes electricFlicker {
            0% { filter: drop-shadow(0 0 3px #0ef) drop-shadow(0 0 8px #0cf) drop-shadow(0 0 18px #0af); }
            50% { filter: drop-shadow(0 0 6px #fff) drop-shadow(0 0 15px #0ef) drop-shadow(0 0 30px #08f); }
        }
        .fx-dark-aura img {
            filter: drop-shadow(0 0 4px #80f)
                    drop-shadow(0 0 12px #50c)
                    drop-shadow(0 0 24px #309);
        }
        .fx-darkgreen-aura img {
            filter: drop-shadow(0 0 4px #0f6)
                    drop-shadow(0 0 12px #0c4)
                    drop-shadow(0 0 24px #083);
        }
        .fx-windy-aura img {
            filter: drop-shadow(-3px 2px 6px rgba(150,230,255,0.6))
                    drop-shadow(-6px 4px 12px rgba(100,200,255,0.4));
            animation: windyShiftAura 1.5s ease-in-out infinite alternate;
        }
        @keyframes windyShiftAura {
            0% { transform: translateX(-2px); filter: drop-shadow(-3px 2px 6px rgba(150,230,255,0.6)); }
            100% { transform: translateX(3px); filter: drop-shadow(-8px 5px 12px rgba(100,200,255,0.7)); }
        }
        .fx-retro-aura img {
            filter: drop-shadow(2px 2px 0 rgba(0,0,0,0.5))
                    drop-shadow(0 0 3px rgba(255,255,200,0.3));
        }
        .fx-overcharged-aura img {
            filter: drop-shadow(0 0 6px #fff)
                    drop-shadow(0 0 16px #8ff)
                    drop-shadow(0 0 35px #0cf);
            animation: overPulseAura 0.8s ease-in-out infinite alternate;
        }
        @keyframes overPulseAura {
            0% { filter: drop-shadow(0 0 4px #fff) drop-shadow(0 0 12px #8ff) drop-shadow(0 0 24px #0cf); }
            100% { filter: drop-shadow(0 0 10px #fff) drop-shadow(0 0 25px #fff) drop-shadow(0 0 50px #0ef); }
        }

        /* ========== DARK THEME OVERRIDES ========== */
        .dark-theme {
            --bg: #1a1a2e; --card-bg: #16213e; --primary: #6c63ff; --primary-dark: #5a52d5;
            --accent: #ffde00; --text-dark: #e2e8f0; --text-light: #a0aec0; --border: #2d3748;
            --success: #48bb78; --danger: #fc8181;
            --battle-bg-start: #1e2a3a; --battle-bg-mid: #2d3748; --battle-bg-end: #1a202c;
            --log-bg: #0f172a;
        }
        .dark-theme #battle-container { background: linear-gradient(145deg, var(--battle-bg-start) 0%, var(--battle-bg-mid) 40%, var(--battle-bg-end) 100%); }
        .dark-theme #battle-log { background: rgba(0,0,0,0.9); }
        .dark-theme .stat-box { background: rgba(0,0,0,0.7); color: #f0f0f0; }
        .dark-theme .trainer-card { background: linear-gradient(135deg, #1e293b, #0f172a); }
        .dark-theme .gym-card, .dark-theme .modal, .dark-theme .pokemon-select-item, .dark-theme .team-pokemon-card {
            background: var(--card-bg); border-color: var(--border); color: var(--text-dark);
        }
        .dark-theme .move-table th { background: #0f172a; }
        .dark-theme .move-table td { border-bottom-color: var(--border); }
        .dark-theme input, .dark-theme textarea, .dark-theme .move-search {
            background: #0f172a; color: #e2e8f0; border-color: var(--border);
        }
        .theme-toggle {
            background: var(--card-bg); border: 1px solid var(--border); border-radius: 40px;
            padding: 8px 16px; cursor: pointer; font-size: 1.2rem; transition: 0.2s;
        }
        .theme-toggle:hover { transform: scale(1.05); }

        .dark-theme .player-side .stat-box,
        .dark-theme .enemy-side .stat-box {
            background: rgba(0, 0, 0, 0.85) !important;
            color: #e2e8f0 !important;
            border-left-color: var(--primary) !important;
        }
        .dark-theme .player-side .stat-box strong,
        .dark-theme .player-side .stat-box small,
        .dark-theme .player-side .stat-box div {
            color: #e2e8f0 !important;
        }
        .dark-theme .player-side .stat-box .hp-bar {
            background: #3d4050 !important;
        }
        .dark-theme .player-side .stat-box .hp-fill {
            background: var(--success) !important;
        }
        .dark-theme .gym-team-pokemon img {
            background: #2d2f3e !important;
        }
        .dark-theme .gym-team-pokemon span {
            color: #e2e8f0 !important;
        }

        /* ========== RESPONSIVE ========== */
        @media (max-width: 768px) {
            .btl-sprite { width: 80px; height: 80px; }
            .stat-box { width: 180px; }
            .move-btn { padding: 8px 12px; }
            .trainer-card { flex-direction: column; text-align: center; width: 100%; }
            .badge-container { justify-content: center; }
        }
        @media (max-width: 640px) {
            .gym-card { padding: 16px; }
            .gym-img { width: 55px; height: 55px; }
            .gym-name { font-size: 1.1rem; }
            .badge-img { width: 38px; height: 38px; }
        }
        .modal {
            will-change: transform;
            transform: translateZ(0);
        }
        .gym-form-modal .modal {
            will-change: transform;
        }