
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}
:root{
  /* 🎨 v13.2 语义化调色板（压缩自 180 → 22 核心色） */
  /* 品牌棕色系 */
  --br:#A0522D; --br2:#C8671E; --br3:#E8924A;
  /* 基础背景 */
  --bg:#F0EAE2; --card:#FFF; --border:#E2D8CC;
  /* 文字层级 */
  --text:#261A0E; --sub:#8A7260;
  /* 语义状态色（主） */
  --green:#2E7D32; --red:#C62828; --blue:#1565C0; --amber:#F59E0B;
  /* 语义状态色（深/浅变体，用于强调/背景） */
  --green-d:#065F46; --green-l:#ECFDF5;
  --red-d:#991B1B;  --red-l:#FEE2E2;
  --blue-d:#1E40AF; --blue-l:#DBEAFE;
  --amber-d:#92400E; --amber-l:#FEF3C7;
  /* 中性灰阶 */
  --gray:#6B7280; --gray-l:#F3F4F6;
  /* 阴影 */
  --sh:0 2px 12px rgba(0,0,0,.08);
}
html,body{height:100%;overflow:hidden}
body{font-family:'Noto Sans SC',sans-serif;background:var(--bg);color:var(--text);font-size:14px;display:flex;flex-direction:column}

/* ═══════════ 桌面端响应式：body 作为"手机外观"居中 ═══════════ */
@media (min-width:768px){
  html{
    background:linear-gradient(135deg,#2C1810,#4A2416);
    display:flex;
    align-items:center;
    justify-content:center;
    padding:20px;
    box-sizing:border-box;
    height:100vh;
    overflow:hidden;
  }
  body{
    width:100%;
    max-width:640px;
    height:100%;
    max-height:960px;
    border-radius:22px;
    box-shadow:0 20px 60px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.08);
    overflow:hidden;
    margin:0;
    position:relative;
  }
  /* 把所有全屏浮层限制在容器内 */
  #mov,.chat-wrap{
    left:50% !important;
    transform:translateX(-50%);
    width:100%;
    max-width:640px;
    right:auto;
  }
  #mbox{max-width:620px}
  #toast{max-width:580px}
  #notif{max-width:640px}
}

/* 更大屏（≥1024px）略放宽到 720，视觉更舒展 */
@media (min-width:1024px){
  body{max-width:720px;max-height:1000px}
  #mov,.chat-wrap{max-width:720px}
  #mbox{max-width:700px}
  #toast{max-width:660px}
  #notif{max-width:720px}
}

/* 🔧 v12.5 新增：iPad/平板横屏——高度受限，宽度可放宽 */
@media (orientation:landscape) and (max-height:900px) and (min-width:1024px){
  body{max-width:900px;max-height:92vh}
  #mov,.chat-wrap{max-width:900px}
  #mbox{max-width:860px}
  #toast{max-width:820px}
  #notif{max-width:900px}
}

/* 🔧 v12.5 新增：超宽屏——限制高度避免拉得过长 */
@media (min-width:1440px){
  body{max-height:920px}
}
#hdr{background:linear-gradient(135deg,#7B3510,#B85820);color:#fff;padding:10px 14px 9px;display:flex;flex-direction:column;gap:8px;box-shadow:0 3px 12px rgba(120,50,10,.4);flex-shrink:0;z-index:50}
.hdr-row-top{display:flex;align-items:center;gap:10px}
.hdr-row-bot{display:flex;align-items:center;gap:10px}
#hdr-name{display:none}
/* 右侧图标按钮 */
.hdr-iconbtn{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;flex-shrink:0;transition:all .15s;user-select:none}
.hdr-iconbtn:active{background:rgba(255,255,255,.3);transform:scale(.94)}
.hdr-tag{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.28);border-radius:6px;padding:4px 10px;font-size:12px;cursor:pointer;white-space:nowrap;font-weight:600}
.hdr-tag:active{background:rgba(255,255,255,.3)}
/* 钱：C 位 */
#hdr-money{font-size:22px;font-weight:800;white-space:nowrap;letter-spacing:.5px;text-shadow:0 1px 3px rgba(0,0,0,.25);flex:1;line-height:1}
.lv-row{display:none}
/* Lv + XP 合并：Lv 作为 XP 条的左侧标签 */
.lv-xp-group{display:flex;align-items:center;gap:8px;flex:1;min-width:0}
.lv-badge{font-size:11px;background:rgba(255,215,0,.2);border:1px solid rgba(255,215,0,.4);border-radius:10px;padding:2px 9px;font-weight:800;color:#FFE76B;white-space:nowrap;flex-shrink:0;letter-spacing:.3px}
.xp-bar{flex:1;height:6px;background:rgba(0,0,0,.28);border-radius:3px;overflow:hidden;min-width:40px;position:relative}
.xp-inner{height:100%;background:linear-gradient(90deg,#FFD700,#FFA500);border-radius:3px;transition:width .4s;box-shadow:0 0 4px rgba(255,215,0,.5)}

/* ═══════ 升级闪光 ═══════ */
.xp-bar.levelup{animation:xp-flash .9s ease-out}
.xp-bar.levelup::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.9) 50%,transparent 100%);
  animation:xp-sweep .8s ease-out;
  pointer-events:none;
}
@keyframes xp-flash{
  0%{box-shadow:0 0 0 rgba(255,215,0,0);transform:scaleY(1)}
  30%{box-shadow:0 0 18px rgba(255,215,0,.95),0 0 30px rgba(255,165,0,.6);transform:scaleY(1.8)}
  100%{box-shadow:0 0 4px rgba(255,215,0,.5);transform:scaleY(1)}
}
@keyframes xp-sweep{
  0%{transform:translateX(-100%)}
  100%{transform:translateX(100%)}
}
/* 店铺盈亏点呼吸灯 */
@keyframes pulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.55;transform:scale(1.18)}
}
/* 🔧 v13.2c 全新呼吸灯：光晕幅度调整为适合 38x38 图标内部 */

