/* =============================================
   ZAPPI MASCOT SYSTEM — SpecZap AI
   Ported from AudZap audzap.com
   ============================================= */

/* ── Variable Bridge: AudZap → SpecZap persona.css ──────────────
   Maps old --card/--gold etc. to --p-card/--p-gold for compatibility */
:root {
  --card:    var(--p-card,    #141414);
  --card2:   var(--p-card-2,  #1c1c1c);
  --bg:      var(--p-black,   #080808);
  --bg2:     var(--p-card-2,  #1c1c1c);
  --border:  var(--p-border,  #2a2a2a);
  --text:    var(--p-white,   #f0ede8);
  --text2:   var(--p-gray-light, #b0b0b0);
  --muted:   var(--p-gray,    #888888);
  --gold:    var(--p-gold,    #f5c842);
  --gold2:   #d4a42a;
  --green:   var(--p-green,   #4ade80);
  --ferrari: var(--p-red,     #e63946);
}

/* 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:calc(50% - 280px);
  width:560px;
  height:540px;
  background:#141414;
  border-top:2px solid rgba(245,200,66,0.35);
  border-radius:20px 20px 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 -12px 50px rgba(0,0,0,.7), 0 0 0 1px rgba(255,255,255,0.04);
}
#zappiShopPanel.open{transform:translateY(0);}
/* Mobile responsive */
@media(max-width:600px){
  #zappiShopPanel{ left:0; width:100%; border-radius:16px 16px 0 0; }
}
#zappiShopOverlay{
  position:fixed;inset:0;background:rgba(0,0,0,.72);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  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;
}
