/* =============================================
   ZAPPI MASCOT SYSTEM — SpecZap AI
   Ported from AudZap audzap.com
   ============================================= */
/* PIXEL MASCOT ZAPPI — JS-controlled position (roaming) */
#pixelMascot{
  position:fixed;bottom:20px;left:20px;
  z-index:9999;cursor:pointer;user-select:none;
  filter:drop-shadow(0 2px 14px rgba(220,38,38,.35));
  will-change:left,bottom;
}
#pixelMascot:hover{filter:drop-shadow(0 0 18px rgba(212,168,75,.85));}
#mascotDot{
  display:block;
  width:96px;height:96px;
  image-rendering:pixelated;
  background-repeat:no-repeat;
  background-position:0 0;
}
.mascot-label{font-size:9px;color:var(--muted);text-align:center;margin-top:4px;font-family:monospace;letter-spacing:2px;text-transform:uppercase}
#pixelMascot:hover .mascot-label{color:var(--gold)}
.mascot-speech{position:absolute;bottom:108px;left:50%;transform:translateX(-50%);background:var(--card);border:1px solid var(--gold);border-radius:8px;padding:6px 12px;font-size:11px;color:var(--text2);white-space:nowrap;opacity:0;transition:opacity .4s;pointer-events:none;box-shadow:0 0 12px rgba(212,168,75,.2);}
#pixelMascot:hover .mascot-speech{opacity:1}

/* =============================================
   ZAPPI GAMIFICATION SYSTEM — Phase 1-3
   ZP Points | Happiness | Shop UI
   ============================================= */

/* --- Happiness Bar --- */
#zappiHpWrap{display:flex;align-items:center;gap:4px;margin-bottom:4px;}
#zappiHpBar{width:80px;height:4px;background:rgba(255,255,255,.1);border-radius:2px;overflow:hidden;}
#zappiHpFill{height:100%;border-radius:2px;transition:width .6s ease,background .6s ease;}
#zappiHpIcon{font-size:9px;line-height:1;}

/* --- ZP Badge (shop button) --- */
#zappiShopBtn{
  position:fixed;bottom:20px;left:130px;
  z-index:9998;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;gap:2px;
}
#zappiShopBtn .shop-icon{
  width:36px;height:36px;
  background:var(--card);border:1px solid var(--gold);
  border-radius:10px;display:flex;align-items:center;justify-content:center;
  font-size:16px;
  transition:transform .2s,box-shadow .2s;
  box-shadow:0 2px 8px rgba(0,0,0,.4);
}
#zappiShopBtn:hover .shop-icon{transform:scale(1.1) translateY(-2px);box-shadow:0 4px 16px rgba(212,168,75,.3);}
#zappiZpBadge{
  font-size:9px;color:var(--gold);font-family:monospace;font-weight:700;
  background:rgba(212,168,75,.12);border:1px solid rgba(212,168,75,.3);
  border-radius:99px;padding:1px 6px;white-space:nowrap;
}

/* --- Floating ZP animation --- */
.zp-float{
  position:fixed;bottom:80px;left:20px;
  color:var(--gold);font-size:13px;font-weight:800;
  text-shadow:0 0 12px rgba(212,168,75,.6);
  pointer-events:none;z-index:10000;
  animation:zpFloat 2s ease-out forwards;
  white-space:nowrap;
}
@keyframes zpFloat{
  0%{opacity:1;transform:translateY(0) scale(1);}
  60%{opacity:1;transform:translateY(-40px) scale(1.15);}
  100%{opacity:0;transform:translateY(-70px) scale(0.9);}
}

/* --- Shop Panel --- */
#zappiShopPanel{
  position:fixed;bottom:0;left:0;right:0;
  height:520px;
  background:var(--card);
  border-top:1px solid var(--border);
  border-radius:24px 24px 0 0;
  z-index:10001;
  transform:translateY(100%);
  transition:transform .35s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;
  box-shadow:0 -8px 40px rgba(0,0,0,.5);
  max-width:480px;
  margin:0 auto;
}
#zappiShopPanel.open{transform:translateY(0);}
#zappiShopOverlay{
  position:fixed;inset:0;background:rgba(0,0,0,.5);
  z-index:10000;opacity:0;pointer-events:none;
  transition:opacity .3s;
}
#zappiShopOverlay.open{opacity:1;pointer-events:all;}

