:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:#f2ead9;font-family:Iowan Old Style,Palatino Linotype,Book Antiqua,serif}*{box-sizing:border-box}body{background:radial-gradient(circle at top,#e3b56a29,#0000 28%),linear-gradient(135deg,#6759381f,#0000 40%),linear-gradient(#171912 0%,#0c0f0b 100%);min-height:100vh;margin:0}button{font:inherit;cursor:pointer;color:#f2ead9;background:#efe4c51a;border:0;border-radius:18px;padding:.85rem 1rem;transition:transform .12s,filter .12s,opacity .12s,background .12s}button:hover:not(:disabled){filter:brightness(1.06);transform:translateY(-1px)}button:disabled{cursor:not-allowed;opacity:.45}#app{width:100%}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.shell{width:min(1240px,100% - 2rem);margin:0 auto;padding:1.25rem 0 2rem}.shell.battle-shell{grid-template-rows:auto minmax(0,1fr);width:min(1380px,100% - 1.5rem);min-height:calc(100svh - .75rem);max-height:calc(100svh - .75rem);padding:.5rem 0 .75rem;display:grid;overflow:hidden}.shell.battle-shell .hero-panel{align-items:center;gap:1rem;margin-bottom:.55rem;padding:.65rem .85rem;display:flex}.shell.battle-shell .hero-panel h1{max-width:none;margin:0 0 .15rem;font-size:1.2rem;line-height:.98}.shell.battle-shell .hero-panel .lede{max-width:none;font-size:.92rem;line-height:1.3}.shell.battle-shell .hero-stats{display:none}.panel{background:linear-gradient(#353a2df0,#181d16f5),#141612eb;border:1px solid #efe4c51c;border-radius:28px;box-shadow:0 18px 60px #00000057,inset 0 1px #ffffff0a}.hero-panel{justify-content:space-between;gap:2rem;margin-bottom:1.25rem;padding:1.4rem 1.5rem;display:flex}.hero-panel h1{max-width:11ch;margin:.35rem 0 .45rem;font-size:clamp(2rem,4vw,3.6rem);line-height:.94}.eyebrow{text-transform:uppercase;letter-spacing:.18em;color:#cfbf95;margin:0;font-size:.72rem}.lede,.subtle,.choice-card span,.card span{color:#d7ccb2}.lede{max-width:54ch;margin:0}.hero-stats{grid-template-columns:repeat(5,minmax(100px,1fr));align-self:start;gap:.75rem;display:grid}.hero-stats div{background:#efe1c20f;border-radius:18px;padding:1rem}.hero-stats span{color:#cfbf95;display:block}.hero-stats strong{margin-top:.35rem;font-size:1.02rem;display:block}.main-grid{grid-template-columns:minmax(0,1fr) clamp(300px,24vw,344px);gap:1.25rem;display:grid}.shell.battle-shell .main-grid{gap:.9rem;min-height:0}.board-column{align-content:start;min-width:0;min-height:0;display:grid;container-type:inline-size}.battle-hud-slot{display:grid}.board-wrap{gap:.85rem;padding:1rem;display:grid}.shell.battle-shell .board-wrap{grid-template-rows:auto minmax(0,1fr) auto;align-content:stretch;height:100%}.board-stage{width:min(100%,576px);margin:0 auto;position:relative}.shell.battle-shell .board-stage{width:min(100%,576px)}.battle-board-banner,.battle-board-prompt{z-index:3;pointer-events:none;position:absolute;left:.75rem;right:auto}.battle-board-banner{top:.75rem}.battle-board-prompt{bottom:.75rem;left:.75rem;right:.75rem}.battle-banner-card,.battle-prompt-card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f1310d1;border:1px solid #efe1c224;border-radius:16px;gap:.18rem;max-width:min(320px,100% - 1.5rem);padding:.6rem .75rem;display:inline-grid;box-shadow:0 14px 24px #00000038}.battle-prompt-card{max-width:none;display:grid}.battle-banner-label{text-transform:uppercase;letter-spacing:.14em;color:#cfbf95;font-size:.66rem}.battle-banner-card strong,.battle-prompt-card strong{margin-bottom:0;font-size:.95rem}.battle-banner-neutral,.battle-prompt-neutral{border-color:#efe1c224}.battle-prompt-valid{background:#132218d1;border-color:#93d6a56b}.battle-prompt-invalid{background:#2d1917d6;border-color:#e5846c70}canvas{background:#131813;border-radius:24px;width:100%;display:block}canvas:focus-visible{outline-offset:4px;outline:3px solid #e1b56aeb}.board-overlay{pointer-events:none;place-items:center;display:grid;position:absolute;inset:0}.board-overlay[data-interactive=true]{pointer-events:auto}.overlay-card{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#0e120dbd;border:1px solid #efe4c524;border-radius:24px;width:min(420px,100% - 2rem);padding:1.15rem}.overlay-close{background:#ffffff14;border-radius:999px;padding:.45rem .75rem;font-size:.85rem}.overlay-card strong,.choice-card strong,.card strong,.history-row strong,.unit-row strong{margin-bottom:.2rem;display:block}.sidebar{padding:1.2rem;overflow:auto}.shell.battle-shell .sidebar{min-height:0;max-height:calc(100dvh - 1rem);padding:.9rem}.battle-sidebar-layout{align-content:start;gap:.7rem}.battle-mobile-sheet-header{display:none}.battle-top-hud,.battle-bottom-hud{padding:.65rem .8rem}.battle-top-hud{display:block}.battle-top-bar{grid-template-columns:auto repeat(5,minmax(78px,auto)) minmax(240px,1fr);align-items:center;gap:.45rem;display:grid}.battle-top-encounter,.battle-top-chip,.battle-top-message{background:#ffffff0a;border-radius:14px;min-height:0;padding:.45rem .6rem}.battle-top-encounter{min-width:176px}.battle-top-message{min-width:0}.battle-top-chip{gap:.08rem;display:grid}.battle-top-chip span{color:#cfbf95;font-size:.72rem;display:block}.battle-top-chip strong,.battle-top-encounter strong,.battle-top-message strong{margin-bottom:0}.battle-top-message strong{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.battle-bottom-hud{gap:.45rem;display:grid}.battle-bottom-row{grid-template-columns:minmax(220px,.7fr) minmax(0,1.4fr) auto;align-items:center;gap:.65rem;display:grid}.battle-bottom-summary,.battle-bottom-tools{background:#ffffff0a;border-radius:16px;gap:.32rem;padding:.56rem .68rem;display:grid}.battle-bottom-summary strong{margin-bottom:0}.battle-bottom-actions{justify-items:stretch;gap:.5rem;display:grid}.battle-bottom-feedback{background:#ffffff0a;border:1px solid #efe1c224;border-radius:14px;gap:.18rem;padding:.62rem .78rem;display:grid}.battle-bottom-feedback strong{margin-bottom:0}.battle-bottom-summary span,.battle-bottom-tools .eyebrow,.battle-top-message .eyebrow{line-height:1.2}.battle-bottom-summary span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.shell.battle-shell .battle-bottom-feedback{display:none}.stack{gap:1rem;display:grid}.tight{gap:.55rem}.card{background:#efe1c212;border-radius:20px;gap:.42rem;padding:.85rem;display:grid}.battle-mobile-dock{display:none}.battle-quick-stats{grid-template-columns:repeat(4,minmax(0,1fr));gap:.55rem;display:grid}.quick-stat{background:#ffffff0a;border-radius:16px;padding:.75rem .8rem}.quick-stat span{color:#cfbf95;font-size:.75rem;display:block}.quick-stat strong{margin-top:.2rem;margin-bottom:0;font-size:1rem}.battle-message{background:#ffffff0a;border-radius:16px;padding:.8rem .9rem}.battle-message strong{margin-bottom:0}.battle-selection-summary,.tool-dock,.battle-tutorial-strip{background:#ffffff0a;border-radius:16px;gap:.4rem;padding:.8rem .9rem;display:grid}.battle-selection-summary strong,.battle-tutorial-strip strong{margin-bottom:0}.battle-primary-actions{align-items:center}.battle-end-turn-button{min-width:130px}.battle-tab-bar{z-index:2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#111512d1;border:1px solid #efe1c214;border-radius:18px;grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem;padding:.25rem;display:grid;position:sticky;top:.3rem}.battle-tab-button{color:#d7ccb2;background:0 0;border-radius:14px;padding:.65rem .8rem}.battle-tab-button.active-tab{color:#f2ead9;background:#e1b56a2e}.battle-panel-region{min-height:0}.battle-tab-panel{align-content:start}.battle-intent-list{gap:.35rem;display:grid}.battle-intent-row{background:#ffffff08;border-radius:12px;gap:.15rem;padding:.42rem .52rem;display:grid}.battle-intent-row strong,.battle-intent-row span{margin:0}.battle-log-compact{max-height:110px}.battle-sidebar-footer{z-index:2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:linear-gradient(#22271dc7,#22271df5 26%,#22271dfa);gap:.45rem;padding:.65rem;position:sticky;bottom:0}.battle-sidebar-footer .button-row{justify-content:space-between;gap:.45rem}.battle-tool-list{scrollbar-width:thin;flex-wrap:nowrap;padding-bottom:.2rem;overflow-x:auto}.tool-chip{white-space:nowrap;border-radius:999px;padding:.65rem .85rem}.muted{color:#a99d82}.choice-card{text-align:left;background:linear-gradient(#efe1c21f,#efe1c20f),#efe1c20d;border:1px solid #efe1c21f;gap:.35rem;width:100%;display:grid}.choice-card strong,.choice-card span{pointer-events:none}.commander-card{min-height:118px}.squad-button{gap:.5rem;min-height:82px;padding:.9rem 1rem}.squad-button strong{margin-bottom:0}.squad-button .pill{justify-self:end}.selected-card{background:linear-gradient(#e1b56a2e,#e1b56a14),#efe1c20d;border-color:#e1b56a80}.button-row{flex-wrap:wrap;gap:.65rem;display:flex}.split-row{justify-content:space-between;align-items:center;gap:1rem;display:flex}.tool-list{flex-wrap:wrap;gap:.55rem;display:flex}.selected-tool{color:#1a1510;background:#e3d4ad}.primary{color:#1a1510;background:#e1b56a}.secondary{color:#f2ead9;background:#e1b56a2e}.ghost{background:#ffffff0f}.compact-button{border-radius:999px;padding:.45rem .7rem;font-size:.82rem}.pill-row{flex-wrap:wrap;gap:.45rem;display:flex}.pill{color:#eadfca;background:#efe1c214;border-radius:999px;align-items:center;gap:.3rem;padding:.3rem .6rem;font-size:.82rem;display:inline-flex}.unit-row,.history-row{border-bottom:1px solid #efe1c214;justify-content:space-between;gap:1rem;padding-bottom:.4rem;display:flex}.unit-row:last-child,.history-row:last-child{border-bottom:0;padding-bottom:0}.tutorial-card{background:linear-gradient(#e1b56a24,#e1b56a0d),#efe1c20d;border:1px solid #e1b56a33}.tutorial-hint{color:#f3ddb0}.log-list{max-height:220px;overflow:auto}.log-list span{background:#ffffff08;border-radius:12px;padding:.42rem .55rem}.victory-card{border:1px solid #99d68747}.defeat-card{border:1px solid #e36f613d}.disabled-card{opacity:.45}@media (width<=1080px){.hero-panel{display:grid}.hero-stats{grid-template-columns:repeat(3,1fr)}.main-grid{grid-template-columns:1fr}}@media (width<=720px){.shell{width:min(100% - 1rem,100%);padding-top:.5rem}.panel{border-radius:22px}.hero-stats{grid-template-columns:repeat(2,1fr)}.button-row{flex-direction:column}.battle-quick-stats{grid-template-columns:1fr 1fr}.shell.battle-shell{width:min(100% - .75rem,100%);min-height:auto;max-height:none;padding-bottom:15rem;display:block;overflow:visible}.shell.battle-shell .hero-panel{display:none}.shell.battle-shell .sidebar{box-shadow:none;background:0 0;border:0;padding:0;display:block;overflow:visible}.shell.battle-shell.mobile-detail-open .sidebar{z-index:14;background:linear-gradient(#353a2dfa,#181d16f7),#141612f5;border-radius:24px;height:min(44vh,360px);padding:.75rem;position:fixed;bottom:.75rem;left:.75rem;right:.75rem;overflow:hidden;box-shadow:0 18px 48px #0006}.shell.battle-shell.mobile-detail-open .battle-mobile-dock,.shell.battle-shell .battle-context-header,.shell.battle-shell .battle-mobile-sheet-header,.shell.battle-shell .battle-tab-bar,.shell.battle-shell .battle-panel-region,.shell.battle-shell .battle-sidebar-footer{display:none}.shell.battle-shell.mobile-detail-open .battle-tab-bar,.shell.battle-shell.mobile-detail-open .battle-panel-region{display:grid}.shell.battle-shell.mobile-detail-open .battle-mobile-sheet-header{z-index:2;background:linear-gradient(#353a2dfa,#353a2df0);padding-bottom:.25rem;display:flex;position:sticky;top:0}.shell.battle-shell.mobile-detail-open .battle-context-header,.shell.battle-shell.mobile-detail-open .battle-sidebar-footer{display:none}.shell.battle-shell.mobile-detail-open .battle-sidebar-layout{grid-template-rows:auto auto minmax(0,1fr);height:100%}.shell.battle-shell.mobile-detail-open .battle-panel-region{padding-bottom:.3rem;padding-right:.1rem;overflow:auto}.shell.battle-shell.mobile-detail-open .battle-context-header,.shell.battle-shell.mobile-detail-open .battle-sidebar-footer{padding:.75rem .85rem}.shell.battle-shell .battle-mobile-dock{display:grid}.shell.battle-shell #battle-hud-bottom{display:none}.shell.battle-shell .battle-top-hud{padding:.65rem .75rem}.shell.battle-shell .battle-top-bar{grid-template-columns:repeat(2,minmax(0,1fr));align-items:stretch}.shell.battle-shell .battle-top-encounter,.shell.battle-shell .battle-top-message{grid-column:1/-1}.shell.battle-shell .battle-top-chip,.shell.battle-shell .battle-top-encounter,.shell.battle-shell .battle-top-message{border-radius:14px;padding:.5rem .6rem}.shell.battle-shell .battle-top-message strong{white-space:normal}.shell.battle-shell .board-wrap{gap:.6rem;padding:.75rem}.shell.battle-shell .battle-board-banner,.shell.battle-shell .battle-board-prompt{display:none}.shell.battle-shell .board-stage{width:100%}.shell.battle-shell .battle-context-header strong{font-size:.95rem}.shell.battle-shell .battle-mobile-sheet-header{display:flex}.shell.battle-shell .battle-tab-bar{position:static}.shell.battle-shell.mobile-detail-open .battle-tab-bar{z-index:2;position:sticky;top:2.65rem}.shell.battle-shell .battle-tab-button{padding:.55rem .65rem}.shell.battle-shell .battle-intent-list{gap:.35rem}.shell.battle-shell .battle-intent-row{padding:.42rem .5rem}.shell.battle-shell .log-list{max-height:none}.shell.battle-shell .battle-tab-panel .card{padding:.85rem}.battle-mobile-dock{z-index:12;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:linear-gradient(#363c2ffa,#1c2119f7),#efe1c214;border:1px solid #e1b56a38;border-radius:22px;position:fixed;bottom:.75rem;left:.75rem;right:.75rem;box-shadow:0 20px 48px #00000073}.battle-mobile-dock .button-row{flex-direction:row}.battle-mobile-tabs{grid-template-columns:repeat(3,minmax(0,1fr));gap:.45rem;display:grid}.battle-mobile-tabs .battle-tab-button{background:#ffffff0a}.battle-mobile-dock .battle-end-turn-button{flex:1}.battle-tab-button{font-size:.9rem}.battle-tool-list{flex-wrap:nowrap}}@media (height<=420px) and (width<=900px){.shell.battle-shell{width:min(100% - .75rem,100%);min-height:auto;max-height:none;padding:.35rem 0 5.5rem;display:block;overflow:visible}.shell.battle-shell .hero-panel{display:none}.shell.battle-shell .main-grid{grid-template-columns:1fr;gap:.45rem}.shell.battle-shell .board-wrap{border-radius:22px;gap:.4rem;padding:.45rem}.shell.battle-shell .board-stage{width:min(100%,290px)}.shell.battle-shell .battle-board-banner,.shell.battle-shell .battle-board-prompt,.shell.battle-shell #battle-hud-bottom{display:none}.shell.battle-shell .battle-top-hud{padding:.45rem .55rem}.shell.battle-shell .battle-top-bar{grid-template-columns:repeat(5,minmax(0,1fr));align-items:stretch;gap:.35rem}.shell.battle-shell .battle-top-encounter,.shell.battle-shell .battle-top-message{grid-column:1/-1}.shell.battle-shell .battle-top-chip,.shell.battle-shell .battle-top-encounter,.shell.battle-shell .battle-top-message{border-radius:12px;padding:.35rem .45rem}.shell.battle-shell .battle-top-chip span,.shell.battle-shell .battle-top-encounter .eyebrow,.shell.battle-shell .battle-top-message .eyebrow{font-size:.62rem}.shell.battle-shell .battle-top-chip strong,.shell.battle-shell .battle-top-encounter strong,.shell.battle-shell .battle-top-message strong{font-size:.9rem}.shell.battle-shell .battle-top-message strong{white-space:nowrap}.shell.battle-shell .sidebar{box-shadow:none;background:0 0;border:0;padding:0;display:block;overflow:visible}.shell.battle-shell .battle-context-header,.shell.battle-shell .battle-mobile-sheet-header,.shell.battle-shell .battle-tab-bar,.shell.battle-shell .battle-panel-region,.shell.battle-shell .battle-sidebar-footer{display:none}.shell.battle-shell .battle-mobile-dock{z-index:12;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:linear-gradient(#363c2ffa,#1c2119f7),#efe1c214;border:1px solid #e1b56a38;border-radius:18px;gap:.35rem;padding:.45rem;display:grid;position:fixed;bottom:.375rem;left:.375rem;right:.375rem;box-shadow:0 20px 48px #00000073}.shell.battle-shell .battle-mobile-tabs{grid-template-columns:repeat(3,minmax(0,1fr));gap:.35rem;display:grid}.shell.battle-shell .battle-mobile-tabs .battle-tab-button{background:#ffffff0a;padding:.42rem .25rem;font-size:.84rem}.shell.battle-shell .battle-mobile-dock .split-row{gap:.45rem}.shell.battle-shell .battle-mobile-dock .split-row strong,.shell.battle-shell .battle-mobile-dock .pill{font-size:.84rem}.shell.battle-shell .battle-mobile-dock .battle-tutorial-strip{display:none}.shell.battle-shell .battle-tool-list{gap:.35rem;padding-bottom:0}.shell.battle-shell .tool-chip{padding:.5rem .7rem}.shell.battle-shell .battle-mobile-dock .button-row{flex-direction:row;gap:.35rem}.shell.battle-shell .battle-mobile-dock .battle-end-turn-button,.shell.battle-shell .battle-mobile-dock .compact-button{min-height:44px}.shell.battle-shell.mobile-detail-open .sidebar{z-index:14;background:linear-gradient(#353a2dfa,#181d16f7),#141612f5;border-radius:20px;height:min(52vh,188px);padding:.5rem;position:fixed;bottom:4.75rem;left:.375rem;right:.375rem;overflow:hidden;box-shadow:0 18px 48px #0006}.shell.battle-shell.mobile-detail-open .battle-mobile-dock{display:none}.shell.battle-shell.mobile-detail-open .battle-mobile-sheet-header{z-index:2;background:linear-gradient(#353a2dfa,#353a2df0);padding-bottom:.25rem;display:flex;position:sticky;top:0}.shell.battle-shell.mobile-detail-open .battle-tab-bar,.shell.battle-shell.mobile-detail-open .battle-panel-region{display:grid}.shell.battle-shell.mobile-detail-open .battle-sidebar-layout{grid-template-rows:auto auto minmax(0,1fr);gap:.35rem;height:100%}.shell.battle-shell.mobile-detail-open .battle-tab-bar{z-index:2;gap:.35rem;padding:.2rem;position:sticky;top:2.3rem}.shell.battle-shell.mobile-detail-open .battle-tab-button{padding:.42rem .4rem;font-size:.84rem}.shell.battle-shell.mobile-detail-open .battle-panel-region{padding-bottom:.25rem;padding-right:.1rem;overflow:auto}.shell.battle-shell.mobile-detail-open .battle-tab-panel .card{border-radius:16px;padding:.7rem}.shell.battle-shell.mobile-detail-open .battle-intent-row{padding:.35rem .45rem}.shell.battle-shell.mobile-detail-open .log-list,.shell.battle-shell.mobile-detail-open .battle-log-compact{max-height:none}}@media (height<=930px) and (width>=721px){.shell.battle-shell{padding:.25rem 0 .35rem}.shell.battle-shell .hero-panel{gap:.75rem;margin-bottom:.4rem;padding:.45rem .7rem}.shell.battle-shell .hero-panel h1{margin-bottom:.08rem;font-size:1.02rem}.shell.battle-shell .hero-panel .lede{white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;line-height:1.1;overflow:hidden}.shell.battle-shell .main-grid{gap:.6rem}.shell.battle-shell .board-wrap,.shell.battle-shell .sidebar{max-height:calc(100svh - .55rem)}.shell.battle-shell .board-wrap{gap:.45rem;padding:.65rem}.shell.battle-shell .board-stage{width:min(100%,clamp(450px,100svh - 27rem,508px))}.shell.battle-shell .battle-top-hud,.shell.battle-shell .battle-bottom-hud{padding:.45rem .55rem}.shell.battle-shell .battle-top-bar,.shell.battle-shell .battle-bottom-row{gap:.38rem}.shell.battle-shell .battle-top-encounter,.shell.battle-shell .battle-top-chip,.shell.battle-shell .battle-top-message,.shell.battle-shell .battle-bottom-summary,.shell.battle-shell .battle-bottom-tools{padding:.42rem .52rem}.shell.battle-shell .battle-top-bar{grid-template-columns:auto repeat(5,minmax(64px,auto)) minmax(150px,1fr)}.shell.battle-shell .battle-bottom-row{grid-template-columns:minmax(180px,.72fr) minmax(0,1fr) auto}.shell.battle-shell .battle-banner-card,.shell.battle-shell .battle-prompt-card{padding:.42rem .55rem}.shell.battle-shell .sidebar{padding:.65rem}.shell.battle-shell .battle-sidebar-layout{gap:.45rem}.shell.battle-shell .card,.shell.battle-shell .battle-sidebar-footer{padding:.6rem}.shell.battle-shell .battle-sidebar-footer .button-row{gap:.35rem}.shell.battle-shell .battle-end-turn-button{min-width:118px}}@container (width<=860px){.battle-top-bar{grid-template-columns:repeat(3,minmax(0,1fr))}.battle-top-encounter,.battle-top-message{grid-column:1/-1}.battle-bottom-row{grid-template-columns:1fr}.battle-bottom-actions{grid-template-columns:repeat(2,minmax(0,1fr))}}@container (width<=620px){.battle-top-bar{grid-template-columns:repeat(2,minmax(0,1fr))}.battle-bottom-actions{grid-template-columns:1fr}}
