(function () {
  // 1) Basic bot filter (extend if you like)
  function isBot() {
    return /(bot|crawl|spider|google|bing|slurp|yandex|facebook|linkedin|pinterest|preview|whatsapp|discord|telegram|headless|puppeteer)/i
      .test(navigator.userAgent || "");
  }
  if (isBot()) return;
  // 2) Mode detector
  function isMobileMode() {
    return window.matchMedia("(max-width: 767px)").matches ||
           /Mobi|Android|iPhone|iPad|iPod/i.test(navigator.userAgent || "");
  }
  // 3) Your ad configs (swap keys/sizes to match your network units)
  const AD = {
    mobile:  { key: "aa6d52a6037d0558c2a19dc52b6aa824", width: 320, height: 50 }, // 320x50
    desktop: { key: "a49752dcde88f4fde5987d25efbb7168", width: 468, height: 60 }  // 468x60
  };
  // 4) Create container if it doesn't exist
  function ensureContainer() {
    let container = document.getElementById("ad-container");
    if (!container) {
      container = document.createElement("div");
      container.id = "ad-container";
      container.style.display = "none";
      document.body.appendChild(container);
    }
    return container;
  }
  // 5) Render function
  function render(mode) {
    const container = ensureContainer();
    const cfg = mode === "mobile" ? AD.mobile : AD.desktop;
    
    // Set global atOptions for ad network
    window.atOptions = {
      key:    cfg.key,
      format: "iframe",
      height: cfg.height,
      width:  cfg.width,
      params: {}
    };
    
    // Clear previous ad/script then inject
    container.innerHTML = "";
    container.style.display = "block";
    
    const s = document.createElement("script");
    s.src = `//selfportraitproved.com/${cfg.key}/invoke.js`;
    s.async = true;
    container.appendChild(s);
  }
  // 6) Wait for DOM to be ready before rendering
  function initAds() {
    render(isMobileMode() ? "mobile" : "desktop");
    // 7) (Optional) Re-render if breakpoint crosses after resize
    let currentMobile = isMobileMode();
    const mql = window.matchMedia("(max-width: 767px)");
    
    if (mql.addEventListener) {
      mql.addEventListener("change", (e) => {
        const nowMobile = e.matches;
        if (nowMobile !== currentMobile) {
          currentMobile = nowMobile;
          render(currentMobile ? "mobile" : "desktop");
        }
      });
    } else if (mql.addListener) { // older browsers
      mql.addListener((e) => {
        const nowMobile = e.matches;
        if (nowMobile !== currentMobile) {
          currentMobile = nowMobile;
          render(currentMobile ? "mobile" : "desktop");
        }
      });
    }
  }
  // 8) Execute when DOM is ready
  if (document.readyState === "loading") {
    document.addEventListener("DOMContentLoaded", initAds);
  } else {
    initAds();
  }
})();      
      
      
      
 Heirlooms are some of the rarest, most sought-after items in Apex Legends, but it’s hard to know exactly when you should expect to get one. For fans eager to know how close they are to unlocking those elusive bragging rights, one website has you covered.
 Apex players are guaranteed at least one heirloom after opening 500 packs. Using this metric, one savvy fan designed a calculator that helps you determine how many packs you’ve opened. The tool creates a step-by-step breakdown using your account level, event progress, and battle pass progress.
 Here’s how the Apex Packs Calculator works.
  Players first begin by inputting their account level, found above your head in the in-game lobby. Once that’s in, the calculator automatically generates how many packs you’ve earned from those levels.
👉 For more insights, check out this resource.
 The calculator then prompts you to input your level for each season, as well as if you purchased the battle pass. To determine what level you achieved in past seasons, players can go to any legend’s “Banner” tab and find the badge for that season. The number on the badge is the level you reached. The data is current as of season 12.
 See Apex Legends on Amazon
 There’s also an option to input how many Apex packs you purchased from the store, as well as entries for events, quests, and Twitch Prime members. If you don’t know exactly how many packs you’ve received from these categories, just make your best guess.
👉 Discover more in this in-depth guide.
 Once all the information has been added to the calculator, it immediately tells you the number of packs bought and how close you are to 500. If you’re under the 50-percent mark, you may want to reconsider buying the over 250 packs needed for a guaranteed heirloom.
 Though Respawn does promise at least one heirloom per 500 packs, it’s completely possible to open the legendary item at any point in time, so don’t lose hope. There’s a reason the calculator calls the 500-pack mark “bad luck protection.”