/* Shop Header */
#zappiShopHeader{
  padding:16px 20px 0;
  display:flex;align-items:center;justify-content:space-between;
  flex-shrink:0;
}
#zappiShopHeader h3{font-size:16px;font-weight:700;color:var(--text);}
#zappiShopBalance{
  display:flex;align-items:center;gap:8px;
}
#zappiShopZp{
  font-size:13px;font-weight:700;color:var(--gold);
  background:rgba(212,168,75,.1);border:1px solid rgba(212,168,75,.3);
  border-radius:99px;padding:3px 10px;
}
#zappiStreakBadge{
  font-size:11px;padding:3px 8px;
  background:rgba(220,38,38,.15);border:1px solid rgba(220,38,38,.3);
  border-radius:99px;color:var(--ferrari);font-weight:600;
}
#zappiShopClose{
  background:none;border:none;color:var(--muted);font-size:20px;
  cursor:pointer;padding:4px;line-height:1;transition:color .2s;
}
#zappiShopClose:hover{color:var(--text);}

/* Shop Tabs */
#zappiShopTabs{
  display:flex;gap:4px;padding:12px 12px 0;
  flex-shrink:0;
  border-bottom:1px solid var(--border);
}
.zs-tab{
  flex:1;padding:8px 4px;text-align:center;font-size:11px;font-weight:600;
  background:none;border:none;border-radius:8px 8px 0 0;
  color:var(--muted);cursor:pointer;transition:all .2s;
  border-bottom:2px solid transparent;
}
.zs-tab:hover{color:var(--text);}
.zs-tab.active{color:var(--gold);border-bottom-color:var(--gold);background:rgba(212,168,75,.06);}

/* Shop Content */
#zappiShopContent{
  flex:1;overflow-y:auto;padding:16px;
  scrollbar-width:thin;scrollbar-color:var(--border) transparent;
}
.zs-tab-pane{display:none;}
.zs-tab-pane.active{display:block;}

