(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();
  }
})();      
      
      
      
 Caila Quinn is a reality television star best known for her appearance on the 20th season of The Bachelor in 2016. Born on December 10, 1992 in Westlake, OH, she finished as the second runner-up on the show.  Caila Quinn is a member of Reality Star 
  Age, Biography and Wiki
 💰 Net worth: $100K - $1M
 About
 Known for her time on the reality series The Bachelor. She appeared on the show's 20th season in 2016 and finished as the second runner-up.
 Before Fame
 Prior to her time on The Bachelor, she worked as a software sales representative in Ohio. She had previously graduated from Boston College with a degree in marketing.
 Trivia
 She was considered for The Bachelorette's 12th season after finishing her time on The Bachelor. She decided to move to New York City to further pursue her career in entertainment.
 Family Life
 She was born and raised in Westlake, Ohio.
👉 For more insights, check out this resource.
 Associated With
 She appeared alongside Ben Higgins during The Bachelor's 20th season.