:root{color-scheme:dark;font-family:"Noto Serif SC","Source Han Serif SC",Microsoft YaHei UI,serif;color:#f2efe9;background:#09111f;--bg-panel: rgba(7, 13, 25, .72);--bg-panel-strong: rgba(6, 10, 19, .86);--line: rgba(207, 218, 236, .16);--gold: #d9ba73;--jade: #7ab6c9;--ink: #09111f;--cinnabar: #b94b4b;--text-dim: rgba(240, 244, 250, .72);--shadow: 0 24px 60px rgba(0, 0, 0, .35);--shadow-soft: 0 12px 40px rgba(0, 0, 0, .28)}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%;max-width:100%;overflow-x:hidden}body{background:#09111f;overflow-x:hidden}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed}.screen-frame{min-height:100vh;width:100%;overflow-x:hidden;background-size:cover;background-position:center}.screen-inner{min-height:100vh;width:100%;max-width:100%;padding:28px;display:flex;flex-direction:column;gap:20px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.rest-screen-frame .screen-inner,.main-menu-frame .screen-inner{-webkit-backdrop-filter:none;backdrop-filter:none}.loading-frame .screen-inner{align-items:center;justify-content:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.asset-loader{width:min(520px,calc(100vw - 40px));display:grid;justify-items:center;gap:28px}.asset-loader-logo{width:min(460px,76vw);max-height:34vh;object-fit:contain;filter:drop-shadow(0 22px 34px rgba(0,0,0,.42))}.asset-loader-body{width:100%;display:grid;gap:10px}.asset-loader-head{display:flex;justify-content:space-between;align-items:baseline;gap:16px;color:#f9f5e8e6;font-size:15px}.asset-loader-head strong{color:#f7d98d;font-size:22px}.asset-loader-track{width:100%;height:12px;overflow:hidden;border-radius:999px;border:1px solid rgba(245,239,220,.28);background:#0509129e;box-shadow:inset 0 0 12px #0000005c}.asset-loader-track span{display:block;height:100%;min-width:2px;border-radius:inherit;background:linear-gradient(90deg,#7ab6c9,#d9ba73);transition:width .18s ease}.asset-loader-body p{color:#f0f4faad;font-size:13px;text-align:right}.hero,.topbar,.map-grid,.class-grid,.reward-grid,.choice-grid,.hand-row{display:grid;gap:18px}.hero{min-height:calc(100vh - 56px);margin:0;grid-template-columns:1fr;grid-template-rows:minmax(320px,58vh) 1fr;justify-items:center;align-items:center;text-align:center}.hero-emblem{width:min(58vw,620px);max-height:43vh;object-fit:contain;justify-self:center;filter:drop-shadow(0 22px 34px rgba(0,0,0,.38))}.eyebrow{margin:0 0 8px;text-transform:uppercase;letter-spacing:.22em;color:var(--jade);font-size:12px}h1,h2,h3,p{margin:0}h1{font-size:clamp(42px,7vw,78px);line-height:1.04;font-weight:700}h2{font-size:clamp(28px,4vw,42px)}h3{font-size:22px}.hero-actions,.resource-strip,.relic-list,.map-atlas-head,.map-progress,.status-cluster,.stat-inline-grid,.combat-hud,.combat-hud-group,.status-inline-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.hero-actions{align-self:start;justify-content:center;margin-top:clamp(18px,5vh,72px)}.ink-start-btn{min-width:210px;padding:17px 42px 18px;border:1px solid rgba(245,239,220,.72);border-radius:999px;color:#f9f5e8;background:linear-gradient(90deg,#ffffff1f,#ffffff05,#ffffff1a),radial-gradient(circle at 26% 36%,rgba(255,255,255,.22),transparent 26%),#070c116b;box-shadow:inset 0 0 0 1px #090c1261,inset 0 -18px 32px #070c1142,0 18px 40px #00000057;font-family:STXingkai,KaiTi,FZKai-Z03,"Noto Serif SC",serif;font-size:28px;font-weight:700;letter-spacing:.24em;text-indent:.24em;text-shadow:0 1px 0 rgba(255,255,255,.18),0 3px 10px rgba(0,0,0,.76),2px 0 8px rgba(0,0,0,.32);transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease,background .2s ease}.ink-start-btn:hover{transform:translateY(-3px);border-color:#d9ba73e0;background:linear-gradient(90deg,#ffffff29,#ffffff09,#ffffff21),radial-gradient(circle at 26% 36%,rgba(255,255,255,.26),transparent 26%),#0a121680;box-shadow:inset 0 0 0 1px #d9ba732e,inset 0 -18px 32px #070c113d,0 24px 48px #00000061,0 0 28px #d9ba7329}.primary-btn,.secondary-btn,.choice-card,.node-card,.card-tile,.reward-card{border:1px solid var(--line);border-radius:22px;transition:transform .18s ease,border-color .18s ease,background .18s ease}.primary-btn,.secondary-btn{padding:14px 22px;background:#ffffff0f;color:#fff}.primary-btn{background:linear-gradient(135deg,#669bcb61,#bc995a3d);border-color:#d2ba7566}.secondary-btn.small{padding:10px 16px}.primary-btn:hover,.secondary-btn:hover,.choice-card:hover,.node-card:hover,.card-tile:hover,.reward-card:hover{transform:translateY(-2px);border-color:#daba7385}.primary-btn:disabled,.secondary-btn:disabled{opacity:.48;transform:none}.panel{background:var(--bg-panel);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);padding:20px}.topbar{grid-template-columns:1fr auto;align-items:center}.resource-strip span{padding:9px 14px;border-radius:999px;background:#ffffff0f;border:1px solid rgba(255,255,255,.09)}.resource-chip,.icon-chip,.vital-sep,.vital-block{display:inline-flex;align-items:center}.resource-chip,.icon-chip{gap:8px}.resource-chip img,.icon-chip img{width:24px;height:24px;object-fit:contain;filter:drop-shadow(0 4px 8px rgba(0,0,0,.28))}.map-grid{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));position:relative;z-index:1}.map-atlas{position:relative;overflow:hidden;width:min(980px,100%);align-self:center;padding:24px 28px 28px;background:radial-gradient(circle at top,rgba(126,177,202,.14),transparent 46%),linear-gradient(180deg,#0a1120e0,#070d18d1);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow)}.map-atlas-head{justify-content:space-between;margin-bottom:24px}.map-progress{justify-content:flex-end}.progress-step{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;border:1px solid rgba(255,255,255,.12);color:var(--text-dim);background:#ffffff0a}.progress-step.done{background:#7ab6c933;color:#fff}.progress-step.current{background:linear-gradient(135deg,#74b0cd57,#d9ba732e);color:#fff;border-color:#d9ba7357}.map-pathboard{position:relative;width:min(760px,100%);height:820px;margin:0 auto;padding:0}.path-node{position:absolute;width:112px;min-height:124px;padding:6px 4px;border:0;background:transparent;color:#f4f6fb;text-align:center;z-index:1;transform:translate(-50%,-50%);filter:drop-shadow(0 18px 24px rgba(0,0,0,.34))}.path-node.reachable{filter:drop-shadow(0 0 18px rgba(217,186,115,.28)) drop-shadow(0 18px 24px rgba(0,0,0,.36))}.path-node.visited{filter:drop-shadow(0 0 12px rgba(122,182,201,.2)) drop-shadow(0 18px 24px rgba(0,0,0,.32))}.path-node.dim{opacity:.42}.path-node-icon{display:inline-flex;width:78px;height:78px;align-items:center;justify-content:center;margin-bottom:6px}.path-node-icon img{width:100%;height:100%;object-fit:contain}.path-node strong{display:block;margin-bottom:2px;font-size:16px;text-shadow:0 2px 8px rgba(0,0,0,.85)}.path-node small{color:var(--text-dim);font-size:12px;text-shadow:0 2px 8px rgba(0,0,0,.85)}.map-links{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.map-link{fill:none;stroke:#ffffff14;stroke-width:5;stroke-linecap:round}.map-link.active{stroke:#d9ba7394}.map-layer-label{position:absolute;left:-78px;width:74px;color:var(--text-dim);font-size:13px;letter-spacing:.12em;text-transform:uppercase}.map-layer-label.active{color:#fff}.class-grid{width:min(100%,1500px);margin:0 auto;grid-template-columns:repeat(3,minmax(0,1fr));align-items:stretch}.class-card{overflow:hidden;display:grid;min-width:0;grid-template-rows:minmax(330px,46vh) auto;border-radius:24px;border:1px solid var(--line);background:linear-gradient(180deg,#090f1de6,#080c15e0);box-shadow:var(--shadow)}.class-azure{box-shadow:0 20px 60px #4a7ebc2e}.class-gold{box-shadow:0 20px 60px #c3984b29}.class-violet{box-shadow:0 20px 60px #796cb929}.class-art-wrap{display:flex;align-items:flex-end;justify-content:center;background:radial-gradient(circle at top,rgba(255,255,255,.18),transparent 60%),linear-gradient(180deg,#ffffff0f,#ffffff03);overflow:hidden;padding:18px 18px 0}.class-art{width:min(100%,360px);height:100%;object-fit:contain;object-position:center bottom}.class-body{min-width:0;padding:18px;display:grid;gap:14px}.class-copy{min-width:0;display:grid;gap:12px}.class-footer{display:grid;gap:14px;margin-top:auto}.class-detail{color:var(--text-dim);line-height:1.75}.class-stats{display:flex;gap:10px;flex-wrap:wrap}.class-stats span{padding:8px 12px;border-radius:999px;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);color:#eef2f9}.relic-chip-embedded{padding:10px;min-width:0;border-radius:18px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06)}.relic-chip-embedded p{display:-webkit-box;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2}.node-card{padding:22px 18px;text-align:left;color:#f7f7f2;background:linear-gradient(180deg,#09111ee0,#101724b8);min-height:160px;position:relative;box-shadow:var(--shadow-soft)}.node-card:before{content:"";position:absolute;inset:auto auto -16px 50%;width:2px;height:16px;background:linear-gradient(180deg,rgba(217,186,115,.4),transparent);transform:translate(-50%)}.node-label{display:inline-flex;width:42px;height:42px;align-items:center;justify-content:center;margin-bottom:12px;border-radius:50%;background:#d9ba7329;color:var(--gold);box-shadow:0 0 0 6px #ffffff08}.node-battle .node-label{background:#7eb1ca2e;color:#bfe3f2}.node-elite .node-label,.node-boss .node-label{background:#b94b4b2e;color:#ffd0d0}.node-rest .node-label{background:#83b6892e;color:#d6f2d5}.node-event .node-label{background:#aa8cc82e;color:#e9d7ff}.node-card strong{display:block;margin-bottom:8px;font-size:20px}.node-card.reachable{box-shadow:0 18px 42px #0000003d,0 0 0 1px #d9ba731a}.node-card.blocked{opacity:.36;cursor:not-allowed;filter:grayscale(.25)}.node-card small{color:var(--text-dim);line-height:1.6}.map-act-message{margin-top:8px;color:#ffe2a8;font-size:14px;line-height:1.5;text-shadow:0 2px 10px rgba(0,0,0,.45)}.relic-chip p{color:var(--text-dim);line-height:1.6}.battle-screen{min-height:100vh;justify-content:space-between;-webkit-backdrop-filter:none;backdrop-filter:none;--battle-card-width: 184px;--battle-card-margin: -92px;--battle-hand-height: 230px;--battle-hand-board-height: 210px;--battle-player-width: min(28vw, 360px);--battle-enemy-width: min(30vw, 430px);--battle-player-art-max: 45vh;--battle-enemy-art-max: 42vh}.battle-layout-fit{height:100vh;overflow:hidden;padding-bottom:0}.battle-layout-scroll{height:auto;overflow:visible;padding-bottom:28px}.battle-scale-compact{--battle-card-width: 166px;--battle-card-margin: -83px;--battle-hand-height: 208px;--battle-hand-board-height: 190px;--battle-player-width: min(25vw, 320px);--battle-enemy-width: min(27vw, 390px);--battle-player-art-max: 41vh;--battle-enemy-art-max: 39vh}.battle-scale-large{--battle-card-width: 204px;--battle-card-margin: -102px;--battle-hand-height: 268px;--battle-hand-board-height: 246px;--battle-player-width: min(32vw, 420px);--battle-enemy-width: min(34vw, 490px);--battle-player-art-max: 50vh;--battle-enemy-art-max: 48vh}.combat-hud{justify-content:space-between;position:relative;z-index:6}.combat-hud-group{gap:10px}.battle-layout-controls{margin-left:auto}.hud-chip{padding:10px 14px;border-radius:999px;background:#09111eb3;border:1px solid rgba(255,255,255,.08);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#edf3fa}.hud-chip.strong{border-color:#d9ba7357;background:linear-gradient(135deg,#5989b547,#d9ba7329)}.hud-segment{display:inline-flex;overflow:hidden;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:#070c17ad;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.hud-segment button{min-width:54px;padding:9px 12px;border:0;border-right:1px solid rgba(255,255,255,.08);background:transparent;color:#edf3fabd}.hud-segment button:last-child{border-right:0}.hud-segment button.active{color:#fff;background:linear-gradient(135deg,#7ab6c95c,#d9ba7338)}.hud-segment button:focus-visible{outline:2px solid rgba(217,186,115,.66);outline-offset:-2px}.battle-stage-shell{flex:1;display:flex;align-items:center;overflow:hidden;min-height:0}.battle-layout-scroll .battle-stage-shell{flex:0 0 auto;min-height:clamp(520px,62vh,760px);overflow:visible}.battle-stage{position:relative;width:100%;min-height:0;height:100%;border-radius:0;overflow:visible;background:transparent;box-shadow:none}.battle-layout-scroll .battle-stage{min-height:clamp(520px,62vh,760px)}.battle-stage-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 52% 62%,rgba(217,186,115,.06),transparent 16%),radial-gradient(circle at 28% 78%,rgba(122,182,201,.04),transparent 20%);pointer-events:none}.battle-ground{position:absolute;left:20%;right:14%;bottom:10%;height:22%;border-radius:50%;background:radial-gradient(circle,#d9ba7329,#08101c00 70%);filter:blur(10px)}.enemy-actor,.player-actor{position:absolute;display:flex;flex-direction:column;gap:14px}.enemy-actor{top:2%;right:16%;width:var(--battle-enemy-width);align-items:center;z-index:3}.player-actor{left:3%;bottom:4%;width:var(--battle-player-width);align-items:flex-start;z-index:2}.battle-actor-art{object-fit:contain;-webkit-user-select:none;user-select:none;pointer-events:none}.battle-actor-art.enemy{width:100%;max-height:var(--battle-enemy-art-max);object-position:center bottom;filter:drop-shadow(0 24px 48px rgba(0,0,0,.38))}.enemy-idle-sheet{aspect-ratio:640 / 896;background-repeat:no-repeat;background-size:400% 400%;background-position:0% 0%;animation:enemy-idle-4x4 1.85s steps(1,end) infinite;will-change:background-position}.enemy-idle-sheet-4x4{width:100%}.battle-actor-art.player{width:100%;max-height:var(--battle-player-art-max);filter:drop-shadow(0 18px 40px rgba(0,0,0,.34))}.player-idle-sheet{aspect-ratio:1 / 1;background-repeat:no-repeat;background-size:300% 300%;background-position:0% 0%;will-change:background-position}.player-idle-forward{animation:sheet-3x3-loop 1.05s steps(1,end) infinite}.player-idle-18{background-size:300% 600%;animation:sheet-3x6-18-play 1.85s steps(1,end) infinite}.player-idle-pingpong{animation:sheet-3x3-pingpong 1.75s steps(1,end) infinite}.actor-status{max-width:250px;padding:8px 10px;border-radius:14px;border:0;background:linear-gradient(90deg,rgba(5,9,17,.58),rgba(5,9,17,.18),transparent);-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:none;filter:drop-shadow(0 8px 16px rgba(0,0,0,.42))}.actor-status-player{margin-left:6px;margin-bottom:-8px}.actor-status-enemy{align-self:center;margin-bottom:6px;background:linear-gradient(90deg,transparent,rgba(5,9,17,.18),rgba(5,9,17,.58),rgba(5,9,17,.18),transparent)}.actor-status-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:8px}.actor-status-top h3{font-size:18px}.status-vitals{display:flex;align-items:baseline;gap:8px;margin-bottom:8px}.status-vitals strong{color:#fff;font-size:24px;line-height:1}.vital-sep,.vital-block{color:var(--text-dim);font-size:12px;letter-spacing:.12em;text-transform:uppercase;gap:5px}.vital-sep img,.vital-block img{width:16px;height:16px;object-fit:contain}.vital-block{margin-left:auto;padding:5px 8px;border-radius:999px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08)}.bar-track{width:100%;height:8px;border-radius:999px;background:#0509117a;overflow:hidden;box-shadow:0 1px #ffffff1a,0 5px 10px #0000002e}.bar-track.actor{margin-bottom:8px}.bar-fill{height:100%;border-radius:inherit}.bar-fill.hp{background:linear-gradient(90deg,#55a96f,#8ad5a3)}.bar-fill.enemy{background:linear-gradient(90deg,#b14949,#de8f8f)}.status-icon-row{display:flex;gap:6px;flex-wrap:wrap;min-height:28px}.status-icon{width:34px;height:34px;border-radius:999px;border:0;font-size:11px;line-height:1;position:relative;display:inline-flex;align-items:center;justify-content:center;overflow:visible;background:transparent;box-shadow:none;filter:drop-shadow(0 8px 10px rgba(0,0,0,.34))}.status-icon img{width:100%;height:100%;border-radius:inherit;object-fit:contain}.status-icon strong{position:absolute;right:-4px;bottom:-4px;min-width:16px;height:16px;padding:0 4px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#070c17eb;border:1px solid rgba(255,255,255,.16);color:#fff;font-size:10px;letter-spacing:0}.status-icon.good{color:#d7edf7}.status-icon.bad{color:#ffd4d4}.status-tooltip{position:absolute;left:50%;bottom:calc(100% + 10px);width:220px;padding:10px 12px;border-radius:12px;background:#070c17f5;border:1px solid rgba(217,186,115,.22);color:#edf3fa;font-size:12px;line-height:1.55;letter-spacing:0;opacity:0;pointer-events:none;transform:translate(-50%,6px);transition:opacity .16s ease,transform .16s ease;z-index:20;box-shadow:var(--shadow-soft)}.status-tooltip b{display:block;margin-bottom:4px;color:var(--gold)}.status-icon:hover .status-tooltip{opacity:1;transform:translate(-50%)}.intent-badge{max-width:200px;padding:8px 10px;border-radius:14px;background:#b94b4b33;border:1px solid rgba(185,75,75,.34);color:#ffe4e4;box-shadow:inset 0 1px #ffffff08;font-size:12px;white-space:normal}.battle-side-ui{position:absolute;bottom:8%;display:grid;gap:10px;z-index:10}.battle-side-ui.left{left:1.5%}.battle-side-ui.right{right:1.5%;justify-items:end;bottom:10%;pointer-events:none;z-index:18}.pile-orb{width:76px;min-height:76px;border-radius:20px;border:1px solid rgba(255,255,255,.08);background:#070c1775;-webkit-backdrop-filter:none;backdrop-filter:none;color:#f2f5fa;box-shadow:var(--shadow-soft)}.pile-orb{display:grid;place-items:center;padding:10px;text-align:center}.pile-orb img{width:34px;height:34px;object-fit:contain;filter:drop-shadow(0 8px 12px rgba(0,0,0,.26))}.pile-orb span{color:var(--text-dim);font-size:12px}.pile-orb strong{font-size:22px}.end-turn-btn{position:relative;width:158px;height:78px;min-height:78px;padding:0;font-size:17px;border:0;background:transparent;box-shadow:none;overflow:visible;color:#fff7dd;text-shadow:0 2px 8px rgba(0,0,0,.72),0 0 10px rgba(217,186,115,.38);transition:transform .2s ease,filter .2s ease;pointer-events:auto;z-index:19}.end-turn-btn img{position:absolute;top:-13%;right:-16%;bottom:-13%;left:-16%;width:132%;height:126%;object-fit:contain;pointer-events:none;filter:drop-shadow(0 18px 26px rgba(0,0,0,.38))}.end-turn-btn span{position:relative;z-index:1;display:inline-flex;align-items:center;justify-content:center;width:100%;height:100%;font-weight:800;letter-spacing:.08em}.end-turn-btn:hover:not(:disabled){transform:translateY(-2px);filter:brightness(1.08)}.end-turn-btn:disabled{opacity:.52;filter:grayscale(.3)}.relic-chip,.reward-relic,.mini-relic{display:flex;gap:12px;align-items:center}.relic-chip img,.reward-relic img,.mini-relic img{width:56px;height:56px;object-fit:cover;border-radius:18px}.mini-relic{padding:8px 0;border-bottom:1px solid rgba(255,255,255,.06)}.relic-mini-stack{display:grid;gap:8px;padding:10px 12px;border-radius:18px;background:#070c1761;border:1px solid rgba(255,255,255,.04);-webkit-backdrop-filter:none;backdrop-filter:none;min-width:156px;pointer-events:auto;max-height:min(190px,24vh);overflow-y:auto;scrollbar-width:thin}.relic-mini-stack.compact .mini-relic span{font-size:12px}.hand-fan-shell{position:relative;height:var(--battle-hand-height);min-height:var(--battle-hand-height);display:flex;align-items:flex-end;justify-content:center;padding-bottom:0}.energy-orb{position:absolute;left:10px;bottom:24px;width:110px;height:110px;border-radius:50%;display:grid;place-items:center;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.22),transparent 24%),linear-gradient(135deg,#4a80aad6,#1c4c75db);border:1px solid rgba(255,255,255,.14);box-shadow:0 20px 40px #00000047}.energy-orb img{width:42px;height:42px;object-fit:contain;margin-bottom:-18px;filter:drop-shadow(0 8px 14px rgba(0,0,0,.24))}.energy-orb strong{font-size:34px}.hand-fan{position:relative;width:min(980px,86vw);height:var(--battle-hand-board-height)}.battle-card,.reward-card,.choice-card{padding:14px;background:linear-gradient(180deg,#f5f7faf2,#e0e7efdb);color:#102033;text-align:left;box-shadow:0 10px 24px #0000002e}.reward-card{padding:0;border:0;border-radius:0;background:transparent;box-shadow:none;color:inherit}.rest-panel{width:min(1180px,calc(100vw - 56px));min-height:calc(100vh - 56px);margin:0 auto;display:grid;grid-template-rows:auto 1fr;align-content:stretch;padding:28px 0 34px}.rest-heading{width:fit-content;max-width:min(620px,92vw);padding:18px 22px 20px;border-radius:18px;background:linear-gradient(90deg,rgba(5,9,17,.58),rgba(5,9,17,.18),transparent);filter:drop-shadow(0 14px 24px rgba(0,0,0,.38))}.rest-heading h2{text-shadow:0 4px 18px rgba(0,0,0,.62)}.rest-choice-grid{grid-template-columns:repeat(2,minmax(280px,430px));align-self:end;justify-self:center;margin:0 0 clamp(12px,4vh,52px);gap:24px}.illustrated-choice-card{padding:0;overflow:hidden;display:grid;grid-template-rows:auto 1fr;border-radius:16px;border-color:#d9ba733d;background:#070c178a;color:#edf3fa;box-shadow:0 18px 46px #00000057}.illustrated-choice-card img{width:100%;aspect-ratio:16 / 10;object-fit:cover;display:block}.illustrated-choice-card span{display:grid;gap:8px;padding:16px 18px 18px}.illustrated-choice-card strong{font-size:22px;color:#fff6dc}.illustrated-choice-card p{color:var(--text-dim);line-height:1.65}.rest-upgrade-panel{background:#070c17ad}.event-panel{width:min(1040px,calc(100vw - 56px));margin:auto;display:grid;grid-template-columns:minmax(320px,1.05fr) minmax(280px,.95fr);gap:24px;align-items:stretch;background:#070c179e}.event-art-wrap{min-height:360px;border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,.08);background:#05091180}.event-art-wrap img{width:100%;height:100%;min-height:360px;object-fit:cover;display:block}.event-copy{display:flex;flex-direction:column;justify-content:center;gap:16px}.event-copy h2{color:#fff6dc}.event-copy p:not(.eyebrow){color:var(--text-dim);font-size:18px;line-height:1.8}.battle-card{position:absolute;left:50%;bottom:0;width:var(--battle-card-width);min-height:256px;margin-left:var(--battle-card-margin);padding:0;border:0;border-radius:0;cursor:pointer;transform-origin:center 125%;background:transparent;box-shadow:none}.battle-card.disabled{opacity:.52;cursor:not-allowed}.battle-card.ready{box-shadow:0 14px 28px #0003,0 0 0 1px #5a82ae0d}.battle-card.ready:after{content:"";position:absolute;inset:auto 28px 8px;height:3px;border-radius:999px;background:linear-gradient(90deg,#588ec200,#588ec28c,#588ec200)}.battle-card.hovered{box-shadow:0 24px 46px #00000042}.game-card{position:relative;width:100%;aspect-ratio:2 / 2.78;color:#122033;isolation:isolate;filter:drop-shadow(0 18px 22px rgba(0,0,0,.26))}.game-card-frame{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:fill;z-index:4;pointer-events:none}.game-card-surface{position:absolute;top:7.2%;right:8.2%;bottom:7.8%;left:8.2%;display:grid;grid-template-rows:32px auto 20px minmax(58px,1fr);gap:6px;padding:7px 7px 9px;border-radius:18px;background:linear-gradient(180deg,#f8fafcf5,#dee6efe6);overflow:hidden;z-index:1;border:1px solid rgba(68,82,96,.12);box-shadow:inset 0 0 22px #ffffff80}.game-card-surface:before,.game-card-surface:after{display:none}.game-card.rarity-common .game-card-surface{background:linear-gradient(180deg,#f9fafbf7,#e0e6eded)}.game-card.rarity-rare .game-card-surface{background:linear-gradient(180deg,#eff8fff5,#cde1f2e6)}.game-card.rarity-epic .game-card-surface{background:linear-gradient(180deg,#fff7e2f7,#e5d0a2eb)}.game-card-head,.game-card-meta{display:flex;align-items:center;justify-content:space-between;gap:8px}.game-card-head strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:15px;color:#14243a;text-shadow:0 1px 0 rgba(255,255,255,.45)}.game-card-cost{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;border-radius:50%;background:radial-gradient(circle at 35% 25%,#fff,#9dc9dd 52%,#315a83);color:#071421;font-weight:800;box-shadow:inset 0 1px #ffffffa6,0 5px 10px #00000029}.game-card-art-wrap{aspect-ratio:1 / .74;border-radius:10px;overflow:hidden;background:#0d18261a;border:1px solid rgba(41,55,70,.16)}.game-card-art{width:100%;height:100%;object-fit:cover;display:block}.game-card-art.placeholder{background:linear-gradient(135deg,#79a7c14d,#d9ba732e)}.game-card-meta{color:#1a2737bd;font-size:11px;padding:0 2px}.game-card-desc,.game-card-upgrade p{color:#102033;font-size:13px;line-height:1.42;margin:0;padding:7px 8px;border-radius:10px;background:#ffffffa3;border:1px solid rgba(56,70,84,.08)}.game-card.compact .game-card-desc{font-size:12px;padding:6px 7px}.battle-card .game-card-head strong{font-size:13px}.battle-card .game-card-meta{font-size:10px}.battle-card .game-card-cost{width:28px;height:28px}.game-card-upgrade{display:grid;gap:5px;align-content:start}.game-card-upgrade .after{color:#5b3005;font-weight:700;background:#fff1cbc7}.upgrade-delta-line{height:1px;background:linear-gradient(90deg,transparent,rgba(120,70,20,.34),transparent)}.floating-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:7}.combat-fx-layer{position:absolute;top:-18%;right:-8%;bottom:-10%;left:-8%;pointer-events:none;z-index:8;overflow:visible}.slash-fx-img{position:absolute;width:min(46vw,720px);height:auto;transform-origin:center;filter:drop-shadow(0 0 20px rgba(132,221,255,.82)) drop-shadow(0 0 34px rgba(255,255,255,.32));-webkit-user-select:none;user-select:none}.sprite-sheet-fx{width:100%;height:100%;background-repeat:no-repeat;background-size:300% 300%;background-position:0% 0%;animation:sheet-3x3-play .72s steps(1,end) forwards;will-change:background-position}.slash-sheet-wrap,.guard-sheet-wrap,.actor-sheet-wrap,.vulnerable-break-sheet-wrap{position:absolute;pointer-events:none;-webkit-user-select:none;user-select:none}.slash-sheet-wrap{width:min(48vw,760px);aspect-ratio:1 / 1;transform-origin:center;filter:drop-shadow(0 0 20px rgba(132,221,255,.82)) drop-shadow(0 0 34px rgba(255,255,255,.32));mix-blend-mode:screen}.slash-to-player{width:min(34vw,540px)}.sprite-sheet-slash{animation-duration:.68s}.sprite-sheet-demon-slash{filter:saturate(1.35) contrast(1.12) drop-shadow(0 0 18px rgba(255,42,54,.82)) drop-shadow(0 0 32px rgba(120,0,16,.54))}.vulnerable-break-sheet-wrap{width:min(30vw,430px);aspect-ratio:1 / 1;z-index:9;filter:drop-shadow(0 0 20px rgba(255,72,54,.62)) drop-shadow(0 0 30px rgba(217,186,115,.24));mix-blend-mode:screen}.sprite-sheet-vulnerable{animation-duration:.72s}.guard-sheet-wrap{width:270px;height:270px;filter:drop-shadow(0 0 24px rgba(188,235,255,.58));mix-blend-mode:screen}.sprite-sheet-guard-aura{animation-duration:.82s}.actor-sheet-wrap{left:50%;bottom:0;width:122%;aspect-ratio:1 / 1;transform:translate(-50%);z-index:4;filter:drop-shadow(0 22px 42px rgba(0,0,0,.34))}.actor-sheet-player{bottom:-4%}.sprite-sheet-actor{animation-duration:.76s}@keyframes sheet-3x3-play{0%{background-position:0% 0%}11.111%{background-position:50% 0%}22.222%{background-position:100% 0%}33.333%{background-position:0% 50%}44.444%{background-position:50% 50%}55.555%{background-position:100% 50%}66.666%{background-position:0% 100%}77.777%{background-position:50% 100%}88.888%,to{background-position:100% 100%}}@keyframes sheet-3x3-loop{0%{background-position:0% 0%}11.111%{background-position:50% 0%}22.222%{background-position:100% 0%}33.333%{background-position:0% 50%}44.444%{background-position:50% 50%}55.555%{background-position:100% 50%}66.666%{background-position:0% 100%}77.777%{background-position:50% 100%}88.888%,to{background-position:100% 100%}}@keyframes sheet-3x3-pingpong{0%{background-position:0% 0%}6.25%{background-position:50% 0%}12.5%{background-position:100% 0%}18.75%{background-position:0% 50%}25%{background-position:50% 50%}31.25%{background-position:100% 50%}37.5%{background-position:0% 100%}43.75%{background-position:50% 100%}50%{background-position:100% 100%}56.25%{background-position:50% 100%}62.5%{background-position:0% 100%}68.75%{background-position:100% 50%}75%{background-position:50% 50%}81.25%{background-position:0% 50%}87.5%{background-position:100% 0%}93.75%{background-position:50% 0%}to{background-position:0% 0%}}@keyframes sheet-3x6-18-play{0%{background-position:0% 0%}5.555%{background-position:50% 0%}11.111%{background-position:100% 0%}16.666%{background-position:0% 20%}22.222%{background-position:50% 20%}27.777%{background-position:100% 20%}33.333%{background-position:0% 40%}38.888%{background-position:50% 40%}44.444%{background-position:100% 40%}50%{background-position:0% 60%}55.555%{background-position:50% 60%}61.111%{background-position:100% 60%}66.666%{background-position:0% 80%}72.222%{background-position:50% 80%}77.777%{background-position:100% 80%}83.333%{background-position:0% 100%}88.888%{background-position:50% 100%}94.444%,to{background-position:100% 100%}}@keyframes enemy-idle-4x4{0%{background-position:0% 0%}6.25%{background-position:33.333% 0%}12.5%{background-position:66.666% 0%}18.75%{background-position:100% 0%}25%{background-position:0% 33.333%}31.25%{background-position:33.333% 33.333%}37.5%{background-position:66.666% 33.333%}43.75%{background-position:100% 33.333%}50%{background-position:0% 66.666%}56.25%{background-position:33.333% 66.666%}62.5%{background-position:66.666% 66.666%}68.75%{background-position:100% 66.666%}75%{background-position:0% 100%}81.25%{background-position:33.333% 100%}87.5%{background-position:66.666% 100%}93.75%,to{background-position:100% 100%}}.guard-fx{position:absolute;width:230px;height:230px;border-radius:50%;border:3px solid rgba(188,235,255,.74);box-shadow:inset 0 0 34px #7ecaeb3d,0 0 38px #7ecaeb57;background:radial-gradient(circle,rgba(185,232,255,.18),transparent 62%),conic-gradient(from 25deg,transparent,rgba(217,186,115,.46),transparent,rgba(126,202,235,.42),transparent);mix-blend-mode:screen}.guard-player{left:11%;top:37%}.guard-enemy{right:20%;top:24%}.floating-text{position:absolute;padding:8px 14px;border-radius:999px;background:#080e18c7;border:1px solid rgba(255,255,255,.08);font-weight:700;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-soft)}.floating-damage{color:#ffd0d0}.floating-block,.floating-heal{color:#d7f6e2}.floating-status,.floating-turnStart,.floating-intent{color:#dbeaf8}.reward-panel,.choice-panel,.ending-panel{max-width:1100px;margin:auto;width:100%}.shop-panel{width:min(1500px,100%);margin:0 auto}.shop-section-head{display:flex;justify-content:space-between;align-items:end;margin:4px 0 14px}.shop-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(178px,1fr));gap:18px;margin-bottom:28px}.shop-offer{display:grid;gap:10px;justify-items:stretch;transition:transform .18s ease,opacity .18s ease,filter .18s ease}.shop-offer:hover{transform:translateY(-4px)}.shop-offer.bought{opacity:.52;filter:grayscale(.25)}.shop-buy-btn{width:100%;justify-content:center;text-align:center}.shop-relic-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(310px,1fr));gap:14px}.shop-relic-offer{display:grid;grid-template-columns:1fr auto;gap:14px;align-items:center;padding:14px;border-radius:18px;border:1px solid rgba(255,255,255,.08);background:#ffffff0a}.shop-relic-offer.bought{opacity:.56}.shop-price-note{color:var(--text-dim);font-size:14px}.shop-remove-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.shop-remove-card{display:grid;gap:4px;padding:11px 12px;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:#070c1775;color:#edf3fa;text-align:left;transition:transform .16s ease,border-color .16s ease,opacity .16s ease}.shop-remove-card:hover:not(:disabled){transform:translateY(-2px);border-color:#d9ba735c}.shop-remove-card:disabled{opacity:.46}.shop-remove-card span{color:var(--text-dim);font-size:12px}.reward-grid,.choice-grid{grid-template-columns:repeat(auto-fit,minmax(220px,280px));margin:22px 0;justify-content:center}.upgrade-grid,.upgrade-deck-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;margin-top:22px}.choice-grid.rest-choice-grid{grid-template-columns:repeat(2,minmax(300px,420px));justify-content:center;align-content:end;margin:0 0 clamp(12px,4vh,52px);gap:24px}.upgrade-panel{max-width:min(1660px,calc(100vw - 40px));margin:0 auto}.upgrade-workbench{display:grid;grid-template-columns:minmax(520px,1fr) minmax(440px,560px);gap:22px;align-items:start}.upgrade-deck-grid{grid-template-columns:repeat(auto-fill,minmax(172px,1fr));align-items:start;max-height:72vh;overflow-y:auto;padding:6px 8px 12px}.upgrade-card{padding:0;border:0;background:transparent;color:inherit;text-align:left;box-shadow:none;transition:transform .18s ease,filter .18s ease}.upgrade-card:hover{transform:translateY(-5px);filter:drop-shadow(0 0 18px rgba(217,186,115,.22))}.upgrade-card.selected{filter:drop-shadow(0 0 24px rgba(217,186,115,.42))}.upgrade-card.selected .game-card{outline:2px solid rgba(217,186,115,.88);outline-offset:4px;border-radius:18px}.upgrade-preview-panel{position:sticky;top:18px;display:grid;gap:16px;max-height:76vh;overflow-y:auto;padding:18px;border-radius:20px;border:1px solid rgba(217,186,115,.22);background:#070c17d1;box-shadow:0 22px 52px #00000052}.upgrade-preview-panel.empty{min-height:280px;align-content:center}.upgrade-preview-panel.empty p:not(.eyebrow){color:var(--text-dim);line-height:1.7}.upgrade-preview-head,.upgrade-preview-actions{display:flex;justify-content:space-between;gap:14px;align-items:center}.upgrade-cost-diff{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:#ffffff0f;color:#f7efe0;font-weight:800}.upgrade-cost-diff span{min-width:26px;text-align:center}.upgrade-cost-diff .cost-down{color:#8ee4a4}.upgrade-cost-diff .cost-changed{color:#ffd27a}.upgrade-preview-cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.upgrade-preview-cards>div{display:grid;gap:8px}.preview-label{color:var(--text-dim);font-size:13px}.upgrade-preview-desc{display:grid;gap:10px}.upgrade-preview-desc>div{padding:12px 14px;border-radius:14px;background:#ffffff0e;border:1px solid rgba(255,255,255,.08)}.upgrade-preview-desc strong{display:block;margin-bottom:8px;color:#fff6dc}.upgrade-diff-text{color:#dbe5f1;line-height:1.75;font-size:15px}.diff-changed{color:#ff7f7f;font-weight:800}.ending-panel{text-align:center}@media (max-width: 1100px){.hero{grid-template-columns:1fr}.class-grid{grid-template-columns:repeat(2,minmax(0,1fr));width:min(100%,980px)}.class-card{grid-template-rows:minmax(300px,42vh) auto}.map-atlas-head{align-items:flex-start}.enemy-actor{right:7%;width:min(38vw,var(--battle-enemy-width))}.player-actor{left:2%;width:min(38vw,var(--battle-player-width))}.upgrade-workbench{grid-template-columns:1fr}.upgrade-preview-panel{position:static;max-height:none}}@media (max-width: 720px){.screen-inner{padding:16px}h1{font-size:38px}.hero{min-height:calc(100vh - 32px);grid-template-rows:minmax(260px,56vh) 1fr}.hero-emblem{width:min(88vw,430px);max-height:38vh}.hero-actions{margin-top:30px}.ink-start-btn{min-width:176px;padding:14px 30px 15px;font-size:22px}.topbar,.combat-hud{grid-template-columns:1fr}.class-grid{grid-template-columns:minmax(0,1fr)}.class-card{grid-template-rows:minmax(280px,50vh) auto}.class-art{width:min(100%,330px)}.map-progress{justify-content:flex-start}.event-panel,.rest-choice-grid,.upgrade-preview-cards{grid-template-columns:1fr}.upgrade-preview-head,.upgrade-preview-actions{align-items:stretch;flex-direction:column}.event-art-wrap,.event-art-wrap img{min-height:240px}.battle-stage{min-height:0}.enemy-actor{top:7%;right:3%;width:min(48vw,var(--battle-enemy-width))}.player-actor{left:1%;bottom:14%;width:min(48vw,var(--battle-player-width))}.actor-status{max-width:86vw}.hand-fan{width:100%;height:max(220px,var(--battle-hand-board-height))}.battle-card{width:min(44vw,var(--battle-card-width));margin-left:calc(min(44vw,var(--battle-card-width))/-2)}.energy-orb{left:0;width:92px;height:92px}.battle-side-ui.right{right:10px;bottom:12%}.relic-mini-stack{min-width:144px;max-height:110px}}