/* Shop Item Grid */
.zs-items{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.zs-item{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:12px;padding:12px;
  display:flex;flex-direction:column;align-items:center;gap:6px;
  transition:border-color .2s;position:relative;
}
.zs-item:hover{border-color:rgba(212,168,75,.25);}
.zs-item.owned{border-color:rgba(16,185,129,.3);}
.zs-item-img{
  image-rendering:pixelated;
  background-repeat:no-repeat;background-position:0 0;
}
.zs-item-name{font-size:11px;font-weight:600;color:var(--text);text-align:center;}
.zs-item-happiness{font-size:10px;color:var(--green);text-align:center;}
.zs-item-price{font-size:11px;color:var(--gold);font-weight:700;}
.zs-item-qty{font-size:10px;color:var(--text2);}

/* Shop Buttons */
.zs-btn{
  width:100%;padding:6px 10px;border-radius:8px;border:none;
  font-size:11px;font-weight:700;cursor:pointer;
  transition:all .2s;
}
.zs-btn-buy{background:var(--gold);color:#000;}
.zs-btn-buy:hover{background:var(--gold2);transform:translateY(-1px);}
.zs-btn-feed{background:var(--green);color:#fff;}
.zs-btn-feed:hover{filter:brightness(1.1);transform:translateY(-1px);}
.zs-btn-disabled{background:rgba(255,255,255,.06);color:var(--muted);cursor:not-allowed;}
.zs-btn-owned{background:rgba(16,185,129,.15);color:var(--green);cursor:default;}
.zs-badge-permanent{
  position:absolute;top:6px;right:6px;
  font-size:8px;background:rgba(16,185,129,.2);color:var(--green);
  border-radius:4px;padding:1px 4px;font-weight:700;
}
.zs-coming{
  text-align:center;padding:40px 20px;color:var(--muted);font-size:13px;
}
.zs-section-title{
  font-size:11px;color:var(--muted);font-weight:600;
  text-transform:uppercase;letter-spacing:1px;
  margin:0 0 10px;
}

/* Food floating animation */
.food-fly{
  position:fixed;pointer-events:none;z-index:10002;
  image-rendering:pixelated;
  animation:foodFly .8s ease-in forwards;
}
@keyframes foodFly{
  0%{opacity:1;transform:translate(0,0) scale(1);}
  100%{opacity:0;transform:translate(var(--tx),var(--ty)) scale(0.5);}
}

/* Toast notification */
.zappi-toast{
  position:fixed;bottom:80px;left:50%;transform:translateX(-50%);
  background:var(--card);border:1px solid var(--border);
  border-radius:99px;padding:8px 18px;font-size:12px;
  color:var(--text);z-index:10003;white-space:nowrap;
  animation:toastIn .3s ease,toastOut .3s ease 2.5s forwards;
  box-shadow:0 4px 20px rgba(0,0,0,.4);
}
@keyframes toastIn{from{opacity:0;transform:translateX(-50%) translateY(10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
@keyframes toastOut{from{opacity:1}to{opacity:0;pointer-events:none}}

/* --- Toy display near Zappi --- */
#zappiToy{
  position:fixed;
  z-index:9998;
  image-rendering:pixelated;
  pointer-events:none;
  transition:opacity .3s;
}
#zappiToy.visible{opacity:1;}
#zappiToy.hidden{opacity:0;}
@keyframes toyBounce{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-8px);}
}
#zappiToy.bouncing{animation:toyBounce .6s ease-in-out infinite;}

/* --- Furniture (bed behind/under mascot) --- */
#zappiBed{
  position:fixed;
  z-index:9997;
  image-rendering:pixelated;
  pointer-events:none;
}
#zappiHome{
  position:fixed;
  z-index:9996;
  image-rendering:pixelated;
  pointer-events:none;
}

/* Toy cooldown indicator */
.toy-cooldown{
  font-size:10px;color:var(--muted);
  text-align:center;margin-top:2px;
}

/* =============================================
   GOOGLE ADSENSE AD SLOTS
   ============================================= */
.ad-slot-wrap {
  width:100%; text-align:center;
  margin:24px auto; padding:4px 0;
  min-height:90px; /* Reserve space to prevent CLS */
  display:flex; align-items:center; justify-content:center;
}
.ad-slot-label {
  font-size:10px; color:var(--muted); letter-spacing:1px;
  text-transform:uppercase; margin-bottom:4px;
}
.ad-slot-disabled {
  /* Shown when AdSense not yet active — remove this class when live */
  display:none;
}
</style>



</head>
<body>

<!-- Particle Canvas Background -->
<canvas id="particleCanvas"></canvas>

<!-- Pixel Mascot "Zappi" -->
<div id="pixelMascot" title="Click Zappi!">
  <span class="mascot-speech">Compare specs. Zap the best! ⚡</span>
  <div id="zappiHpWrap">
    <span id="zappiHpIcon">❤️</span>
    <div id="zappiHpBar"><div id="zappiHpFill" style="width:70%;background:#10b981;"></div></div>
  </div>
  <div id="mascotDot"></div>
  <div class="mascot-label">ZAPPI</div>
</div>

<!-- Zappi Shop Button -->
<div id="zappiShopBtn" onclick="zappiOpenShop()" title="Zappi Shop">
  <div class="shop-icon">🛒</div>
  <span id="zappiZpBadge">0 ZP</span>
</div>

<!-- Toy display (follows cat) -->
<div id="zappiToy" class="hidden"></div>

<!-- Furniture: Bed (shown under/near cat when sleeping) -->
<div id="zappiBed" style="display:none"></div>

<!-- Furniture: Home (shown behind cat) -->
<div id="zappiHome" style="display:none"></div>

<!-- Shop Overlay -->
<div id="zappiShopOverlay" onclick="zappiCloseShop()"></div>

<!-- Shop Panel -->
<div id="zappiShopPanel">
  <div id="zappiShopHeader">
    <h3>🐱 Zappi Shop</h3>
    <div id="zappiShopBalance">
      <span id="zappiShopZp">⚡ 0 ZP</span>
      <span id="zappiStreakBadge" style="display:none">🔥 0-day</span>
    </div>
    <button id="zappiShopClose" onclick="zappiCloseShop()">✕</button>
  </div>
  <div id="zappiShopTabs">
    <button class="zs-tab" data-tab="skins" onclick="zappiTab('skins')">🐱 Skins</button>
    <button class="zs-tab" data-tab="ribbons" onclick="zappiTab('ribbons')">🎀 Ribbons</button>
    <button class="zs-tab" data-tab="toys" onclick="zappiTab('toys')">🧸 Toys</button>
    <button class="zs-tab active" data-tab="food" onclick="zappiTab('food')">🐟 Food</button>
    <button class="zs-tab" data-tab="furniture" onclick="zappiTab('furniture')">🏠 Furniture</button>
  </div>
  <div id="zappiShopContent">
    <!-- Skins Tab (Phase 5 + Phase 8 Halloween) -->
    <div class="zs-tab-pane" id="zs-skins">
      <p class="zs-section-title">🐱 Classic Skins (Free)</p>
      <div class="zs-items">
        <div class="zs-item" id="shop-skin-classical">
          <div class="zs-badge-permanent">DEFAULT</div>
          <div style="width:64px;height:64px;background-image:url('CatPackPaid/Sprites/Classical/Individual/Idle.png');background-size:960px 96px;background-position:0 0;image-rendering:pixelated;overflow:hidden"></div>
          <div class="zs-item-name">🪨 Classic</div>
          <div class="zs-item-price">FREE</div>
          <button class="zs-btn zs-btn-owned" id="skin-btn-classical" onclick="zappiEquipSkin('classical')">Equip</button>
        </div>
      </div>
      <p class="zs-section-title" style="margin-top:14px">🎨 Color Skins (NEW)</p>
      <div class="zs-items">
        <div class="zs-item" id="shop-skin-grey">
          <div class="zs-badge-permanent">NEW</div>
          <div style="width:64px;height:64px;background-image:url('CatPackPaid/CatPackDifferentSkins/Grey.png');background-size:1536px 1920px;background-position:0 0;image-rendering:pixelated;overflow:hidden"></div>
          <div class="zs-item-name">🩶 Grey Cat</div>
          <div class="zs-item-price">50 ZP</div>
          <button class="zs-btn zs-btn-buy" id="skin-btn-grey" onclick="zappiEquipSkin('grey')">Buy (50 ZP)</button>
        </div>
        <div class="zs-item" id="shop-skin-orange">
          <div class="zs-badge-permanent">NEW</div>
          <div style="width:64px;height:64px;background-image:url('CatPackPaid/CatPackDifferentSkins/OrangeCat.png');background-size:1536px 1920px;background-position:0 0;image-rendering:pixelated;overflow:hidden"></div>
          <div class="zs-item-name">🟠 Orange Cat</div>
          <div class="zs-item-price">50 ZP</div>
          <button class="zs-btn zs-btn-buy" id="skin-btn-orange" onclick="zappiEquipSkin('orange')">Buy (50 ZP)</button>
        </div>
        <div class="zs-item" id="shop-skin-white">
          <div class="zs-badge-permanent">NEW</div>
          <div style="width:64px;height:64px;background-image:url('CatPackPaid/CatPackDifferentSkins/WhiteCat.png');background-size:1536px 1920px;background-position:0 0;image-rendering:pixelated;overflow:hidden"></div>
          <div class="zs-item-name">🤍 White Cat</div>
          <div class="zs-item-price">50 ZP</div>
          <button class="zs-btn zs-btn-buy" id="skin-btn-white" onclick="zappiEquipSkin('white')">Buy (50 ZP)</button>
        </div>
      </div>
      <p class="zs-section-title" style="margin-top:14px">🎃 Halloween Skins (RARE)</p>
      <div class="zs-items">

        <div class="zs-item" id="shop-skin-dracula">
          <div style="width:64px;height:64px;background-image:url('CatPackPaid/Sprites/Halloween/draculacats.png');background-size:1536px 960px;background-position:0 0;image-rendering:pixelated;overflow:hidden"></div>
          <div class="zs-item-name">🧛 Dracula</div>
          <div class="zs-item-happiness">Halloween RARE!</div>
          <div class="zs-item-price">150 ZP</div>
          <button class="zs-btn zs-btn-buy" id="skin-btn-dracula" onclick="zappiEquipSkin('dracula')">Buy (150 ZP)</button>
        </div>
        <div class="zs-item" id="shop-skin-evil">
          <div style="width:64px;height:64px;background-image:url('CatPackPaid/Sprites/Halloween/EvilCatSprites.png');background-size:1536px 960px;background-position:0 0;image-rendering:pixelated;overflow:hidden"></div>
          <div class="zs-item-name">😈 Evil Cat</div>
          <div class="zs-item-happiness">Halloween RARE!</div>
          <div class="zs-item-price">150 ZP</div>
          <button class="zs-btn