/* 好：心跳式（双节拍，模拟心脏收缩） */
@keyframes shop-pulse-good{
  0%,40%,100%{transform:scale(1);box-shadow:0 0 0 0 rgba(34,197,94,.5)}
  10%{transform:scale(1.25);box-shadow:0 0 6px 1px rgba(34,197,94,.7)}
  20%{transform:scale(1.05);box-shadow:0 0 3px 1px rgba(34,197,94,.4)}
  30%{transform:scale(1.18);box-shadow:0 0 6px 1px rgba(34,197,94,.6)}
}

/* 警（持平）：光芒旋转（星星闪） */
@keyframes shop-pulse-warn{
  0%,100%{transform:scale(1) rotate(0deg);box-shadow:0 0 4px 1px rgba(234,179,8,.5)}
  25%{transform:scale(1.15) rotate(90deg);box-shadow:0 0 6px 2px rgba(234,179,8,.7)}
  50%{transform:scale(1.05) rotate(180deg);box-shadow:0 0 4px 1px rgba(234,179,8,.5)}
  75%{transform:scale(1.15) rotate(270deg);box-shadow:0 0 6px 2px rgba(234,179,8,.7)}
}

/* 差（亏损）：警报 —— 快速闪烁 + 轻微抖动 */
@keyframes shop-pulse-bad{
  0%,100%{transform:scale(1) translateX(0);box-shadow:0 0 4px 1px rgba(239,68,68,.7)}
  15%{transform:scale(1.3) translateX(-1px);box-shadow:0 0 8px 2px rgba(239,68,68,.9)}
  30%{transform:scale(1.08) translateX(1px);box-shadow:0 0 3px 1px rgba(239,68,68,.5)}
  45%{transform:scale(1.25) translateX(-1px);box-shadow:0 0 8px 2px rgba(239,68,68,.85)}
  60%{transform:scale(1.05) translateX(0);box-shadow:0 0 3px 1px rgba(239,68,68,.5)}
}
@keyframes priceBump{
  0%{transform:scale(1)}
  40%{transform:scale(1.22)}
  100%{transform:scale(1)}
}

/* 🔧 v13 震屏效果：破产、大损失、Boss 事件时触发 */
@keyframes shake-mild{
  0%,100%{transform:translateX(0)}
  20%{transform:translateX(-3px)}
  40%{transform:translateX(3px)}
  60%{transform:translateX(-2px)}
  80%{transform:translateX(2px)}
}
@keyframes shake-strong{
  0%,100%{transform:translate(0,0)}
  10%{transform:translate(-5px,-2px)}
  20%{transform:translate(5px,2px)}
  30%{transform:translate(-4px,3px)}
  40%{transform:translate(4px,-3px)}
  50%{transform:translate(-3px,2px)}
  60%{transform:translate(3px,-2px)}
  70%{transform:translate(-2px,1px)}
  80%{transform:translate(2px,-1px)}
  90%{transform:translate(-1px,0)}
}
body.shake-mild{animation:shake-mild .3s 1}
body.shake-strong{animation:shake-strong .6s 1}

/* 🔧 v13 情绪色滤镜：按现金状况或破产等级，整体色调微调 */
body.mood-crisis{filter:saturate(.8) contrast(1.05) hue-rotate(-5deg)}
body.mood-prosper{filter:saturate(1.1) brightness(1.03)}
body.mood-bankrupt{filter:grayscale(.35) brightness(.92)}

/* 🔧 v13 粒子特效：升级时从 xp 条中心爆开 */
@keyframes particle-burst{
  0%{opacity:1;transform:translate(-50%,-50%) scale(.3)}
  100%{opacity:0;transform:translate(calc(-50% + var(--px)),calc(-50% + var(--py))) scale(1.4)}
}
.particle{
  position:fixed;z-index:9998;pointer-events:none;
  width:8px;height:8px;border-radius:50%;
  animation:particle-burst .9s ease-out forwards;
}

