/* battle.css — 抄自 reference/demo_v3.html 的戰鬥/編隊視覺，全部 scope 在 .bz 容器下，
   避免與 FRA 殼 styles.css 的 .btn/.screen/.muted 等同名類別衝突。
   美術效果（face-shot/光暈/cutin/log）沿用 demo。chrome 規則(.app/.appbar/.appnav/.home/.live)
   雖被 scope 但 .bz 內無對應元素 → 自然失效、無害。 */
:root{
    --bg:#1b1530; --panel:#272042cc; --panel2:#322a55; --ink:#f3ecff; --muted:#a99fce;
    --fire:#ff6b4a; --wood:#5ec97a; --water:#4aa8ff; --gold:#ffd24a; --gold-d:#b8902f; --line:#473d6e;
    --hp:#54d98c; --shield:#7fd0ff; --good:#7bf0a8; --bad:#ff7d7d;
  }
.bz * {box-sizing:border-box}
.bz h1 {font-size:22px;margin:0}
.bz header {padding:12px 20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--line);
    background:linear-gradient(90deg,#3a2f63,#241d40)}
.bz header .tag {font-size:12px;color:var(--muted);background:#0003;padding:3px 8px;border-radius:20px;border:1px solid var(--line)}
.bz header .right {margin-left:auto;display:flex;gap:8px;align-items:center}
.bz .wrap {max-width:1180px;margin:0 auto;padding:18px}
.bz .screen {display:none}
.bz .screen.active {display:block}
.bz .btn {cursor:pointer;border:none;border-radius:12px;padding:10px 18px;font-size:15px;font-weight:700;
    color:#1b1530;background:linear-gradient(180deg,#ffe27a,#ffc24a);box-shadow:0 3px 0 #b8860040;transition:.1s}
.bz .btn:hover {filter:brightness(1.05)}
.bz .btn:active {transform:translateY(2px)}
.bz .btn.ghost {background:#3a3263;color:var(--ink);border:1px solid var(--line)}
.bz .btn.sm {padding:6px 12px;font-size:13px;border-radius:9px}
.bz .btn.big {padding:16px 44px;font-size:20px;border-radius:16px}
.bz .btn:disabled {opacity:.4;cursor:not-allowed;filter:grayscale(.5)}
.bz .panel {background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:16px;backdrop-filter:blur(3px)}
.bz .row {display:flex;gap:14px;flex-wrap:wrap}
.bz .muted {color:var(--muted)}
.bz .center {text-align:center}
.bz /* ============ TITLE / MAIN MENU ============ */
  #screen-title {position:relative;min-height:100vh;flex-direction:column;
    align-items:center;justify-content:center;text-align:center;overflow:hidden}
.bz #screen-title.active {display:flex}
.bz #screen-title .bgmoon {position:absolute;top:-120px;left:50%;transform:translateX(-50%);
    width:520px;height:520px;border-radius:50%;
    background:radial-gradient(circle at 38% 34%,#fff8,#7fb8ff33 45%,transparent 66%);filter:blur(6px);opacity:.5}
.bz #screen-title .heroes {position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:center;
    align-items:flex-end;gap:0;pointer-events:none;z-index:1}
.bz #screen-title .heroes img {height:300px;filter:drop-shadow(0 10px 18px #0009);opacity:.9;
    animation:bob 4s ease-in-out infinite}
.bz #screen-title .heroes img:nth-child(1) {animation-delay:0s;margin-right:-40px;height:240px;opacity:.78}
.bz #screen-title .heroes img:nth-child(2) {animation-delay:.6s;z-index:3}
.bz #screen-title .heroes img:nth-child(3) {animation-delay:1.2s;z-index:2;margin-left:-40px;height:240px;opacity:.78}
.bz #screen-title .heroes img:nth-child(4) {animation-delay:1.8s;height:200px;margin-left:-30px;opacity:.62}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}
.bz #screen-title .titlebox {position:relative;z-index:5;margin-bottom:40px}
.bz .gametitle {font-size:64px;font-weight:900;letter-spacing:2px;line-height:1.05;
    background:linear-gradient(180deg,#fff,#ffd24a 55%,#ff9d4a);-webkit-background-clip:text;background-clip:text;
    color:transparent;text-shadow:0 4px 30px #ffd24a55;margin:0}
.bz .gametitle .sub-en {display:block;font-size:20px;letter-spacing:8px;font-weight:700;
    background:linear-gradient(90deg,#9ad6ff,#c9b8ff);-webkit-background-clip:text;background-clip:text;color:transparent;margin-top:6px}
.bz .tagline {color:var(--muted);font-size:15px;margin:14px 0 30px}
.bz .tagline b {color:var(--gold)}
.bz .menu-btns {display:flex;flex-direction:column;gap:12px;align-items:center;z-index:5;position:relative}
.bz .credit {position:absolute;bottom:10px;width:100%;text-align:center;font-size:11px;color:#6f659a;z-index:6}
.bz /* ============ LEVEL SELECT ============ */
  .levels {display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:6px}
.bz .lvl {background:var(--panel2);border:2px solid var(--line);border-radius:16px;padding:14px 8px;text-align:center;
    cursor:pointer;transition:.12s;position:relative}
.bz .lvl:hover:not(.locked) {transform:translateY(-3px);border-color:var(--gold)}
.bz .lvl.sel {border-color:var(--gold);box-shadow:0 0 0 3px #ffd24a40}
.bz .lvl.locked {opacity:.45;cursor:not-allowed}
.bz .lvl.cleared::after {content:"✓";position:absolute;top:6px;right:9px;color:var(--good);font-weight:900}
.bz .lvl .ln {font-size:26px;font-weight:900;color:var(--gold)}
.bz .lvl .lt {font-size:12px;color:var(--muted);margin-top:4px;min-height:30px}
.bz .lvl .foes {font-size:18px;margin-top:6px}
.bz .lvl.locked .lockicon {font-size:20px}
.bz /* roster cards */
  .roster {display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media(max-width:680px) {
  .bz .roster {grid-template-columns:repeat(2,1fr)}
  .bz .levels {grid-template-columns:repeat(3,1fr)}
}
.bz .card {background:var(--panel2);border:2px solid var(--line);border-radius:16px;padding:12px;cursor:pointer;
    position:relative;transition:.12s;text-align:center;overflow:hidden}
.bz .card:hover {transform:translateY(-3px);border-color:var(--gold)}
.bz .card.picked {border-color:var(--gold);box-shadow:0 0 0 3px #ffd24a40}
.bz .card .art {height:96px;display:flex;align-items:center;justify-content:center;margin-bottom:2px}
.bz .card .art img {height:96px;filter:drop-shadow(0 4px 6px #0007)}
.bz .card .art .emoji {font-size:54px;line-height:1;filter:drop-shadow(0 4px 4px #0005)}
.bz .card.haspic {background:linear-gradient(180deg,#3a2f63,#241d40)}
.bz .card .nm {font-weight:800;margin-top:4px;font-size:15px}
.bz .card .meta {font-size:12px;color:var(--muted);margin-top:2px}
.bz .pill {display:inline-block;font-size:11px;padding:2px 7px;border-radius:20px;margin:2px 2px 0;font-weight:700;color:#1b1530}
.bz .e-fire {background:var(--fire)}
.bz .e-wood {background:var(--wood)}
.bz .e-water {background:var(--water)}
.bz .dice {font-size:11px;color:var(--muted);margin-top:6px}
.bz .badge {position:absolute;top:6px;right:8px;background:var(--gold);color:#1b1530;font-weight:900;
    width:24px;height:24px;border-radius:50%;display:none;align-items:center;justify-content:center;font-size:13px;z-index:2}
.bz .card.picked .badge {display:flex}
.bz /* grids */
  .arena {display:flex;gap:30px;justify-content:center;align-items:flex-start;flex-wrap:wrap}
.bz .side {flex:1;min-width:300px}
.bz .grid {display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:8px}
.bz .cell {aspect-ratio:1;background:#0003;border:2px dashed var(--line);border-radius:14px;display:flex;
    flex-direction:column;align-items:center;justify-content:flex-end;position:relative;padding:4px;transition:.1s;overflow:hidden}
.bz .cell.filled {border-style:solid}
.bz .cell.foe {border-color:#6b3a4a}
.bz .cell .uart {flex:1;display:flex;align-items:center;justify-content:center;width:100%;min-height:0}
.bz .cell .uart img {max-height:100%;max-width:92%;object-fit:contain;filter:drop-shadow(0 3px 4px #0008)}
.bz .cell .uart .uemoji {font-size:38px;line-height:1}
.bz .cell.foe .uart img {transform:scaleX(-1)}
.bz .cell .uname {font-size:10px;text-align:center;margin-top:1px;white-space:nowrap}
.bz .cell.dead {opacity:.28;filter:grayscale(1)}
.bz .cell.dead .uart img {transform:rotate(8deg);animation:none !important}
.bz .cell.foe.dead .uart img {transform:scaleX(-1) rotate(8deg);animation:none !important}
.bz .cell.acting {box-shadow:0 0 0 3px var(--gold);transform:scale(1.05);z-index:4}
.bz .cell.acting .uart img {animation:lunge .3s}
@keyframes lunge{0%,100%{transform:translateY(0)}40%{transform:translateY(-6px) scale(1.06)}}
.bz .cell.hit {animation:shake .25s}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}
.bz .bar {height:6px;width:92%;background:#0006;border-radius:6px;margin-top:3px;overflow:hidden;flex:none}
.bz .bar > i {display:block;height:100%;background:var(--hp);transition:width .2s}
.bz .sbar {height:4px;width:92%;background:#0004;border-radius:6px;margin-top:2px;overflow:hidden;flex:none}
.bz .sbar > i {display:block;height:100%;background:var(--shield);width:0;transition:width .2s}
.bz /* 理智條：≥70%綠 / 30~70%黃 / <30%紅 / 脆弱紫黑 */
  .sanbar {height:4px;width:92%;background:#0005;border-radius:6px;margin-top:2px;overflow:hidden;flex:none}
.bz .sanbar > i {display:block;height:100%;width:100%;transition:width .25s,background .25s}
.bz .sanbar.san-hi  > i {background:#46d07a}
.bz .sanbar.san-mid > i {background:#e8c33a}
.bz .sanbar.san-low > i {background:#e0653e}
.bz .sanbar.san-vuln> i {background:#a04ad0}
.bz .cell.vuln {box-shadow:0 0 0 2px #a04ad0,0 0 14px #a04ad0aa !important}
.bz .cell.vuln .uart {animation:vulnshiver .5s infinite}
@keyframes vulnshiver{0%,100%{transform:translate(0,0)}25%{transform:translate(-1px,1px)}75%{transform:translate(1px,-1px)}}
.bz .float {position:absolute;top:4px;font-weight:900;font-size:16px;pointer-events:none;z-index:6;
    animation:rise 1s ease-out forwards;text-shadow:0 1px 2px #000}
@keyframes rise{0%{opacity:0;transform:translateY(6px)}20%{opacity:1}100%{opacity:0;transform:translateY(-26px)}}
.bz /* log */
  .log {height:300px;overflow:auto;background:#0004;border-radius:12px;padding:10px;font-size:13px;line-height:1.6}
.bz .log .line {padding:2px 4px;border-bottom:1px solid #ffffff0d}
.bz .log .turnhead {color:var(--gold);font-weight:800;margin-top:6px}
.bz .log .dmg {color:var(--bad)}
.bz .log .heal {color:var(--good)}
.bz .log .sh {color:var(--shield)}
.bz .log .trig {color:var(--gold)}
.bz .log .die {color:#ffd24a;font-weight:700}
.bz .log .san {color:#46d07a;font-weight:700}
.bz .log .vlab {color:#c98aff;font-weight:800}
.bz .float.san {color:#46d07a}
.bz .float.vlab {color:#c98aff;font-size:15px}
.bz .controls {display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:10px}
.bz .spd {display:flex;gap:4px}
.bz .spd .btn.sm {min-width:42px}
.bz .spd .btn.sm.on {background:linear-gradient(180deg,#7bf0a8,#37c97a)}
.bz .vs {font-size:28px;font-weight:900;color:var(--gold);align-self:center}
.bz .hint {font-size:13px;color:var(--muted);margin:6px 0 0}
.bz .result {font-size:30px;font-weight:900;text-align:center;padding:14px}
.bz .win {color:var(--good)}
.bz .lose {color:var(--bad)}
.bz /* ============ 手遊 APP 外框 / 導覽 ============ */
  .gbtn {cursor:pointer;border:2px solid var(--gold-d);border-radius:16px;padding:11px 22px;font-size:15px;
    font-weight:800;color:#3a2a12;background:linear-gradient(#ffe9b0,#f0c869);
    box-shadow:0 3px 0 var(--gold-d),inset 0 1px 0 #fff8;transition:.1s}
.bz .gbtn:hover {filter:brightness(1.04)}
.bz .gbtn:active {transform:translateY(2px);box-shadow:0 1px 0 var(--gold-d)}
.bz .gbtn.primary {background:linear-gradient(#ffb347,#f08000);color:#fff;border-color:#a85400;
    box-shadow:0 3px 0 #a85400,inset 0 1px 0 #ffd9a0}
.bz .gbtn.big {padding:15px 40px;font-size:19px;border-radius:20px}
.bz .gbtn:disabled {opacity:.45;filter:grayscale(.5);cursor:not-allowed}
.bz .app {max-width:1180px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column;position:relative;padding-bottom:72px}
.bz .appbar {position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:8px;padding:10px 18px;
    background:linear-gradient(90deg,#3a2f63,#241d40);border-bottom:2px solid var(--gold);box-shadow:0 2px 12px #0007}
.bz .appbar .ab-logo {font-size:18px;font-weight:900;color:#fff;text-shadow:0 2px 4px #000}
.bz .appbar .ab-spacer {flex:1}
.bz .appbar .cur {display:inline-flex;align-items:center;gap:4px;background:#0005;border:1px solid var(--gold-d);
    border-radius:16px;padding:3px 11px;font-size:13px;font-weight:800;color:#ffe9b0}
.bz .appbar .ab-prog {font-size:12px;color:var(--muted);margin-left:8px}
.bz .appbody {flex:1}
.bz .appnav {position:fixed;left:50%;transform:translateX(-50%);bottom:0;width:100%;max-width:1180px;z-index:45;
    display:flex;background:linear-gradient(180deg,#2a2348,#15102a);border-top:2px solid var(--gold);box-shadow:0 -4px 18px #0008}
.bz .navtab {flex:1;border:none;background:none;cursor:pointer;color:var(--muted);font-weight:800;
    padding:7px 0 9px;display:flex;flex-direction:column;align-items:center;gap:1px;transition:.12s}
.bz .navtab b {font-size:23px;line-height:1;filter:grayscale(.4) opacity(.7)}
.bz .navtab span {font-size:12px}
.bz .navtab.active {color:var(--gold)}
.bz .navtab.active b {filter:drop-shadow(0 0 7px #ffd24a99)}
.bz .appnav.hide {display:none}
.bz .tabscreen {padding:16px 18px 78px}
.bz .sectionhead {display:flex;align-items:baseline;gap:12px;margin-bottom:12px;flex-wrap:wrap}
.bz .sectionhead h2 {margin:0;font-size:20px}
.bz /* 主頁 hub */
  .home-hero {position:relative;text-align:center;padding:18px 0 0;min-height:320px;overflow:hidden}
.bz .home-moon {position:absolute;top:-110px;left:50%;transform:translateX(-50%);width:440px;height:440px;border-radius:50%;
    background:radial-gradient(circle at 40% 36%,#fff8,#7fb8ff33 45%,transparent 66%);filter:blur(6px);opacity:.45}
.bz .home-title {position:relative;z-index:3}
.bz .home-art {position:relative;z-index:2;display:flex;justify-content:center;align-items:flex-end;margin-top:10px}
.bz .home-art img {height:215px;filter:drop-shadow(0 8px 14px #000a);animation:bob 4s ease-in-out infinite}
.bz .home-art img:nth-child(1) {height:172px;margin-right:-28px;opacity:.85;animation-delay:.2s}
.bz .home-art img:nth-child(2) {z-index:3}
.bz .home-art img:nth-child(3) {z-index:2;margin-left:-28px;opacity:.85;animation-delay:.9s}
.bz .home-art img:nth-child(4) {height:150px;margin-left:-22px;opacity:.7;animation-delay:1.4s}
.bz .home-actions {display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:4px}
.bz .home-sub {display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.bz .news {margin:14px 0 0;max-width:520px;background:#0004;border:1px solid var(--line);border-radius:12px;
    padding:9px 16px;font-size:13px;color:#d9cffa}
.bz /* gacha hub: 左選單 + 右 Live2D */
  .home2 {display:flex;gap:20px;align-items:stretch;min-height:540px}
.bz /* mobile：堆疊時 .home-right 內的 rig-box 是 absolute，父容器會 collapse → 給 min-height 才能撐出畫布 */
  @media(max-width:860px) {
    .home2{flex-direction:column;min-height:0;gap:14px}
    .home-right{min-height:min(58vw,420px)}
  }
.bz .home-left {flex:1;position:relative;display:flex;flex-direction:column;justify-content:center;padding:14px 6px;overflow:hidden}
.bz .home-left .home-moon {top:-150px;left:-60px;transform:none;opacity:.4}
.bz .home-left .gametitle {position:relative;z-index:2;text-align:left;font-size:54px}
.bz .home-left .tagline {position:relative;z-index:2;text-align:left;margin:8px 0 0}
.bz .home-menu {position:relative;z-index:2;display:flex;flex-direction:column;gap:12px;max-width:320px;margin-top:24px}
.bz .home-menu .gbtn {text-align:left}
.bz .home-right {flex:0 0 46%;position:relative;display:flex;align-items:center;justify-content:center;border-radius:18px;
    overflow:hidden;border:2px solid var(--gold);
    background:radial-gradient(125% 90% at 60% 22%,#46376e,#1a1430 76%);box-shadow:inset 0 0 70px #0009}
.bz .live-floor {position:absolute;bottom:34px;width:62%;height:34px;border-radius:50%;
    background:radial-gradient(ellipse,#0008,transparent 70%);filter:blur(3px)}
.bz .live-aura {position:absolute;width:380px;height:380px;border-radius:50%;
    background:radial-gradient(circle,#7fb8ff44,transparent 62%);filter:blur(8px);animation:auraPulse 4s ease-in-out infinite}
@keyframes auraPulse{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.08);opacity:1}}
.bz .live2d {position:relative;z-index:2;animation:floatY2 5s ease-in-out infinite}
@keyframes floatY2{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.bz .live-tilt {transform-style:preserve-3d;will-change:transform;transition:transform .1s ease-out}
.bz .live-tilt img {height:460px;max-height:62vh;display:block;filter:drop-shadow(0 16px 24px #000b);
    animation:breatheL 3.6s ease-in-out infinite}
@keyframes breatheL{0%,100%{transform:scale(1,1)}50%{transform:scale(1.015,1.03)}}
.bz .live-sheen {position:absolute;inset:0;pointer-events:none;mix-blend-mode:overlay;
    background:linear-gradient(115deg,transparent 44%,#ffffffb0 50%,transparent 56%);
    translate:-130% 0;animation:sheen2 6.5s ease-in-out infinite}
@keyframes sheen2{0%,72%{translate:-130% 0}88%,100%{translate:130% 0}}
.bz .live-badge {position:absolute;top:12px;right:12px;background:#0009;border:1px solid var(--gold);color:var(--gold);
    font-size:11px;font-weight:900;letter-spacing:1px;padding:3px 10px;border-radius:10px;z-index:3}
.bz .live-switch {position:absolute;bottom:12px;display:flex;align-items:center;gap:14px;z-index:3}
.bz .lsw {width:36px;height:36px;border-radius:50%;border:2px solid var(--gold);background:#0007;color:#fff;
    font-size:20px;cursor:pointer;line-height:1;transition:.1s}
.bz .lsw:hover {background:var(--gold);color:#1b1530}
.bz .live-name {color:#fff;font-weight:900;font-size:15px;text-shadow:0 2px 5px #000;min-width:96px;text-align:center}
.bz /* 真 Live2D 部件骨架舞台 */
  .rig-box {position:absolute;left:50%;top:48%;width:490px;height:650px;transform-origin:center center}
.bz .rig-fig {position:absolute;inset:0;will-change:transform}
.bz .rig-fig img {position:absolute;-webkit-user-drag:none;user-select:none;
    filter:drop-shadow(0 4px 4px rgba(0,0,0,.35));will-change:transform}
.bz /* 編隊 slots */
  .team-slots {display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:12px}
.bz .tslot {width:86px;height:100px;border-radius:14px;border:2px dashed var(--line);background:#0003;
    display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative}
.bz .tslot.full {border-style:solid;border-color:var(--gold);background:linear-gradient(180deg,#3a2f63,#241d40)}
.bz .tslot img {height:64px;filter:drop-shadow(0 3px 4px #0008)}
.bz .tslot .semoji {font-size:42px;line-height:1}
.bz .tslot .sn {font-size:11px;margin-top:2px;font-weight:800}
.bz .tslot .empty {color:var(--muted);font-size:12px}
.bz .tslot .x {position:absolute;top:1px;right:6px;color:var(--bad);font-weight:900;cursor:pointer;font-size:15px}
.bz .team-bar, .bz .chapter-bar {display:flex;align-items:center;gap:12px;justify-content:center;margin:2px 0 16px;flex-wrap:wrap}
.bz /* ============ 出陣編成 stage (信喵風) ============ */
  .roster-stage {display:flex;gap:14px;align-items:stretch;margin-bottom:12px}
@media(max-width:820px) {
  .bz .roster-stage {flex-direction:column}
}
.bz .detail {flex:0 0 320px;border:3px solid var(--gold);border-radius:16px;color:#4a2f1a;padding:14px;
    background:linear-gradient(160deg,#fdf6e3,#efe0bc);box-shadow:0 6px 20px #0008;display:flex;flex-direction:column;gap:10px}
.bz .detail .dhead {display:flex;gap:12px;align-items:flex-start}
.bz .detail .dport {width:108px;height:120px;flex:none;border-radius:14px;border:3px solid var(--gold);overflow:hidden;
    display:flex;align-items:flex-end;justify-content:center;box-shadow:inset 0 2px 8px #0004}
.bz .detail .dport.fire {background:radial-gradient(circle at 48% 34%,#ffe2d2,#ff9a78 80%)}
.bz .detail .dport.wood {background:radial-gradient(circle at 48% 34%,#dff5e0,#86d293 80%)}
.bz .detail .dport.water {background:radial-gradient(circle at 48% 34%,#d6ecff,#85c0f3 80%)}
.bz .detail .dport img {height:118%;object-fit:contain;filter:drop-shadow(0 3px 4px #0007)}
.bz .detail .dport .demoji {font-size:70px;line-height:1.5}
.bz .detail .dname {font-size:23px;font-weight:900;color:#3a1d52;line-height:1.1}
.bz .detail .dfull {font-size:12px;color:#7a5a2a;font-weight:700;margin-top:2px}
.bz .detail .dtags {display:flex;gap:5px;margin-top:7px;flex-wrap:wrap}
.bz .detail .tag {font-size:12px;font-weight:800;color:#fff;border-radius:10px;padding:2px 9px}
.bz .detail .tag.fire {background:#e0653e}
.bz .detail .tag.wood {background:#4a9a4a}
.bz .detail .tag.water {background:#3f7eae}
.bz .detail .tag.prof {background:#7a4fa0}
.bz .detail .tag.cost {background:#b8902f}
.bz .detail .ddice {display:flex;gap:14px;font-size:13px;color:#5a3d1a;font-weight:800;
    border-top:1px dashed #d8c79a;border-bottom:1px dashed #d8c79a;padding:7px 2px}
.bz .detail .skills {display:flex;flex-direction:column;gap:7px}
.bz .detail .skill {display:flex;gap:9px;align-items:flex-start;background:#7a4fa014;border:1px solid #e3d0a2;border-radius:10px;padding:6px 9px}
.bz .detail .skill .si {width:30px;height:30px;border-radius:8px;flex:none;display:flex;align-items:center;justify-content:center;
    font-size:17px;background:linear-gradient(135deg,#8b5fb0,#5b2d7a)}
.bz .detail .skill .stxt b {font-size:14px;color:#3a1d52}
.bz .detail .skill .stxt .sc {font-size:11px;color:#a8741f;font-weight:800;margin-left:3px}
.bz .detail .skill .stxt p {font-size:11.5px;color:#6a4a2a;line-height:1.3;margin-top:1px}
.bz .detail .dformula {font-size:11.5px;color:#5a3d1a;font-weight:700;background:#fff6df;border:1px solid #e3d0a2;
    border-radius:9px;padding:6px 9px;margin:8px 0}
.bz .detail .dformula b {color:#b8702f}
.bz .detail .skill .stxt p.est {font-size:11.5px;color:#9a3a2a;font-weight:800;margin-top:3px;background:#ffece4;border-radius:7px;padding:2px 7px;display:inline-block}
.bz .detail .skill .stxt p.est b {color:#c0341a;font-size:13px}
.bz .detail .estnote {color:#a07a5a;font-weight:600;font-size:10px}
/* 武將列表：2 列橫向捲動條，超出寬度往右流（左右滑動），不再往下長 → 貼合可拖曳佈陣 */
.bz .rgrid {flex:1;min-width:0;display:grid;grid-auto-flow:column;
    grid-template-rows:repeat(2,max-content);grid-auto-columns:100px;gap:10px;
    justify-content:start;align-content:start;
    overflow-x:auto;overflow-y:hidden;padding-bottom:8px;
    scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain}
.bz .rgrid::-webkit-scrollbar {height:8px}
.bz .rgrid::-webkit-scrollbar-thumb {background:#ffd24a66;border-radius:8px}
.bz .rgrid::-webkit-scrollbar-track {background:#0003;border-radius:8px}
.bz .rtile {scroll-snap-align:start}
@media(max-width:520px) {
  .bz .rgrid {grid-auto-columns:86px}
}
.bz .rtile {border-radius:14px;border:2px solid var(--line);background:linear-gradient(180deg,#322a55,#241d40);
    padding:9px 6px 10px;display:flex;flex-direction:column;align-items:center;gap:1px;cursor:pointer;position:relative;transition:.12s}
.bz .rtile:hover {transform:translateY(-3px);border-color:var(--gold)}
.bz .rtile.focus {border-color:#9ad6ff;box-shadow:0 0 0 2px #9ad6ff55}
.bz .rtile.picked {border-color:var(--gold);box-shadow:0 0 0 2px #ffd24a66,0 0 16px #ffaa3344}
/* 未擁有：灰掉、不可上陣（招募/里程碑取得後解鎖） */
.bz .rtile.locked {filter:grayscale(.85) brightness(.65);cursor:default}
.bz .rtile.locked:hover {transform:none;border-color:var(--line)}
.bz .rtile .lock {position:absolute;top:6px;right:8px;font-size:13px;z-index:3}
.bz .rtile .frame {width:80px;height:80px;border-radius:50%;border:3px solid var(--gold);overflow:hidden;position:relative;
    display:flex;align-items:flex-start;justify-content:center;box-shadow:inset 0 2px 6px #0005}
.bz .rtile .frame.fire {background:radial-gradient(circle at 47% 36%,#ffe2d2,#ff8a64 80%)}
.bz .rtile .frame.wood {background:radial-gradient(circle at 47% 36%,#dff5e0,#7ace8b 80%)}
.bz .rtile .frame.water {background:radial-gradient(circle at 47% 36%,#d6ecff,#7abdf3 80%)}
.bz .rtile .frame img {height:150%;margin-top:4%;object-fit:contain}
.bz .rtile .frame .femoji {font-size:48px;line-height:1.6}
.bz .rtile .rn {font-size:13px;font-weight:800;color:#fff;margin-top:4px}
.bz .rtile .rcost {font-size:10.5px;color:#ffd27a;font-weight:800}
.bz .rtile .chk {position:absolute;top:5px;right:7px;width:22px;height:22px;border-radius:50%;background:var(--gold);
    color:#1b1530;font-weight:900;font-size:12px;display:none;align-items:center;justify-content:center;z-index:2}
.bz .rtile.picked .chk {display:flex}
.bz .rtile .star {position:absolute;top:6px;left:8px;font-size:12px;z-index:2}
.bz .detail .tag.troop {background:#3f7e6e}
.bz .detail .tag.san {background:#46a06a}
.bz .detail .dietag {font-weight:800;border-radius:8px;padding:2px 8px;font-size:12.5px}
.bz .detail .dietag.red {background:#f3d6cc;color:#b83a1a}
.bz .detail .dietag.blue {background:#cfe0f3;color:#1a5aa8}
.bz .detail .dietag.green {background:#d2efd6;color:#2a8a3a}
.bz /* ============ 站位部署 ============ */
  .deploy-stage {display:flex;gap:18px;flex-wrap:wrap;align-items:flex-start;justify-content:center;
    background:#0003;border:1px solid var(--line);border-radius:16px;padding:14px;margin-bottom:12px}
.bz .deploy-board, .bz .cover-board {display:flex;flex-direction:column;gap:5px}
.bz .dlabel {font-size:12.5px;font-weight:800;color:#ffd27a}
.bz .depthtags {display:grid;grid-template-columns:repeat(3,76px);gap:7px;font-size:10px;color:var(--muted);text-align:center;font-weight:800}
.bz .cover-board .depthtags {grid-template-columns:repeat(3,46px)}
.bz .dgrid {display:grid;grid-template-columns:repeat(3,76px);grid-auto-rows:76px;gap:7px}
.bz .dcell {border-radius:12px;border:2px dashed var(--line);background:#0004;position:relative;cursor:pointer;
    display:flex;flex-direction:column;align-items:center;justify-content:center;transition:.12s;overflow:hidden}
.bz .dcell.z-front {background:linear-gradient(180deg,#4a2a2a55,#0004)}
.bz .dcell.z-mid {background:linear-gradient(180deg,#2a3a4a55,#0004)}
.bz .dcell.z-back {background:linear-gradient(180deg,#2a4a3055,#0004)}
.bz .dcell .dz {color:var(--muted);font-size:12px;font-weight:800;opacity:.6}
.bz .dcell.filled {border-style:solid;border-color:var(--gold)}
.bz .dcell.focus {box-shadow:0 0 0 3px #9ad6ff88}
.bz .dcell.over {border-color:#9ad6ff;background:#9ad6ff22}
.bz .dcell.drag {opacity:.4}
.bz .dcell img {height:60px;object-fit:contain;filter:drop-shadow(0 2px 3px #0008)}
.bz .dcell .uemoji {font-size:34px}
.bz .dcell .dn {font-size:10.5px;font-weight:800;color:#fff;line-height:1}
.bz .dcell .dzt {font-size:9px;color:#ffd27a;font-weight:800}
.bz .dcell .dx {position:absolute;top:0;right:4px;color:var(--bad);font-weight:900;font-size:14px;z-index:2}
/* 敵盤＝我方盤的鏡像小卡（76px）：每格直接疊 立繪 + 名字 + 元素·職業·兵種，一目了然 */
.bz .cover-board .depthtags {grid-template-columns:repeat(3,76px)}
.bz .cgrid {display:grid;grid-template-columns:repeat(3,76px);grid-auto-rows:76px;gap:7px}
.bz .ccell {border-radius:12px;border:1.5px solid #6b3a4a;background:#0004;transition:.12s;position:relative;
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;overflow:hidden}
.bz .ccell.hot {background:#ff5a5a33;border-color:#ff7a6a;box-shadow:0 0 8px #ff5a5a88}
.bz .ccell.occ {background:#1a0e16;border-style:solid}
.bz .ccell .cface {width:46px;height:42px;border-radius:7px;flex:none}
/* 通用：所有 .cface 立繪吃容器上限，避免原圖 360px 撐爆版面 */
.bz .cface {overflow:hidden;display:flex;align-items:center;justify-content:center}
.bz .cface img {max-width:100%;max-height:100%;object-fit:contain;filter:drop-shadow(0 2px 3px #000a)}
.bz .cface.fire {box-shadow:inset 0 0 0 2px var(--fire)}
.bz .cface.wood {box-shadow:inset 0 0 0 2px var(--wood)}
.bz .cface.water {box-shadow:inset 0 0 0 2px var(--water)}
.bz .cemoji {font-size:30px;line-height:1}
.bz .ccell .cn {font-size:10px;font-weight:800;color:#ffd9c2;line-height:1;white-space:nowrap}
.bz .ccell .ct {font-size:9.5px;font-weight:800;color:#cdb8e6;line-height:1.1;white-space:nowrap}
.bz .ct .ce.fire {color:var(--fire)} .bz .ct .ce.wood {color:var(--wood)} .bz .ct .ce.water {color:var(--water)}
.bz .ccell.hot.occ {box-shadow:0 0 8px #ff5a5a88, inset 0 0 0 2px #ff7a6a}
.bz .form-totals {flex:1;min-width:240px;align-self:center;font-size:12.5px;color:#e8def0;display:flex;flex-direction:column;gap:6px}
.bz .form-totals .ftrow {background:#0004;border:1px solid var(--line);border-radius:9px;padding:6px 10px}
.bz .form-totals .ftrow b {color:#ffd27a}
.bz /* 戰鬥格 zone 邊條 + 覆蓋高亮 + 日誌標籤 */
  .cell.z-front {box-shadow:inset 3px 0 0 #ff6b4a66}
.bz .cell.foe.z-front {box-shadow:inset -3px 0 0 #ff6b4a66}
.bz .cell.z-back {box-shadow:inset 3px 0 0 #5ec97a66}
.bz .cell.foe.z-back {box-shadow:inset -3px 0 0 #5ec97a66}
.bz .cell.cover {outline:3px solid #ff5a5a;outline-offset:-2px;animation:coverpulse .8s infinite alternate}
@keyframes coverpulse{to{outline-color:#ffd24a}}
.bz .zlab {font-size:10px;font-weight:800;border-radius:6px;padding:1px 6px;margin:0 2px}
.bz .zlab.z-front {background:#ff6b4a33;color:#ffb8a0}
.bz .zlab.z-mid {background:#4aa8ff33;color:#a8d4ff}
.bz .zlab.z-back {background:#5ec97a33;color:#b0e8c0}
.bz .shapelab {font-size:11px;font-weight:800;color:#ffd27a;background:#ffd27a22;border-radius:6px;padding:1px 7px}
.bz /* ============ BATTLE FX ============ */
  .arena-wrap {position:relative}
.bz .fxlayer {position:absolute;inset:0;pointer-events:none;z-index:20;overflow:visible}
.bz .spark {position:absolute;width:8px;height:8px;border-radius:50%;pointer-events:none;
    will-change:transform,opacity;box-shadow:0 0 8px currentColor}
@keyframes sparkfly{0%{opacity:1;transform:translate(0,0) scale(1)}100%{opacity:0;transform:translate(var(--dx),var(--dy)) scale(.25)}}
.bz .ring-pulse {position:absolute;border:3px solid currentColor;border-radius:50%;pointer-events:none;
    transform:translate(-50%,-50%);animation:ringpulse .5s ease-out forwards}
@keyframes ringpulse{0%{width:8px;height:8px;opacity:.95}100%{width:118px;height:118px;opacity:0}}
.bz .slashfx {position:absolute;height:6px;border-radius:5px;transform-origin:0 50%;pointer-events:none;
    background:linear-gradient(90deg,transparent,currentColor 60%,#fff);box-shadow:0 0 12px currentColor;
    transform:rotate(var(--ang,0deg));animation:slashgo .3s ease-out forwards}
/* rotate 用 --ang 帶進每個 keyframe，否則動畫的 transform 會蓋掉方向 → 敵方近戰會往後飛 */
@keyframes slashgo{0%{opacity:0;transform:rotate(var(--ang,0deg)) scaleX(.15)}30%{opacity:1}100%{opacity:0;transform:rotate(var(--ang,0deg)) scaleX(1.05)}}
.bz .bolt {position:absolute;pointer-events:none;font-size:20px;line-height:1;z-index:21;
    transform:translate(-50%,-50%);animation:boltfly var(--t,.3s) linear forwards;filter:drop-shadow(0 0 6px currentColor)}
@keyframes boltfly{to{left:var(--tx);top:var(--ty)}}
.bz .screenflash {position:absolute;inset:0;pointer-events:none;z-index:24;opacity:0;border-radius:16px}
.bz .screenflash.go {animation:scrflash .4s ease-out}
@keyframes scrflash{0%{opacity:0}18%{opacity:.5}100%{opacity:0}}
.bz .arena.shake {animation:ashake .3s}
.bz .arena.shake.big {animation:ashakeBig .45s}
@keyframes ashake{0%,100%{transform:translate(0,0)}20%{transform:translate(-6px,3px)}50%{transform:translate(5px,-3px)}80%{transform:translate(-3px,2px)}}
@keyframes ashakeBig{0%,100%{transform:translate(0,0)}15%{transform:translate(-12px,6px)}40%{transform:translate(11px,-7px)}65%{transform:translate(-8px,5px)}85%{transform:translate(5px,-3px)}}
.bz /* elemental aura + idle life */
  .cell.ele-fire.filled {box-shadow:inset 0 -16px 24px -12px #ff6b4a66}
.bz .cell.ele-wood.filled {box-shadow:inset 0 -16px 24px -12px #5ec97a66}
.bz .cell.ele-water.filled {box-shadow:inset 0 -16px 24px -12px #4aa8ff66}
.bz .cell.acting.ele-fire {box-shadow:0 0 0 3px var(--gold),0 0 26px #ff6b4aaa}
.bz .cell.acting.ele-wood {box-shadow:0 0 0 3px var(--gold),0 0 26px #5ec97aaa}
.bz .cell.acting.ele-water {box-shadow:0 0 0 3px var(--gold),0 0 26px #4aa8ffaa}
.bz .cell .uart img {transition:filter .12s}
.bz .cell.filled .uart img {animation:ubreathe 3.4s ease-in-out infinite}
@keyframes ubreathe{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-3px) scale(1.015)}}
.bz .cell.foe.filled .uart img {animation:ubreatheF 3.4s ease-in-out infinite}
@keyframes ubreatheF{0%,100%{transform:scaleX(-1) translateY(0)}50%{transform:scaleX(-1) translateY(-3px) scale(1.015)}}
.bz .cell.acting .uart img {animation:lunge .34s !important}
.bz .cell.foe.acting .uart img {animation:lungeF .34s !important}
@keyframes lungeF{0%,100%{transform:scaleX(-1) translateY(0)}40%{transform:scaleX(-1) translateY(-6px) scale(1.06)}}
.bz .cell.struck {animation:knock .32s ease-out}
.bz .cell.foe.struck {animation:knockF .32s ease-out}
@keyframes knock{0%{transform:translateX(0)}25%{transform:translateX(9px)}55%{transform:translateX(-4px)}100%{transform:translateX(0)}}
@keyframes knockF{0%{transform:translateX(0)}25%{transform:translateX(-9px)}55%{transform:translateX(4px)}100%{transform:translateX(0)}}
.bz .cell.struck .uart img {filter:brightness(2.6) drop-shadow(0 0 9px #fff) !important}
.bz .float.big {font-size:24px}
.bz .float.crit {color:#ffd24a;font-size:26px;text-shadow:0 0 8px #ff6b4a}
.bz /* skill cut-in banner */
  .cutin {position:absolute;left:0;right:0;top:34%;height:80px;pointer-events:none;z-index:30;
    display:flex;align-items:center;justify-content:center;opacity:0}
.bz .cutin.go {animation:cutin 1.1s ease-out}
@keyframes cutin{0%{opacity:0;transform:translateX(-70px)}13%{opacity:1;transform:translateX(0)}80%{opacity:1;transform:translateX(0)}100%{opacity:0;transform:translateX(70px)}}
.bz .cutin .ci-bar {display:flex;align-items:center;gap:14px;padding:10px 30px 10px 14px;transform:skewX(-9deg);
    background:linear-gradient(90deg,#000d,#000a 60%,transparent);border-left:6px solid var(--ci,var(--gold));
    box-shadow:0 8px 28px #000b}
.bz .cutin .ci-bar > * {transform:skewX(9deg)}
.bz /* ── 行動 face-shot 橫幅（每次出手：臉+三骰彩色數字）── */
  .actchip {position:absolute;left:50%;top:6px;transform:translateX(-50%);z-index:32;pointer-events:none;opacity:0;
    display:flex;align-items:center;gap:10px;padding:6px 14px 6px 6px;border-radius:40px;
    background:linear-gradient(90deg,#1b1530ee,#2a2150cc);border:2px solid var(--ac,#ffd24a);box-shadow:0 4px 18px #000a}
.bz .actchip.go {animation:actpop 1.05s ease-out}
@keyframes actpop{0%{opacity:0;transform:translateX(-50%) translateY(-14px) scale(.9)}14%{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}82%{opacity:1}100%{opacity:0;transform:translateX(-50%) translateY(-8px)}}
.bz .actchip .ac-face {width:46px;height:46px;border-radius:50%;overflow:hidden;border:2px solid var(--ac,#ffd24a);
    background:#0006;display:flex;align-items:center;justify-content:center;flex:none}
.bz .actchip .ac-face img {height:150%;object-fit:contain}
.bz .actchip .ac-face span {font-size:30px}
.bz .actchip .ac-name {font-weight:900;color:#fff;font-size:14px;margin-right:2px}
.bz .actchip .ac-die {font-weight:900;font-size:15px;border-radius:8px;padding:2px 8px;color:#fff}
.bz .actchip .ac-die.r {background:#c0341a}
.bz .actchip .ac-die.b {background:#1a5aa8}
.bz .actchip .ac-die.g {background:#2a8a3a}
.bz /* ── 行動者底光暈（ATB 滿發光的地面感）── */
  .cell.acting::after {content:'';position:absolute;left:50%;bottom:-2px;width:120%;height:42%;transform:translateX(-50%);
    border-radius:50%;background:radial-gradient(ellipse at center,var(--floor,#ffd24a99),transparent 70%);
    pointer-events:none;z-index:0;animation:floorpulse .9s ease-in-out infinite alternate}
.bz .cell.acting.ele-fire {--floor:#ff6b4abb}
.bz .cell.acting.ele-wood {--floor:#5ec97abb}
.bz .cell.acting.ele-water {--floor:#4aa8ffbb}
@keyframes floorpulse{from{opacity:.5}to{opacity:1}}
.bz /* ── 受擊十字光暈 ── */
  .crossglow {position:absolute;inset:0;pointer-events:none;z-index:18}
.bz .crossglow .cg-h {position:absolute;left:-30%;top:46%;width:160%;height:8%;transform:translateY(-50%);
    background:linear-gradient(90deg,transparent,var(--cg,#fff),transparent);filter:blur(1px)}
.bz .crossglow .cg-v {position:absolute;top:-30%;left:46%;height:160%;width:8%;transform:translateX(-50%);
    background:linear-gradient(180deg,transparent,var(--cg,#fff),transparent);filter:blur(1px)}
.bz .crossglow.go {animation:cgflash .42s ease-out forwards}
@keyframes cgflash{0%{opacity:0;transform:scale(.6)}30%{opacity:1;transform:scale(1)}100%{opacity:0;transform:scale(1.15)}}
.bz /* ── 理智靈氣（外圈光環，顏色隨理智分級）── */
  .sanaura {position:absolute;inset:6px;border-radius:18px;pointer-events:none;z-index:0;opacity:.0;transition:box-shadow .3s,opacity .3s}
.bz .cell.filled .sanaura {opacity:1}
.bz .sanaura.san-hi {box-shadow:0 0 14px 2px #46d07a99, inset 0 0 10px #46d07a55}
.bz .sanaura.san-mid {box-shadow:0 0 12px 2px #e8c33a88, inset 0 0 8px #e8c33a44}
.bz .sanaura.san-low {box-shadow:0 0 14px 2px #e0653eaa, inset 0 0 10px #e0653e55;animation:sanflick .7s infinite alternate}
.bz .sanaura.san-vuln {box-shadow:0 0 20px 4px #a04ad0dd, inset 0 0 14px #a04ad088;animation:sanflick .4s infinite alternate}
@keyframes sanflick{from{opacity:.55}to{opacity:1}}
.bz /* ─── 規則速查 modal ─── */
  .rmodal {position:fixed;inset:0;background:#000c;z-index:120;display:none;align-items:flex-start;justify-content:center;
    overflow-y:auto;padding:18px;backdrop-filter:blur(2px)}
.bz .rmodal.show {display:flex}
.bz .rmodal .rbox {background:linear-gradient(180deg,#241936,#16102a);border:2px solid var(--gold);
    border-radius:18px;max-width:720px;width:100%;padding:18px 18px 22px;color:#eee;
    box-shadow:0 16px 40px #000c;position:relative}
.bz .rmodal .rh {display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #fff2;padding-bottom:8px;margin-bottom:12px}
.bz .rmodal .rh h2 {margin:0;color:var(--gold);font-size:22px}
.bz .rmodal .rx {background:#0006;border:1px solid #fff3;color:#fff;width:32px;height:32px;border-radius:50%;
    cursor:pointer;font-size:18px;line-height:1}
.bz .rmodal section {margin:14px 0 4px}
.bz .rmodal h3 {color:#ffd24a;font-size:15px;margin:0 0 8px;letter-spacing:.5px}
.bz .rmodal p {margin:4px 0;font-size:13px;line-height:1.55;color:#ddd}
.bz .rmodal .tip {background:#fff1;border-left:3px solid var(--gold);padding:6px 10px;border-radius:0 6px 6px 0;
    font-size:12px;color:#ffe9b5;margin-top:6px}
.bz .rmodal .warn {background:#a4504a40;border-left:3px solid #e0483c;padding:6px 10px;border-radius:0 6px 6px 0;
    font-size:12px;color:#ffb6ac;margin-top:6px}
.bz /* 五行三圓相剋圖 */
  .relmt {display:flex;align-items:center;gap:14px;flex-wrap:wrap;justify-content:center;margin:8px 0}
.bz .relmt .e {display:flex;flex-direction:column;align-items:center;gap:3px;min-width:62px}
.bz .relmt .eb {width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;
    font-size:22px;font-weight:900;color:#fff;text-shadow:0 1px 2px #0008;box-shadow:0 0 12px var(--c)}
.bz .relmt .e.fire {--c:#ff5d3a}
.bz .relmt .e.fire .eb {background:linear-gradient(160deg,#ff8d3a,#c0271a)}
.bz .relmt .e.wood {--c:#5ec06a}
.bz .relmt .e.wood .eb {background:linear-gradient(160deg,#7be07a,#1f8a3b)}
.bz .relmt .e.water {--c:#3ea8e0}
.bz .relmt .e.water .eb {background:linear-gradient(160deg,#6ed3ff,#1e6db0)}
.bz .relmt .en {font-size:11px;color:#ccc}
.bz .relmt .ev {font-size:13px;font-weight:900}
.bz .relmt .arr {font-size:18px;color:#ffd24a;font-weight:900}
.bz /* 兵種剋制鏈 */
  .pchain {display:flex;flex-wrap:wrap;gap:6px;align-items:center;justify-content:center;margin:8px 0;font-size:13px}
.bz .pchain .pp {padding:4px 10px;background:#2a2042;border:1px solid #6a548e;border-radius:8px;color:#cce}
.bz .pchain .pp.solo {background:#1a1530;border-color:#444;color:#999;font-size:12px}
.bz .pchain .arr {color:#ffd24a;font-weight:900}
.bz /* 基礎值表 */
  .rtbl {width:100%;border-collapse:collapse;font-size:12px;margin-top:4px}
.bz .rtbl th, .bz .rtbl td {padding:5px 6px;text-align:center;border-bottom:1px solid #fff2}
.bz .rtbl th {color:#ffd24a;font-weight:700}
.bz .rtbl td.pl {text-align:left;color:#bbb}
.bz /* 戰術提示 */
  .rstrat li {font-size:12.5px;line-height:1.7;color:#ddd;margin:0 0 4px 16px}
.bz .rstrat li b {color:#ffd24a}
.bz .cutin .ci-emoji {font-size:44px;filter:drop-shadow(0 2px 3px #000)}
.bz .cutin img.ci-port {height:58px;filter:drop-shadow(0 2px 4px #000)}
.bz .cutin .ci-name {font-size:27px;font-weight:900;letter-spacing:3px;color:#fff;text-shadow:0 0 12px var(--ci,#ffd24a)}
.bz .cutin .ci-sub {font-size:12px;color:#d9cffaee;display:block;margin-top:2px;font-weight:600}
.bz /* victory overlay */
  .overlay {position:fixed;inset:0;background:#0b0820cc;backdrop-filter:blur(4px);display:none;
    align-items:center;justify-content:center;z-index:50}
.bz .overlay.show {display:flex}
.bz .ovbox {background:linear-gradient(180deg,#2c2350,#1a1430);border:2px solid var(--gold);border-radius:20px;
    padding:30px 40px;text-align:center;max-width:420px;box-shadow:0 20px 60px #000a}
.bz .ovbox h2 {font-size:34px;margin:0 0 6px}
