*{margin:0;padding:0;box-sizing:border-box}
html,body{width:100%;height:100%;font-family:-apple-system,BlinkMacSystemFont,'PingFang SC','Hiragino Sans GB','Microsoft YaHei',sans-serif;background:#0e0e24;color:#fff;-webkit-tap-highlight-color:transparent;overscroll-behavior:none;overflow-x:hidden}

/* ====== 加载页 ====== */
.loading-screen{position:fixed;inset:0;background:#0e0e24;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999;transition:opacity .4s}
.loading-logo{font-size:64px;animation:bounce 2s ease-in-out infinite;margin-bottom:12px}
.loading-title{font-size:28px;font-weight:900;background:linear-gradient(135deg,#ff7e5f,#feb47b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:24px}
.loading-bar{width:200px;height:4px;background:rgba(255,255,255,0.08);border-radius:4px;overflow:hidden}
.loading-fill{height:100%;width:0;background:linear-gradient(90deg,#ff7e5f,#feb47b);border-radius:4px;transition:width .15s}
.loading-tip{font-size:12px;color:rgba(255,255,255,0.3);margin-top:12px}

/* ====== 首页 ====== */
.page{max-width:440px;margin:0 auto;padding:20px 16px 40px}

.hero{text-align:center;padding:32px 0 24px}
.hero-emoji{font-size:52px;margin-bottom:8px;animation:bounce 2.5s ease-in-out infinite}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.hero-title{font-size:30px;font-weight:900;letter-spacing:2px;background:linear-gradient(135deg,#ff7e5f,#feb47b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-desc{font-size:13px;color:rgba(255,255,255,0.4);margin-top:6px;letter-spacing:1px}

.card{background:#1a1a38;border:1px solid rgba(255,255,255,0.06);border-radius:16px;padding:20px;margin-bottom:14px}
.card-head{font-size:17px;font-weight:700;margin-bottom:14px}

/* ====== 签到 ====== */
.checkin-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.checkin-info{display:flex;gap:14px;font-size:13px}
.checkin-streak{color:#ff9f43;font-weight:700}
.checkin-total{color:rgba(255,255,255,0.4)}
.checkin-rewards{display:flex;justify-content:space-between;gap:6px}
.cr-item{flex:1;text-align:center;padding:8px 4px;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.06);border-radius:8px;font-size:11px;color:rgba(255,255,255,0.35);transition:all .3s}
.cr-item span{font-size:10px;color:rgba(255,255,255,0.25)}
.cr-item.done{border-color:rgba(255,126,95,0.3);background:rgba(255,126,95,0.08);color:#feb47b}
.cr-item.done span{color:#ff9f43}

.trial-row{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:rgba(255,126,95,0.08);border:1px solid rgba(255,126,95,0.15);border-radius:10px;margin-bottom:12px;font-size:14px}
.trial-num{color:#feb47b;font-weight:700}

.btn{display:inline-block;padding:14px 20px;border:none;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;transition:opacity .2s,transform .15s;text-align:center}
.btn:active{transform:scale(0.97);opacity:.85}
.btn-block{display:block;width:100%}
.btn-orange{background:linear-gradient(135deg,#ff7e5f,#feb47b);color:#fff;box-shadow:0 4px 16px rgba(255,126,95,0.3)}
.btn-sm{padding:10px 18px;font-size:13px;background:linear-gradient(135deg,#ff7e5f,#feb47b);color:#fff;border-radius:10px}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}

.sep{height:1px;background:rgba(255,255,255,0.06);margin:14px 0}

.activate-row{display:flex;gap:10px}
.activate-row input{flex:1;padding:12px 14px;border:1.5px solid rgba(255,255,255,0.1);border-radius:10px;background:rgba(255,255,255,0.04);color:#fff;font-size:14px;outline:none}
.activate-row input:focus{border-color:#ff7e5f}
.activate-row input::placeholder{color:rgba(255,255,255,0.2)}

/* ====== 皮肤 ====== */
.skin-list{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}
.skin-item{flex-shrink:0;width:72px;padding:10px 6px;background:rgba(255,255,255,0.03);border:1.5px solid rgba(255,255,255,0.06);border-radius:12px;text-align:center;cursor:pointer;transition:all .2s}
.skin-item:active{background:rgba(255,255,255,0.06)}
.skin-item.active{border-color:#ff7e5f;background:rgba(255,126,95,0.1)}
.skin-icon{font-size:28px;display:block;margin-bottom:4px}
.skin-name{font-size:11px;color:rgba(255,255,255,0.6);display:block}
.skin-badge{display:inline-block;margin-top:4px;padding:2px 6px;border-radius:4px;font-size:9px;font-weight:700;background:rgba(255,255,255,0.06);color:rgba(255,255,255,0.4)}
.skin-item.active .skin-badge{background:rgba(255,126,95,0.2);color:#ff9f43}
.skin-badge.owned{background:rgba(46,213,115,0.15);color:#2ed573}

/* ====== 成就 ====== */
.ach-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.ach-item{text-align:center;padding:8px 4px;background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.04);border-radius:10px;transition:all .3s}
.ach-item.done{border-color:rgba(255,215,0,0.2);background:rgba(255,215,0,0.06)}
.ach-icon{font-size:22px;display:block;margin-bottom:2px}
.ach-name{font-size:9px;color:rgba(255,255,255,0.25);display:block}
.ach-item.done .ach-name{color:#ffd700}

/* ====== 商城 ====== */
.shop-list{display:flex;flex-direction:column;gap:10px;margin-bottom:10px}
.shop-item{display:flex;justify-content:space-between;align-items:center;padding:14px;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.06);border-radius:12px;cursor:pointer;transition:background .2s}
.shop-item:active{background:rgba(255,255,255,0.06)}
.si-left{display:flex;align-items:center;gap:12px}
.si-icon{font-size:28px}
.si-name{font-size:14px;font-weight:600}
.si-desc{font-size:11px;color:rgba(255,255,255,0.35);margin-top:2px}
.si-right{display:flex;align-items:center;gap:12px}
.si-price{font-size:18px;font-weight:800;color:#feb47b}
.si-buy{padding:6px 14px;background:linear-gradient(135deg,#6c5ce7,#a29bfe);border-radius:8px;font-size:12px;font-weight:600;color:#fff}
.shop-tip{font-size:11px;color:rgba(255,255,255,0.25);text-align:center;margin-top:8px}

/* ====== 排行榜 ====== */
.lb-tabs{float:right;font-size:12px;display:flex;gap:4px}
.lb-tab{padding:3px 10px;border-radius:6px;background:rgba(255,255,255,0.05);color:rgba(255,255,255,0.35);cursor:pointer;transition:all .2s}
.lb-tab.active{background:rgba(255,126,95,0.2);color:#ff9f43}
.lb-list{display:flex;flex-direction:column;gap:2px}
.lb-row{display:flex;align-items:center;padding:8px 0}
.lb-rank{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;margin-right:10px;background:rgba(255,255,255,0.06);color:rgba(255,255,255,0.4);flex-shrink:0}
.lb-rank.top-1{background:linear-gradient(135deg,#ffd700,#f0932b);color:#333}
.lb-rank.top-2{background:linear-gradient(135deg,#c0c0c0,#95a5a6);color:#333}
.lb-rank.top-3{background:linear-gradient(135deg,#cd7f32,#a0522d);color:#fff}
.lb-name{flex:1;font-size:14px}
.lb-score{font-size:15px;font-weight:800;color:#feb47b}

.empty-state{text-align:center;color:rgba(255,255,255,0.25);padding:20px;font-size:14px}

/* ====== 好友PK ====== */
.pk-info{font-size:13px;color:rgba(255,255,255,0.4);margin-bottom:10px}
.pk-section{display:flex;gap:8px;margin-bottom:10px}
.pk-input{flex:1;padding:10px 14px;border:1.5px solid rgba(255,255,255,0.1);border-radius:10px;background:rgba(255,255,255,0.04);color:#fff;font-size:14px;outline:none}
.pk-input:focus{border-color:#6c5ce7}
.pk-input::placeholder{color:rgba(255,255,255,0.2)}
.pk-card{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);border-radius:12px;padding:14px}
.pk-name{font-size:16px;font-weight:700;margin-bottom:8px}
.pk-scores{display:flex;gap:12px;justify-content:space-around}
.pk-stat{text-align:center}
.pk-label{font-size:10px;color:rgba(255,255,255,0.3);display:block}
.pk-val{font-size:18px;font-weight:800;color:#a29bfe}
.pk-notfound{text-align:center;color:rgba(255,255,255,0.3);font-size:13px;padding:12px}

/* ====== 玩法 ====== */
.guide{display:flex;flex-direction:column;gap:8px}
.guide-row{font-size:13px;color:rgba(255,255,255,0.5);display:flex;align-items:center;gap:8px}
.guide-row span{font-size:16px;width:24px;text-align:center}

.footer{text-align:center;font-size:11px;color:rgba(255,255,255,0.12);padding:24px 0 0;letter-spacing:1px}

/* ====== 游戏页 ====== */
.game-page{background:#0e0e24;min-height:100vh;min-height:100dvh}
.game-wrap{max-width:440px;margin:0 auto;padding:10px 10px 20px;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}
.game-hud{display:flex;justify-content:space-around;padding:10px 0;background:#1a1a38;border:1px solid rgba(255,255,255,0.06);border-radius:12px;margin-bottom:8px;flex-shrink:0}
.hud-cell{display:flex;flex-direction:column;align-items:center;min-width:55px}
.hud-lbl{font-size:9px;color:rgba(255,255,255,0.35);letter-spacing:1px;margin-bottom:2px}
.hud-val{font-size:15px;font-weight:800;color:#feb47b}

.canvas-box{flex:1;min-height:0;display:flex;justify-content:center;align-items:center;border-radius:14px;overflow:hidden;border:1px solid rgba(255,255,255,0.06);background:#0b0b2a}
#gameCanvas{display:block;touch-action:none}

.game-btns{display:flex;gap:10px;justify-content:center;flex-shrink:0;padding-top:8px}
.gbtn{padding:10px 24px;border:1px solid rgba(255,255,255,0.1);border-radius:10px;background:rgba(255,255,255,0.03);color:rgba(255,255,255,0.6);font-size:13px;font-weight:600;cursor:pointer}
.gbtn:active{background:rgba(255,255,255,0.08)}

.mode-tag{text-align:center;font-size:11px;color:rgba(255,255,255,0.25);margin-top:10px;flex-shrink:0}

/* ====== 弹窗 ====== */
.modal-mask{position:fixed;inset:0;background:rgba(0,0,0,0.7);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}
.modal-box{background:#1a1a38;border:1px solid rgba(255,255,255,0.08);border-radius:20px;padding:28px 22px;max-width:320px;width:100%;text-align:center}
.modal-icon{font-size:42px;margin-bottom:8px}
.modal-title{font-size:22px;font-weight:800;margin-bottom:6px}
.modal-score{font-size:48px;font-weight:900;background:linear-gradient(135deg,#ff7e5f,#feb47b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:12px 0}
.modal-sub{color:rgba(255,255,255,0.45);font-size:13px;margin-bottom:16px;white-space:pre-line;line-height:1.5}
.modal-btns{display:flex;flex-direction:column;gap:8px}
.input-row{margin-bottom:14px}
.input-row input{width:100%;padding:12px;border:1px solid rgba(255,255,255,0.1);border-radius:10px;background:rgba(255,255,255,0.04);color:#fff;font-size:14px;text-align:center;outline:none}
.input-row input:focus{border-color:#ff7e5f}
.input-row input::placeholder{color:rgba(255,255,255,0.2)}
.mbtn{padding:12px;border:none;border-radius:10px;font-size:14px;font-weight:700;cursor:pointer;transition:opacity .2s,transform .15s}
.mbtn:active{transform:scale(0.97);opacity:.85}
.mbtn-primary{background:linear-gradient(135deg,#ff7e5f,#feb47b);color:#fff}
.mbtn-outline{background:transparent;border:1px solid rgba(255,255,255,0.15);color:rgba(255,255,255,0.7)}
.mbtn-ghost{background:transparent;color:rgba(255,255,255,0.4);font-size:13px}

/* ====== Toast ====== */
.toast{position:fixed;top:20px;left:50%;transform:translateX(-50%) translateY(-80px);background:linear-gradient(135deg,#ff7e5f,#feb47b);color:#fff;padding:10px 24px;border-radius:12px;font-size:14px;font-weight:700;z-index:2000;transition:transform .35s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 6px 24px rgba(255,126,95,0.35);white-space:nowrap}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ====== 手机适配 ====== */
@media(max-width:375px){
  .hero-title{font-size:26px}
  .card{padding:16px}
  .si-price{font-size:16px}
  .ach-grid{grid-template-columns:repeat(3,1fr)}
}

@supports(padding:max(0px)){
  .game-wrap{padding-bottom:max(20px,env(safe-area-inset-bottom))}
  .page{padding-bottom:max(40px,env(safe-area-inset-bottom))}
}

body{position:fixed;top:0;left:0;right:0;bottom:0;overflow-y:auto;-webkit-overflow-scrolling:touch}