/* Lv 徽章在升级时也跳一下 */
.lv-badge.levelup{animation:lv-pop .7s ease-out}
@keyframes lv-pop{
  0%{transform:scale(1);background:rgba(255,215,0,.2)}
  35%{transform:scale(1.25) rotate(-4deg);background:rgba(255,215,0,.9);color:#7B3510;box-shadow:0 0 20px rgba(255,215,0,.8)}
  100%{transform:scale(1) rotate(0);background:rgba(255,215,0,.2)}
}
/* 钱变多时轻微发光 */
#hdr-money.gain{animation:money-gain .6s ease-out}
#hdr-money.loss{animation:money-loss .6s ease-out}
@keyframes money-gain{
  0%{color:#fff}
  30%{color:#FFE76B;text-shadow:0 0 12px rgba(255,231,107,.9),0 1px 3px rgba(0,0,0,.25);transform:scale(1.06)}
  100%{color:#fff;transform:scale(1)}
}
@keyframes money-loss{
  0%{color:#fff}
  30%{color:#FF8A80;transform:scale(.96)}
  100%{color:#fff;transform:scale(1)}
}
.xp-txt{display:none}  /* 隐藏 XP 数字，条已经表达进度 */
/* 体力/心情 —— 图标+数字紧凑组 */
.hdr-stat{font-size:11px;font-weight:700;background:rgba(255,255,255,.1);border-radius:10px;padding:3px 9px;white-space:nowrap;letter-spacing:.3px;display:inline-flex;align-items:center;gap:3px;transition:background .2s}
.hdr-stat.warn{background:rgba(220,38,38,.35)}
.sta-txt{font-size:11px;opacity:.8}
/* 顶部右侧组 */
.hdr-right-group{display:flex;align-items:center;gap:4px;flex-shrink:0}
#notif{max-height:0;overflow:hidden;transition:max-height .3s,padding .3s,filter .15s;background:rgba(21,101,192,.9);color:#fff;font-size:12px;display:flex;align-items:center;justify-content:space-between;padding:0 14px;flex-shrink:0}
#notif.on{max-height:32px;padding:6px 14px}
#notif[style*="cursor:pointer"]:hover{filter:brightness(1.1)}
#notif[style*="cursor:pointer"]:active{filter:brightness(.92)}
#notif.g{background:rgba(46,125,50,.9)}
#notif.r{background:rgba(198,40,40,.9)}
#notif.b{background:rgba(21,101,192,.9)}
#body{flex:1;display:flex;min-height:0}
#sidebar{width:60px;background:var(--card);border-right:1px solid var(--border);display:flex;flex-direction:column;align-items:center;padding:6px 3px;gap:3px;overflow-y:auto;flex-shrink:0;scrollbar-width:none;z-index:1}
#sidebar::-webkit-scrollbar{display:none}
.si{display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;padding:5px 2px;border-radius:8px;width:54px;transition:background .18s;overflow:visible}
.si.on{background:#FFF0E5}
.si-ico{width:38px;height:38px;border-radius:8px;background:#EDE6DC;display:flex;align-items:center;justify-content:center;font-size:18px;transition:all .18s}
.si.on .si-ico{color:#fff}
.si-lbl{font-size:10px;color:var(--sub);text-align:center;line-height:1.3}
.si-price{font-size:10px;color:var(--br2);font-weight:700}
.si.locked .si-ico{background:#DDD8D0}
#main{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}
.page{display:none;flex:1;overflow-y:auto;flex-direction:column;gap:10px;padding:12px}
.page.on{display:flex}
.page::-webkit-scrollbar{width:3px}
.page::-webkit-scrollbar-thumb{background:#CCBFB4;border-radius:2px}
#nav{background:var(--card);border-top:1px solid var(--border);display:flex;flex-shrink:0;padding-bottom:env(safe-area-inset-bottom)}
/* 🔧 v13.2g 彻底修抖动：所有动画走 transform/opacity，不动 font-size 避免 reflow */
.nb{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px 0 12px;cursor:pointer;border:none;background:none;font-family:inherit;color:var(--sub);font-size:10px;gap:2px;transition:color .35s ease,background .35s ease;-webkit-tap-highlight-color:transparent;position:relative}
/* .ni 用 inline-block + 固定行高，transform 不影响布局 */
.nb .ni{font-size:18px;line-height:1;display:inline-block;transition:transform .35s cubic-bezier(.4,0,.2,1),filter .35s;transform-origin:center center;will-change:transform}

/* 激活态：多重视觉信号 */
.nb.on{color:var(--br);background:linear-gradient(180deg,rgba(232,146,74,.12),rgba(232,146,74,.02))}
/* 不再改 font-weight 避免文字宽度抖动 */
.nb.on .ni{
  /* 🔑 用 transform scale 放大图标（22/18 ≈ 1.22），不改 font-size 就不会 reflow */
  transform:translateY(-2px) scale(1.22);
  filter:drop-shadow(0 2px 4px rgba(160,82,45,.35));
}
/* 顶部光条：加 transition，激活/退出都有过渡 */
.nb::after{
  content:'';position:absolute;top:0;left:50%;right:50%;height:3.5px;
  background:linear-gradient(90deg,var(--br2),var(--br),var(--br2));
  border-radius:0 0 4px 4px;
  box-shadow:0 1px 6px rgba(160,82,45,.5);
  opacity:0;
  transition:left .35s cubic-bezier(.4,0,.2,1),right .35s cubic-bezier(.4,0,.2,1),opacity .35s;
}
.nb.on::after{
  left:20%;right:20%;opacity:1;
}
/* 底部圆点指示：同样加淡入淡出（用 opacity+scale 避免影响布局） */
.nb::before{
  content:'';position:absolute;bottom:5px;left:50%;
  width:4px;height:4px;border-radius:50%;
  background:var(--br);
  transform:translateX(-50%) scale(0);
  box-shadow:0 0 6px rgba(160,82,45,.7);
  transition:transform .35s cubic-bezier(.34,1.2,.5,1);
}
.nb.on::before{
  transform:translateX(-50%) scale(1);
}
/* 浅色背景 */
/* .nb.on 背景已合并到上方 */

/* 🔧 v13.2g 舒缓轻跳：0.4s 柔和弹起；用 scale 和 translateY 组合 */
@keyframes nb-hop{
  0%{transform:translateY(0) scale(1)}
  45%{transform:translateY(-7px) scale(1.22)}
  75%{transform:translateY(0) scale(1.22)}
  100%{transform:translateY(-2px) scale(1.22)}   /* 停在激活态位置 */
}
.nb.just-tapped .ni{animation:nb-hop .4s cubic-bezier(.34,1.2,.5,1)}
.card{background:var(--card);border-radius:14px;padding:13px;box-shadow:var(--sh)}
.ctit{font-size:14px;font-weight:700;margin-bottom:10px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.sgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;text-align:center;margin-top:4px}
.sbox .sv{font-size:14px;font-weight:800;color:var(--br2)}
.sbox .sl{font-size:10px;color:var(--sub);margin-top:1px}
.sbox .se{font-size:14px;margin-bottom:2px}
.cr{display:flex;align-items:center;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--border);gap:8px}
.cr:last-child{border-bottom:none}
.ck{font-size:13px;color:var(--sub);flex-shrink:0}
.cv{font-size:13px;font-weight:500;text-align:right}
.tdgrid{display:grid;grid-template-columns:repeat(3,1fr);text-align:center;gap:8px}
.tdb .ti{font-size:22px;margin-bottom:3px}
.tdb .tv{font-size:16px;font-weight:800}
.tdb .tl{font-size:10px;color:var(--sub);margin-top:2px}
.pt{width:100%;border-collapse:collapse;font-size:11px}
.pt th{color:var(--sub);padding:4px 2px;font-weight:500;text-align:right}
.pt th:first-child{text-align:left}
.pt td{padding:5px 2px;text-align:right;border-top:1px solid var(--border)}
.pt td:first-child{text-align:left;font-weight:500}
.pt .tot td{font-weight:700;background:#FBF7F2;border-top:2px solid var(--border)}
.ai{display:flex;justify-content:space-between;align-items:flex-start;background:#FFF8F2;border:1px solid #F4D6BB;border-radius:10px;padding:11px;margin-bottom:8px;gap:10px}
.an{font-weight:700;font-size:14px;margin-bottom:2px}
.ad{font-size:12px;color:var(--sub);margin-bottom:3px}
.ac{font-size:11px;color:var(--br2)}
.ebtn{background:var(--br);color:#fff;border:none;border-radius:8px;padding:8px 15px;font-family:inherit;font-weight:700;font-size:12px;cursor:pointer;white-space:nowrap;transition:all .15s;flex-shrink:0}
.ebtn:hover{background:var(--br2)}
.ebtn:active{transform:scale(.96)}
.ebtn.bl{background:var(--blue)}
.ebtn.gr{background:var(--green)}
.ebtn:disabled{background:#CCC;cursor:not-allowed}
.grow{display:flex;align-items:center;gap:9px;padding:9px 0;border-bottom:1px solid var(--border)}
.grow:last-child{border-bottom:none}
.gsold{text-align:center;flex-shrink:0;width:42px}
.gsv{font-size:16px;font-weight:900;color:var(--green);line-height:1}
.gsl{font-size:10px;color:var(--sub)}
.gmid{flex:1;min-width:0}
.gname{font-size:13px;font-weight:600;margin-bottom:2px}
.gstock{font-size:11px;color:var(--sub)}
.gstock.out{color:var(--red);font-weight:700}
.gbtns{display:flex;gap:4px;margin-top:4px;flex-wrap:wrap}
.gbtn{font-size:10px;padding:3px 7px;border:none;border-radius:5px;cursor:pointer;font-family:inherit;font-weight:600;transition:all .12s}
.gbtn:active{transform:scale(.92)}
.gbtn.nor{background:#D6EAFF;color:#1A4E8A}
.gbtn.pre{background:#EEE0FA;color:#5B21B6}
.pctrl{display:flex;align-items:center;gap:5px;flex-shrink:0}
.pval{font-weight:700;font-size:13px;color:var(--br2);min-width:32px;text-align:center}
.qb{width:28px;height:28px;border-radius:8px;border:none;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-weight:700;transition:all .12s;line-height:1;flex-shrink:0;padding:0}
.qb:active{transform:scale(.88)}
.qb.m{background:#FFF;color:#8C7B6B;border:1.5px solid #E5DED2}
.qb.p{background:var(--br2);color:#fff;border:1.5px solid var(--br)}
.pbanner{background:#FFFBEB;border:1px solid #FCD34D;border-radius:8px;padding:8px 11px;display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:8px}
.ptag{background:#EF4444;color:#fff;border-radius:4px;padding:2px 6px;font-size:11px;font-weight:700;margin-right:4px}
.trow{display:flex;gap:6px;overflow-x:scroll;padding:6px 4px;scrollbar-width:none;margin-bottom:8px;position:relative;z-index:2;min-height:44px;align-items:center;background:var(--card);border-radius:10px;border:1px solid var(--border);box-shadow:0 1px 4px rgba(0,0,0,.05);flex-shrink:0;-webkit-overflow-scrolling:touch;touch-action:pan-x;overscroll-behavior-x:contain}
.trow::-webkit-scrollbar{display:none}
.tpill{display:flex;align-items:center;gap:4px;background:#F2EDE8;border:1.5px solid var(--border);border-radius:18px;padding:6px 14px;cursor:pointer;white-space:nowrap;font-size:11px;font-weight:600;flex-shrink:0;transition:all .15s}
.tpill.act{border-color:var(--green);background:#EDF7EE;color:var(--green)}
.tdays{background:var(--green);color:#fff;border-radius:3px;padding:1px 5px;font-size:10px}
.wbox{background:#FFF8E1;border:1px solid #FFC107;border-radius:8px;padding:9px 12px;font-size:12px;color:#7A5A00;margin-bottom:8px;line-height:1.6}
.oempty{text-align:center;padding:36px 16px;color:var(--sub);font-size:13px;line-height:2}
.ocard{background:var(--card);border:1.5px solid var(--border);border-radius:12px;padding:11px;margin-bottom:8px}
.ocard.loss{border-color:#FCA5A5;background:#FFF5F5}
/* 🔧 v13.6.2 订单完成特效：纯单向下沉 + 柔和绿光 + 0.5s 快干脆 */
@keyframes order-done-flash{
  0%{transform:translate(0,0);opacity:1;background:var(--card);box-shadow:0 0 0 rgba(16,185,129,0);border-color:var(--border)}
  25%{background:#D1FAE5;box-shadow:0 0 10px 1px rgba(16,185,129,.35);border-color:#34D399}
  100%{transform:translate(0,16px);opacity:0;background:#ECFDF5;box-shadow:0 0 0 rgba(16,185,129,0)}
}
.order-done-ghost.order-done-anim{animation:order-done-flash .5s cubic-bezier(.4,.0,.6,1) forwards}
/* 🔧 v13.6.3 钱数位置浮现 +¥XX：简化关键帧 + will-change 防卡顿 */
@keyframes coin-float-up{
  0%{opacity:0;transform:translate(-50%,-50%) scale(.85)}
  15%{opacity:1;transform:translate(-50%,calc(-50% - 10px)) scale(1.08)}
  100%{opacity:0;transform:translate(-50%,calc(-50% - 32px)) scale(.95)}
}
.coin-float{
  position:fixed;z-index:9999;pointer-events:none;
  font-size:14px;font-weight:800;color:#F59E0B;
  text-shadow:0 1px 3px rgba(0,0,0,.4),0 0 8px rgba(255,215,0,.7);
  will-change:transform,opacity;
  animation:coin-float-up .9s cubic-bezier(.25,.46,.45,.94) forwards;
}
.ohead{display:flex;align-items:center;gap:5px;margin-bottom:7px;flex-wrap:wrap}
.onum{font-size:14px;font-weight:800}
.otag{border-radius:4px;padding:2px 7px;font-size:11px;font-weight:700}
.td{background:#DCFCE7;color:#14532D}.tde{background:#DBEAFE;color:#1E3A8A}
.tw{background:#FEF3C7;color:#78350F}.tc{background:#DBEAFE;color:#1E3A8A}
.te{background:#DCFCE7;color:#14532D}.tdi{background:#EDE9FE;color:#3B0764}
.tls{background:#FEE2E2;color:#7F1D1D;border-radius:4px;padding:2px 6px;font-size:10px;font-weight:700}
.mbtn{background:var(--br);color:#fff;border:none;border-radius:6px;padding:4px 11px;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;margin-left:auto}
.oitems{font-size:12px;margin-bottom:6px}
.oi{display:flex;justify-content:space-between;padding:2px 0}
.pcut{font-size:11px;color:var(--red);background:#FFF5F5;border-radius:5px;padding:3px 8px;margin-bottom:5px}
.oprog{height:4px;background:#F0EBE4;border-radius:2px;margin-bottom:3px;overflow:hidden}
.obar{height:100%;border-radius:2px;transition:width .8s}
.obar.ck{background:var(--blue)}.obar.et{background:var(--green)}.obar.dv{background:#7C3AED}
.otim{font-size:11px;color:var(--sub);margin-bottom:3px}
.ofoot{display:flex;justify-content:space-between;align-items:center;padding-top:6px;border-top:1px solid var(--border)}
.ocus{font-size:12px;color:var(--sub)}
.opri{font-size:14px;font-weight:800;color:var(--br2)}
.opri.r{color:var(--red)}
.erow{display:flex;align-items:center;gap:9px;padding:9px 0;border-bottom:1px solid var(--border)}
.erow:last-child{border-bottom:none}
.eava{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.ea-c{background:#FEF3C7}.ea-p{background:#DBEAFE}
.einfo{flex:1;min-width:0}
.ename{font-size:13px;font-weight:700}
.erole{font-size:11px;color:var(--sub);margin-top:1px}
.ewage{font-size:11px;color:var(--br2);margin-top:1px}
.eacts{display:flex;gap:5px;flex-shrink:0}
.sb2{border:none;border-radius:6px;padding:5px 8px;font-size:11px;font-weight:700;cursor:pointer;font-family:inherit;white-space:nowrap}
.tr{background:#DCFCE7;color:#14532D}
.fr{background:#FEE2E2;color:#7F1D1D}
.hi{background:#DBEAFE;color:#1E3A8A}
.btag{font-size:10px;background:#FEE2E2;color:#7F1D1D;border-radius:3px;padding:1px 4px;vertical-align:middle}
.opt{display:flex;justify-content:space-between;align-items:center;padding:9px 11px;border-radius:9px;border:1.5px solid var(--border);margin-bottom:6px;cursor:pointer;transition:all .18s;gap:8px}
.opt.cur{border-color:var(--green);background:#F0FBF2}
.opt.sel{border-color:var(--br);background:#FFF8F2}
.olft{font-size:13px;font-weight:500}
.osub{font-size:11px;color:var(--sub);margin-top:2px}
.clbl{color:var(--green);font-size:12px;font-weight:700}
.opbtn{background:var(--br);color:#fff;border:none;border-radius:6px;padding:4px 10px;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;white-space:nowrap}
.opbtn.alt{background:var(--green)}
.itag{border-radius:3px;padding:1px 6px;font-size:10px;font-weight:700}
.ilight{background:#374151;color:#fff}.irec{background:#1E40AF;color:#fff}.istrong{background:#7F1D1D;color:#fff}
.mbox{background:#F5F7FF;border:1px solid #C5CAE9;border-radius:10px;padding:11px}
.mrow{display:grid;grid-template-columns:repeat(3,1fr);text-align:center;gap:8px;margin-bottom:10px}
.comp{padding:7px 0;border-top:1px solid var(--border)}
.promo-cur{background:#FFFBEB;border:1.5px solid #FCD34D;border-radius:9px;padding:10px;margin-bottom:10px}
.psect{font-size:12px;color:var(--sub);font-weight:700;margin:8px 0 5px}
.lstats{display:grid;grid-template-columns:repeat(3,1fr);text-align:center;gap:8px}
.lsb .li{font-size:22px;margin-bottom:3px}
.lsb .lv{font-size:14px;font-weight:700}
.lsb .ll{font-size:10px;color:var(--sub);margin-top:2px}
.lprow{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--border);font-size:13px}
.lprow:last-child{border-bottom:none}
.lpk{color:var(--sub)}
.dgrid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.ditem{background:#FFF8F2;border:1.5px solid #F0D4B8;border-radius:10px;padding:11px;cursor:pointer;text-align:center;transition:all .18s}
.ditem:hover:not(.dused){transform:translateY(-2px);box-shadow:0 4px 14px rgba(0,0,0,.1)}
.ditem:active:not(.dused){transform:scale(.96)}
.dused{opacity:.45;cursor:not-allowed}
.agrid{display:grid;grid-template-columns:1fr 1fr;gap:7px}
.aitem{border:1px solid var(--border);border-radius:8px;padding:8px;font-size:12px}
.aitem.done{border-color:#86EFAC;background:#F0FBF4}
.eday-btn{background:linear-gradient(135deg,#D06020,#A84010);color:#fff;border:none;border-radius:12px;padding:14px;font-size:14px;font-weight:800;cursor:pointer;font-family:inherit;box-shadow:0 4px 14px rgba(160,64,16,.4);width:100%;transition:all .18s;display:flex;align-items:center;justify-content:center;gap:8px}
.eday-btn:hover{transform:translateY(-2px)}
#mov{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:200;display:none;align-items:flex-end;justify-content:center}
#mov.on{display:flex}
#mbox{background:#fff;border-radius:20px 20px 0 0;width:100%;max-height:80vh;overflow-y:auto;padding:20px 18px 32px;position:relative}
#mbox::-webkit-scrollbar{display:none}
.mhero{font-size:48px;text-align:center;margin:4px 0 10px}
.mtit{font-size:16px;font-weight:800;text-align:center;margin-bottom:4px}
.msub{font-size:13px;color:var(--sub);text-align:center;white-space:pre-line;margin-bottom:12px}
.mrow2{display:flex;justify-content:space-between;padding:10px 0;border-top:1px solid var(--border);font-size:13px}
.mcbtn{width:100%;background:var(--br);color:#fff;border:none;border-radius:12px;padding:14px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;margin-top:8px;display:flex;align-items:center;justify-content:center;gap:6px}
.mcbtn.bl{background:var(--blue)}
.mcbtn.dis{background:#CCC;cursor:not-allowed}
.abadge{background:var(--green);color:#fff;border-radius:6px;padding:4px 12px;font-size:13px;font-weight:700;display:block;text-align:center;width:fit-content;margin:10px auto}
#mclose{position:absolute;right:16px;top:14px;background:none;border:none;font-size:22px;cursor:pointer;color:var(--sub)}
#toast{position:fixed;bottom:72px;left:50%;transform:translateX(-50%) translateY(10px);background:#261A0E;color:#fff;padding:8px 20px;border-radius:18px;font-size:13px;font-weight:600;pointer-events:none;opacity:0;transition:all .28s;z-index:300;white-space:nowrap;max-width:88vw;text-align:center}
#toast.on{opacity:1;transform:translateX(-50%) translateY(0)}
#toast.g{background:var(--green)}
#toast.r{background:var(--red)}
#toast.b{background:var(--blue)}
/* 撤销条 */
#undoBar{position:fixed;top:60px;left:50%;transform:translateX(-50%) translateY(-30px);background:#261A0E;color:#fff;padding:10px 14px;border-radius:14px;font-size:12px;font-weight:600;opacity:0;transition:all .25s;z-index:305;display:flex;align-items:center;gap:10px;max-width:92vw;pointer-events:none;box-shadow:0 6px 20px rgba(0,0,0,.25)}
#undoBar.on{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}
#undoBar button{background:#F59E0B;color:#261A0E;border:none;border-radius:8px;padding:5px 12px;font-size:12px;font-weight:800;cursor:pointer;font-family:inherit;flex-shrink:0}
#undoBar .undoX{background:transparent;color:#9CA3AF;padding:2px 4px;font-size:14px;font-weight:700}
/* Chat UI */
.chat-wrap{position:fixed;inset:0;z-index:150;background:var(--bg);display:none;flex-direction:column}
.chat-wrap.on{display:flex}
.chat-hdr{background:var(--green);color:#fff;padding:10px 14px;display:flex;align-items:center;gap:12px;flex-shrink:0}
.chat-back{background:none;border:none;color:#fff;font-size:16px;cursor:pointer;font-family:inherit;font-weight:700;padding:4px 8px}
.chat-name{font-size:16px;font-weight:700;flex:1;text-align:center}
.chat-body{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px}
.chat-body::-webkit-scrollbar{display:none}
.msg-l,.msg-r{max-width:75%;padding:10px 14px;border-radius:14px;font-size:13px;line-height:1.6;word-break:break-word}
.msg-l{background:#fff;align-self:flex-start;border-top-left-radius:4px;box-shadow:0 1px 4px rgba(0,0,0,.06)}
.msg-r{background:#95EC69;align-self:flex-end;border-top-right-radius:4px}
.msg-transfer{background:#fff;align-self:flex-start;border-radius:10px;padding:12px;box-shadow:0 1px 4px rgba(0,0,0,.1);max-width:60%}
.msg-transfer .mt-amt{font-size:18px;font-weight:800}
.msg-transfer .mt-lbl{font-size:11px;color:var(--sub)}
.msg-transfer .mt-btn{background:#F0F0F0;color:#999;border:none;border-radius:6px;padding:4px 12px;font-size:12px;margin-top:6px;font-family:inherit;cursor:pointer}
.msg-transfer .mt-btn.can{background:var(--green);color:#fff;cursor:pointer}
.chat-input{display:flex;gap:8px;padding:10px 12px;background:#fff;border-top:1px solid var(--border);flex-shrink:0}
.chat-input input{flex:1;border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:14px;font-family:inherit;outline:none}
.chat-input button{background:var(--green);color:#fff;border:none;border-radius:8px;padding:8px 16px;font-weight:700;cursor:pointer;font-family:inherit}
/* Live stream UI */
.live-wrap{position:fixed;inset:0;z-index:150;background:#1a1a2e;display:none;flex-direction:column;color:#fff}
.live-wrap.on{display:flex}
.live-top{padding:12px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}
.live-close{background:rgba(255,255,255,.2);border:none;color:#fff;border-radius:50%;width:32px;height:32px;font-size:16px;cursor:pointer}
.live-stage{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}
.live-ani{font-size:48px;animation:live-pulse 1.5s infinite}
@keyframes live-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}
.live-viewers{color:#FF6B6B;font-size:14px;font-weight:700}
.live-chat{flex:1;overflow-y:auto;padding:0 16px;max-height:150px}
.live-chat::-webkit-scrollbar{display:none}
.lc-msg{font-size:13px;margin-bottom:4px;padding:2px 0}
.lc-msg span{color:#FFD700}
.live-tip{background:rgba(255,215,0,.15);border:1px solid rgba(255,215,0,.3);border-radius:12px;padding:12px;text-align:center;margin:12px 16px;font-size:16px;font-weight:700;color:#FFD700}
/* Contact list */
.contact-wrap{position:fixed;inset:0;z-index:150;background:var(--bg);display:none;flex-direction:column}
.contact-wrap.on{display:flex}
.contact-hdr{background:var(--green);color:#fff;padding:10px 14px;display:flex;align-items:center;gap:12px;flex-shrink:0}
.contact-list{flex:1;overflow-y:auto;background:#fff}
.contact-item{display:flex;align-items:center;gap:12px;padding:14px;border-bottom:1px solid var(--border);cursor:pointer}
.contact-item:active{background:#F8F4F0}
.ct-ava{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;background:#FEF3C7;flex-shrink:0}
.ct-info{flex:1}
.ct-name{font-weight:700;font-size:14px}
.ct-sub{font-size:12px;color:var(--sub);margin-top:2px}
.ct-heart{color:#E53E3E;font-weight:700;font-size:13px}
/* Goods enhanced */
.bulk-row{display:flex;gap:8px;margin-bottom:10px}
.bulk-btn{flex:1;border:none;border-radius:8px;padding:8px;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;text-align:center;transition:all .15s}
.bulk-btn:active{transform:scale(.96)}
.bulk-btn.nor2{background:#D6EAFF;color:#1A4E8A}
.bulk-btn.pre2{background:#EEE0FA;color:#5B21B6}
.bulk-btn.snor{background:var(--blue);color:#fff}
.bulk-btn.spre{background:#7C3AED;color:#fff}
.stock-bar{height:6px;background:#EDEAE6;border-radius:3px;overflow:hidden;margin-top:3px}
.stock-fill{height:100%;border-radius:3px;transition:width .3s}
.stock-fill.ok{background:var(--green)}
.stock-fill.low{background:var(--amber)}
.stock-fill.out{background:var(--red)}
.gdesc{font-size:10px;color:var(--blue);margin-top:2px;font-style:italic}


/* ═══════════ 减弱动画支持（低端设备/用户偏好） ═══════════ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  .xp-bar.levelup, .xp-bar.levelup::after,
  .lv-badge.levelup,
  #hdr-money.gain, #hdr-money.loss,
  .nb.just-tapped .ni,
  body.shake-mild, body.shake-strong,
  .particle {
    animation: none !important;
  }
  body.mood-crisis, body.mood-prosper, body.mood-bankrupt {
    filter: none !important;
  }
}

/* ═══════════ 从 JS inline style 提取的复用类 ═══════════ */
/* 布局辅助 */
.flex-center{display:flex;align-items:center;justify-content:center}
.flex-between{display:flex;justify-content:space-between;align-items:center}
.flex-col-center{display:flex;flex-direction:column;align-items:center}
.flex-gap6{display:flex;align-items:center;gap:6px}
.flex-gap8{display:flex;align-items:center;gap:8px}
.flex-gap10{display:flex;align-items:center;gap:10px}
.flex-gap12{display:flex;align-items:center;gap:12px}

/* 文字辅助 */
.hint-text{font-size:10px;color:var(--sub);text-align:center;margin-top:8px}
.hint-text-b{font-size:10px;color:var(--sub);text-align:center;margin-bottom:8px}
.sub-text{font-size:11px;color:var(--sub);margin-bottom:10px;line-height:1.55}
.label-sm{font-size:12px;font-weight:700;color:var(--text);margin-bottom:8px}
.label-warn{font-weight:700;color:var(--amber-d);margin-bottom:6px}
.empty-state{text-align:center;color:var(--sub);padding:14px;font-size:13px}

/* 卡片/容器辅助 */
.card-section{background:#fff;border:1px solid var(--border);border-radius:10px;margin:8px 0;overflow:hidden}
.card-section-pad{background:#fff;border:1px solid var(--border);border-radius:10px;padding:12px;margin:8px 0}
.alert-box{margin-top:8px;padding:8px;background:var(--red-l);border:1px solid var(--red-l);border-radius:8px;font-size:12px;color:var(--red)}
.info-box{font-size:11px;color:var(--sub);padding:9px 11px;background:var(--gray-l);border-radius:8px;border:1px solid var(--border);line-height:1.5}

/* 按钮辅助 */
.btn-disabled{background:var(--gray-l);color:var(--sub);border:1px solid var(--border);box-shadow:none;margin-top:6px}
.btn-action{margin-top:16px;background:var(--br);color:#fff;border:none;border-radius:8px;padding:10px 20px;font-weight:700;cursor:pointer;font-family:inherit}

/* 浮层装饰 */
.overlay-icon-bg{position:absolute;top:-16px;right:-14px;font-size:48px;opacity:0.18;color:#fff;line-height:1;pointer-events:none}
.overlay-avatar{width:46px;height:46px;background:rgba(255,255,255,.22);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);flex-shrink:0}

/* ═══════════ 无障碍：焦点可见性 ═══════════ */
:focus-visible {
  outline: 2px solid var(--br2);
  outline-offset: 2px;
}
button:focus-visible, .ebtn:focus-visible, .mcbtn:focus-visible, .nb:focus-visible, .hdr-iconbtn:focus-visible {
  outline: 2px solid var(--br2);
  outline-offset: 2px;
  box-shadow: 0 0 0 4px rgba(200,103,30,.2);
}
/* 鼠标点击时不显示焦点框 */
:focus:not(:focus-visible) {
  outline: none;
}

/* ═══════════ 深色模式 ═══════════ */
@media (prefers-color-scheme: dark) {
  :root {
    --bg:#1A1612; --card:#2A2420; --border:#3D342A;
    --text:#E8DED0; --sub:#9A8A78;
    --green-l:#0D2818; --red-l:#2D1010; --blue-l:#0D1B2A; --amber-l:#2D2008;
    --gray-l:#2A2420; --sh:0 2px 12px rgba(0,0,0,.3);
  }
  html{background:#0F0D0A !important}
  body{color:var(--text)}
  #hdr{background:linear-gradient(135deg,#3D1F08,#5A2E10)}
  .card,.table-box,.chart-box{background:var(--card);border-color:var(--border)}
  #sidebar{background:var(--card);border-color:var(--border)}
  #nav{background:var(--card);border-color:var(--border)}
  .si.on{background:#3D2E1E}
  .si-ico{background:#3D342A}
  .field input,.field select,.field textarea{background:#1A1612;border-color:var(--border);color:var(--text)}
  #mov .mbox,#mbox{background:var(--card)}
  table th{background:var(--card)}
  table tbody tr:hover{background:rgba(232,146,74,.08)}
  .ebtn{background:#3D342A;color:var(--text)}
  .mcbtn{background:#3D342A;color:var(--text)}
}

/* ═══════════ 库存告急边框闪烁 ═══════════ */
@keyframes stock-alert{
  0%,100%{border-color:var(--border)}
  50%{border-color:var(--red)}
}
.stock-alert{animation:stock-alert 1.5s ease-in-out infinite}

/* ═══════════ 破产倒计时脉冲边框 ═══════════ */
@keyframes bankrupt-pulse{
  0%,100%{box-shadow:inset 0 0 0 0 rgba(198,40,40,0)}
  50%{box-shadow:inset 0 0 0 3px rgba(198,40,40,.4)}
}
body.bankrupt-warning{animation:bankrupt-pulse 2s ease-in-out infinite}

/* ═══════════ 员工疲劳滤镜 ═══════════ */
.staff-tired{filter:grayscale(.5) opacity(.7)}

/* ═══════════ ebtn 最小触摸高度 ═══════════ */
.ebtn{min-height:36px;min-width:44px}
