:root{--paper:#e8dcc0;--ink:#1f2528;--indigo:#253b56;--cinnabar:#a33a2b;--bronze:#9a7138;--focus-ring:#e2bd70;--danger:#d15a45;--stage-transition-duration:.36s;--effect-duration:.52s;--touch-target:44px}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:1ms!important;animation-duration:1ms!important;animation-iteration-count:1!important}}:root{color:#e7ddc7;background:var(--ink);font-synthesis:none;font-family:Noto Serif SC,Songti SC,STSong,serif}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}button{color:inherit;font:inherit}button:focus-visible{outline:2px solid var(--focus-ring);outline-offset:3px}.sr-only{clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}.app-viewport{background:radial-gradient(circle at 50% 0,#384c5a47,#0000 44rem),#111820;place-items:center;min-height:100svh;display:grid;overflow-x:hidden}.phone-frame{background:#111820;border-inline:1px solid #b6924d38;width:min(100%,430px);min-height:100svh;position:relative;overflow:hidden;box-shadow:0 0 48px #000000b3}.screen{width:100%;min-height:100svh;position:relative}.start-screen,.result-screen{isolation:isolate;background-position:50%;background-size:cover;flex-direction:column;align-items:center;display:flex}.start-screen{background-image:linear-gradient(#060b111f,#060b110d 58%,#060b11d1),url(/assets/start-night-escape.png);justify-content:space-between;padding:clamp(3.25rem,11svh,6.4rem) 1.25rem 1.6rem}.start-title-lockup{text-align:center;color:#e9d19a;text-shadow:0 3px 10px #000;width:100%}.brand-title{letter-spacing:-.08em;margin:0;font-family:STKaiti,KaiTi,"FangSong",serif;font-size:clamp(3.3rem,17vw,5.1rem);font-weight:700;line-height:.95}.start-title-lockup h1{letter-spacing:.16em;align-items:center;gap:.75rem;margin:1.8rem 0 0;font-family:STKaiti,KaiTi,serif;font-size:clamp(1.2rem,5.3vw,1.6rem);font-weight:500;display:flex}.start-title-lockup h1:before,.start-title-lockup h1:after{content:"";background:linear-gradient(90deg,#0000,#b6924d);flex:1;height:1px}.start-title-lockup h1:after{transform:scaleX(-1)}.primary-action,.secondary-action{cursor:pointer;letter-spacing:.14em;border:1px solid #b6924d;border-radius:2px;min-height:48px;font-family:STKaiti,KaiTi,"FangSong",serif;font-size:1.35rem;font-weight:700;transition:transform .2s,filter .2s,opacity .2s}.primary-action{color:#f0dfb6;background:linear-gradient(#792219ed,#5b1713f5),#7c2c22;box-shadow:inset 0 0 0 3px #6d211a,inset 0 0 0 4px #ddb159b8,0 8px 24px #0000007a}.secondary-action{color:#e7ddc7;background:linear-gradient(#1d2b3e,#111c2b);box-shadow:inset 0 0 0 3px #172235}.primary-action:hover:not(:disabled),.secondary-action:hover:not(:disabled){filter:brightness(1.12);transform:translateY(-1px)}.primary-action:active:not(:disabled),.secondary-action:active:not(:disabled){transform:translateY(1px)scale(.99)}.primary-action:disabled,.secondary-action:disabled{cursor:not-allowed;filter:grayscale(.6);opacity:.48}.start-action{width:min(78%,310px);min-height:76px;margin-top:auto;margin-bottom:8svh;font-size:clamp(1.8rem,8vw,2.45rem)}.story-entry-trigger{z-index:3;color:#dfc383;cursor:pointer;background:#0b1219db;border:1px solid #b6924db8;min-width:112px;min-height:44px;position:absolute;bottom:3.35rem;right:1rem}.historical-note{color:#caaa6b;letter-spacing:.08em;text-shadow:0 2px 5px #000;justify-content:center;align-items:center;gap:.55rem;width:100%;font-size:.84rem;display:flex}.game-screen{--stage-background:var(--indigo);--stage-accent:var(--cinnabar);background:radial-gradient(circle at 20% 12%, color-mix(in srgb, var(--stage-accent) 28%, transparent), transparent 34%), linear-gradient(color-mix(in srgb, var(--stage-background) 42%, transparent), #090e137a), url(/assets/battlefield-prologue.png) center / cover fixed;height:100svh;min-height:100svh;transition:background-color var(--stage-transition-duration) ease, filter var(--stage-transition-duration) ease;flex-direction:column;gap:.45rem;padding:.55rem;display:flex;overflow:hidden}.game-screen[data-theme-phase=palace-chaos]{filter:saturate(1.04)brightness(1.03)}.game-screen[data-theme-phase=beimang-night]{filter:saturate(.94)brightness(.86)}.game-screen[data-theme-phase=xiaopingjin-dawn]{filter:saturate(.92)brightness()}.battle-hud{z-index:2;grid-template-columns:.85fr .9fr 1.25fr;gap:.35rem;display:grid}.environment-label{z-index:3;min-height:1.8rem;color:var(--paper);border:1px solid color-mix(in srgb, var(--stage-accent) 58%, transparent);background:color-mix(in srgb, var(--ink) 72%, transparent);box-shadow:inset 0 0 18px color-mix(in srgb, var(--stage-background) 48%, transparent);letter-spacing:.12em;text-shadow:0 2px 6px #000;transition:border-color var(--stage-transition-duration) ease, box-shadow var(--stage-transition-duration) ease;justify-content:center;align-items:center;margin:0;font-size:.84rem;display:flex}.hud-block{color:#e7ddc7;white-space:nowrap;background:linear-gradient(145deg,#181e20f5,#090f15f5);border:1px solid #b6924d94;justify-content:center;align-items:center;min-height:48px;padding:.35rem .4rem;font-size:clamp(.72rem,3.2vw,.91rem);display:flex;box-shadow:inset 0 0 0 2px #06080ab3}.grain-status{color:#dfc37e;gap:.35rem}.protectee-status{justify-content:space-between;gap:.25rem}.protectee-status>div{flex-direction:column;line-height:1.08;display:flex}.protectee-status strong{color:#e5c783;font-family:STKaiti,KaiTi,serif;font-size:1rem}.protectee-status>div span{color:#a99c85;font-size:.68rem}.lives{gap:.12rem;display:flex}.lives i{color:#5c5042;background:#2c2220;border:1px solid #685244;place-items:center;width:18px;height:18px;font-size:.52rem;font-style:normal;display:grid}.lives i.is-live{color:#e2b45c;background:#5c1f1a;border-color:#a33b2b}.battlefield-frame{background:#0a101657;border:1px solid #b6924d8a;flex:auto;min-height:0;position:relative;overflow:hidden;box-shadow:inset 0 0 20px #0000007a}.pixi-battlefield,.pixi-battlefield canvas{width:100%;height:100%;display:block}.pixi-battlefield{position:absolute;inset:0}.battlefield-caption{z-index:2;color:#e7ddc7b3;pointer-events:none;justify-content:space-between;font-family:STKaiti,KaiTi,serif;font-size:.72rem;display:flex;position:absolute;inset:31% .55rem auto}.army-roster{z-index:4;scrollbar-width:thin;pointer-events:auto;align-items:center;gap:.35rem;height:48px;padding:0 6px;display:flex;position:absolute;bottom:0;left:0;right:0;overflow-x:auto}.military-token{color:#eedbb1;cursor:pointer;pointer-events:auto;background:linear-gradient(145deg,#7b2d22,#421a18);border:1px solid #87502f;border-radius:4px;place-items:center;width:48px;min-width:48px;height:48px;font-family:STKaiti,KaiTi,serif;display:grid;position:relative;box-shadow:inset 0 0 0 2px #0a09089e,0 2px 3px #000}.military-token>span{font-size:1.6rem;line-height:1}.military-token small{color:#d9b96f;font-size:.52rem;position:absolute;bottom:0;right:2px}.military-token.token-qiang,.military-token.token-gong{background:linear-gradient(145deg,#334b61,#182839);border-color:#596c7e}.military-token.token-qi,.glyph-token{background:linear-gradient(145deg,#4f5630,#242d1d);border-color:#8b8046}.military-token.level-2,.military-token.level-3,.military-token.is-selected{border-color:#ddbd6b;box-shadow:inset 0 0 0 2px #2b2112,0 0 10px #ddbd6bc2}.empty-roster{color:#a99c85;letter-spacing:.08em;text-shadow:0 2px 5px #000;margin:0 auto;font-size:.76rem}.formation-shell{width:var(--board-width,calc(100% - 20px));height:var(--board-height,250px);z-index:3;top:var(--board-top,37%);left:var(--board-left,10px);pointer-events:none;padding:0;position:absolute}.formation-grid{grid-template-rows:repeat(5,1fr);grid-template-columns:repeat(6,1fr);gap:0;width:100%;height:100%;display:grid}.formation-cell{color:#0000;background:0 0;border:0;border-radius:0;place-items:center;min-width:0;min-height:0;font-family:STKaiti,KaiTi,serif;font-size:clamp(1.2rem,7vw,2rem);display:grid}button.formation-cell{min-height:var(--touch-target);cursor:pointer;pointer-events:auto}.formation-cell.is-locked{color:#0000;-webkit-user-select:none;user-select:none;font-size:.55rem}.formation-cell.is-occupied{color:#0000}button.formation-cell:focus-visible,button.formation-cell:hover{outline:2px solid var(--focus-ring);outline-offset:-4px;background:#b6924d14}button.formation-cell[data-drop-target]{box-shadow:inset 0 0 0 2px color-mix(in srgb, var(--stage-accent) 72%, transparent)}button.formation-cell[data-drop-target=merge]{box-shadow:inset 0 0 0 2px var(--focus-ring), inset 0 0 16px color-mix(in srgb, var(--bronze) 48%, transparent)}button.formation-cell[data-drop-target=invalid]{box-shadow:inset 0 0 0 2px color-mix(in srgb, var(--danger) 62%, transparent)}.army-roster .military-token{color:#0000;box-shadow:none;background:0 0;border-color:#0000}.army-roster .military-token>*{opacity:0}.army-roster .military-token:is(:focus-visible,.is-selected){outline-offset:-3px;background:#b6924d1a;outline:2px solid #ddbd6b}.battle-actions{grid-template-columns:1.5fr 1fr;gap:.55rem;display:grid}.battle-actions button{min-height:58px}.recruit-action{justify-content:center;align-items:center;gap:.65rem;display:flex}.recruit-action small{letter-spacing:0;font-size:.94rem}.status-ribbon{color:#a99c85;letter-spacing:.03em;justify-content:space-between;gap:.5rem;min-height:26px;font-size:.64rem;display:flex}.battle-effects{z-index:6;pointer-events:none;justify-items:center;gap:.35rem;display:grid;position:absolute;inset:16% .75rem auto}.battle-effect{max-width:min(94%,330px);color:var(--paper);border:1px solid color-mix(in srgb, var(--stage-accent) 72%, transparent);background:color-mix(in srgb, var(--ink) 76%, transparent);letter-spacing:.14em;text-align:center;text-shadow:0 2px 6px #000;animation:battle-effect-rise var(--effect-duration) ease both;margin:0;padding:.35rem .75rem;font-family:STKaiti,KaiTi,serif;font-size:clamp(1.05rem,5vw,1.55rem);box-shadow:0 8px 22px #0000006b}.battle-effect[data-effect=merge-ink-burst]{border-color:color-mix(in srgb, var(--ink) 34%, var(--focus-ring));filter:drop-shadow(0 0 10px color-mix(in srgb, var(--indigo) 48%, transparent))}.battle-effect[data-effect=protectee-hit]{border-color:var(--danger);box-shadow:0 0 0 2px color-mix(in srgb, var(--danger) 34%, transparent), 0 8px 22px #0000006b}.battle-effect[data-effect=reinforcement-arrival]{color:#f1d99a;border-color:var(--bronze);filter:drop-shadow(0 0 12px color-mix(in srgb, var(--bronze) 54%, transparent))}@keyframes battle-effect-rise{0%{opacity:0;transform:translateY(12px)scale(.96)}24%{opacity:1;transform:translateY(0)scale(1)}to{opacity:.92;transform:translateY(-8px)scale(1)}}.result-screen{background-image:linear-gradient(#060d160d,#111820 44%,#0c1115fa),url(/assets/result-dawn.png);justify-content:flex-start;gap:1.25rem;padding:1.25rem 1.1rem 1.4rem;overflow-y:auto}.result-heading{color:#dfc383;text-shadow:0 2px 6px #000;align-self:flex-start}.result-heading p{margin:0}.result-brand{font-family:STKaiti,KaiTi,serif;font-size:1.6rem;font-weight:700}.result-heading p:last-child{letter-spacing:.13em;margin-top:.25rem;font-size:.78rem}.result-copy{text-align:center;text-shadow:0 3px 8px #000;width:100%;margin-top:clamp(5rem,17svh,9rem)}.result-copy h1{color:#f0d595;background:#5b1914c7;border:4px double #8c2f24;width:fit-content;margin:0 auto;padding:.6rem 1rem;font-family:STKaiti,KaiTi,serif;font-size:clamp(2.4rem,12vw,3.7rem);line-height:1;transform:rotate(-1deg)}.result-copy p{color:#d4c8b1;margin:.9rem 0 0;font-size:.86rem}.seal-reward{background:#0a0e12b8;border-block:1px solid #b6924d9e;grid-template-columns:86px 1fr;align-items:center;gap:1rem;width:100%;padding:.9rem;display:grid}.seal-mark{color:#4c170f;white-space:pre-line;background:#b89655;border:4px double #7b2117;place-items:center;width:82px;height:82px;padding:.35rem;font-family:STKaiti,KaiTi,serif;font-size:1.42rem;font-weight:700;line-height:1.05;display:grid;box-shadow:inset 0 0 0 2px #d6bd7f,0 6px 13px #0000007a}.seal-mark.is-earned{animation:seal-stamp var(--effect-duration) cubic-bezier(.2, 1.4, .3, 1) both}@keyframes seal-stamp{0%{opacity:.38;transform:translateY(-8px)scale(1.28)rotate(-4deg)}70%{opacity:1;transform:translateY(0)scale(.96)rotate(1deg)}to{opacity:1;transform:translateY(0)scale(1)rotate(0)}}.seal-reward h2,.seal-reward p{margin:0}.seal-reward h2{color:#dfc383;font-family:STKaiti,KaiTi,serif;font-size:1.65rem}.seal-reward p{color:#c5b8a2;margin-top:.4rem;font-size:.78rem;line-height:1.55}.chapter-preview{background:#0e1317d1;border:1px solid #b6924d66;flex-direction:column;width:100%;padding:.7rem .85rem;display:flex}.chapter-preview strong{color:#d8c494;font-family:STKaiti,KaiTi,serif;font-size:1rem}.chapter-preview span{color:#a99c85;margin-top:.25rem;font-size:.7rem}.result-actions{gap:.65rem;width:100%;margin-top:auto;display:grid}.result-actions button{width:100%}.feedback-form{background:#0a0e12e6;border:1px solid #b6924d80;gap:.6rem;width:100%;padding:.8rem;display:grid}.feedback-form h2,.feedback-form p,.feedback-form fieldset{margin:0}.feedback-form h2{color:#dfc383;font-family:STKaiti,KaiTi,serif}.feedback-form p,.feedback-form legend,.feedback-text-label{color:#c5b8a2;font-size:.78rem}.feedback-form .feedback-privacy-note{color:#f1d89d}.feedback-form fieldset{border:0;padding:0}.feedback-rating{grid-template-columns:repeat(5,1fr);gap:.35rem;margin-top:.35rem;display:grid}.feedback-rating label{cursor:pointer;border:1px solid #b6924d8c;place-items:center;min-height:44px;display:grid;position:relative}.feedback-rating input{opacity:0;position:absolute}.feedback-rating label:has(input:checked){color:#f0dfb6;background:#6d211a;border-color:#dfc383}.feedback-rating label:has(input:focus-visible){outline-offset:2px;outline:2px solid #e2bd70}.feedback-form textarea{resize:vertical;color:#e7ddc7;min-height:72px;font:inherit;background:#111c2b;border:1px solid #b6924d8c}.feedback-form button{min-height:44px}.feedback-thanks{color:#f1d89d;text-align:center;background:#1f3e2ae0;border:1px solid #b6924d80;width:100%;margin:0;padding:.75rem}.debug-panel{z-index:8;color:#e7ddc7;background:#080c10f0;width:min(230px,100% - .8rem);font-family:ui-monospace,monospace;font-size:.7rem;position:absolute;top:.4rem;right:.4rem}.debug-panel summary,.debug-panel button{cursor:pointer;min-height:44px}.debug-panel summary{justify-content:flex-end;align-items:center;padding:0 .7rem;display:flex}.debug-panel dl{margin:0;padding:.5rem .7rem}.debug-panel dl div{grid-template-columns:4rem 1fr;gap:.5rem;display:grid}.debug-panel dd{overflow-wrap:anywhere;margin:0}.debug-panel button{width:100%;color:inherit;background:#111c2b;border:1px solid #b6924d8c}.story-panel{color:#d8ccb6;background:linear-gradient(#0c141cf0,#0a0f14fc),url(/assets/result-dawn.png) 50%/cover fixed;flex-direction:column;gap:.8rem;padding:1.15rem 1rem 1.4rem;display:flex;overflow-y:auto}.story-heading h1,.story-heading p,.story-entry h2,.story-entry p{margin:0}.story-heading h1{color:#f0d595;margin-top:.25rem;font-family:STKaiti,KaiTi,serif;font-size:2.3rem}.story-heading>p:last-child{color:#b8a987;font-size:.78rem}.story-entry{gap:.7rem;display:grid}.story-entry section{background:#0f151ac2;border:1px solid #b6924d5c;padding:.75rem}.story-entry h2{color:#dfc383;font-family:STKaiti,KaiTi,serif;font-size:1.12rem}.story-entry p{margin-top:.35rem;font-size:.78rem;line-height:1.65}.story-entry a{color:#d6bd7f;align-items:center;min-height:44px;font-size:.74rem;display:inline-flex}.story-entry .story-seal{border-color:#a03627b8;box-shadow:inset 4px 0 #8c2f24}.storage-warning,.app-storage-warning{color:#f1d89d;background:#5b3418eb;border:1px solid #b6924d80;margin:0;padding:.6rem .75rem;font-size:.75rem}.app-storage-warning{z-index:6;text-align:center;position:absolute;bottom:.55rem;left:.55rem;right:.55rem}.story-actions{gap:.55rem;margin-top:auto;display:grid}.story-actions button{width:100%;min-height:48px}.data-clear-action{color:#cbbfa9;cursor:pointer;background:#311917db;border:1px solid #a33a2bb8}@media (height<=700px){.game-screen{gap:.3rem;padding:.35rem}.battlefield-frame{min-height:0}.military-token{width:44px;min-width:44px;height:44px}.battle-actions button{min-height:50px}.status-ribbon{display:none}.result-screen{gap:.65rem}.result-copy{margin-top:2.3rem}}@media (width>=431px){.phone-frame{border:1px solid #b6924d59;height:min(100svh - 2rem,900px);min-height:0;margin-block:1rem}.screen{height:100%;min-height:100%}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
