/* ============================================================
   星光魔法学院 · 样式
   绘本风 / 暖色 / 圆润 / 适配 iPad·手机·桌面
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Baloo+2:wght@500;600;700;800&family=ZCOOL+KuaiLe&display=swap');

:root{
  --cream:#FFF6E9; --cream2:#FBEAD2;
  --wood:#E6B877; --wood-d:#C99355;
  --teal:#5FBEB6; --teal-d:#3FA39B;
  --pink:#F6A8BC; --rose:#F582A0;
  --gold:#F4C84B; --gold-d:#E0A82E;
  --lav:#9D86CF;  --lav-d:#7E63B8;
  --star:#FFD75E;
  --ink:#6B5238; --ink-soft:#9A8166;
  --card:#FFFDF7;
  --line: rgba(150,110,60,.18);
  --shadow: 0 8px 22px rgba(150,110,60,.20);
  --shadow-sm: 0 3px 10px rgba(150,110,60,.18);
  --r: 22px; --r-sm: 14px;
  --display:'ZCOOL KuaiLe','Baloo 2',system-ui,sans-serif;
  --num:'Baloo 2',system-ui,sans-serif;
}

*{ box-sizing:border-box; -webkit-tap-highlight-color:transparent; }
html,body{ margin:0; height:100%; overflow:hidden; }
body{
  font-family:var(--display);
  color:var(--ink);
  background:
    radial-gradient(circle at 30% 0%, #FFF7EC, #F7E3C6 70%);
  user-select:none; -webkit-user-select:none;
  touch-action:manipulation;
}
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
.num{ font-family:var(--num); font-weight:700; }

/* ---------- 整体布局 ---------- */
#app{
  position:fixed; inset:0;
  display:flex; flex-direction:column;
  max-width:1100px; margin:0 auto;
}

/* ---------- 顶部 HUD ---------- */
.hud{
  display:flex; align-items:center; gap:10px;
  padding:10px 12px 6px; flex-wrap:nowrap;
  z-index:30;
}
.stage-chip{
  display:flex; align-items:center; gap:8px;
  background:var(--card); border-radius:999px;
  padding:6px 12px 6px 6px; box-shadow:var(--shadow-sm);
  border:2px solid #fff;
}
.stage-chip .avatar{
  width:38px; height:38px; border-radius:50%;
  background:radial-gradient(circle at 50% 35%, var(--star), var(--gold-d));
  display:grid; place-items:center; font-size:20px; flex:none;
  box-shadow:inset 0 -2px 4px rgba(0,0,0,.12);
}
.stage-chip .meta{ line-height:1.05; min-width:0; }
.stage-chip .meta .nm{ font-size:14px; white-space:nowrap; }
.stage-chip .meta .lv{ font-size:11px; color:var(--ink-soft); }
.xpbar{
  flex:1 1 auto; height:14px; min-width:60px;
  background:#F0E0C8; border-radius:999px; overflow:hidden;
  box-shadow:inset 0 1px 3px rgba(150,110,60,.25); position:relative;
}
.xpbar > i{
  display:block; height:100%; width:0;
  background:linear-gradient(90deg,var(--lav),var(--rose));
  border-radius:999px; transition:width .5s cubic-bezier(.2,.8,.2,1);
}
.xpbar > span{
  position:absolute; inset:0; display:grid; place-items:center;
  font-family:var(--num); font-size:9px; font-weight:700; color:#fff;
  text-shadow:0 1px 2px rgba(120,80,40,.5);
}
.wallet{ display:flex; gap:7px; flex:none; }
.coin,.sticker-c{
  display:flex; align-items:center; gap:4px;
  background:var(--card); border-radius:999px; padding:6px 11px;
  box-shadow:var(--shadow-sm); border:2px solid #fff;
  font-family:var(--num); font-weight:700; font-size:14px;
}
.coin .ic,.sticker-c .ic{ font-size:15px; }
.icon-btn{
  width:42px; height:42px; border-radius:50%; flex:none;
  background:var(--card); box-shadow:var(--shadow-sm); border:2px solid #fff;
  display:grid; place-items:center; font-size:19px;
  transition:transform .12s;
}
.icon-btn:active{ transform:scale(.9); }

