:root{
  --bg:#071713;--bg2:#102a24;--panel:rgba(13,38,32,.88);--panel2:rgba(20,53,44,.92);
  --ink:#f3f0dc;--muted:#a9bdad;--jade:#78d6ae;--jade2:#34a77a;--gold:#e4c172;
  --danger:#dd776e;--shadow:0 18px 52px rgba(0,0,0,.38);--radius:22px;
  --lin:#67c98d;--wen:#7eafdf;--cang:#a789d8;--yin:#e48ab7;--shi:#a9afba;--jin:#d7ae58;
}
*{box-sizing:border-box}html,body{margin:0;min-height:100%;background:radial-gradient(circle at 50% -10%,#194b3e 0,#081a16 46%,#040e0c 100%);color:var(--ink);font-family:"Noto Serif SC","Songti SC","STSong",serif;overflow-x:hidden}
body{min-height:100dvh}button,input{font:inherit}button{cursor:pointer}
#mist-layer{position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.38;background:
radial-gradient(ellipse at 5% 18%,rgba(173,231,208,.12),transparent 38%),
radial-gradient(ellipse at 90% 72%,rgba(173,231,208,.09),transparent 35%);animation:mist 14s ease-in-out infinite alternate}
@keyframes mist{to{transform:translate3d(2.5%,-1%,0) scale(1.03);opacity:.52}}
#app{position:relative;z-index:1;min-height:100dvh;max-width:680px;margin:auto;padding:env(safe-area-inset-top) 14px calc(86px + env(safe-area-inset-bottom))}
.screen{min-height:calc(100dvh - 20px);display:flex;flex-direction:column;gap:14px;padding-top:14px}
.center{align-items:center;justify-content:center;text-align:center}
.hero-logo{width:min(84vw,420px);filter:drop-shadow(0 18px 30px rgba(0,0,0,.36));animation:float 5s ease-in-out infinite}
@keyframes float{50%{transform:translateY(-8px)}}
.kicker{letter-spacing:.3em;color:var(--gold);font-size:.82rem}.title{font-size:clamp(2rem,8vw,3.8rem);margin:.15em 0;text-shadow:0 3px 18px #000}.subtitle{color:var(--muted);line-height:1.8;max-width:520px}
.card,.panel{background:linear-gradient(155deg,rgba(28,66,55,.94),rgba(8,29,24,.94));border:1px solid rgba(215,231,215,.13);box-shadow:var(--shadow);border-radius:var(--radius);backdrop-filter:blur(14px)}
.panel{padding:18px}.card{padding:14px}
.btn{border:0;border-radius:999px;padding:13px 21px;color:#082018;background:linear-gradient(135deg,#e9d68c,#7bd4ad);box-shadow:0 8px 24px rgba(78,191,146,.24);font-weight:800;transition:.18s transform,.18s filter}
.btn:hover{transform:translateY(-2px);filter:brightness(1.06)}.btn:active{transform:translateY(1px)}
.btn.secondary{color:var(--ink);background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);box-shadow:none}
.btn.danger{background:linear-gradient(135deg,#f2a19a,#c85750);color:#2b0908}.btn.small{padding:8px 13px;font-size:.86rem}.btn:disabled{opacity:.42;cursor:not-allowed;transform:none}
.actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.topbar{display:flex;align-items:center;justify-content:space-between;gap:10px}
.topbar h1{font-size:1.35rem;margin:0}.icon-btn{width:42px;height:42px;border-radius:50%;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);color:var(--ink)}
.resource-row{display:grid;grid-template-columns:repeat(4,1fr);gap:7px}.resource{padding:8px 6px;border-radius:14px;background:rgba(255,255,255,.055);text-align:center}.resource b{display:block;font-size:1.04rem}.resource small{color:var(--muted);font-size:.68rem}
.home-hero{position:relative;min-height:250px;overflow:hidden;padding:0}.home-hero .forest{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.62}.home-hero .hero-copy{position:absolute;inset:auto 16px 14px;z-index:2}.home-hero h2{font-size:1.7rem;margin:.2em 0}.baize-home{position:absolute;right:-10px;bottom:-16px;width:185px;z-index:1;filter:drop-shadow(0 8px 25px rgba(0,0,0,.55))}
.progress-track{height:8px;border-radius:99px;background:rgba(255,255,255,.09);overflow:hidden}.progress-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--jade2),var(--gold))}
.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:11px}.menu-tile{min-height:112px;text-align:left;border:1px solid rgba(255,255,255,.11);border-radius:18px;padding:14px;color:var(--ink);background:linear-gradient(145deg,rgba(255,255,255,.075),rgba(255,255,255,.025));position:relative;overflow:hidden}
.menu-tile span{font-size:1.7rem;display:block;margin-bottom:8px}.menu-tile b{font-size:1.08rem}.menu-tile small{display:block;color:var(--muted);margin-top:4px}.menu-tile:after{content:"";position:absolute;width:90px;height:90px;border:1px solid rgba(255,255,255,.06);border-radius:50%;right:-30px;bottom:-36px}
.bottom-nav{position:fixed;z-index:50;left:50%;bottom:max(10px,env(safe-area-inset-bottom));transform:translateX(-50%);width:min(calc(100% - 22px),640px);display:grid;grid-template-columns:repeat(5,1fr);gap:4px;padding:8px;background:rgba(7,27,22,.94);border:1px solid rgba(255,255,255,.12);border-radius:22px;box-shadow:0 12px 50px rgba(0,0,0,.5);backdrop-filter:blur(16px)}
.bottom-nav button{border:0;background:transparent;color:var(--muted);padding:7px 3px;border-radius:13px;font-size:.72rem}.bottom-nav button b{display:block;font-size:1.25rem;margin-bottom:2px}.bottom-nav button.active{color:var(--ink);background:rgba(110,204,164,.13)}
.story-stage{flex:1;position:relative;min-height:520px;overflow:hidden}.story-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.65}.story-shade{position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(3,12,10,.9) 86%)}.dialogue{position:absolute;left:12px;right:12px;bottom:12px;padding:18px;border-radius:20px;background:rgba(7,24,20,.92);border:1px solid rgba(255,255,255,.12);box-shadow:0 16px 40px #000}.speaker{color:var(--gold);font-weight:800;letter-spacing:.12em}.dialogue-text{font-size:1.08rem;line-height:1.85;min-height:74px}.dialogue-next{float:right}
.clue-stage{position:relative;min-height:520px;overflow:hidden}.clue-stage>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.76}.clue{position:absolute;width:58px;height:58px;border-radius:50%;border:2px solid rgba(255,235,164,.85);background:rgba(229,197,104,.18);box-shadow:0 0 0 8px rgba(229,197,104,.07),0 0 24px rgba(229,197,104,.42);animation:pulse 1.6s infinite}
.clue.done{background:rgba(89,190,142,.35);border-color:var(--jade);animation:none}.clue:nth-of-type(1){left:19%;top:27%}.clue:nth-of-type(2){right:16%;top:43%}.clue:nth-of-type(3){left:42%;bottom:17%}@keyframes pulse{50%{transform:scale(1.12)}}
.battle-enemy{text-align:center;padding:12px;position:relative}.enemy-orb{width:122px;height:122px;border-radius:50%;margin:8px auto;background:radial-gradient(circle at 40% 35%,#8b8e8b,#343a37 38%,#101714 72%);box-shadow:0 0 45px rgba(167,173,169,.2);display:grid;place-items:center;font-size:3rem;animation:enemy 3.6s ease-in-out infinite}@keyframes enemy{50%{transform:translateY(-5px) scale(1.03)}}
.boss .enemy-orb{background:radial-gradient(circle at 40% 35%,#a67c78,#49303a 42%,#130c11 73%);box-shadow:0 0 55px rgba(191,90,102,.25)}
.intent{display:inline-flex;gap:8px;align-items:center;padding:7px 12px;border-radius:99px;background:rgba(255,255,255,.065);color:var(--muted)}
.meter{margin:8px 0}.meter-head{display:flex;justify-content:space-between;font-size:.78rem;color:var(--muted);margin-bottom:5px}.meter-bar{height:12px;border-radius:99px;background:rgba(255,255,255,.08);overflow:hidden}.meter-bar i{display:block;height:100%;border-radius:inherit;transition:width .3s}.harmony i{background:linear-gradient(90deg,#4cb78a,#d8c16a)}.pollution i{background:linear-gradient(90deg,#6a4a58,#cf6968)}.stability i{background:linear-gradient(90deg,#7299be,#c8d8df)}
.hand{display:flex;gap:9px;overflow-x:auto;padding:7px 2px 16px;scroll-snap-type:x mandatory}.game-card{flex:0 0 142px;min-height:206px;border-radius:17px;border:1px solid rgba(255,255,255,.17);padding:11px;color:#0c1c17;position:relative;overflow:hidden;scroll-snap-align:center;box-shadow:0 10px 26px rgba(0,0,0,.3);transition:.18s transform,.18s filter;text-align:left}
.game-card:hover{transform:translateY(-6px)}.game-card:disabled{filter:grayscale(.7) brightness(.65);transform:none}.game-card .cost{position:absolute;right:9px;top:8px;width:29px;height:29px;border-radius:50%;display:grid;place-items:center;background:#0c241e;color:#fff;font-weight:900}.game-card h3{font-size:1rem;margin:32px 0 8px}.game-card p{font-size:.76rem;line-height:1.45}.game-card small{position:absolute;bottom:8px;left:10px;opacity:.7}
.rhythm-lin{background:linear-gradient(155deg,#d7f0d8,#72b98b)}.rhythm-wen{background:linear-gradient(155deg,#dbe9f8,#77a7d0)}.rhythm-cang{background:linear-gradient(155deg,#e7ddf3,#9b7dc1)}.rhythm-yin{background:linear-gradient(155deg,#f3dbe8,#cd75a1)}.rhythm-shi{background:linear-gradient(155deg,#e1e3e4,#929aa0)}.rhythm-jin{background:linear-gradient(155deg,#f0e4bd,#c89f4d)}.rhythm-baize{background:linear-gradient(155deg,#f2f5ec,#76c9ad)}.rhythm-corruption{background:linear-gradient(155deg,#cbc3c6,#5a4851);color:#fff}
.battle-actions{display:flex;gap:8px;justify-content:space-between;align-items:center}.combat-log{max-height:86px;overflow:auto;font-size:.76rem;line-height:1.55;color:var(--muted);padding:9px;background:rgba(0,0,0,.18);border-radius:12px}
.album-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.album-grid .game-card{width:100%;min-height:190px;flex:auto}.filters{display:flex;gap:7px;overflow:auto;padding-bottom:4px}.chip{border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.055);color:var(--muted);border-radius:99px;padding:7px 11px;white-space:nowrap}.chip.active{background:rgba(118,208,169,.18);color:var(--ink);border-color:rgba(118,208,169,.35)}
.deck-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid rgba(255,255,255,.08)}.deck-row:last-child{border-bottom:0}.deck-row .mini{width:42px;height:56px;border-radius:8px;display:grid;place-items:center;color:#14221e;font-weight:900}.deck-row .grow{flex:1}.counter{display:flex;align-items:center;gap:8px}.counter button{width:30px;height:30px;border-radius:50%;border:1px solid rgba(255,255,255,.13);background:rgba(255,255,255,.07);color:#fff}
.stone-wheel{aspect-ratio:1;position:relative;border-radius:50%;margin:12px auto;max-width:420px;background:radial-gradient(circle,#183e34 0 26%,rgba(15,45,37,.9) 27% 46%,rgba(255,255,255,.05) 47% 48%,transparent 49%);border:1px solid rgba(255,255,255,.12)}
.stone{position:absolute;width:76px;height:76px;border-radius:50%;display:grid;place-items:center;text-align:center;background:#172b26;border:1px solid rgba(255,255,255,.14);color:var(--muted);transform:translate(-50%,-50%)}.stone.lit{color:#102018;background:radial-gradient(circle,#f5e7a7,#62ca9b);box-shadow:0 0 28px rgba(102,207,157,.42)}.stone:nth-child(1){left:50%;top:9%}.stone:nth-child(2){left:85%;top:30%}.stone:nth-child(3){left:85%;top:70%}.stone:nth-child(4){left:50%;top:91%}.stone:nth-child(5){left:15%;top:70%}.stone:nth-child(6){left:15%;top:30%}
.identity-card{position:relative;overflow:hidden;min-height:440px;padding:24px;background:linear-gradient(160deg,#143a30,#071711);border:1px solid rgba(229,207,127,.35)}.identity-card:before{content:"";position:absolute;inset:10px;border:1px solid rgba(229,207,127,.22);border-radius:16px}.identity-card>*{position:relative}.seal{width:92px;height:92px;border:2px solid var(--gold);border-radius:50%;display:grid;place-items:center;margin:18px auto;color:var(--gold);font-size:2.4rem}.identity-card h2{text-align:center;font-size:2rem}.identity-meta{text-align:center;color:var(--muted);line-height:1.8}
.baize-profile{text-align:center}.baize-profile img{width:230px;filter:drop-shadow(0 15px 20px rgba(0,0,0,.36))}.skill-grid{display:grid;gap:9px}.skill{display:flex;gap:12px;align-items:center;padding:11px;border-radius:15px;background:rgba(255,255,255,.055)}.skill .icon{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;background:rgba(114,208,167,.14);font-size:1.4rem}.skill.locked{opacity:.46}
.question{font-size:1.25rem;line-height:1.7;text-align:center;margin:22px 0}.answer-list{display:grid;gap:10px}.answer{border:1px solid rgba(255,255,255,.13);border-radius:17px;padding:14px;background:rgba(255,255,255,.055);color:var(--ink);text-align:left}.answer:hover{border-color:rgba(119,213,173,.42);background:rgba(119,213,173,.11)}
.code-input{width:100%;padding:14px 16px;border-radius:14px;border:1px solid rgba(255,255,255,.15);background:rgba(0,0,0,.25);color:#fff;text-transform:uppercase;letter-spacing:.12em}.qr-view{width:100%;border-radius:18px;display:none;background:#000;min-height:240px}
.setting-row{display:flex;align-items:center;justify-content:space-between;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.08)}.switch{width:48px;height:28px;border-radius:99px;border:0;background:#354b44;padding:3px}.switch i{display:block;width:22px;height:22px;border-radius:50%;background:#fff;transition:.2s}.switch.on{background:var(--jade2)}.switch.on i{transform:translateX(20px)}
.badge{display:inline-flex;padding:4px 8px;border-radius:99px;background:rgba(228,193,114,.13);color:var(--gold);font-size:.72rem}.locked-overlay{opacity:.55;filter:grayscale(.55)}.complete{color:var(--jade)}.notice{border-left:3px solid var(--gold);padding:10px 12px;background:rgba(228,193,114,.08);border-radius:8px;color:#dfd8bd;line-height:1.6}
#toast{position:fixed;z-index:100;left:50%;top:24px;transform:translate(-50%,-150%);background:#f2e9c6;color:#13231e;padding:11px 17px;border-radius:99px;box-shadow:0 10px 32px rgba(0,0,0,.35);transition:.25s;max-width:90%;text-align:center}#toast.show{transform:translate(-50%,0)}
@media(min-width:560px){.grid{grid-template-columns:repeat(3,1fr)}.album-grid{grid-template-columns:repeat(3,1fr)}}
@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation:none!important;scroll-behavior:auto!important;transition:none!important}}

.chapter-card{padding:0;overflow:hidden}.chapter-cover{width:100%;height:165px;object-fit:cover;display:block;opacity:.72}.chapter-content{padding:16px}.chapter-content h2{margin:.4em 0}
.admin-shell{max-width:980px;margin:auto;padding:24px}.admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.json-editor{width:100%;min-height:430px;padding:14px;border-radius:15px;background:#06110f;color:#dfeadd;border:1px solid rgba(255,255,255,.15);font:13px/1.55 ui-monospace,SFMono-Regular,Menlo,monospace;resize:vertical}
.admin-log{white-space:pre-wrap;min-height:90px;color:var(--muted)}a.btn{text-decoration:none;display:inline-block}
@media(max-width:760px){.admin-grid{grid-template-columns:1fr}.admin-shell{padding:14px}}


/* v1.8.0：白泽三阶段成长与回声天阶 */
.enemy-orb img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}
.baize-current{text-align:center;overflow:hidden;position:relative}
.baize-current:after{content:"";position:absolute;inset:auto -20% -45% 40%;height:260px;background:radial-gradient(circle,rgba(143,193,207,.24),transparent 70%);pointer-events:none}
.baize-stage-main{width:min(72vw,360px);max-height:360px;object-fit:contain;display:block;margin:4px auto 10px;filter:drop-shadow(0 18px 24px rgba(0,0,0,.35))}
.baize-stage-grid{display:grid;gap:12px}
.baize-stage-card{display:grid;grid-template-columns:140px 1fr;gap:14px;align-items:center;padding:12px;border-radius:18px;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.1);transition:.2s transform,.2s border-color,.2s background}
.baize-stage-card.active{border-color:rgba(228,193,114,.58);background:linear-gradient(135deg,rgba(228,193,114,.12),rgba(120,214,174,.08));transform:translateY(-2px)}
.baize-stage-card img{width:140px;height:150px;object-fit:contain;filter:drop-shadow(0 10px 14px rgba(0,0,0,.3))}
.baize-stage-card h3{margin:.45em 0}.baize-stage-card p{color:var(--muted);line-height:1.6;font-size:.86rem}
.cam{width:100%;min-height:210px;display:none;background:#020806;border-radius:18px;object-fit:cover;border:1px solid rgba(255,255,255,.12)}
.cam.active{display:block}
.echo-ring{position:absolute;inset:50% auto auto 50%;width:220px;height:220px;border:1px solid rgba(229,210,143,.25);border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;animation:echo-ring 2.8s ease-out infinite}
@keyframes echo-ring{0%{opacity:.7;transform:translate(-50%,-50%) scale(.45)}100%{opacity:0;transform:translate(-50%,-50%) scale(1.55)}}
@media(max-width:520px){
 .baize-stage-card{grid-template-columns:108px 1fr}
 .baize-stage-card img{width:108px;height:126px}
}

/* v1.8.0 六韵终章 */
.finale-panel{display:grid;grid-template-columns:150px 1fr;gap:18px;align-items:center;background:linear-gradient(135deg,rgba(231,211,155,.13),rgba(126,178,161,.08))}
.finale-panel img{width:150px;height:150px;object-fit:contain;filter:drop-shadow(0 12px 20px rgba(0,0,0,.35))}
@media(max-width:520px){.finale-panel{grid-template-columns:105px 1fr}.finale-panel img{width:105px;height:105px}}


/* v1.8.0 正式版本强化轮 */
.difficulty-row,.performance-options{display:flex;flex-wrap:wrap;gap:7px;margin:10px 0 6px}
.difficulty-chip{border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.045);color:var(--muted);border-radius:999px;padding:7px 11px;font:inherit;font-size:.76rem;cursor:pointer;min-height:36px}
.difficulty-chip.active{color:var(--ink);border-color:rgba(226,194,112,.62);background:linear-gradient(135deg,rgba(226,194,112,.2),rgba(119,190,164,.1));box-shadow:0 0 0 1px rgba(226,194,112,.08) inset}
.difficulty-chip:disabled{opacity:.42;cursor:not-allowed}
.difficulty-copy{display:block;min-height:2.8em;line-height:1.4;color:var(--muted)}
.difficulty-battle{position:absolute;right:12px;top:12px;font-size:.74rem;color:#f1dfab;background:rgba(7,15,18,.72);border:1px solid rgba(231,211,155,.28);padding:5px 8px;border-radius:999px}
.battle-help{display:block;margin-top:9px;text-align:center;color:var(--muted)}

.boss-transition-screen{min-height:100svh}
.boss-transition{position:relative;overflow:hidden;width:min(100%,620px);padding:30px 22px;text-align:center;isolation:isolate}
.boss-transition-rings{position:absolute;inset:50% auto auto 50%;width:420px;height:420px;border:2px solid rgba(231,211,155,.22);border-radius:50%;transform:translate(-50%,-50%);animation:boss-ring 2.2s ease-out infinite;z-index:-1}
.boss-transition-rings:after{content:"";position:absolute;inset:54px;border:1px dashed rgba(127,190,168,.36);border-radius:50%;animation:boss-spin 8s linear infinite}
.boss-transition-orb{width:150px;height:150px;margin:0 auto 16px;animation:boss-rise .75s cubic-bezier(.2,.8,.2,1)}
.boss-transition h1{font-size:clamp(1.8rem,7vw,3rem);margin:.55em 0 .35em}
.boss-transition p{max-width:36em;margin:0 auto 20px;color:var(--muted);line-height:1.8}
.boss-baize-action{width:210px;max-height:185px;object-fit:contain;display:block;margin:-20px auto 4px;filter:drop-shadow(0 16px 24px rgba(0,0,0,.4))}
@keyframes boss-ring{0%{opacity:.75;transform:translate(-50%,-50%) scale(.58)}100%{opacity:0;transform:translate(-50%,-50%) scale(1.25)}}
@keyframes boss-spin{to{transform:rotate(360deg)}}
@keyframes boss-rise{from{opacity:0;transform:translateY(25px) scale(.72)}to{opacity:1;transform:none}}

.card-fx{position:fixed;inset:0;z-index:90;pointer-events:none;display:grid;place-items:center;background:radial-gradient(circle,rgba(255,255,255,.08),transparent 55%);animation:fx-fade .62s ease-out forwards}
.card-fx-inner{width:min(68vw,280px);min-height:350px;border-radius:24px;border:1px solid rgba(255,255,255,.24);background:linear-gradient(160deg,rgba(21,49,42,.96),rgba(8,19,22,.97));box-shadow:0 30px 80px rgba(0,0,0,.6);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:24px;text-align:center;animation:card-cast .62s cubic-bezier(.2,.8,.2,1)}
.card-fx-inner>span{font-size:4rem}.card-fx-inner>b{font-size:1.45rem}.card-fx-inner>small{color:#f0dfaa;line-height:1.5}
.card-fx.rhythm-lin .card-fx-inner{box-shadow:0 30px 90px rgba(85,174,113,.28)}
.card-fx.rhythm-wen .card-fx-inner{box-shadow:0 30px 90px rgba(129,145,211,.28)}
.card-fx.rhythm-cang .card-fx-inner{box-shadow:0 30px 90px rgba(189,160,108,.28)}
.card-fx.rhythm-yin .card-fx-inner{box-shadow:0 30px 90px rgba(102,177,210,.28)}
.card-fx.rhythm-shi .card-fx-inner{box-shadow:0 30px 90px rgba(163,173,186,.28)}
.card-fx.rhythm-jin .card-fx-inner{box-shadow:0 30px 90px rgba(224,187,82,.32)}
@keyframes card-cast{0%{opacity:0;transform:translateY(90px) rotate(-5deg) scale(.7)}55%{opacity:1;transform:translateY(-8px) rotate(1deg) scale(1.04)}100%{opacity:0;transform:translateY(-70px) scale(.92)}}
@keyframes fx-fade{0%,65%{opacity:1}100%{opacity:0}}

.story-baize{position:absolute;right:-1%;bottom:112px;width:min(46%,330px);max-height:58%;object-fit:contain;z-index:2;filter:drop-shadow(0 18px 30px rgba(0,0,0,.5));opacity:.86;transform:translateY(4px);transition:.25s}
.story-baize.speaking{opacity:1;transform:translateY(0) scale(1.025)}
.baize-battle-companion{position:absolute;right:-18px;bottom:-28px;width:155px;height:142px;object-fit:contain;opacity:.9;filter:drop-shadow(0 12px 18px rgba(0,0,0,.48));pointer-events:none}
.baize-battle-companion.acting{animation:baize-action .7s cubic-bezier(.2,.8,.2,1)}
@keyframes baize-action{0%{transform:translateY(18px) scale(.82);opacity:.3}45%{transform:translateY(-10px) scale(1.08);opacity:1}100%{transform:none}}
.result-baize{width:220px;max-height:230px;object-fit:contain;filter:drop-shadow(0 16px 24px rgba(0,0,0,.4))}
.baize-expression-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px}
.baize-expression-grid article{padding:10px;border:1px solid rgba(255,255,255,.09);border-radius:16px;background:rgba(255,255,255,.035);text-align:center;content-visibility:auto;contain-intrinsic-size:170px}
.baize-expression-grid img{width:100%;height:145px;object-fit:contain;display:block}
.baize-expression-grid b{font-size:.82rem}

.sync-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:12px 0}
.sync-grid>div{padding:10px;border-radius:13px;background:rgba(255,255,255,.04);display:flex;flex-direction:column;gap:5px}
.sync-grid b{font-size:.85rem;overflow-wrap:anywhere}.sync-grid small{color:var(--muted)}
.save-conflict{border:1px solid rgba(230,167,99,.36);background:rgba(126,63,31,.13);padding:14px;border-radius:16px;margin:12px 0}
.notice.warning{border-color:rgba(230,167,99,.36);background:rgba(126,63,31,.13)}
.sync-synced{color:#9cd8b1}.sync-conflict,.sync-offline{color:#f0b08c}.sync-syncing,.sync-checking,.sync-pending{color:#ecd790}

/* Mobile performance and layout containment */
.chapter-card,.deck-row,.game-card,.baize-stage-card{contain:layout paint}
.chapter-card,.deck-row{content-visibility:auto;contain-intrinsic-size:280px}
.hand-wrap{overflow:hidden}
.hand{-webkit-overflow-scrolling:touch;scroll-snap-type:x proximity;overscroll-behavior-x:contain}
.game-card{scroll-snap-align:center;touch-action:manipulation}
img{max-width:100%}
.performance-saver .panel,.performance-saver .card{backdrop-filter:none!important;box-shadow:none!important}
.performance-saver .story-bg,.performance-saver .chapter-cover{filter:none!important}
.performance-saver .baize-home,.performance-saver .story-baize,.performance-saver .baize-battle-companion{filter:none!important}
.performance-saver .boss-transition-rings,.performance-saver .card-fx{display:none!important}
.performance-saver *{text-shadow:none!important}
.card-animations-off .card-fx{display:none!important}

.reduce-motion *, .reduce-motion *:before, .reduce-motion *:after{
 animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important
}
@media(prefers-reduced-motion:reduce){
 *,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
}
@media(max-width:520px){
 .story-baize{width:52%;right:-8%;bottom:145px;max-height:46%}
 .baize-battle-companion{width:118px;height:112px;right:-12px;bottom:-18px}
 .card-fx-inner{min-height:310px}
 .boss-transition-orb{width:122px;height:122px}
 .sync-grid{grid-template-columns:1fr}
 .difficulty-row{gap:5px}.difficulty-chip{padding:6px 9px}
}


/* v1.8.0 可运营性与无障碍强化轮 */
.sr-only{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}
.skip-link{position:fixed;left:12px;top:8px;z-index:9999;padding:10px 14px;border-radius:10px;background:#fff;color:#000;font-weight:800;transform:translateY(-160%);transition:transform .15s}
.skip-link:focus{transform:translateY(0)}
:where(button,a,input,select,textarea,[tabindex]):focus-visible{outline:3px solid #ffe36e;outline-offset:3px;box-shadow:0 0 0 5px rgba(0,0,0,.72)}
input,select,textarea{max-width:100%;min-height:44px;border-radius:11px;border:1px solid rgba(255,255,255,.2);background:rgba(0,0,0,.22);color:var(--ink);padding:10px 12px}
label{display:flex;flex-direction:column;gap:7px;color:var(--ink)}
label small{color:var(--muted)}
button,.btn,.icon-btn,.difficulty-chip,.chip{min-height:44px}
.bottom-nav button{min-height:52px}
.dialog-overlay{position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.76);display:grid;place-items:center;padding:18px}
.keyboard-help{width:min(100%,560px);max-height:90dvh;overflow:auto}
.shortcut-list{display:grid;gap:8px}
.shortcut-list>div{display:grid;grid-template-columns:minmax(120px,1fr) 1.5fr;gap:12px;padding:9px;border-bottom:1px solid rgba(255,255,255,.1)}
.shortcut-list dt{font-weight:800;color:var(--gold)}.shortcut-list dd{margin:0;color:var(--muted)}
.file-button{position:relative;overflow:hidden;display:inline-flex;align-items:center}
.file-button input{position:absolute;inset:0;opacity:0;cursor:pointer}
.account-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.account-grid form{display:flex;flex-direction:column;gap:14px}
.account-summary dl{display:grid;gap:8px;margin:0 0 16px}
.account-summary dl>div{display:grid;grid-template-columns:120px 1fr;gap:12px;padding:9px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.account-summary dt{color:var(--muted)}.account-summary dd{margin:0;overflow-wrap:anywhere}
.weekly-task{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.weekly-task:last-child{border-bottom:0}.weekly-task.complete b{color:#baf0c9}
.weekly-task .mini{width:48px;height:54px;border-radius:12px;display:grid;place-items:center;color:#15231e;font-weight:900;flex:0 0 auto}
.weekly-task .grow{min-width:0;flex:1}.weekly-task small{display:block;color:var(--muted);margin:4px 0 8px}
.badge-list{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.table-scroll{overflow:auto;-webkit-overflow-scrolling:touch;border-radius:14px}
.leaderboard-table{width:100%;border-collapse:collapse;min-width:480px}
.leaderboard-table caption{text-align:left;font-weight:800;padding:8px 0}
.leaderboard-table th,.leaderboard-table td{padding:10px 8px;text-align:left;border-bottom:1px solid rgba(255,255,255,.09)}
.leaderboard-table thead th{color:var(--gold);font-size:.78rem}
.leaderboard-table .current-player{background:rgba(120,214,174,.12)}
.sync-auth-required{color:#ffd37d}
[data-keyboard-group="true"]{scroll-margin:90px}
[aria-current="page"]{font-weight:900}
.high-contrast{
 --bg:#000;--bg2:#000;--panel:#000;--panel2:#000;--ink:#fff;--muted:#fff;
 --jade:#00ffb3;--jade2:#00ffb3;--gold:#ffe600;--danger:#ff6b6b;--shadow:none
}
.high-contrast body{background:#000}
.high-contrast #mist-layer{display:none}
.high-contrast .panel,.high-contrast .card,.high-contrast .bottom-nav,.high-contrast .dialogue{
 background:#000!important;border:2px solid #fff!important;box-shadow:none!important;backdrop-filter:none!important
}
.high-contrast .btn{background:#ffe600!important;color:#000!important;border:2px solid #fff!important}
.high-contrast .btn.secondary,.high-contrast .icon-btn,.high-contrast .chip,.high-contrast .difficulty-chip{
 background:#000!important;color:#fff!important;border:2px solid #fff!important
}
.high-contrast .btn.danger{background:#ff6b6b!important;color:#000!important}
.high-contrast .subtitle,.high-contrast small,.high-contrast .combat-log,.high-contrast .intent{color:#fff!important}
.high-contrast .progress-track,.high-contrast .meter-bar{background:#222!important;border:1px solid #fff}
.high-contrast .progress-fill,.high-contrast .meter-bar i{background:#ffe600!important}
.high-contrast .game-card{border:3px solid #000!important;color:#000!important}
.high-contrast .bottom-nav button.active{background:#ffe600!important;color:#000!important}
@media(forced-colors:active){
 :where(button,a,input,select,textarea,[tabindex]):focus-visible{outline:3px solid Highlight!important}
 .panel,.card,.bottom-nav,.dialogue{forced-color-adjust:auto;border:1px solid CanvasText}
 .progress-fill,.meter-bar i{background:Highlight!important}
}
@media(max-width:620px){
 .account-grid{grid-template-columns:1fr}
 .account-summary dl>div{grid-template-columns:1fr;gap:4px}
 .shortcut-list>div{grid-template-columns:1fr;gap:4px}
}
@media(max-width:390px){
 #app{padding-left:9px;padding-right:9px}
 .grid{gap:8px}.menu-tile{min-height:104px;padding:11px}
 .resource-row{grid-template-columns:repeat(2,1fr)}
 .bottom-nav{width:calc(100% - 12px);padding:6px}
 .bottom-nav button{font-size:.66rem}
}


/* v1.8.0 公开运营安全、隐私与实体设备验收 */
.security-strip,.challenge-security-list{display:flex;flex-wrap:wrap;gap:7px;margin:12px 0}
.security-strip span,.challenge-security-list span{border:1px solid rgba(137,224,188,.32);background:rgba(91,177,139,.1);border-radius:999px;padding:6px 10px;font-size:.75rem;color:#c9f5dd}
.challenge-gate{width:min(100%,620px);text-align:center}
.challenge-gate .challenge-security-list{justify-content:center}
.badge.verified{color:#baf0c9;border-color:rgba(108,219,151,.45)}
.badge.unverified{color:#ffd37d;border-color:rgba(255,211,125,.45)}
.security-form,.danger-zone{display:flex;flex-direction:column;gap:14px}
.danger-zone{border-color:rgba(255,107,107,.42)!important;background:linear-gradient(145deg,rgba(96,20,24,.17),rgba(10,20,20,.9))!important}
.consent-row{display:flex!important;flex-direction:row!important;align-items:flex-start;gap:10px}
.consent-row input{min-height:22px;width:22px;flex:0 0 auto;margin-top:2px}
.moderation-dialog{width:min(100%,560px);display:flex;flex-direction:column;gap:14px}
.report-entry{min-height:36px}
.danger-chip{border-color:rgba(255,107,107,.5)!important;color:#ffc1c1!important}
.policy-page{max-width:900px}
.policy-page h2{margin-top:0}.policy-page li{margin:.55em 0;line-height:1.65}
.policy-page code{padding:.15em .35em;border-radius:6px;background:rgba(255,255,255,.08);overflow-wrap:anywhere}
.qa-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:13px}
.qa-task{border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:12px;margin:0 0 10px}
.qa-task legend{font-weight:800;padding:0 6px;line-height:1.5}
.qa-task>label:not(:last-child){display:inline-flex;flex-direction:row;align-items:center;margin:6px 12px 8px 0}
.qa-task input[type=radio]{width:20px;min-height:20px}
.qa-task>label:last-child{margin-top:7px}
.admin-screen{max-width:1180px}.admin-list{display:grid;gap:8px}
.admin-item{display:grid;gap:6px;padding:10px;border:1px solid rgba(255,255,255,.1);border-radius:12px;background:rgba(255,255,255,.035)}
.admin-item small{color:var(--muted)}.admin-item code{overflow-wrap:anywhere;font-size:.72rem}
.admin-item details{margin-top:4px}.admin-item summary{cursor:pointer;color:var(--gold)}
.high-contrast .security-strip span,.high-contrast .challenge-security-list span{border:2px solid #fff!important;background:#000!important;color:#fff!important}
.high-contrast .danger-zone{border:3px solid #ff6b6b!important;background:#000!important}
@media(max-width:620px){.qa-meta{grid-template-columns:1fr}.policy-page{padding-bottom:90px}}


/* v1.9.0 外部验收与生产基础设施 */
[hidden]{display:none!important}
.governance-panel details{margin-top:12px}
.governance-panel summary{cursor:pointer;color:var(--gold);font-weight:800}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:12px}
.acceptance-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.acceptance-card strong{display:block;font-size:1.3rem;margin:12px 0;color:var(--gold)}
.acceptance-card.complete{border-color:rgba(108,219,151,.45)!important}
.acceptance-card.pending{border-color:rgba(255,211,125,.35)!important}
.admin-screen pre.admin-log{white-space:pre-wrap;overflow:auto;max-height:420px}
.admin-screen [data-permission]{scroll-margin-top:20px}
.admin-screen .leaderboard-table button{white-space:nowrap}
.admin-screen textarea.json-editor{min-height:360px}
.admin-screen .form-grid input{width:100%}
.qa-submit-panel{border-color:rgba(137,224,188,.28)}
.high-contrast .acceptance-card.complete,.high-contrast .acceptance-card.pending{border:2px solid #fff!important}
@media(max-width:720px){
 .acceptance-grid,.form-grid{grid-template-columns:1fr}
 .admin-screen .actions{align-items:stretch}
 .admin-screen .actions .btn,.admin-screen .actions button{flex:1 1 auto}
}

/* bzxyl-singlemodel v2.0.0 hook rebuild */
:root{--single-bg:#071610;--single-panel:rgba(255,255,255,.08);--single-panel-strong:rgba(255,255,255,.13);--single-text:#f6f0df;--single-muted:#cabf9a;--single-gold:#d8b45b;--single-green:#5fc89a;--single-red:#d96f57;--single-line:rgba(255,255,255,.18)}
body{background:radial-gradient(circle at 80% 0%,rgba(69,169,121,.24),transparent 34rem),radial-gradient(circle at 10% 10%,rgba(216,180,91,.18),transparent 28rem),linear-gradient(180deg,#071610 0%,#10271f 50%,#08120f 100%);color:var(--single-text)}
#mist-layer{opacity:.55;background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.08),transparent 20rem),radial-gradient(circle at 70% 60%,rgba(135,102,74,.14),transparent 18rem)}
.single-screen{min-height:100svh;padding:16px 16px 96px;max-width:980px;margin:0 auto}.single-hero{display:grid;grid-template-columns:1.05fr .95fr;gap:18px;align-items:center;overflow:hidden;min-height:420px}.single-hero h1,.single-top h1{font-size:clamp(2rem,7vw,4.5rem);line-height:1.08;letter-spacing:-.04em;margin:.25rem 0}.single-hero p,.panel p,.subtitle{font-size:1rem;line-height:1.8;color:var(--single-muted)}.hero-text{position:relative;z-index:2}.hero-figure{position:relative;min-height:360px;display:flex;justify-content:center;align-items:end}.hero-figure>img:first-child{max-height:440px;filter:drop-shadow(0 20px 42px rgba(0,0,0,.45));animation:singleFloat 6s ease-in-out infinite}.hero-badge{position:absolute;right:5%;bottom:18%;width:132px;height:132px;border-radius:28px;border:1px solid var(--single-line);background:rgba(5,16,13,.72);box-shadow:0 20px 40px rgba(0,0,0,.32);object-fit:cover}.panel{background:linear-gradient(180deg,var(--single-panel-strong),var(--single-panel));border:1px solid var(--single-line);border-radius:26px;padding:18px;box-shadow:0 24px 72px rgba(0,0,0,.28);backdrop-filter:blur(18px)}.kicker{display:inline-flex;align-items:center;gap:.45rem;color:#ffe6a0;letter-spacing:.14em;text-transform:uppercase;font-weight:800;font-size:.76rem}.btn{border:0;border-radius:999px;background:linear-gradient(135deg,#f0cf72,#a87428);color:#190e07;font-weight:900;padding:.86rem 1.1rem;min-height:46px;box-shadow:0 16px 34px rgba(216,180,91,.22);cursor:pointer}.btn.secondary{background:rgba(255,255,255,.1);color:var(--single-text);border:1px solid var(--single-line);box-shadow:none}.btn.small{padding:.62rem .86rem;min-height:40px;font-size:.9rem}.actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.play-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:14px 0}.play-steps article{border-radius:22px;background:rgba(255,255,255,.07);border:1px solid var(--single-line);padding:16px}.play-steps b{display:grid;place-items:center;width:34px;height:34px;border-radius:50%;background:rgba(216,180,91,.18);color:#ffe6a0}.play-steps h3{margin:.7rem 0 .2rem}.play-steps p{margin:0;color:var(--single-muted);line-height:1.65}.result-strip{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;margin-bottom:14px}.result-strip img{width:82px;height:82px;border-radius:22px;object-fit:cover}.offline-call{margin-top:14px;background:linear-gradient(135deg,rgba(95,200,154,.12),rgba(216,180,91,.12))}.single-top{display:flex;gap:14px;align-items:flex-start;margin-bottom:14px}.icon-btn{display:grid;place-items:center;width:44px;height:44px;border-radius:50%;border:1px solid var(--single-line);background:rgba(255,255,255,.09);color:var(--single-text);font-size:1.25rem}.quiz-meter{height:10px;border-radius:999px;background:rgba(255,255,255,.1);overflow:hidden;margin:8px 0 16px}.quiz-meter i{display:block;height:100%;background:linear-gradient(90deg,#5fc89a,#d8b45b)}.answer-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.answer-card{display:flex;align-items:center;gap:12px;text-align:left;min-height:78px;border-radius:22px;border:1px solid var(--single-line);background:rgba(255,255,255,.08);color:var(--single-text);padding:14px;font-weight:800;line-height:1.5}.answer-card span{display:grid;place-items:center;width:42px;height:42px;border-radius:14px;background:color-mix(in srgb,var(--c) 26%,transparent);color:#fff}.result-hero,.trial-scene{display:grid;grid-template-columns:minmax(180px,320px) 1fr;gap:18px;align-items:center;border-color:color-mix(in srgb,var(--accent) 40%,rgba(255,255,255,.2))}.result-hero img,.trial-scene img{max-height:480px;max-width:100%;justify-self:center;filter:drop-shadow(0 22px 44px rgba(0,0,0,.42))}.seal{display:grid;place-items:center;width:54px;height:54px;border-radius:18px;background:color-mix(in srgb,var(--accent,#d8b45b) 36%,rgba(255,255,255,.08));border:1px solid color-mix(in srgb,var(--accent,#d8b45b) 60%,rgba(255,255,255,.2));font-weight:900;color:#fff}.single-progress{height:34px;border-radius:999px;background:rgba(255,255,255,.09);border:1px solid var(--single-line);overflow:hidden;position:relative;margin-bottom:14px}.single-progress i{height:100%;display:block;background:linear-gradient(90deg,#5fc89a,#d8b45b)}.single-progress span{position:absolute;inset:0;display:grid;place-items:center;font-weight:900;text-shadow:0 1px 2px rgba(0,0,0,.6)}.rhythm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.rhythm-card{position:relative;overflow:hidden;min-height:290px;border-radius:24px;border:1px solid color-mix(in srgb,var(--accent) 36%,rgba(255,255,255,.18));background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 18%,rgba(255,255,255,.08)),rgba(255,255,255,.06));padding:16px}.rhythm-card img{width:96px;height:96px;border-radius:26px;object-fit:cover;float:right;margin-left:10px}.rhythm-card.done:after{content:"已点亮";position:absolute;right:14px;top:14px;border-radius:999px;background:rgba(0,0,0,.42);padding:.3rem .6rem;color:#ffe6a0;font-size:.78rem}.choice-list{display:grid;gap:10px}.choice{display:flex;gap:12px;align-items:center;text-align:left;border-radius:18px;border:1px solid var(--single-line);background:rgba(255,255,255,.08);color:var(--single-text);padding:12px;font-weight:800}.choice b{display:grid;place-items:center;width:30px;height:30px;border-radius:50%;background:color-mix(in srgb,var(--accent) 32%,rgba(255,255,255,.08));color:#fff}.outcome{margin-top:14px}.archive-list{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.postshow input,.share-card+section textarea{width:100%;border-radius:16px;border:1px solid var(--single-line);background:rgba(255,255,255,.08);color:var(--single-text);padding:12px}.share-card{max-width:520px;margin:0 auto 14px;text-align:center;border-color:color-mix(in srgb,var(--accent) 40%,rgba(255,255,255,.2));background:radial-gradient(circle at top, color-mix(in srgb,var(--accent) 22%,transparent), transparent 20rem),linear-gradient(180deg,rgba(255,255,255,.14),rgba(255,255,255,.06))}.share-card img{width:140px;height:140px;border-radius:36px;object-fit:cover;border:1px solid var(--single-line);box-shadow:0 20px 42px rgba(0,0,0,.32)}.share-card h2{font-size:2.2rem;margin:.4rem 0}.notice{border-radius:18px;background:rgba(95,200,154,.12);border:1px solid rgba(95,200,154,.28);padding:12px;color:#dff7e9}.single-nav{position:fixed;left:50%;bottom:calc(12px + env(safe-area-inset-bottom));transform:translateX(-50%);width:min(640px,calc(100% - 18px));display:grid;grid-template-columns:repeat(5,1fr);gap:6px;padding:8px;border-radius:24px;background:rgba(5,16,13,.88);border:1px solid var(--single-line);backdrop-filter:blur(20px);z-index:30;box-shadow:0 20px 56px rgba(0,0,0,.45)}.single-nav button{border:0;border-radius:18px;background:transparent;color:var(--single-muted);padding:8px 6px;font-weight:800;min-height:52px;display:grid;gap:2px;place-items:center}.single-nav button.active{background:rgba(216,180,91,.18);color:#ffe6a0}.single-nav b{font-size:1.1rem}.single-nav span{font-size:.82rem}@keyframes singleFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}@media(max-width:760px){.single-screen{padding:12px 10px 92px}.single-hero,.result-hero,.trial-scene{grid-template-columns:1fr}.single-hero{min-height:auto}.single-hero h1,.single-top h1{font-size:clamp(1.85rem,10vw,3rem)}.hero-figure{min-height:260px}.hero-figure>img:first-child{max-height:300px}.hero-badge{width:96px;height:96px}.play-steps,.archive-list,.answer-grid,.rhythm-grid{grid-template-columns:1fr}.result-strip{grid-template-columns:auto 1fr}.result-strip .btn{grid-column:1/-1}.rhythm-card{min-height:220px}.single-nav{width:calc(100% - 10px);border-radius:20px}.single-nav button{font-size:.8rem}}@media(prefers-reduced-motion:reduce){*{animation:none!important;scroll-behavior:auto!important}}
