Mudanças entre as edições de "Widget:VisnoTeste"

De Wiki Gla
Ir para navegação Ir para pesquisar
Linha 1: Linha 1:
<!DOCTYPE html>
<!-- WEAPON TOGGLE SYSTEM - Estado global + popup -->
<html lang="pt-BR">
<script>
    (() => {
        let modalListenersBound = false;


<head>
        const bindModalEvents = () => {
  <meta charset="UTF-8">
            if (modalListenersBound) return;
  <title>Teste GIF Hover</title>
            modalListenersBound = true;
  <style>
            document.addEventListener('click', (ev) => {
    body {
                if (ev.target.closest('.weapon-modal-close') || ev.target.closest('.weapon-modal-btn')) {
      margin: 0;
                    const checkbox = document.getElementById('weapon-dont-show');
      font-family: sans-serif;
                    if (checkbox && checkbox.checked) {
      color: white;
                        try { localStorage.setItem('glaWeaponPopupDismissed', '1'); } catch (x) { }
    }
                    }
                    hidePopup();
                    return;
                }
                if (ev.target.classList.contains('weapon-modal-overlay')) {
                    hidePopup();
                }
            });
        };


    .search-bar {
        const applyWeaponState = (enabled) => {
      text-align: right;
            // Atualizar flag global
      padding: 20px;
            if (typeof window.__setGlobalWeaponEnabled === 'function') {
    }
                window.__setGlobalWeaponEnabled(enabled);
            }


    .search-bar input {
            // Salvar preferência
      padding: 8px;
            try {
      width: 250px;
                localStorage.setItem('glaWeaponEnabled', enabled ? '1' : '0');
      border-radius: 5px;
            } catch (x) { }
      border: 1px solid #ccc;
    }


.container {
            // Aplicar/remover classe e indicador visual em TODAS as skills com arma
  display: grid;
            document.querySelectorAll('.skill-icon[data-weapon]').forEach(el => {
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
                if (enabled) {
  gap: 18px;
                    el.classList.add('has-weapon-available');
  width: 100%;
                    let ind = el.querySelector('.weapon-indicator');
  margin: 0 auto;
                    if (!ind) {
  justify-items: center;
                        ind = document.createElement('div');
}
                        ind.className = 'weapon-indicator';
                        el.appendChild(ind);
                    }
                } else {
                    el.classList.remove('has-weapon-available');
                    el.classList.remove('weapon-equipped');
                    el.style.removeProperty('--weapon-badge-url');
                    const ind = el.querySelector('.weapon-indicator');
                    if (ind) ind.remove();
                }
            });
        };


    @media (max-width: 1400px) {
        const ensureModal = () => {
      .container {
            let modal = document.getElementById('weapon-info-modal');
        grid-template-columns: repeat(4, 1fr);
            if (modal) return modal;
      }
            modal = document.createElement('div');
    }
            modal.id = 'weapon-info-modal';
            modal.className = 'weapon-modal';
            modal.innerHTML = `
            <div class="weapon-modal-overlay"></div>
            <div class="weapon-modal-content">
                <div class="weapon-modal-header">
                    <h3>Visualização com Arma Especial</h3>
                    <button class="weapon-modal-close">&times;</button>
                </div>
                <div class="weapon-modal-body">
                    <p>Este modo ativa a visualização do personagem equipado com sua <strong>arma especial</strong>.</p>
                    <p>As habilidades melhoradas ficam <strong>destacadas com borda e brilho azul</strong>, mesmo quando não selecionadas.</p>
                    <p class="weapon-info-link" style="margin-top:8px;display:none"></p>
                </div>
                <div class="weapon-modal-footer">
                    <label class="weapon-modal-checkbox">
                        <input type="checkbox" id="weapon-dont-show">
                        <span>Não mostrar novamente</span>
                    </label>
                    <button class="weapon-modal-btn">Entendi</button>
                </div>
            </div>
        `;
            document.body.appendChild(modal);
            try {
                const firstWithWeapon = document.querySelector('.skill-icon[data-weapon]');
                if (firstWithWeapon) {
                    const raw = firstWithWeapon.getAttribute('data-weapon');
                    const obj = JSON.parse(raw || '{}');
                    const nm = (obj && obj.name) ? String(obj.name).trim() : '';
                    if (nm) {
                        const linkHost = (window.mw && mw.util && typeof mw.util.getUrl === 'function') ? mw.util.getUrl(nm) : ('/index.php?title=' + encodeURIComponent(nm));
                        const holder = modal.querySelector('.weapon-info-link');
                        if (holder) {
                            holder.style.display = 'block';
                            holder.innerHTML = `<a href="${linkHost}" style="color:#6BB3FF;text-decoration:none;font-weight:600">Ver página da arma: ${nm}</a>`;
                        }
                    }
                }
            } catch (_) { }
            bindModalEvents();
            return modal;
        };


    @media (max-width: 1100px) {
        const showPopup = () => {
      .container {
            const modal = ensureModal();
        grid-template-columns: repeat(3, 1fr);
            if (modal) modal.classList.add('show');
      }
        };
    }


    @media (max-width: 800px) {
        const hidePopup = () => {
      .container {
            const m = document.getElementById('weapon-info-modal');
        grid-template-columns: repeat(2, 1fr);
            if (m) m.classList.remove('show');
      }
        };
    }


    @media (max-width: 500px) {
        window.__applyWeaponState = applyWeaponState;
      .container {
        window.__glaWeaponShowPopup = showPopup;
        grid-template-columns: 1fr;
        window.__glaWeaponHidePopup = hidePopup;
      }
        try {
    }
            window.dispatchEvent(new CustomEvent('weapon:ready', { detail: { applyWeaponState, showPopup, hidePopup } }));
        } catch (err) {
        }


    .personagem {
        const boot = () => {
      width: 250px;
            // Verificar se existe alguma skill com arma
      height: 115px;
            const hasAnyWeapon = document.querySelectorAll('.skill-icon[data-weapon]').length > 0;
      aspect-ratio: 16/7;
            if (!hasAnyWeapon) return;
      border-radius: 10px;
      background-size: 150%;
      background-position: center -30px;
      transition: transform 0.3s;
      display: flex;
      align-items: flex-end;
      justify-content: flex-end;
      padding: 5px;
      font-weight: bold;
      color: white;
      text-shadow: 1px 1px 4px #000, 0 0 20px #000;
      position: relative;
      cursor: pointer;
      border: 2px solid #58aaff;
      overflow: hidden;
      text-decoration: none;
    }


    .personagem span {
            ensureModal();
      z-index: 2;
      font-size: 1.10rem;
      font-weight: bold;
      padding: 2px 8px;
      border-radius: 6px;
      background: linear-gradient(90deg, #000000cc 60%, #22222288 100%);
      color: #fff;
      text-shadow:
        0 0 6px #000,
        0 2px 8px #000,
        2px 2px 0 #000,
        -2px -2px 0 #000;
      box-shadow: 0 2px 8px #0008;
    }


    .gif-overlay {
            // Estado inicial do toggle
      position: absolute;
            let init = false;
      inset: 0;
            try {
      background-repeat: no-repeat;
                if (localStorage.getItem('glaWeaponEnabled') === '1') init = true;
      background-size: 150%;
            } catch (x) { }
      background-position: center -30px;
            setTimeout(() => applyWeaponState(init), 150);
      opacity: 0;
        };
      z-index: 1;
      pointer-events: none;
    }


     .personagem:hover .gif-overlay {
        if (document.readyState === 'loading') {
      opacity: 1;
            document.addEventListener('DOMContentLoaded', boot);
        } else {
            boot();
        }
    })();
</script>
<style>
     .weapon-modal {
        position: fixed;
        inset: 0;
        z-index: 9999;
        display: flex;
        align-items: center;
        justify-content: center;
        opacity: 0;
        pointer-events: none;
        transition: opacity .3s;
     }
     }


     .personagem.luffy .gif-overlay {
     .weapon-modal.show {
      background-position: center 0px;
        opacity: 1;
        pointer-events: all;
     }
     }


     .personagem.hancock {
     .weapon-modal-overlay {
      background-size: 115%;
        position: absolute;
        inset: 0;
        background: rgba(0, 0, 0, .75);
        -webkit-backdrop-filter: blur(4px);
        backdrop-filter: blur(4px);
     }
     }


     .personagem.daddy {
     .weapon-modal-content {
      background-size: 100%;
        position: relative;
      background-position: top;
        background: linear-gradient(135deg, #1f1f1f, #2a2a2a);
        border: 1px solid rgba(255, 255, 255, .12);
        border-radius: 12px;
        max-width: 420px;
        width: 90%;
        box-shadow: 0 20px 60px rgba(0, 0, 0, .6);
        animation: modalIn .3s;
     }
     }


     .personagem.kizaru {
     @keyframes modalIn {
      background-position: center -20px;
        from {
    }
            transform: translateY(-20px);
            opacity: 0;
        }


    .personagem.luffypre {
        to {
      background-position: center;
            transform: translateY(0);
    }
            opacity: 1;
 
        }
    .personagem.perona {
      background-position: center -80px;
    }
 
    .personagem.sanjipre {
      background-position: center -50px;
    }
 
    .personagem.cabaji {
      background-size: 240%;
      background-position: center -80px;
    }
 
    .personagem.gin {
      background-position: center -120px;
    }
 
    .personagem.jango {
      background-position: left -40px top -20px;
      background-size: 180%;
    }
 
    /* --------- Tiers ----------- */
    .tier-diamante .personagem {
      background-color: #414c5c;
    }
 
    .tier-gold .personagem {
      background-color: #d4af37;
    }
 
    .tier-prata .personagem {
      background-color: #c0c0c0;
    }
 
    .tier-bronze .personagem {
      background-color: #7e4f20;
    }
 
    .filtros {
      flex-wrap: wrap;
      align-items: flex-start;
      padding: 10px 20px;
      display: flex;
      gap: 20px;
      justify-content: space-between;
      margin-bottom: 20px;
     }
     }


     .filtros button {
     .weapon-modal-header {
      padding: 8px 14px;
        display: flex;
      margin: 0 4px;
        align-items: center;
      border: none;
        justify-content: space-between;
      border-radius: 5px;
        padding: 16px 20px;
      background-color: #58aaff;
        border-bottom: 1px solid rgba(255, 255, 255, .08);
      color: white;
      font-weight: bold;
      cursor: pointer;
      transition: background-color 0.3s;
     }
     }


     .filtro-grupo {
     .weapon-modal-header h3 {
      /*display: flex;
        margin: 0;
      flex-wrap: wrap;
        font-size: 16px;
      gap: 6px;*/
        font-weight: 600;
      display: grid;
        color: #fff;
      grid-template-columns: repeat(2, auto);
      gap: 6px 10px;
     }
     }


     .filtro-box {
     .weapon-modal-close {
      background: #5a5a5a13;
        background: transparent;
      padding: 10px;
        border: none;
      border-radius: 8px;
        color: rgba(255, 255, 255, .5);
        font-size: 24px;
        cursor: pointer;
        padding: 0;
        width: 28px;
        height: 28px;
        display: flex;
        align-items: center;
        justify-content: center;
        border-radius: 4px;
        transition: background .15s, color .15s;
     }
     }


     .filtro-box legend {
     .weapon-modal-close:hover {
      font-size: 16px;
        background: rgba(255, 255, 255, .1);
      font-weight: bold;
        color: #fff;
      color: #000000cc;
      margin-bottom: 6px;
      text-align: center;
     }
     }


     .filtros button:hover {
     .weapon-modal-body {
      background-color: #3388dd;
        padding: 20px;
        color: rgba(255, 255, 255, .8);
        line-height: 1.6;
        font-size: 14px;
     }
     }


     .filtros button.ativo {
     .weapon-modal-body p {
      background-color: #3588f5;
        margin: 0 0 12px;
      color: white;
      border-color: #2672d4;
      box-shadow: 0 0 5px rgba(0, 0, 0, 0.15);
      transform: scale(1.05);
     }
     }


     .classe-icon-wrapper {
     .weapon-modal-body p:last-child {
      position: absolute;
        margin: 0;
      top: 5px;
      left: 5px;
      display: flex;
      flex-direction: column;
      gap: 1px;
      z-index: 10;
      pointer-events: none;
      transition: transform 0.4s ease;
     }
     }


     .classe-icon {
     .weapon-modal-body strong {
      width: 28px;
        color: #6BB3FF;
      height: 28px;
      user-select: none;
      pointer-events: none;
      opacity: 1;
      transition: opacity 0.3s ease-in-out;
     }
     }


     .personagem-box {
     .weapon-modal-footer {
      position: relative;
        display: flex;
      transition: transform 0.4s ease;
        align-items: center;
      transform-origin: center center;
        justify-content: space-between;
        padding: 14px 20px;
        border-top: 1px solid rgba(255, 255, 255, .08);
        gap: 12px;
     }
     }


     .personagem-box:hover {
     .weapon-modal-checkbox {
      transform: scale(1.05);
        display: flex;
        align-items: center;
        gap: 8px;
        font-size: 12px;
        color: rgba(255, 255, 255, .6);
        cursor: pointer;
     }
     }


     .personagem-box:hover .classe-icon {
     .weapon-modal-checkbox input[type="checkbox"] {
      opacity: 0.8;
        accent-color: #4A9EFF;
     }
     }


     .classe-filtro-container {
     .weapon-modal-btn {
      display: flex;
        background: #4A9EFF;
      align-items: center;
        border: none;
      gap: 12px;
        color: #fff;
        padding: 10px 24px;
        border-radius: 6px;
        font-weight: 600;
        font-size: 13px;
        cursor: pointer;
        transition: background .15s;
     }
     }


     .btn-vertical {
     .weapon-modal-btn:hover {
      writing-mode: vertical-rl;
        background: #3A8EEF;
      rotate: 270deg;
     }
     }


     .classe-grid {
     @media (max-width: 600px) {
      display: grid;
        .weapon-modal-content {
      grid-template-columns: repeat(4, auto);
            width: 95%;
      gap: 6px 10px;
    }
 
    .tooltip-img {
      position: absolute;
      top: -110px;
      left: 50%;
      transform: translateX(-50%);
      width: 60px;
      height: auto;
      display: none;
      pointer-events: none;
      border-radius: 6px;
      box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
      z-index: 99;
    }
 
 
    .novos-container {
      padding: 20px;
      background: linear-gradient(to right, #e0f0ff, #ffffff);
      border-radius: 12px;
      margin: 20px auto;
      width: 95%;
      box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
      border: 2px solid #58aaff;
    }
 
    .novos-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      margin-bottom: 15px;
      border-bottom: 2px solid #58aaff;
      padding-bottom: 6px;
    }
 
    .novos-title {
      font-size: 20px;
      font-weight: bold;
      color: #006eff;
    }
 
    .new-gif {
      width: 32px;
      height: 32px;
      animation: pulse 1.5s infinite;
    }
 
    @keyframes pulse {
      0% {
        transform: scale(1);
        opacity: 1;
      }
 
      50% {
        transform: scale(1.2);
        opacity: 0.7;
      }
 
      100% {
        transform: scale(1);
        opacity: 1;
      }
    }
 
    .novos-grid {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      justify-content: center;
    }
 
    .estrela {
      font-size: 28px;
      line-height: 1;
      pointer-events: none;
      text-shadow: 0 0 2px #000, 0 0 1px #000, 1px 1px 0 #000, -1px -1px 0 #000;
    }
 
    .estrela.azul {
      color: #14a3ee;
    }
 
    .estrela.dourada {
      color: #ffc107;
    }
 
    .estrela.prata {
      color: #c0c0c0;
    }
 
    .estrela.bronze {
      color: #cd7f32;
    }
 
    .tier-btn {
      background: none;
      border: none;
      border-radius: 50%;
      padding: 6px 8px;
      cursor: pointer;
      transition: background 0.2s;
      font-size: 0;
      box-shadow: none;
      outline: none;
    }
 
    .tier-btn.ativo {
      background: #eaf2fb;
      outline: 2px solid #58aaff;
    }
 
    .filtro-grupo {
      display: flex;
      flex-direction: row;
      gap: 10px;
      justify-content: center;
      align-items: center;
    }
 
    .tipo-btn[data-tipo="parede"],
    .tipo-btn[data-tipo="ponte"] {
      margin-left: 16px;
    }
  </style>
</head>
 
<body>
 
  <!-- Barra de Pesquisa -->
  <div class="search-bar">
    <input type="text" id="search" placeholder="Pesquisar personagem...">
  </div>
 
 
  <div class="filtros">
    <!-- Filtro por Classe -->
    <fieldset class="filtro-box classe-filtro-container">
      <legend>Classe</legend>
      <button class="btn-vertical tipo-btn ativo" data-tipo="all">ALL</button>
      <div class="classe-grid">
        <button class="tipo-btn" data-tipo="lutador">Lutador</button>
        <button class="tipo-btn" data-tipo="atirador">Atirador</button>
        <button class="tipo-btn" data-tipo="cortante">Cortante</button>
        <button class="tipo-btn" data-tipo="especialista">Especialista</button>
        <button class="tipo-btn" data-tipo="tanque">Tanque</button>
        <button class="tipo-btn" data-tipo="dps">DPS</button>
        <button class="tipo-btn" data-tipo="suporte">Suporte</button>
        <button class="tipo-btn" data-tipo="bruiser">Bruiser</button>
      </div>
    </fieldset>
 
    <!-- Filtro por Outros (Parede e Ponte) -->
    <fieldset class="filtro-box">
      <legend>Outros</legend>
      <div class="classe-grid">
        <button class="tipo-btn" data-tipo="parede" data-tooltip-text="Personagens que quebram parede">
          <img src="https://wiki.gla.com.br/images/2/21/Wall-break.png" alt="parede" width="32" height="32">
        </button>
        <button class="tipo-btn" data-tipo="ponte" data-tooltip-text="Personagens que fazem ponte">
          <img src="https://wiki.gla.com.br/images/8/80/Bridge.png" alt="ponte" width="32" height="32">
        </button>
      </div>
    </fieldset>
 
    <!-- Filtro por Tier -->
    <fieldset class="filtro-box">
      <legend>Tier</legend>
      <div class="filtro-grupo">
        <button class="tier-btn" data-tier="tier-diamante"><span class="estrela azul" title="Diamante">★</span></button>
        <button class="tier-btn" data-tier="tier-gold"><span class="estrela dourada" title="Ouro">★</span></button>
        <button class="tier-btn" data-tier="tier-prata"><span class="estrela prata" title="Prata">★</span></button>
        <button class="tier-btn" data-tier="tier-bronze"><span class="estrela bronze" title="Bronze">★</span></button>
      </div>
    </fieldset>
 
  </div>
 
  <div class="novos-container">
    <div class="novos-header">
      <span class="novos-title">Novos Personagens</span>
      <img src="https://cdn-icons-png.flaticon.com/128/11135/11135991.png" alt="new" class="new-gif">
    </div>
    <div class="novos-grid" id="novos-grid">
      <!-- Os personagens com classe "novo" serão movidos para cá automaticamente -->
    </div>
  </div>
 
  <!-- Personagens -->
  <div class="container">
 
    <!-- aokiji -->
    <div class="personagem-box tier-diamante cortante especialista tanque ponte parede">
      <div class="personagem" data-static="https://i.postimg.cc/0NMJrvjJ/fundoaokiji.png" data-gif="">
        <span>Aokiji</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- kuma -->
    <div class="personagem-box tier-diamante especialista tanque parede">
      <div class="personagem" data-static="https://i.postimg.cc/8chnZGsF/kuma2.png" data-gif="">
        <span>Bartholomew Kuma</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- hancock -->
    <div class="personagem-box tier-diamante dps lutador">
      <div class="personagem hancock" data-static="https://i.postimg.cc/2j25Px4K/boahan.png" data-gif="">
        <span>Boa Hancock</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- kizaru -->
    <div class="personagem-box tier-diamante dps especialista atirador parede">
      <div class="personagem kizaru" data-static="https://i.postimg.cc/PqjhLLWD/kizaru.webp" data-gif="">
        <span>Borsalino Kizaru</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- brook -->
    <div class="personagem-box tier-diamante suporte cortante ponte">
      <div class="personagem" data-static="https://i.postimg.cc/rmsHzcPW/brookts.png" data-gif="">
        <span>Brook (TS)</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- chopper -->
    <div class="personagem-box tier-diamante suporte lutador parede">
      <div class="personagem hancock" data-static="https://i.postimg.cc/QM26N5cL/chopperts.png" data-gif="">
        <span>Chopper (TS)</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- doflamingo -->
    <div class="personagem-box tier-diamante dps especialista atirador ponte parede">
      <div class="personagem hancock" data-static="https://i.postimg.cc/3JfFJmHL/doflamingo.png" data-gif="">
        <span>Donquixote Doflamingo</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- mihawk -->
    <div class="personagem-box tier-diamante dps cortante parede">
      <div class="personagem" data-static="https://i.postimg.cc/6QWWj28X/Dracule-Mihawk.webp" data-gif="">
        <span>Dracule Mihawk</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- ivankov -->
    <div class="personagem-box tier-diamante suporte lutador parede">
      <div class="personagem" data-static="https://i.postimg.cc/C1pWP9Pf/Ivan-chan.webp" data-gif="">
        <span>Emporio Ivankov</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- enel -->
    <div class="personagem-box tier-diamante especialista atirador dps">
      <div class="personagem perona" data-static="https://i.postimg.cc/DzLNXBvf/enel2.png" data-gif="">
        <span>Enel</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- franky ts -->
    <div class="personagem-box tier-diamante tanque atirador parede">
      <div class="personagem" data-static="https://i.postimg.cc/mgDHryfP/frankyts.png" data-gif="">
        <span>Franky (TS)</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- jinbe -->
    <div class="personagem-box tier-diamante tanque lutador parede">
      <div class="personagem" data-static="https://i.postimg.cc/s2mqJzH6/jinbe.png" data-gif="">
        <span>Jinbe</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- teach -->
    <div class="personagem-box tier-diamante especialista bruiser">
      <div class="personagem" data-static="https://i.postimg.cc/vm5fRHwh/barba-Negra.png" data-gif="">
        <span>Marshall D. Teach</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- marco -->
    <div class="personagem-box tier-diamante especialista lutador suporte">
      <div class="personagem" data-static="https://i.postimg.cc/d11ChRTH/marco.png" data-gif="">
        <span>Marco</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- luffy -->
    <div class="personagem-box tier-diamante dps lutador parede">
      <div class="personagem luffy" data-static="https://i.postimg.cc/L8hJ0Sz0/luffycard.png" data-gif="">
        <span>Monkey D. Luffy (TS)</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- nami ts -->
    <div class="personagem-box tier-diamante dps especialista">
      <div class="personagem" data-static="https://i.postimg.cc/CLnPG8Bz/namits2.png" data-gif="">
        <span>Nami (TS)</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- ace -->
    <div class="personagem-box tier-diamante dps atirador especialista ">
      <div class="personagem" data-static="https://i.postimg.cc/52md08JF/ace.png" data-gif="">
        <span>Portgas D. Ace</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- robin ts -->
    <div class="personagem-box tier-diamante dps especialista ponte parede">
      <div class="personagem" data-static="https://i.postimg.cc/9QL8KbV1/robints.png" data-gif="">
        <span>Nico Robin (TS)</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
 
    <!-- zoro ts -->
    <div class="personagem-box tier-diamante dps cortante parede">
      <div class="personagem" data-static="https://i.postimg.cc/N01yLJMk/zorots.png" data-gif="">
        <span>Roronoa Zoro (TS)</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- sabo -->
    <div class="personagem-box tier-diamante dps especialista lutador parede">
      <div class="personagem hancock" data-static="https://i.postimg.cc/1tTQpXZP/sabo2.png" data-gif="">
        <span>Sabo</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
 
    <!-- akainu -->
    <div class="personagem-box tier-diamante especialista lutador dps parede">
      <div class="personagem" data-static="https://i.postimg.cc/j2TBtj1h/akainu.png" data-gif="">
        <span>Sakazuki (Akainu)</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- shanks -->
    <div class="personagem-box tier-diamante cortante bruiser parede">
      <div class="personagem" data-static="https://i.postimg.cc/HnTvFhJZ/shanks.png" data-gif="">
        <span>Shanks</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- usopp ts -->
    <div class="personagem-box tier-diamante dps atirador parede">
      <div class="personagem" data-static="https://i.postimg.cc/tCVbsY9z/usoppts2.png" data-gif="">
        <span>Usopp (TS)</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- uta -->
    <div class="personagem-box tier-diamante dps especialista parede">
      <div class="personagem hancock" data-static="https://i.postimg.cc/2y5FQRLD/uta.png" data-gif="">
        <span>Uta</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- sanji ts -->
    <div class="personagem-box tier-diamante dps lutador parede">
      <div class="personagem" data-static="https://i.postimg.cc/Vv5nSq2s/sanjits.png" data-gif="">
        <span>Sanji (TS)</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- baby 5 -->
    <div class="personagem-box tier-gold atirador cortante dps">
      <div class="personagem" data-static="https://i.postimg.cc/DZf9sHxQ/bb5.webp" data-gif="">
        <span>Baby 5</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- Bartolomeo -->
    <div class="personagem-box tier-gold dps especialista ponte parede">
      <div class="personagem" data-static="https://i.postimg.cc/ryrmqPvK/barto.png" data-gif="">
        <span>Bartolomeo</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- Basil Hawkins -->
    <div class="personagem-box tier-gold bruiser especialista ponte">
      <div class="personagem" data-static="https://i.postimg.cc/V6FKtRhM/basil.png" data-gif="">
        <span>Basil Hawkins</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- Bastille -->
    <div class="personagem-box tier-gold tanque cortante parede">
      <div class="personagem" data-static="https://i.postimg.cc/C1J45KZs/bastille.png" data-gif="">
        <span>Bastille</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- Bellamy -->
    <div class="personagem-box tier-gold dps lutador parede">
      <div class="personagem hancock" data-static="https://i.postimg.cc/8ckxzHGK/bella.png" data-gif="">
        <span>Bellamy</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- Bonney -->
    <div class="personagem-box tier-gold suporte lutador">
      <div class="personagem hancock" data-static="https://i.postimg.cc/mD8LyqnN/bonney4.png" data-gif="">
        <span>Jewelry Bonney</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- Kalifa -->
    <div class="personagem-box novo tier-gold suporte especialista">
      <div class="personagem hancock" data-static="https://i.postimg.cc/x1C8H4zG/kalifa.png" data-gif="">
        <span>Kalifa</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- Kaku -->
    <div class="personagem-box novo tier-gold atirador cortante dps">
      <div class="personagem" data-static="https://i.postimg.cc/vmyVnzGG/kaku.png" data-gif="">
        <span>Kaku</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- Brook pré -->
    <div class="personagem-box tier-gold suporte cortante">
      <div class="personagem" data-static="https://i.postimg.cc/Sx7D24vR/brookpre.png" data-gif="">
        <span>Brook</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- Blueno -->
    <div class="personagem-box novo tier-gold lutador dps">
      <div class="personagem" data-static="https://i.postimg.cc/m248bQHW/blueno.png" data-gif="">
        <span>Blueno</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- bege -->
    <div class="personagem-box tier-gold dps atirador parede">
      <div class="personagem" data-static="https://i.postimg.cc/TwvptHqy/bege.webp" data-gif="">
        <span>Capone Gang Bege</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- carrot -->
    <div class="personagem-box tier-gold dps especialista cortante">
      <div class="personagem" data-static="https://i.postimg.cc/MpPfrrct/carrot.png" data-gif="">
        <span>Carrot</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- chopper pré -->
    <div class="personagem-box tier-gold suporte lutador parede">
      <div class="personagem" data-static="https://i.postimg.cc/7YqCPy0m/tonytony.png" data-gif="">
        <span>Chopper</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- crocodile -->
    <div class="personagem-box tier-gold tanque especialista ponte parede">
      <div class="personagem hancock" data-static="https://i.postimg.cc/hGm4bCVX/croco.png" data-gif="">
        <span>Sir Crocodile</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- dalmatian -->
    <div class="personagem-box tier-gold bruiser cortante parede">
      <div class="personagem hancock" data-static="https://i.postimg.cc/Gpnnrbsp/dalma.png" data-gif="">
        <span>Dalmatian</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- franky pré -->
    <div class="personagem-box tier-gold bruiser atirador parede">
      <div class="personagem hancock" data-static="https://i.postimg.cc/RCJr33Q0/frankypre.png" data-gif="">
        <span>Franky</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- moria -->
    <div class="personagem-box tier-gold cortante suporte">
      <div class="personagem" data-static="https://i.postimg.cc/tg4w974p/moria.png" data-gif="">
        <span>Gecko Moria</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- hina -->
    <div class="personagem-box tier-gold bruiser lutador ponte parede">
      <div class="personagem" data-static="https://i.postimg.cc/90hBFNYZ/hina.png" data-gif="">
        <span>Hina</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- burgess -->
    <div class="personagem-box tier-gold tanque lutador parede">
      <div class="personagem hancock" data-static="https://i.postimg.cc/hv27WCyS/burgess.png" data-gif="">
        <span>Jesus Burgess</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- Jabra -->
    <div class="personagem-box novo tier-gold cortante dps">
      <div class="personagem" data-static="https://i.postimg.cc/J4y4zkVK/jabra.png" data-gif="">
        <span>Jabra</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- kid -->
    <div class="personagem-box tier-gold atirador tanque ponte parede">
      <div class="personagem" data-static="https://i.postimg.cc/wMq0QGRH/kid.png" data-gif="">
        <span>Eustass Kid</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- killer -->
    <div class="personagem-box tier-gold dps cortante">
      <div class="personagem" data-static="https://i.postimg.cc/44W5Twh7/killer.png" data-gif="">
        <span>Killer</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- koala -->
    <div class="personagem-box tier-gold dps lutador">
      <div class="personagem" data-static="https://i.postimg.cc/FsqwhhJL/koala.png" data-gif="">
        <span>Koala</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- Rob Lucci -->
    <div class="personagem-box novo tier-gold lutador dps">
      <div class="personagem" data-static="https://i.postimg.cc/9MvgPK0D/lucci.png" data-gif="">
        <span>Rob Lucci</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- leo e mansherry -->
    <div class="personagem-box tier-gold suporte especialista ponte">
      <div class="personagem hancock" data-static="https://i.postimg.cc/2yyXftkG/leo-masherry.png" data-gif="">
        <span>Leo & Mansherry</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- luffy pré -->
    <div class="personagem-box tier-gold bruiser lutador parede">
      <div class="personagem luffypre" data-static="https://i.postimg.cc/PrZ0fBbV/luffypre.png" data-gif="">
        <span>Monkey D. Luffy</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- nami pré -->
    <div class="personagem-box tier-gold dps especialista parede">
      <div class="personagem" data-static="https://i.postimg.cc/Jn7YZdZL/nami3.png" data-gif="">
        <span>Nami</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- perona -->
    <div class="personagem-box tier-gold suporte especialista parede">
      <div class="personagem" data-static="https://i.postimg.cc/BQfYC6xp/perona3.png" data-gif="">
        <span>Perona</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- rebecca -->
    <div class="personagem-box tier-gold tanque cortante">
      <div class="personagem hancock" data-static="https://i.postimg.cc/9XKgwCct/rebecca.png" data-gif="">
        <span>Rebecca</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- robin pré -->
    <div class="personagem-box tier-gold dps especialista ponte parede">
      <div class="personagem" data-static="https://i.postimg.cc/W13DRLJC/robinpre.png" data-gif="">
        <span>Robin</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- zoro pré -->
    <div class="personagem-box tier-gold bruiser cortante parede">
      <div class="personagem" data-static="https://i.postimg.cc/B6q9ysj1/zoropre.png" data-gif="">
        <span>Zoro</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- ryuma -->
    <div class="personagem-box tier-gold dps cortante">
      <div class="personagem" data-static="https://i.postimg.cc/vmhS4nmc/ryuma.png" data-gif="">
        <span>Ryuma</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- apoo -->
    <div class="personagem-box tier-gold suporte atirador">
      <div class="personagem hancock" data-static="https://i.postimg.cc/fWVDhzHx/apoo.png" data-gif="">
        <span>Scratchmen Apoo</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- smoker -->
    <div class="personagem-box tier-gold tanque lutador">
      <div class="personagem kizaru" data-static="https://i.postimg.cc/P53ShjVw/smoker.png" data-gif="">
        <span>Smoker</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- law -->
    <div class="personagem-box tier-gold dps cortante especialista parede">
      <div class="personagem" data-static="https://i.postimg.cc/FRtgssy7/law.png" data-gif="">
        <span>Trafalgar D. Water Law</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- urouge -->
    <div class="personagem-box tier-gold tanque lutador parede">
      <div class="personagem" data-static="https://i.postimg.cc/1zDVB0F3/urouge.png" data-gif="">
        <span>Urouge</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- usopp pré -->
    <div class="personagem-box tier-gold dps atirador parede">
      <div class="personagem" data-static="https://i.postimg.cc/qRSRdzy5/usopppre.png" data-gif="">
        <span>Usopp</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- van augur -->
    <div class="personagem-box tier-gold dps atirador parede">
      <div class="personagem hancock" data-static="https://i.postimg.cc/ZKTk5JH7/van.png" data-gif="">
        <span>Van Augur</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- ichiji -->
    <div class="personagem-box tier-gold bruiser lutador parede">
      <div class="personagem" data-static="https://i.postimg.cc/x1wtqRYf/ichiji.png" data-gif="">
        <span>Vinsmoke Ichiji</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- niji -->
    <div class="personagem-box tier-gold dps atirador">
      <div class="personagem" data-static="https://i.postimg.cc/RhYwySZS/niji.png" data-gif="">
        <span>Vinsmoke Niji</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- reiju -->
    <div class="personagem-box tier-gold suporte especialista">
      <div class="personagem" data-static="https://i.postimg.cc/5NHBvCs6/reiju.png" data-gif="">
        <span>Vinsmoke Reiju</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- sanji pré -->
    <div class="personagem-box tier-gold dps lutador parede">
      <div class="personagem sanjipre" data-static="https://i.postimg.cc/CKKkhnnh/sanjipre.png" data-gif="">
        <span>Vinsmoke Sanji</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- yonji -->
    <div class="personagem-box tier-gold tanque lutador parede">
      <div class="personagem" data-static="https://i.postimg.cc/KvFKc3C6/yonji.png" data-gif="">
        <span>Vinsmoke Yonji</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- drake -->
    <div class="personagem-box tier-gold bruiser lutador parede">
      <div class="personagem" data-static="https://i.postimg.cc/tRDbP1sQ/drake.png" data-gif="">
        <span>X Drake</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- satori -->
    <div class="personagem-box tier-prata especialista atirador suporte">
      <div class="personagem" data-static="https://i.postimg.cc/mkYZvRRx/satori.png" data-gif="">
        <span>Satori</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- gedatsu -->
    <div class="personagem-box tier-prata lutador dps">
      <div class="personagem hancock" data-static="https://i.postimg.cc/pTv60t05/gedatsu.png" data-gif="">
        <span>Gedatsu</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- ohm -->
    <div class="personagem-box tier-prata cortante tanque">
      <div class="personagem hancock" data-static="https://i.postimg.cc/65q1bchc/ohm.png" data-gif="">
        <span>Ohm</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- shura -->
    <div class="personagem-box tier-prata cortante dps">
      <div class="personagem" data-static="https://i.postimg.cc/j25v9qy2/shura.png" data-gif="">
        <span>Shura</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- arlong -->
    <div class="personagem-box tier-prata bruiser lutador parede">
      <div class="personagem" data-static="https://i.postimg.cc/j2LQcgrJ/arlong.png" data-gif="">
        <span>Arlong</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- bepo -->
    <div class="personagem-box tier-prata dps lutador">
      <div class="personagem" data-static="https://i.postimg.cc/MKfmjFDC/bepo.png" data-gif="">
        <span>Bepo</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- bon clay -->
    <div class="personagem-box tier-prata dps lutador">
      <div class="personagem" data-static="https://i.postimg.cc/bJ3jBpZF/BonClay.webp" data-gif="">
        <span>Bon Clay</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- buggy -->
    <div class="personagem-box tier-prata dps atirador parede">
      <div class="personagem" data-static="https://i.postimg.cc/Vvmdg40W/buggy.png" data-gif="">
        <span>Buggy</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- daddy -->
    <div class="personagem-box tier-prata dps atirador">
      <div class="personagem daddy" data-static="https://i.postimg.cc/X7mfYHVX/daddy3.png" data-gif="">
        <span>Daddy Masterson</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- daz -->
    <div class="personagem-box tier-prata tanque cortante">
      <div class="personagem" data-static="https://i.postimg.cc/wjjymWDX/daz.png" data-gif="">
        <span>Daz Bonez</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- zala -->
    <div class="personagem-box tier-prata bruiser cortante">
      <div class="personagem" data-static="https://i.postimg.cc/PqZtpZVb/zala.png" data-gif="">
        <span>Zala</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- krieg -->
    <div class="personagem-box tier-prata dps atirador">
      <div class="personagem" data-static="https://i.postimg.cc/8Cg2YYwW/krieg.png" data-gif="">
        <span>Don Krieg</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- kuro -->
    <div class="personagem-box tier-prata dps cortante">
      <div class="personagem" data-static="https://i.postimg.cc/W47HH1dL/kuro.png" data-gif="">
        <span>Kuro</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- galdino -->
    <div class="personagem-box tier-prata suporte especialista ponte">
      <div class="personagem" data-static="https://i.postimg.cc/VkZRr00N/galdino.png" data-gif="">
        <span>Galdino</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- tashigi -->
    <div class="personagem-box tier-prata dps cortante">
      <div class="personagem kizaru" data-static="https://i.postimg.cc/rwH1F670/tashigi.png" data-gif="">
        <span>Tashigi</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- nefertari vivi -->
    <div class="personagem-box tier-prata suporte cortante">
      <div class="personagem" data-static="https://i.postimg.cc/jdFwyHcB/vivi.png" data-gif="">
        <span>Nefertari Vivi</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- wapol -->
    <div class="personagem-box tier-prata tanque atirador parede">
      <div class="personagem" data-static="https://i.postimg.cc/26k8syT4/wapol.png" data-gif="">
        <span>Wapol</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- alvida -->
    <div class="personagem-box tier-bronze suporte lutador">
      <div class="personagem" data-static="https://i.postimg.cc/yxGC7jXm/Alvida-Slime.webp" data-gif="">
        <span>Alvida</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- buchi -->
    <div class="personagem-box tier-bronze bruiser cortante">
      <div class="personagem" data-static="https://i.postimg.cc/VLLZJ8ZD/Splashartbuchi.png" data-gif="">
        <span>Buchi & Sham</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- cabaji -->
    <div class="personagem-box tier-bronze dps cortante">
      <div class="personagem cabaji" data-static="https://i.postimg.cc/G3MJSszx/cabaji.png" data-gif="">
        <span>Cabaji</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- chew -->
    <div class="personagem-box tier-bronze dps atirador parede">
      <div class="personagem sanjipre" data-static="https://i.postimg.cc/NG1LKh29/chew.png" data-gif="">
        <span>Chew</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- eric -->
    <div class="personagem-box tier-bronze dps atirador cortante">
      <div class="personagem hancock" data-static="https://i.postimg.cc/rmGcwkZq/eric.png" data-gif="">
        <span>Eric</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- gin -->
    <div class="personagem-box tier-bronze dps atirador lutador">
      <div class="personagem gin" data-static="https://i.postimg.cc/pLB6rdRG/gin.png" data-gif="">
        <span>Gin</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- goldenweek -->
    <div class="personagem-box tier-bronze suporte especialista">
      <div class="personagem sanjipre" data-static="https://i.postimg.cc/8CMsMxX0/goldenweek.png" data-gif="">
        <span>Miss GoldenWeek</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- hatchan -->
    <div class="personagem-box tier-bronze suporte cortante">
      <div class="personagem gin" data-static="https://i.postimg.cc/fy2bMskJ/hatchan.png" data-gif="">
        <span>Hatchan</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- jango -->
    <div class="personagem-box tier-bronze atirador suporte">
      <div class="personagem jango" data-static="https://i.postimg.cc/t40jW709/jango2.png" data-gif="">
        <span>Jango</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- kuroobi -->
    <div class="personagem-box tier-bronze tanque lutador parede">
      <div class="personagem sanjipre" data-static="https://i.postimg.cc/bvkHrCxz/kuroobi.png" data-gif="">
        <span>Kuroobi</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- mohji -->
    <div class="personagem-box tier-bronze bruiser especialista">
      <div class="personagem sanjipre" data-static="https://i.postimg.cc/MTRWhRJ3/mohji.png" data-gif="">
        <span>Mohji</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- morgan -->
    <div class="personagem-box tier-bronze bruiser cortante">
      <div class="personagem cabaji" data-static="https://i.postimg.cc/RVwPpLpJ/morgan.png" data-gif="">
        <span>Morgan</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- babe & drophy -->
    <div class="personagem-box tier-bronze bruiser atirador">
      <div class="personagem hancock" data-static="https://i.postimg.cc/vmTtyrhz/babe.png" data-gif="">
        <span>Babe & Drophy</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- gem & mikita -->
    <div class="personagem-box tier-bronze dps atirador">
      <div class="personagem hancock" data-static="https://i.postimg.cc/FsxyJWnp/gem.png" data-gif="">
        <span>Gem & Mikita</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
 
    <!-- pearl -->
    <div class="personagem-box  tier-bronze tanque lutador especialista">
      <div class="personagem" data-static="https://i.postimg.cc/Y0HFvY6T/pearl.png" data-gif="">
        <span>Pearl</span>
        <div class="gif-overlay"></div>
      </div>
    </div>
  </div>
 
  <!-- Scripts -->
  <script>
    // Mover personagens com classe "novo" para a área de novos
    const novosGrid = document.getElementById('novos-grid');
    document.querySelectorAll('.personagem-box.novo').forEach(novoCard => {
      novosGrid.appendChild(novoCard);
    });
 
    const cards = document.querySelectorAll('.personagem');
 
    // Define as imagens estáticas e gifs, além do reset ao sair
    cards.forEach(card => {
      const staticImg = card.getAttribute('data-static');
      const gifImg = card.getAttribute('data-gif');
      const overlay = card.querySelector('.gif-overlay');
      card.style.backgroundImage = `url('${staticImg}')`;
 
      card.addEventListener('mouseenter', () => {
        const uniqueGifUrl = `${gifImg}?t=${new Date().getTime()}`; // Força reset
        overlay.style.backgroundImage = `url('${uniqueGifUrl}')`;
      });
 
      card.addEventListener('mouseleave', () => {
        overlay.style.backgroundImage = '';
      });
    });
 
    // Filtragem por nome no campo de busca
    document.getElementById('search').addEventListener('input', function () {
      const term = this.value.toLowerCase();
      cards.forEach(card => {
        const name = card.querySelector('span').textContent.toLowerCase();
        const wrapper = card.parentElement;
        const tierBox = wrapper.parentElement;
        // Só filtra se NÃO estiver na grid de novos personagens
        if (!tierBox.classList.contains('novos-grid')) {
          tierBox.style.display = name.includes(term) ? 'block' : 'none';
         }
         }
      });
    });
    //  Links dos personagens
    const personagemLinks = {
      "Aokiji": "https://wiki.gla.com.br/index.php/Aokiji",
      "Bartholomew Kuma": "https://wiki.gla.com.br/index.php/Kuma",
      "Boa Hancock": "https://wiki.gla.com.br/index.php/Boa_Hancock",
      "Borsalino Kizaru": "https://wiki.gla.com.br/index.php/Kizaru",
      "Brook (TS)": "https://wiki.gla.com.br/index.php/Brook_(Timeskip)",
      "Chopper (TS)": "https://wiki.gla.com.br/index.php/Chopper_(Timeskip)",
      "Donquixote Doflamingo": "https://wiki.gla.com.br/index.php/Doflamingo",
      "Dracule Mihawk": "https://wiki.gla.com.br/index.php/Mihawk",
      "Emporio Ivankov": "https://wiki.gla.com.br/index.php/Ivankov",
      "Enel": "https://wiki.gla.com.br/index.php/Enel",
      "Franky (TS)": "https://wiki.gla.com.br/index.php/Franky_(Timeskip)",
      "Jinbe": "https://wiki.gla.com.br/index.php/Jinbe",
      "Marshall D. Teach": "https://wiki.gla.com.br/index.php/Marshall_D._Teach",
      "Marco": "https://wiki.gla.com.br/index.php/Marco",
      "Monkey D. Luffy (TS)": "https://wiki.gla.com.br/index.php/Luffy_(Timeskip)",
      "Nami (TS)": "https://wiki.gla.com.br/index.php/Nami_(Timeskip)",
      "Portgas D. Ace": "https://wiki.gla.com.br/index.php/Ace",
      "Nico Robin (TS)": "https://wiki.gla.com.br/index.php/Robin_(Timeskip)",
      "Roronoa Zoro (TS)": "https://wiki.gla.com.br/index.php/Zoro_(Timeskip)",
      "Sabo": "https://wiki.gla.com.br/index.php/Sabo",
      "Sakazuki (Akainu)": "https://wiki.gla.com.br/index.php/Akainu",
      "Shanks": "https://wiki.gla.com.br/index.php/Shanks",
      "Usopp (TS)": "https://wiki.gla.com.br/index.php/Usopp_(Timeskip)",
      "Uta": "https://wiki.gla.com.br/index.php/Uta",
      "Sanji (TS)": "https://wiki.gla.com.br/index.php/Sanji_(Timeskip)",
      "Baby 5": "https://wiki.gla.com.br/index.php/Baby_5",
      "Bartolomeo": "https://wiki.gla.com.br/index.php/Bartolomeo",
      "Basil Hawkins": "https://wiki.gla.com.br/index.php/Basil_Hawkins",
      "Bastille": "https://wiki.gla.com.br/index.php/Bastille",
      "Bellamy": "https://wiki.gla.com.br/index.php/Bellamy",
      "Jewelry Bonney": "https://wiki.gla.com.br/index.php/Bonney",
      "Brook": "https://wiki.gla.com.br/index.php/Brook",
      "Capone Gang Bege": "https://wiki.gla.com.br/index.php/Capone_Bege",
      "Carrot": "https://wiki.gla.com.br/index.php/Carrot",
      "Chopper": "https://wiki.gla.com.br/index.php/Chopper",
      "Sir Crocodile": "https://wiki.gla.com.br/index.php/Crocodile",
      "Dalmatian": "https://wiki.gla.com.br/index.php/Dalmatian",
      "Franky": "https://wiki.gla.com.br/index.php/Franky",
      "Gecko Moria": "https://wiki.gla.com.br/index.php/Gecko_Moria",
      "Hina": "https://wiki.gla.com.br/index.php/Hina",
      "Jesus Burgess": "https://wiki.gla.com.br/index.php/Jesus_Burgess",
      "Eustass Kid": "https://wiki.gla.com.br/index.php/Kid",
      "Killer": "https://wiki.gla.com.br/index.php/Killer",
      "Koala": "https://wiki.gla.com.br/index.php/Koala",
      "Leo & Mansherry": "https://wiki.gla.com.br/index.php/Leo",
      "Monkey D. Luffy": "https://wiki.gla.com.br/index.php/Luffy",
      "Nami": "https://wiki.gla.com.br index.php/Nami",
      "Perona": "https://wiki.gla.com.br index.php/Perona",
      "Rebecca": "https://wiki.gla.com.br index.php/Rebecca",
      "Robin": "https://wiki.gla.com.br index.php/Robin",
      "Zoro": "https://wiki.gla.com.br index.php/Zoro",
      "Ryuma": "https://wiki.gla.com.br index.php/Ryuma",
      "Scratchmen Apoo": "https://wiki.gla.com.br index.php/Apoo",
      "Smoker": "https://wiki.gla.com.br index.php/Smoker",
      "Trafalgar D. Water Law": "https://wiki.gla.com.br index.php/Law",
      "Urouge": "https://wiki.gla.com.br index.php/Urouge",
      "Usopp": "https://wiki.gla.com.br index.php/Usopp",
      "Van Augur": "https://wiki.gla.com.br index.php/Van_Augur",
      "Vinsmoke Ichiji": "https://wiki.gla.com.br index.php/Ichiji",
      "Vinsmoke Niji": "https://wiki.gla.com.br index.php/Niji",
      "Vinsmoke Reiju": "https://wiki.gla.com.br index.php/Reiju",
      "Vinsmoke Sanji": "https://wiki.gla.com.br index.php/Sanji",
      "Vinsmoke Yonji": "https://wiki.gla.com.br index.php/Yonji",
      "X Drake": "https://wiki.gla.com.br index.php/X_Drake",
      "Satori": "https://wiki.gla.com.br index.php/Satori",
      "Gedatsu": "https://wiki.gla.com.br index.php/Gedatsu",
      "Ohm": "https://wiki.gla.com.br index.php/Ohm",
      "Shura": "https://wiki.gla.com.br index.php/Shura",
      "Arlong": "https://wiki.gla.com.br index.php/Arlong",
      "Bepo": "https://wiki.gla.com.br index.php/Bepo",
      "Bon Clay": "https://wiki.gla.com.br index.php/Mr.2",
      "Buggy": "https://wiki.gla.com.br index.php/Buggy",
      "Daddy Masterson": "https://wiki.gla.com.br index.php/Daddy_Masterson",
      "Daz Bonez": "https://wiki.gla.com.br index.php/Mr.1",
      "Zala": "https://wiki.gla.com.br index.php/Miss_Doublefinger",
      "Don Krieg": "https://wiki.gla.com.br index.php/Don_Krieg",
      "Kuro": "https://wiki.gla.com.br index.php/Kuro",
      "Galdino": "https://wiki.gla.com.br index.php/Mr.3",
      "Tashigi": "https://wiki.gla.com.br index.php/Tashigi",
      "Nefertari Vivi": "https://wiki.gla.com.br index.php/Vivi",
      "Wapol": "https://wiki.gla.com.br index.php/Wapol",
      "Alvida": "https://wiki.gla.com.br index.php/Alvida",
      "Buchi & Sham": "https://wiki.gla.com.br index.php/Buchi",
      "Cabaji": "https://wiki.gla.com.br index.php/Cabaji",
      "Chew": "https://wiki.gla.com.br index.php/Chew",
      "Eric": "https://wiki.gla.com.br index.php/Eric",
      "Gin": "https://wiki.gla.com.br index.php/Gin",
      "Miss GoldenWeek": "https://wiki.gla.com.br index.php/Goldenweek",
      "Hatchan": "https://wiki.gla.com.br index.php/Hatchan",
      "Jango": "https://wiki.gla.com.br index.php/Jango",
      "Kuroobi": "https://wiki.gla.com.br index.php/Kuroobi",
      "Mohji": "https://wiki.gla.com.br index.php/Mohji",
      "Morgan": "https://wiki.gla.com.br index.php/Morgan",
      "Babe & Drophy": "https://wiki.gla.com.br index.php/Mr.4",
      "Gem & Mikita": "https://wiki.gla.com.br index.php/Mr.5",
      "Pearl": "https://wiki.gla.com.br index.php/Pearl"
    };
    // Envolve as boxes com <a> e aplica links clicáveis
    cards.forEach(card => {
      const span = card.querySelector('span');
      const nomePersonagem = span?.textContent.trim();
      const link = personagemLinks[nomePersonagem];
      if (link) {
        const wrapper = document.createElement('a');
        wrapper.href = link;
        wrapper.target = "_blank";
        wrapper.style.display = "flex";
        wrapper.style.textDecoration = "none";
        wrapper.style.flex = "0 1 auto";
        wrapper.style.alignItems = "stretch";
        card.parentElement.replaceChild(wrapper, card);
        wrapper.appendChild(card);
      }
    });
    const tierButtons = document.querySelectorAll('.tier-btn');
    const tipoButtons = document.querySelectorAll('.tipo-btn');
    const personagemBoxes = document.querySelectorAll('.personagem-box');
    let activeTier = 'all';
    let activeTipos = new Set();
    const iconesClasse = {
      lutador: 'https://wiki.gla.com.br/images/e/e6/Fighter.png',
      especialista: 'https://wiki.gla.com.br/images/f/f6/Especialist.png',
      tanque: 'https://wiki.gla.com.br/images/9/9d/Tank.png',
      suporte: 'https://wiki.gla.com.br/images/a/ab/Support.png',
      bruiser: 'https://wiki.gla.com.br/images/e/e4/Bruiser.png',
      atirador: 'https://wiki.gla.com.br/images/e/ed/Shooter.png',
      dps: 'https://wiki.gla.com.br/images/6/60/Dps.png',
      cortante: 'https://wiki.gla.com.br/images/9/9a/Slasher.png',
      fruta: 'https://wiki.gla.com.br/images/e/e4/Devil-fruit.png',
    };
    function updateFiltros() {
      personagemBoxes.forEach(box => {
        const matchesTier = activeTier === 'all' || box.classList.contains(activeTier);
        const matchesTipo =
          activeTipos.size === 0 ||
          [...activeTipos].every(tipo => box.classList.contains(tipo));
        box.style.display = (matchesTier && matchesTipo) ? 'block' : 'none';
      });
    }


    tierButtons.forEach(button => {
        .weapon-modal-header,
      button.addEventListener('click', () => {
         .weapon-modal-body,
         const selectedTier = button.dataset.tier;
         .weapon-modal-footer {
         if (selectedTier === activeTier || selectedTier === 'all') {
            padding: 12px 16px;
          activeTier = 'all';
          tierButtons.forEach(btn => btn.classList.remove('ativo'));
        } else {
          activeTier = selectedTier;
          tierButtons.forEach(btn => btn.classList.remove('ativo'));
          button.classList.add('ativo');
         }
         }
        updateFiltros();
      });
    });


    tipoButtons.forEach(button => {
         .weapon-modal-footer {
      button.addEventListener('click', () => {
             flex-direction: column;
         const selectedTipo = button.dataset.tipo;
        console.log(selectedTipo)
        if (selectedTipo === 'all') {
          activeTipos.clear();
          tipoButtons.forEach(btn => { if (btn.dataset.tipo === 'all') { btn.classList.add('ativo'); } else { btn.classList.remove('ativo'); } });
        } else {
          if (activeTipos.has(selectedTipo)) {
             activeTipos.delete(selectedTipo);
            button.classList.remove('ativo');
          } else {
            activeTipos.add(selectedTipo);
            button.classList.add('ativo');
          }
          tipoButtons.forEach(btn => {
            if (btn.dataset.tipo === 'all') btn.classList.remove('ativo');
          });
          if (activeTipos.size === 0) {
            tipoButtons.forEach(btn => { if (btn.dataset.tipo === 'all') { btn.classList.add('ativo'); } });
          }
         }
         }
        updateFiltros();
      });
    });
    document.querySelectorAll('.personagem-box').forEach(box => {
      const classes = box.className.split(/\s+/);
      const icones = classes
        .filter(classe => iconesClasse.hasOwnProperty(classe))
        .map(classe => {
          const img = document.createElement('img');
          img.src = iconesClasse[classe];
          img.alt = classe;
          img.className = 'classe-icon';
          return img;
        });
      if (icones.length > 0) {
        const wrapper = document.createElement('div');
        wrapper.className = 'classe-icon-wrapper';
        icones.forEach(icon => wrapper.appendChild(icon));
        box.appendChild(wrapper);
      }
    });
    document.querySelectorAll('[data-tooltip-img], [data-tooltip-text]').forEach(btn => {
      const imgUrl = btn.getAttribute('data-tooltip-img');
      const tooltipText = btn.getAttribute('data-tooltip-text');
      let tooltip;
      if (imgUrl) {
        tooltip = document.createElement('img');
        tooltip.src = imgUrl;
        tooltip.classList.add('tooltip-img');
        btn.style.position = 'relative';
        btn.appendChild(tooltip);
      }
      if (tooltipText) {
        tooltip = document.createElement('div');
        tooltip.textContent = tooltipText;
        tooltip.classList.add('tooltip-img');
        tooltip.style.background = '#222';
        tooltip.style.color = '#fff';
        tooltip.style.padding = '6px 10px';
        tooltip.style.fontSize = '14px';
        tooltip.style.textAlign = 'center';
        tooltip.style.width = '180px';
        btn.style.position = 'relative';
        btn.appendChild(tooltip);
      }
      if (tooltip) {
        btn.addEventListener('mouseenter', () => {
          tooltip.style.display = 'block';
        });
        btn.addEventListener('mouseleave', () => {
          tooltip.style.display = 'none';
        });
      }
    });
    if (novosGrid.children.length === 0) {
      document.querySelector('.novos-container').style.display = 'none';
     }
     }
  </script>
</style>
 
</body>
 
</html>

Edição das 17h36min de 1 de dezembro de 2025

<script>

   (() => {
       let modalListenersBound = false;
       const bindModalEvents = () => {
           if (modalListenersBound) return;
           modalListenersBound = true;
           document.addEventListener('click', (ev) => {
               if (ev.target.closest('.weapon-modal-close') || ev.target.closest('.weapon-modal-btn')) {
                   const checkbox = document.getElementById('weapon-dont-show');
                   if (checkbox && checkbox.checked) {
                       try { localStorage.setItem('glaWeaponPopupDismissed', '1'); } catch (x) { }
                   }
                   hidePopup();
                   return;
               }
               if (ev.target.classList.contains('weapon-modal-overlay')) {
                   hidePopup();
               }
           });
       };
       const applyWeaponState = (enabled) => {
           // Atualizar flag global
           if (typeof window.__setGlobalWeaponEnabled === 'function') {
               window.__setGlobalWeaponEnabled(enabled);
           }
           // Salvar preferência
           try {
               localStorage.setItem('glaWeaponEnabled', enabled ? '1' : '0');
           } catch (x) { }
           // Aplicar/remover classe e indicador visual em TODAS as skills com arma
           document.querySelectorAll('.skill-icon[data-weapon]').forEach(el => {
               if (enabled) {
                   el.classList.add('has-weapon-available');
                   let ind = el.querySelector('.weapon-indicator');
                   if (!ind) {
                       ind = document.createElement('div');
                       ind.className = 'weapon-indicator';
                       el.appendChild(ind);
                   }
               } else {
                   el.classList.remove('has-weapon-available');
                   el.classList.remove('weapon-equipped');
                   el.style.removeProperty('--weapon-badge-url');
                   const ind = el.querySelector('.weapon-indicator');
                   if (ind) ind.remove();
               }
           });
       };
       const ensureModal = () => {
           let modal = document.getElementById('weapon-info-modal');
           if (modal) return modal;
           modal = document.createElement('div');
           modal.id = 'weapon-info-modal';
           modal.className = 'weapon-modal';
           modal.innerHTML = `

Visualização com Arma Especial

                   <button class="weapon-modal-close">×</button>

Este modo ativa a visualização do personagem equipado com sua arma especial.

As habilidades melhoradas ficam destacadas com borda e brilho azul, mesmo quando não selecionadas.

       `;
           document.body.appendChild(modal);
           try {
               const firstWithWeapon = document.querySelector('.skill-icon[data-weapon]');
               if (firstWithWeapon) {
                   const raw = firstWithWeapon.getAttribute('data-weapon');
                   const obj = JSON.parse(raw || '{}');
                   const nm = (obj && obj.name) ? String(obj.name).trim() : ;
                   if (nm) {
                       const linkHost = (window.mw && mw.util && typeof mw.util.getUrl === 'function') ? mw.util.getUrl(nm) : ('/index.php?title=' + encodeURIComponent(nm));
                       const holder = modal.querySelector('.weapon-info-link');
                       if (holder) {
                           holder.style.display = 'block';
                           holder.innerHTML = `<a href="${linkHost}" style="color:#6BB3FF;text-decoration:none;font-weight:600">Ver página da arma: ${nm}</a>`;
                       }
                   }
               }
           } catch (_) { }
           bindModalEvents();
           return modal;
       };
       const showPopup = () => {
           const modal = ensureModal();
           if (modal) modal.classList.add('show');
       };
       const hidePopup = () => {
           const m = document.getElementById('weapon-info-modal');
           if (m) m.classList.remove('show');
       };
       window.__applyWeaponState = applyWeaponState;
       window.__glaWeaponShowPopup = showPopup;
       window.__glaWeaponHidePopup = hidePopup;
       try {
           window.dispatchEvent(new CustomEvent('weapon:ready', { detail: { applyWeaponState, showPopup, hidePopup } }));
       } catch (err) {
       }
       const boot = () => {
           // Verificar se existe alguma skill com arma
           const hasAnyWeapon = document.querySelectorAll('.skill-icon[data-weapon]').length > 0;
           if (!hasAnyWeapon) return;
           ensureModal();
           // Estado inicial do toggle
           let init = false;
           try {
               if (localStorage.getItem('glaWeaponEnabled') === '1') init = true;
           } catch (x) { }
           setTimeout(() => applyWeaponState(init), 150);
       };
       if (document.readyState === 'loading') {
           document.addEventListener('DOMContentLoaded', boot);
       } else {
           boot();
       }
   })();

</script> <style>

   .weapon-modal {
       position: fixed;
       inset: 0;
       z-index: 9999;
       display: flex;
       align-items: center;
       justify-content: center;
       opacity: 0;
       pointer-events: none;
       transition: opacity .3s;
   }
   .weapon-modal.show {
       opacity: 1;
       pointer-events: all;
   }
   .weapon-modal-overlay {
       position: absolute;
       inset: 0;
       background: rgba(0, 0, 0, .75);
       -webkit-backdrop-filter: blur(4px);
       backdrop-filter: blur(4px);
   }
   .weapon-modal-content {
       position: relative;
       background: linear-gradient(135deg, #1f1f1f, #2a2a2a);
       border: 1px solid rgba(255, 255, 255, .12);
       border-radius: 12px;
       max-width: 420px;
       width: 90%;
       box-shadow: 0 20px 60px rgba(0, 0, 0, .6);
       animation: modalIn .3s;
   }
   @keyframes modalIn {
       from {
           transform: translateY(-20px);
           opacity: 0;
       }
       to {
           transform: translateY(0);
           opacity: 1;
       }
   }
   .weapon-modal-header {
       display: flex;
       align-items: center;
       justify-content: space-between;
       padding: 16px 20px;
       border-bottom: 1px solid rgba(255, 255, 255, .08);
   }
   .weapon-modal-header h3 {
       margin: 0;
       font-size: 16px;
       font-weight: 600;
       color: #fff;
   }
   .weapon-modal-close {
       background: transparent;
       border: none;
       color: rgba(255, 255, 255, .5);
       font-size: 24px;
       cursor: pointer;
       padding: 0;
       width: 28px;
       height: 28px;
       display: flex;
       align-items: center;
       justify-content: center;
       border-radius: 4px;
       transition: background .15s, color .15s;
   }
   .weapon-modal-close:hover {
       background: rgba(255, 255, 255, .1);
       color: #fff;
   }
   .weapon-modal-body {
       padding: 20px;
       color: rgba(255, 255, 255, .8);
       line-height: 1.6;
       font-size: 14px;
   }
   .weapon-modal-body p {
       margin: 0 0 12px;
   }
   .weapon-modal-body p:last-child {
       margin: 0;
   }
   .weapon-modal-body strong {
       color: #6BB3FF;
   }
   .weapon-modal-footer {
       display: flex;
       align-items: center;
       justify-content: space-between;
       padding: 14px 20px;
       border-top: 1px solid rgba(255, 255, 255, .08);
       gap: 12px;
   }
   .weapon-modal-checkbox {
       display: flex;
       align-items: center;
       gap: 8px;
       font-size: 12px;
       color: rgba(255, 255, 255, .6);
       cursor: pointer;
   }
   .weapon-modal-checkbox input[type="checkbox"] {
       accent-color: #4A9EFF;
   }
   .weapon-modal-btn {
       background: #4A9EFF;
       border: none;
       color: #fff;
       padding: 10px 24px;
       border-radius: 6px;
       font-weight: 600;
       font-size: 13px;
       cursor: pointer;
       transition: background .15s;
   }
   .weapon-modal-btn:hover {
       background: #3A8EEF;
   }
   @media (max-width: 600px) {
       .weapon-modal-content {
           width: 95%;
       }
       .weapon-modal-header,
       .weapon-modal-body,
       .weapon-modal-footer {
           padding: 12px 16px;
       }
       .weapon-modal-footer {
           flex-direction: column;
       }
   }

</style>