/* ---------- 状态条 ---------- */
.stats{
  position:relative; z-index:20;
  display:grid; grid-template-columns:repeat(3,1fr); gap:6px 10px;
  padding:4px 12px 0;
}
.stat{
  display:flex; align-items:center; gap:6px;
  background:rgba(255,253,247,.78); backdrop-filter:blur(2px);
  border-radius:999px; padding:4px 9px 4px 5px; box-shadow:var(--shadow-sm);
}
.stat .em{ font-size:14px; flex:none; }
.stat .col{ flex:1 1 auto; min-width:0; }
.stat .lab{ font-size:10px; color:var(--ink-soft); line-height:1; }
.stat .track{ height:7px; background:#EFE0C8; border-radius:999px; overflow:hidden; margin-top:2px; }
.stat .track > i{ display:block; height:100%; border-radius:999px; transition:width .45s cubic-bezier(.2,.8,.2,1); }

/* ---------- 中央舞台（房间 + 小星喵） ---------- */
.stage{
  position:relative; flex:1 1 auto; min-height:0;
  margin:6px 8px; border-radius:var(--r); overflow:hidden;
  box-shadow:var(--shadow); border:3px solid #fff;
}
.room{ position:absolute; inset:0; background-size:cover; background-position:center 38%; }
.room::after{ /* 柔和暖光罩 */
  content:""; position:absolute; inset:0;
  background:radial-gradient(circle at 50% 78%, rgba(255,240,200,.10), rgba(120,80,40,.16) 95%);
}
.furni-layer{ position:absolute; inset:0; pointer-events:none; }
.furni{ position:absolute; font-size:30px; filter:drop-shadow(0 3px 5px rgba(0,0,0,.25)); animation:floaty 5s ease-in-out infinite; }

.cat-wrap{
  position:absolute; left:50%; bottom:6%;
  transform:translateX(-50%);
  width:min(46%, 230px); aspect-ratio:876/1114;
  cursor:pointer; z-index:5;
  transition:transform .2s ease;
}
.cat-shadow{
  position:absolute; left:50%; bottom:-2%; transform:translateX(-50%);
  width:62%; height:7%; background:rgba(90,60,30,.30);
  border-radius:50%; filter:blur(5px); z-index:0;
  animation:shadowPulse 3.4s ease-in-out infinite;
}
.cat{
  position:absolute; inset:0; width:100%; height:100%; z-index:1;
  background-size:contain; background-repeat:no-repeat; background-position:bottom center;
  transform-origin:50% 95%;
  animation:breathe 3.4s ease-in-out infinite;
  filter:drop-shadow(0 6px 8px rgba(90,60,30,.25));
}
/* 占位猫（图片没加载时的温柔兜底） */
.cat.fallback{ background-image:none; display:grid; place-items:center; font-size:120px; }

/* 装扮叠加 */
.outfit{ position:absolute; z-index:6; pointer-events:none; filter:drop-shadow(0 2px 3px rgba(0,0,0,.3)); }
.outfit.head{ top:-2%;  left:50%; transform:translateX(-50%); font-size:clamp(22px,7vw,40px); }
.outfit.neck{ top:46%;  left:50%; transform:translateX(-50%); font-size:clamp(16px,5vw,28px); }
.outfit.foot{ bottom:0; left:50%; transform:translateX(-50%); font-size:clamp(16px,5vw,28px); }

/* 说话气泡 */
.bubble{
  position:absolute; left:50%; top:8%; transform:translateX(-50%) scale(.6);
  background:#fff; color:var(--ink); padding:7px 14px; border-radius:18px;
  font-size:15px; box-shadow:var(--shadow); opacity:0; pointer-events:none;
  white-space:nowrap; z-index:8; border:2px solid var(--cream2);
}
.bubble.show{ animation:pop 1.8s ease both; }
.bubble::after{ content:""; position:absolute; bottom:-7px; left:50%; transform:translateX(-50%);
  border:7px solid transparent; border-top-color:#fff; }

/* 粒子层 */
.fx-layer{ position:absolute; inset:0; pointer-events:none; z-index:9; overflow:hidden; }
.fx{ position:absolute; font-size:24px; will-change:transform,opacity; }

/* ---------- 小星喵动作动画 ---------- */
@keyframes breathe{ 0%,100%{ transform:scaleY(1) } 50%{ transform:scaleY(1.025) translateY(-1%) } }
@keyframes shadowPulse{ 0%,100%{ transform:translateX(-50%) scaleX(1); opacity:.30 } 50%{ transform:translateX(-50%) scaleX(.9); opacity:.22 } }
@keyframes floaty{ 0%,100%{ transform:translateY(0) } 50%{ transform:translateY(-5px) } }

.cat.act-eat{ animation:eat .5s ease 3; }
@keyframes eat{ 0%,100%{ transform:translateY(0) rotate(0) } 40%{ transform:translateY(3%) rotate(-3deg) } }
.cat.act-clean{ animation:wiggle .35s ease 4; }
@keyframes wiggle{ 0%,100%{ transform:rotate(0) } 25%{ transform:rotate(4deg) } 75%{ transform:rotate(-4deg) } }
.cat.act-play{ animation:hop .42s cubic-bezier(.3,1.4,.5,1) 3; }
@keyframes hop{ 0%,100%{ transform:translateY(0) } 45%{ transform:translateY(-12%) scaleY(1.05) } }
.cat.act-study{ animation:tilt 1s ease 2; }
@keyframes tilt{ 0%,100%{ transform:rotate(0) } 30%{ transform:rotate(-5deg) } 60%{ transform:rotate(3deg) } }
.cat.act-sleep{ animation:snooze 2.2s ease both; }
@keyframes snooze{ 0%{ transform:rotate(0) } 30%{ transform:rotate(8deg) translateY(4%) } 100%{ transform:rotate(8deg) translateY(4%) } }
.cat.act-magic{ animation:cast .7s ease 2; }
@keyframes cast{ 0%,100%{ transform:scale(1) } 50%{ transform:scale(1.06) translateY(-4%) } }
.cat.act-pet{ animation:nuzzle .4s ease 2; }
@keyframes nuzzle{ 0%,100%{ transform:rotate(0) } 50%{ transform:rotate(-6deg) translateX(-2%) } }
.cat.act-cheer{ animation:cheer .5s cubic-bezier(.3,1.5,.5,1) 2; }
@keyframes cheer{ 0%,100%{ transform:translateY(0) } 50%{ transform:translateY(-16%) scale(1.04) } }
.cat.idle-look{ animation:lookAround 2s ease both; }
@keyframes lookAround{ 0%,100%{ transform:rotate(0) } 25%{ transform:rotate(4deg) } 65%{ transform:rotate(-4deg) } }
.cat.idle-hop{ animation:hop .5s ease both; }

@keyframes pop{ 0%{ opacity:0; transform:translateX(-50%) scale(.6) } 12%{ opacity:1; transform:translateX(-50%) scale(1.05) } 22%{ transform:translateX(-50%) scale(1) } 82%{ opacity:1 } 100%{ opacity:0; transform:translateX(-50%) scale(.9) } }

/* ---------- 底部照顾栏 ---------- */
.care-bar{
  display:flex; gap:8px; justify-content:center; align-items:flex-end;
  padding:6px 10px calc(8px + env(safe-area-inset-bottom)); z-index:30;
}
.care-btn{
  flex:1 1 0; max-width:90px;
  display:flex; flex-direction:column; align-items:center; gap:2px;
  background:var(--card); border-radius:18px; padding:8px 4px 6px;
  box-shadow:var(--shadow-sm); border:2px solid #fff;
  transition:transform .12s;
}
.care-btn:active{ transform:translateY(2px) scale(.96); }
.care-btn .ce{ font-size:24px; }
.care-btn .cn{ font-size:12px; }
.care-btn.locked{ opacity:.45; filter:grayscale(.5); }

/* 道具托盘 */
.tray{
  position:fixed; left:0; right:0;
  bottom:calc(82px + env(safe-area-inset-bottom));
  z-index:40; display:none; padding:0 12px;
}
.tray.show{ display:block; animation:trayUp .25s ease both; }
@keyframes trayUp{ from{ opacity:0; transform:translateY(14px) } to{ opacity:1; transform:translateY(0) } }
.tray-inner{
  max-width:520px; margin:0 auto;
  background:var(--card); border-radius:20px; padding:12px;
  box-shadow:var(--shadow); border:2px solid #fff;
}
.tray-title{ font-size:14px; margin:0 4px 8px; color:var(--ink-soft);
  display:flex; align-items:center; justify-content:space-between; gap:8px; }
.tray-close{ flex:none; width:30px; height:30px; border-radius:50%; background:var(--cream);
  box-shadow:var(--shadow-sm); display:grid; place-items:center; font-size:14px; color:var(--ink); }
.tray-close:active{ transform:scale(.92); }
.tray-items{ display:flex; gap:8px; overflow-x:auto; padding-bottom:2px; }
.tray-item{
  flex:none; width:74px; background:var(--cream); border-radius:14px;
  padding:8px 4px; text-align:center; box-shadow:var(--shadow-sm);
  border:2px solid transparent; transition:transform .1s;
}
.tray-item:active{ transform:scale(.93); }
.tray-item.empty{ opacity:.4; }
.tray-item .ie{ font-size:24px; }
.tray-item .ina{ font-size:11px; line-height:1.1; margin-top:2px; }
.tray-item .ict{ font-size:11px; font-family:var(--num); font-weight:700; color:var(--teal-d); }
.tray-empty{ text-align:center; color:var(--ink-soft); font-size:13px; padding:8px; }
.tray-empty button{ display:block; margin:8px auto 0; background:var(--teal); color:#fff;
  padding:7px 16px; border-radius:999px; font-size:13px; box-shadow:var(--shadow-sm); }

/* ---------- 浮动导航（任务/商店/收藏） ---------- */
.fab-col{ position:fixed; right:10px; top:96px; display:flex; flex-direction:column; gap:9px; z-index:30; }
.fab{
  width:50px; height:50px; border-radius:18px;
  background:var(--card); box-shadow:var(--shadow); border:2px solid #fff;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  font-size:18px; position:relative; transition:transform .12s;
}
.fab:active{ transform:scale(.9); }
.fab .fl{ font-size:9px; color:var(--ink-soft); margin-top:1px; }
.fab .badge{
  position:absolute; top:-5px; right:-5px; min-width:18px; height:18px; padding:0 4px;
  background:var(--rose); color:#fff; border-radius:999px; font-size:10px;
  font-family:var(--num); font-weight:700; display:grid; place-items:center;
  box-shadow:0 2px 5px rgba(0,0,0,.25); border:1.5px solid #fff;
}

/* ---------- 面板（底部抽屉 / 桌面弹窗） ---------- */
.scrim{ position:fixed; inset:0; background:rgba(80,55,30,.38); z-index:50; opacity:0; pointer-events:none; transition:opacity .25s; }
.scrim.show{ opacity:1; pointer-events:auto; }
.sheet{
  position:fixed; left:0; right:0; bottom:0; z-index:60;
  background:var(--cream); border-radius:26px 26px 0 0;
  max-height:80vh; transform:translateY(102%); transition:transform .3s cubic-bezier(.2,.8,.2,1);
  box-shadow:0 -10px 30px rgba(120,80,40,.25); display:flex; flex-direction:column; overflow:hidden;
}
.sheet.show{ transform:translateY(0); }
.sheet-head{ padding:14px 18px 8px; display:flex; align-items:center; gap:10px; position:relative; }
.sheet-head .h-em{ font-size:22px; }
.sheet-head h2{ margin:0; font-size:19px; }
.sheet-head .sub{ font-size:12px; color:var(--ink-soft); }
.sheet-close{ margin-left:auto; width:34px; height:34px; border-radius:50%; background:#fff;
  box-shadow:var(--shadow-sm); display:grid; place-items:center; font-size:16px; }
.sheet-body{ flex:1 1 auto; min-height:0; overflow-y:auto; padding:4px 16px 22px; -webkit-overflow-scrolling:touch; }
.grabber{ width:42px; height:5px; background:var(--line); border-radius:999px; margin:8px auto 0; }

/* 选项卡 */
.tabs, #sheetTabs{ display:flex; gap:6px; padding:8px 16px 4px; flex:none; }
.tab{ flex:1; text-align:center; padding:8px 4px; border-radius:14px; font-size:13px;
  background:#fff; box-shadow:var(--shadow-sm); }
.tab.active{ background:var(--lav); color:#fff; }

/* 任务卡 */
.task{
  background:var(--card); border-radius:16px; padding:12px 14px; margin-bottom:10px;
  box-shadow:var(--shadow-sm); display:flex; align-items:center; gap:12px;
}
.task .t-main{ flex:1 1 auto; min-width:0; }
.task .t-name{ font-size:14px; }
.task .t-bar{ height:9px; background:#EFE0C8; border-radius:999px; margin-top:7px; overflow:hidden; }
.task .t-bar > i{ display:block; height:100%; background:linear-gradient(90deg,var(--teal),var(--gold)); border-radius:999px; transition:width .4s; }
.task .t-rew{ font-size:11px; color:var(--ink-soft); margin-top:5px; }
.task .t-act{ flex:none; }
.btn{
  background:var(--teal); color:#fff; padding:9px 16px; border-radius:999px;
  font-size:13px; box-shadow:var(--shadow-sm); transition:transform .1s; white-space:nowrap;
}
.btn:active{ transform:scale(.94); }
.btn.gold{ background:var(--gold-d); }
.btn.ghost{ background:#fff; color:var(--ink-soft); box-shadow:var(--shadow-sm); }
.btn.done{ background:#D9C9AC; color:#fff; }
.btn[disabled]{ opacity:.5; pointer-events:none; }
.btn.lg{ padding:12px 26px; font-size:15px; }

/* 章节卡 */
.chapter-card{ background:var(--card); border-radius:18px; padding:16px; box-shadow:var(--shadow-sm); }
.chapter-card .c-num{ font-family:var(--num); font-weight:800; color:var(--lav-d); font-size:13px; letter-spacing:1px; }
.chapter-card h3{ margin:2px 0 6px; font-size:18px; }
.chapter-card .c-story{ font-size:13px; color:var(--ink-soft); line-height:1.7; margin-bottom:12px; }
.obj{ display:flex; align-items:center; gap:10px; margin:7px 0; font-size:13px; }
.obj .o-bar{ flex:1; height:8px; background:#EFE0C8; border-radius:999px; overflow:hidden; }
.obj .o-bar > i{ display:block; height:100%; background:linear-gradient(90deg,var(--rose),var(--gold)); border-radius:999px; transition:width .4s; }
.obj .o-ct{ font-family:var(--num); font-size:12px; color:var(--ink-soft); flex:none; }
.obj.ok .o-ct{ color:var(--teal-d); }

/* 商店 / 收藏 网格 */
.grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:10px; }
.card-it{ background:var(--card); border-radius:16px; padding:12px; box-shadow:var(--shadow-sm); text-align:center; position:relative; }
.card-it .ci-em{ font-size:30px; }
.card-it .ci-nm{ font-size:13px; margin-top:2px; }
.card-it .ci-ds{ font-size:11px; color:var(--ink-soft); line-height:1.4; margin:3px 0 8px; min-height:30px; }
.card-it .ci-own{ position:absolute; top:8px; right:8px; font-size:11px; background:var(--gold); color:#7a5b10;
  border-radius:999px; padding:1px 8px; font-family:var(--num); font-weight:700; }
.card-it.have{ opacity:.96; }
.card-it.locked{ opacity:.5; filter:grayscale(.4); }
.price{ font-family:var(--num); font-weight:700; }

/* 收藏：贴纸册 */
.sticker-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.sticker{ aspect-ratio:1; border-radius:16px; background:#fff; box-shadow:var(--shadow-sm);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:2px; }
.sticker .se{ font-size:26px; }
.sticker .sn{ font-size:9px; color:var(--ink-soft); text-align:center; line-height:1.1; padding:0 2px; }
.sticker.locked{ background:#EFE3CD; }
.sticker.locked .se{ filter:grayscale(1); opacity:.35; }
.sticker.locked .sn{ opacity:.5; }
.collect-head{ font-size:13px; color:var(--ink-soft); margin:14px 2px 8px; }
.collect-head:first-child{ margin-top:4px; }

/* ---------- 提示 toast ---------- */
.toast-wrap{ position:fixed; left:0; right:0; top:64px; z-index:80; display:flex; flex-direction:column; align-items:center; gap:8px; pointer-events:none; }
.toast{ background:rgba(80,55,30,.92); color:#fff; padding:10px 18px; border-radius:999px;
  font-size:13px; box-shadow:var(--shadow); animation:toastIn .3s ease both, toastOut .3s ease 2.2s both; max-width:84vw; text-align:center; }
@keyframes toastIn{ from{ opacity:0; transform:translateY(-12px) } to{ opacity:1; transform:translateY(0) } }
@keyframes toastOut{ to{ opacity:0; transform:translateY(-10px) } }

/* ---------- 升级/章节庆祝 ---------- */
.celebrate{ position:fixed; inset:0; z-index:90; display:none; place-items:center;
  background:radial-gradient(circle at 50% 40%, rgba(255,245,215,.5), rgba(80,55,30,.55)); backdrop-filter:blur(2px); }
.celebrate.show{ display:grid; animation:fadeIn .3s ease both; }
.celebrate .panel{ background:var(--card); border-radius:26px; padding:26px 30px; text-align:center;
  box-shadow:var(--shadow); border:3px solid #fff; max-width:84vw; animation:popBig .4s cubic-bezier(.3,1.5,.5,1) both; }
.celebrate .big-em{ font-size:60px; animation:floaty 2.6s ease-in-out infinite; }
.celebrate h2{ margin:6px 0 4px; font-size:24px; }
.celebrate p{ margin:0 0 16px; color:var(--ink-soft); font-size:14px; line-height:1.6; }
@keyframes fadeIn{ from{opacity:0} to{opacity:1} }
@keyframes popBig{ from{ transform:scale(.6); opacity:0 } to{ transform:scale(1); opacity:1 } }

/* 音量小面板 */
.sound-pop{ position:fixed; right:10px; top:60px; z-index:70; background:var(--card);
  border-radius:18px; padding:14px 16px; box-shadow:var(--shadow); border:2px solid #fff;
  display:none; width:220px; }
.sound-pop.show{ display:block; animation:trayUp .2s ease both; }
.sound-pop .row{ display:flex; align-items:center; gap:10px; margin-top:10px; }
.sound-pop .row:first-child{ margin-top:0; }
.sound-pop input[type=range]{ flex:1; accent-color:var(--teal); }
.toggle{ width:46px; height:26px; border-radius:999px; background:#E0CFAF; position:relative; transition:background .2s; flex:none; }
.toggle.on{ background:var(--teal); }
.toggle > i{ position:absolute; top:3px; left:3px; width:20px; height:20px; border-radius:50%; background:#fff; transition:left .2s; box-shadow:0 1px 3px rgba(0,0,0,.2); }
.toggle.on > i{ left:23px; }

/* ---------- 响应式 ---------- */
@media (min-width:760px){
  .stats{ grid-template-columns:repeat(6,1fr); }
  .care-btn{ max-width:110px; }
  .cat-wrap{ width:min(34%,300px); }
  .sheet{ left:50%; right:auto; top:50%; bottom:auto;
    width:560px; max-height:84vh; border-radius:26px;
    transform:translate(-50%,-50%) scale(.96); opacity:0; pointer-events:none;
    transition:transform .25s cubic-bezier(.2,.8,.2,1), opacity .25s; }
  .sheet.show{ transform:translate(-50%,-50%) scale(1); opacity:1; pointer-events:auto; }
  .sheet-head{ padding-top:18px; }
  .grabber{ display:none; }
  .grid{ grid-template-columns:repeat(3,1fr); }
}
@media (max-width:420px){
  .stage-chip .meta .nm{ font-size:13px; }
  .coin,.sticker-c{ padding:6px 9px; font-size:13px; }
  .care-btn .cn{ font-size:11px; }
  .stat .lab{ font-size:9px; }
}
@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001s !important; animation-iteration-count:1 !important; }
}
