:root{--ink: #23180e;--muted: #765b36;--paper: #f1dfb9;--paper-deep: #d7b879;--wood: #4a2d18;--wood-dark: #1f130c;--gold: #f0bd45;--blue: #1f66b2;--blue-dark: #12365d;--red: #a72d24;--red-dark: #5e1712;--green: #4e8d3f;--purple: #7141a6;color:var(--ink);font-family:Inter,Microsoft YaHei,PingFang SC,system-ui,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}html,body,#root{width:100%;min-height:100%;margin:0}body{background:linear-gradient(90deg,rgba(255,240,184,.06) 1px,transparent 1px),linear-gradient(rgba(255,240,184,.04) 1px,transparent 1px),radial-gradient(circle at 30% 20%,#5d3b20 0,#1c120b 62%);background-size:34px 34px,34px 34px,cover;overflow-x:hidden}*{scrollbar-color:#c58a24 #211209;scrollbar-width:thin}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-track{border:2px solid #130804;border-radius:999px;background:linear-gradient(#3b2110,#160904)}*::-webkit-scrollbar-thumb{border:2px solid #130804;border-radius:999px;background:radial-gradient(circle at 35% 25%,rgba(255,255,255,.38),transparent 24%),linear-gradient(#ffe08a,#9b651d)}button,input{font:inherit}button{min-height:44px;border:2px solid #2b1a0f;border-radius:7px;background:linear-gradient(#f6d674,#b77a22);color:#201308;font-weight:800;cursor:pointer;box-shadow:inset 0 2px #ffffff59,inset 0 -3px #45230c4d,0 3px #1b1009;transition:transform .12s ease,filter .12s ease}button:hover:not(:disabled){filter:brightness(1.08);transform:translateY(-1px)}button:active:not(:disabled){transform:translateY(1px);box-shadow:inset 0 2px #2d16094d,0 1px #1b1009}button:disabled{cursor:not-allowed;filter:saturate(.72) brightness(.82);opacity:.86}button svg{width:20px;height:20px;vertical-align:middle}.app-shell{min-height:100vh}.parchment-panel{border:5px solid var(--wood);border-radius:8px;background:linear-gradient(#fffce480,#e5c47e5c),radial-gradient(circle at 20% 0%,rgba(255,255,255,.5),transparent 40%),var(--paper);box-shadow:0 0 0 2px #130c07,inset 0 0 0 2px #fff8cc73,0 12px 28px #00000047}.eyebrow{margin:0 0 5px;color:#f0bd45;font-size:.78rem;font-weight:900;letter-spacing:0;text-transform:uppercase;text-shadow:0 2px #1d1209}.icon-button{display:inline-flex;align-items:center;justify-content:center;width:48px;min-width:48px;padding:0}.primary-action{background:linear-gradient(#ffe07a,#df9b20);color:#1f1308}.danger-action{background:linear-gradient(#d95a4d,#822119);color:#fff2ce}.page-screen{width:min(1440px,100%);margin:0 auto;padding:24px}.page-header{display:flex;align-items:center;gap:18px;margin-bottom:20px;color:#fff1c4}.page-header h1{margin:0;font-size:clamp(2rem,3vw,3.3rem);line-height:1;text-shadow:0 4px #180d06}.narrow-page{max-width:980px}@media (max-width: 720px){.page-screen{padding:14px}.page-header h1{font-size:2rem}}.battle-screen.landscape-game{--top-hud-height: clamp(50px, 11.8svh, 70px);--bottom-hud-height: clamp(70px, 14.8svh, 100px);--safe-left: max(env(safe-area-inset-left), 8px);--safe-right: max(env(safe-area-inset-right), 8px);--safe-top: max(env(safe-area-inset-top), 4px);--safe-bottom: max(env(safe-area-inset-bottom), 6px);--ui-gold: #d9a441;--ui-gold-light: #ffe08a;--ui-gold-dark: #6b3e12;--ui-wood-dark: #160c05;--ui-wood-mid: #3c220f;--ui-wood-light: #7d4d20;--ui-blue: #1f68c8;--ui-red: #b63a2d;--ui-parchment: #ead39a;--ui-outline: #100804;--ui-radius-sm: 8px;--ui-radius-md: 12px;--ui-border: 2px;--ui-border-heavy: 4px;--touch-target: 42px;--font-xs: clamp(10px, 1.8svh, 12px);--font-sm: clamp(12px, 2.1svh, 14px);--font-md: clamp(14px, 2.5svh, 18px);--font-lg: clamp(20px, 4svh, 30px)}.menu-screen{min-height:100vh;display:grid;grid-template-columns:minmax(280px,620px) minmax(260px,360px);align-items:center;justify-content:center;gap:28px;padding:36px}.menu-hero{display:grid;grid-template-columns:96px 1fr;gap:22px;align-items:center;color:#fff1c4}.menu-hero h1{margin:0;font-size:clamp(3rem,7vw,6.2rem);line-height:.92;text-shadow:0 5px #1d1008,0 12px 24px rgba(0,0,0,.35)}.hero-copy{max-width:620px;color:#f8ddb0;font-size:1.12rem;line-height:1.7}.crest{display:grid;place-items:center;width:88px;height:108px;border:5px solid #29180d;border-radius:10px 10px 28px 28px;box-shadow:inset 0 0 0 3px #ffffff2e,0 8px #00000059}.crest-blue{background:linear-gradient(#347dcc,#174477);color:#f3c852}.menu-actions{display:grid;gap:12px;padding:22px}.menu-actions button,.settings-list button,.modal-actions button{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:12px 16px}.menu-stats{grid-column:1 / -1;display:grid;grid-template-columns:repeat(3,minmax(140px,220px));justify-content:center;gap:14px}.menu-stats div{padding:14px 18px;border:3px solid #2b1a0f;border-radius:8px;background:#120a05b8;color:#f8e6bd;text-align:center}.menu-stats strong{display:block;color:#ffd55a;font-size:2rem}.chapter-list{display:grid;gap:22px}.chapter-section{padding:18px}.chapter-title{display:flex;align-items:center;gap:14px;margin-bottom:14px}.chapter-title>span{display:grid;place-items:center;width:54px;height:54px;border:3px solid #2b1a0f;border-radius:8px;background:linear-gradient(#215f9b,#123b62);color:#ffe397;font-size:1.6rem;font-weight:900}.chapter-title h2,.chapter-title p{margin:0}.chapter-title p{color:var(--muted);font-weight:700}.level-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.level-card{position:relative;min-height:184px;padding:12px;border-color:#5a351b;background:linear-gradient(#fff0c5,#d2a65d);text-align:left}.level-card h3{margin:10px 0 8px;font-size:1.02rem}.level-card p{min-height:48px;margin:0;color:#654725;font-size:.84rem;line-height:1.45}.level-card-top{display:flex;justify-content:space-between;gap:10px}.level-card-top strong{display:grid;place-items:center;width:34px;height:34px;border-radius:7px;background:#123b62;color:#ffe397}.difficulty{align-self:start;padding:5px 8px;border-radius:6px;color:#fff6d2;font-size:.76rem;font-weight:900}.difficulty.easy{background:#427c45}.difficulty.normal{background:#1f66b2}.difficulty.hard{background:#a43a22}.difficulty.nightmare{background:#6d3e9d}.stars{display:flex;gap:2px;margin-top:10px;color:#d4911f}.level-action{position:absolute;right:10px;bottom:9px}.locked{opacity:.68}.battle-screen.landscape-game{width:100vw;height:100vh;min-width:900px;min-height:520px;display:grid;grid-template-columns:minmax(620px,1fr) 330px;grid-template-rows:72px minmax(0,1fr) 118px;grid-template-areas:"top top" "map side" "bottom bottom";gap:10px;padding:10px;overflow:hidden;background:radial-gradient(circle at 25% 10%,rgba(255,213,110,.18),transparent 24%),linear-gradient(135deg,#2b160b,#120906 45%,#3c2110)}.battle-screen.landscape-game button:hover:not(:disabled),.battle-screen.landscape-game button:active:not(:disabled){transform:none}.battle-topbar{grid-area:top;position:relative;display:grid;grid-template-columns:52px minmax(230px,1fr) 116px minmax(230px,1fr) 52px;align-items:center;gap:10px;padding:7px 10px;border:6px solid #120805;border-radius:9px;background:url(/assets/ui/wood_panel_horizontal.png) center / 100% 100% no-repeat,linear-gradient(90deg,rgba(255,221,119,.1) 1px,transparent 1px),linear-gradient(180deg,rgba(255,228,142,.18),transparent 36%),linear-gradient(180deg,#6a3d1e,#2c170b 48%,#120906);background-size:100% 100%,36px 100%,auto,auto;box-shadow:inset 0 0 0 2px #ffdc8052,inset 0 -8px #00000042,0 5px #070302;color:#fff0c4}.battle-topbar:before,.battle-topbar:after{content:"";position:absolute;top:50%;width:34px;height:48px;transform:translateY(-50%);border:4px solid #120805;background:linear-gradient(#f4c04b,#7a4916);box-shadow:inset 0 0 0 2px #ffffff38;pointer-events:none;z-index:0}.battle-topbar>*{position:relative;z-index:1}.battle-topbar:before{left:-2px;clip-path:polygon(0 0,100% 14%,72% 50%,100% 86%,0 100%)}.battle-topbar:after{right:-2px;clip-path:polygon(100% 0,0 14%,28% 50%,0 86%,100% 100%)}.game-icon-button{width:46px;height:46px;min-height:46px;display:grid;place-items:center;padding:0;border:4px solid #130804;border-radius:9px;background:radial-gradient(circle at 34% 22%,rgba(255,255,255,.42),transparent 24%),linear-gradient(#ffe18a,#b77822 64%,#6d3f10);box-shadow:inset 0 0 0 2px #ffeb9b73,inset 0 -5px #391d084d,0 3px #090403}.settings-top-button{justify-self:end;color:#2b160b}.faction-plaque{--progress: 50%;position:relative;min-width:0;display:flex;align-items:center;gap:9px;height:50px;padding:6px 12px;border:4px solid #130804;border-radius:8px;box-shadow:inset 0 1px #ffffff42,inset 0 -5px #00000047,0 3px #00000059;overflow:hidden}.faction-plaque:after{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border:2px solid rgba(255,226,132,.28);border-radius:5px;pointer-events:none}.faction-plaque>div{min-width:0;flex:1}.faction-plaque.player{background:radial-gradient(circle at 14% 22%,rgba(143,215,255,.45),transparent 22%),linear-gradient(90deg,#123b78,#1f6fd1 62%,#0f315f)}.faction-plaque.enemy{justify-content:flex-end;background:radial-gradient(circle at 85% 22%,rgba(255,170,118,.4),transparent 22%),linear-gradient(90deg,#741912,#c7352b 58%,#7a1a14)}.faction-plaque svg{color:#ffd96a;filter:drop-shadow(0 2px #180c05)}.faction-plaque strong,.level-plaque h1{display:block;overflow:hidden;color:#fff5c9;text-overflow:ellipsis;white-space:nowrap;text-shadow:0 2px #160a04}.faction-plaque span,.level-plaque span{display:block;overflow:hidden;color:#ffd96a;font-size:.78rem;font-weight:900;text-overflow:ellipsis;white-space:nowrap}.faction-progress{height:8px;margin-top:4px;overflow:hidden;border:2px solid #130804;border-radius:8px;background:#140a058c;box-shadow:inset 0 1px #ffffff2e}.faction-progress i{display:block;width:var(--progress);height:100%;border-radius:inherit;background:linear-gradient(90deg,#8fd7ff,#1f6fd1);box-shadow:inset 0 1px #ffffff8f,0 0 10px #8fd7ff73}.faction-plaque.enemy .faction-progress i{margin-left:auto;background:linear-gradient(90deg,#ff9272,#c7352b);box-shadow:inset 0 1px #ffffff7a,0 0 10px #ff6e526b}.level-plaque{min-width:0;align-self:stretch;display:grid;place-items:center;padding:2px 8px;text-align:center}.level-plaque h1{margin:0;font-size:clamp(1.12rem,2.1vw,1.75rem);line-height:1}.top-timer{justify-self:center;min-width:104px;padding:8px 14px;border:5px solid #120805;border-radius:8px 8px 16px 16px;background:radial-gradient(circle at 36% 18%,rgba(255,236,164,.34),transparent 22%),linear-gradient(#7b4b22,#2a150a 54%,#100604);color:#ffe8a6;text-align:center;font-size:1.25rem;font-weight:950;text-shadow:0 3px #130804;box-shadow:inset 0 0 0 2px #ffda804d,0 4px #070302}.top-stars{display:flex;gap:1px;color:#ffd96a}.top-stars svg{width:17px;height:17px}.battle-map-panel{grid-area:map;min-width:0;min-height:0;padding:7px;border:6px solid #1c1008;border-radius:12px;background:linear-gradient(180deg,rgba(255,228,142,.22),transparent 36%),linear-gradient(#7d4d25,#241309);box-shadow:inset 0 0 0 2px #ffda8047,0 7px #090403}.game-canvas{width:100%;height:100%;display:block;border:4px solid #110805;border-radius:8px;background:#78994e;touch-action:none}.medieval-panel{border:7px solid #120805;border-radius:12px;background:url(/assets/ui/parchment_panel.png) center / cover no-repeat,linear-gradient(90deg,rgba(99,58,24,.08) 1px,transparent 1px),radial-gradient(circle at 35% 0%,rgba(255,255,255,.32),transparent 28%),linear-gradient(180deg,#f6e6bd,#d8b879);background-size:cover,22px 22px,auto,auto;box-shadow:inset 0 0 0 2px #fffada73,inset 0 0 0 6px #75481d38,0 7px #090403;color:#29170b}.medieval-panel__header,.medieval-panel__body{position:relative;z-index:1}.medieval-tooltip{max-width:min(280px,calc(100vw - 32px));padding:9px 11px;border:4px solid #130804;border-radius:9px;background:linear-gradient(180deg,#fff7ccb8,#e0bb6fc7),url(/assets/ui/parchment_panel.png) center / cover no-repeat;color:#2a170b;font-size:var(--font-xs, 12px);font-weight:900;line-height:1.35;box-shadow:inset 0 0 0 2px #fff2b87a,0 6px #090402b8,0 14px 24px #00000061}.icon-frame,.status-badge{display:inline-flex;align-items:center;justify-content:center;border:3px solid #130804;box-shadow:inset 0 0 0 2px #ffe89452,0 3px #00000057}.icon-frame{width:44px;min-width:44px;height:44px;border-radius:10px;background:radial-gradient(circle at 34% 24%,rgba(255,255,255,.42),transparent 24%),linear-gradient(#ffe08a,#9b651d)}.status-badge{min-height:24px;padding:3px 7px;border-radius:8px;color:#fff4c8;font-size:.7rem;font-weight:950;line-height:1;text-shadow:0 2px #130804}.status-badge--gold{background:linear-gradient(#ffe08a,#9b651d);color:#211207;text-shadow:0 1px rgba(255,255,255,.42)}.status-badge--blue{background:linear-gradient(#2d7de0,#123b78)}.status-badge--red{background:linear-gradient(#d44a3c,#741912)}.status-badge--green{background:linear-gradient(#76bd4c,#255f1f)}.status-badge--locked{background:repeating-linear-gradient(-45deg,rgba(255,226,132,.18) 0 5px,transparent 5px 10px),linear-gradient(#5f513d,#24170d)}.battle-side-panel{grid-area:side;min-height:0;display:grid;grid-template-rows:auto 104px auto 86px auto minmax(146px,1fr);gap:6px;padding:8px;overflow:hidden}.medieval-title-bar{position:relative;min-height:33px;display:flex;align-items:center;justify-content:center;padding:5px 10px;border:4px solid #130804;border-radius:7px;color:#fff2c4;font-weight:950;text-align:center;text-shadow:0 2px #120804;box-shadow:inset 0 1px #ffffff38,inset 0 -5px #00000047,0 2px #0000004d}.medieval-title-bar:before,.medieval-title-bar:after{content:"";position:absolute;top:50%;width:16px;height:26px;transform:translateY(-50%);background:inherit;border:3px solid #130804;z-index:-1}.medieval-title-bar:before{left:-11px;clip-path:polygon(0 0,100% 18%,78% 50%,100% 82%,0 100%)}.medieval-title-bar:after{right:-11px;clip-path:polygon(100% 0,0 18%,22% 50%,0 82%,100% 100%)}.red-title{background:linear-gradient(90deg,#6f1a14,#c0392c)}.blue-title{background:linear-gradient(90deg,#123b78,#1f6fd1)}.purple-title{background:linear-gradient(90deg,#38194c,#7740ad)}.side-unit-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:5px}.unit-showcase-board{position:relative;min-height:104px;overflow:hidden;border:5px solid #130804;border-radius:10px;background:linear-gradient(180deg,rgba(255,255,255,.18),transparent 42%),url(/assets/units/unit_lineup_showcase.png) center / cover no-repeat;box-shadow:inset 0 0 0 2px #ffe78e5c,inset 0 -10px #2311072e,0 4px #0a04027a}.unit-showcase-board:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(90deg,transparent 19.6%,rgba(73,48,21,.26) 19.9% 20.2%,transparent 20.5% 39.6%,rgba(73,48,21,.24) 39.9% 40.2%,transparent 40.5% 59.6%,rgba(73,48,21,.24) 59.9% 60.2%,transparent 60.5% 79.6%,rgba(73,48,21,.24) 79.9% 80.2%,transparent 80.5%),radial-gradient(circle at 35% 12%,rgba(255,255,255,.28),transparent 24%)}.unit-showcase-hotspot{position:absolute;top:0;bottom:0;width:20%;min-width:0;padding:0 2px 5px;border:0;border-radius:0;background:transparent;color:#fff3bb;font-weight:950;text-shadow:0 2px 0 #130804,0 0 5px rgba(19,8,4,.9);cursor:pointer}.unit-showcase-hotspot.infantry{left:0%}.unit-showcase-hotspot.runner{left:20%}.unit-showcase-hotspot.guard{left:40%}.unit-showcase-hotspot.rider{left:60%}.unit-showcase-hotspot.engineer{left:80%}.unit-showcase-hotspot strong,.unit-showcase-hotspot span{position:absolute;left:4px;right:4px;z-index:2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;pointer-events:none}.unit-showcase-hotspot strong{bottom:17px;font-size:.66rem}.unit-showcase-hotspot span{bottom:4px;color:#ffe8a0;font-size:.52rem}.unit-showcase-hotspot.selected{box-shadow:inset 0 0 0 4px #ffe18a,inset 0 0 0 7px #1f6fd1,0 0 18px #ffe18ab8}.unit-showcase-hotspot:disabled{cursor:not-allowed}.unit-showcase-hotspot:disabled:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;background:#261f1457;-webkit-backdrop-filter:grayscale(.55);backdrop-filter:grayscale(.55)}.unit-token{min-width:0;min-height:82px;display:grid;place-items:center;gap:2px;padding:5px 3px 4px;border-width:4px;border-radius:8px;background:radial-gradient(circle at 35% 20%,rgba(255,255,255,.36),transparent 24%),linear-gradient(#ffe8a8,#c8903f 58%,#6e3e17);font-size:.68rem;overflow:hidden}.unit-portrait-canvas{width:40px!important;height:40px!important;display:block;overflow:hidden;border:3px solid #160b05;border-radius:50%;background:radial-gradient(circle at 35% 24%,rgba(255,255,255,.42),transparent 25%),linear-gradient(#f1d28b,#704018);box-shadow:inset 0 0 0 2px #ffe28461,0 3px #00000061}.unit-portrait{position:relative;width:34px;height:34px;display:block;border:3px solid #160b05;border-radius:50%;background:radial-gradient(circle at 38% 25%,rgba(255,255,255,.38),transparent 24%),linear-gradient(#2c7bd6,#123b78);box-shadow:inset 0 0 0 2px #ffe28452,0 2px #00000059}.unit-head,.unit-body,.unit-gear{position:absolute;left:50%;transform:translate(-50%);display:block}.unit-head{top:5px;width:12px;height:10px;border:2px solid #160b05;border-radius:50% 50% 45% 45%;background:#f0c18a}.unit-body{top:15px;width:16px;height:13px;border:2px solid #160b05;border-radius:5px 5px 7px 7px;background:#236dc4}.unit-gear{top:14px;width:23px;height:16px;border-bottom:3px solid #f0bd45}.unit-portrait.runner{background:radial-gradient(circle at 38% 25%,rgba(255,255,255,.32),transparent 24%),linear-gradient(#2f557f,#161514)}.unit-portrait.runner .unit-head{border-radius:50% 50% 35% 35%;background:#1f66b2}.unit-portrait.guard{background:radial-gradient(circle at 38% 25%,rgba(255,255,255,.4),transparent 24%),linear-gradient(#cfd6dc,#59616a)}.unit-portrait.guard .unit-body{width:19px;background:#687581}.unit-portrait.rider{background:radial-gradient(circle at 38% 25%,rgba(255,255,255,.34),transparent 24%),linear-gradient(#9a6732,#432514)}.unit-portrait.rider .unit-gear{top:20px;width:27px;height:8px;border:2px solid #160b05;border-radius:50%;background:#805027}.unit-portrait.engineer{background:radial-gradient(circle at 38% 25%,rgba(255,255,255,.32),transparent 24%),linear-gradient(#7fa23c,#4d6621)}.unit-portrait.engineer .unit-head{background:#d19a62}.unit-portrait.engineer .unit-gear{top:12px;width:25px;border-bottom-color:#c58a24;transform:translate(-50%) rotate(-28deg)}.unit-token strong,.unit-token span{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.unit-token span{color:#6d4b25;font-size:.62rem;text-shadow:0 1px rgba(255,255,255,.35)}.castle-info-card{min-height:0;display:grid;gap:5px;padding:9px;border:3px solid rgba(73,48,21,.55);border-radius:9px;background:linear-gradient(90deg,rgba(91,55,22,.07) 1px,transparent 1px),radial-gradient(circle at 20% 5%,rgba(255,255,255,.52),transparent 28%),linear-gradient(#fff0c8,#e2c47d);background-size:18px 18px,auto,auto;box-shadow:inset 0 0 0 2px #ffffff52,inset 0 -8px #5b37171a;overflow:hidden}.castle-info-card:has(.castle-mini),.castle-info-card:has(.castle-portrait-canvas){grid-template-columns:92px 1fr;gap:2px 7px;align-items:center;min-height:98px;padding:6px 7px}.castle-info-card.empty{grid-template-columns:92px 1fr;min-height:0;padding:4px 8px}.empty-castle-hint{grid-column:1;display:grid;place-items:center;overflow:hidden}.castle-portrait-canvas{grid-row:1 / span 5;grid-column:1;justify-self:center;width:104px;height:88px;margin:-13px -7px -10px;object-fit:contain;object-position:center bottom;transform:scale(1.14);transform-origin:center bottom;filter:drop-shadow(0 5px 0 rgba(42,25,13,.22))}.empty-castle-hint .castle-portrait-canvas{grid-row:auto;grid-column:auto;transform:scale(1.06);transform-origin:center}.empty-castle-hint .castle-mini{grid-row:auto;grid-column:auto;transform:scale(.82);transform-origin:center}.castle-info-card.empty p{grid-column:2;align-self:center;margin:0;color:#5f3d1b;font-size:.64rem;line-height:1.45;text-align:left}.castle-mini{position:relative;grid-row:1 / span 5;grid-column:1;justify-self:center;width:72px;height:48px;margin:-3px 0 0;border-bottom:8px solid rgba(36,21,10,.22)}.castle-mini span{position:absolute;display:block}.castle-mini .mini-keep,.castle-mini .mini-tower{bottom:8px;border:3px solid #1d1208;background:linear-gradient(#eee5cc,#a9a391 70%,#6d6a60);box-shadow:inset 3px 0 #ffffff47}.castle-mini .mini-keep{left:27px;width:32px;height:38px;border-radius:7px 7px 4px 4px}.castle-mini .mini-tower{width:22px;height:34px;border-radius:7px 7px 4px 4px}.castle-mini .mini-tower.left{left:8px}.castle-mini .mini-tower.right{right:8px}.castle-mini .mini-keep:before,.castle-mini .mini-tower:before{content:"";position:absolute;left:50%;top:-18px;width:28px;height:22px;transform:translate(-50%);clip-path:polygon(50% 0,100% 100%,0 100%);border:3px solid #1d1208;background:linear-gradient(#7cc4ff,#1f67c1 60%,#123b6d)}.castle-mini .mini-gate{left:36px;bottom:8px;width:14px;height:22px;border:3px solid #1d1208;border-bottom:0;border-radius:10px 10px 2px 2px;background:#4b2714}.castle-mini .mini-flag{left:42px;top:0;width:26px;height:16px;border:2px solid #1d1208;border-left-width:4px;border-radius:2px 8px 8px 2px;background:#1f65bd}.castle-mini.enemy .mini-keep:before,.castle-mini.enemy .mini-tower:before{background:linear-gradient(#ff9272,#c73529 60%,#741912)}.castle-mini.enemy .mini-flag{background:#bd2f27}.castle-mini.neutral .mini-keep:before,.castle-mini.neutral .mini-tower:before{background:linear-gradient(#d1c9ad,#77736a 60%,#444139)}.castle-mini.neutral .mini-flag{background:#706c62}.castle-mini.magic .mini-keep{box-shadow:0 0 15px #955dff94,inset 3px 0 #ffffff47}.castle-mini.boss .mini-keep,.castle-mini.boss .mini-tower{background:linear-gradient(#777179,#3d3841 66%,#161018)}.castle-mini.boss .mini-keep:before,.castle-mini.boss .mini-tower:before{background:linear-gradient(#d8a5ff,#2b142f 60%,#24102f)}.castle-info-card>strong{grid-column:2;color:#241208;font-size:.78rem;line-height:1.1}.castle-info-card>span,.castle-info-card p{grid-column:2;margin:0;color:#65431e;font-size:.64rem;font-weight:800;line-height:1.35}.castle-stat-bar{grid-column:2;display:flex;justify-content:space-between;gap:8px;padding:2px 7px;border:2px solid rgba(42,25,13,.25);border-radius:6px;background:linear-gradient(180deg,rgba(255,255,255,.34),transparent 45%),linear-gradient(90deg,#4c2f131f,#ffffff29);font-size:.62rem;font-weight:900}.castle-meter{grid-column:1 / -1;height:10px;overflow:hidden;border:2px solid #2b1a0f;border-radius:9px;background:#36211047}.castle-meter:before{content:"";display:block;width:var(--meter);height:100%;border-radius:inherit;background:linear-gradient(90deg,#1f6fd1,#8fd7ff);box-shadow:inset 0 1px #ffffff73}.castle-info-card:has(.castle-mini.enemy) .castle-meter:before{background:linear-gradient(90deg,#c7352b,#ff9272)}.castle-info-card:has(.castle-mini.neutral) .castle-meter:before{background:linear-gradient(90deg,#706c62,#d1c9ad)}.side-skill-list{min-height:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:5px;overflow:hidden}.skill-showcase-board{position:relative;min-height:0;overflow:hidden;border:5px solid #130804;border-radius:10px;background:linear-gradient(180deg,rgba(255,255,255,.14),transparent 38%),url(/assets/skills/skill_fx_showcase.png) center / cover no-repeat;box-shadow:inset 0 0 0 2px #ffe78e5c,inset 0 -12px #2311073d,0 4px #0a04027a}.skill-showcase-board:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(90deg,transparent 19.6%,rgba(73,48,21,.28) 19.9% 20.2%,transparent 20.5% 39.6%,rgba(73,48,21,.24) 39.9% 40.2%,transparent 40.5% 59.6%,rgba(73,48,21,.24) 59.9% 60.2%,transparent 60.5% 79.6%,rgba(73,48,21,.24) 79.9% 80.2%,transparent 80.5%),linear-gradient(180deg,transparent 55%,rgba(33,18,9,.56))}.skill-showcase-label{position:absolute;bottom:4px;z-index:2;width:20%;text-align:center;color:#fff3bb;text-shadow:0 2px 0 #130804,0 0 6px rgba(19,8,4,.9);pointer-events:none}.skill-showcase-label.reinforce{left:0%}.skill-showcase-label.fireball{left:20%}.skill-showcase-label.freeze{left:40%}.skill-showcase-label.haste{left:60%}.skill-showcase-label.shield{left:80%}.skill-showcase-label strong,.skill-showcase-label span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.skill-showcase-label strong{font-size:.6rem}.skill-showcase-label span{color:#ffe18a;font-size:.52rem;font-weight:950}.skill-note{position:relative;box-sizing:border-box;display:grid;grid-template-columns:32px 1fr;gap:6px;align-items:center;min-height:39px;overflow:hidden;padding:3px 6px;border:3px solid rgba(73,48,21,.64);border-radius:8px;background:linear-gradient(90deg,#fff6d6f5,#f4d9a0b8),radial-gradient(circle at 88% 38%,rgba(255,255,255,.44),transparent 22%);box-shadow:inset 0 1px #ffffff94,inset 0 -5px #5b37171a}.skill-note:before,.skill-note:after{content:"";position:absolute;pointer-events:none}.skill-note:before{right:-10px;bottom:-13px;width:62px;height:34px;border:3px solid rgba(42,25,13,.38);border-radius:50%;opacity:.42}.skill-note.reinforce:before,.skill-note.fireball:before,.skill-note.freeze:before,.skill-note.haste:before,.skill-note.shield:before{right:-18px;bottom:-25px;width:84px;height:84px;border:0;border-radius:0;background-repeat:no-repeat;background-position:center;background-size:contain;opacity:.32}.skill-note.reinforce:before{background-image:url(/assets/skills/reinforce_fx.png)}.skill-note.fireball:before{background-image:url(/assets/skills/fireball_fx.png)}.skill-note.freeze:before{background-image:url(/assets/skills/freeze_fx.png)}.skill-note.haste:before{background-image:url(/assets/skills/haste_fx.png)}.skill-note.shield:before{background-image:url(/assets/skills/shield_fx.png)}.skill-note:after{right:9px;top:6px;width:26px;height:26px;border-radius:50%;opacity:.72}.skill-note.reinforce:after{background:radial-gradient(circle,#e8fbff 0 18%,#2f82d8 42%,transparent 70%);box-shadow:0 0 18px #48abff6b}.skill-note.fireball:after{background:radial-gradient(circle,#fff7ae 0 14%,#ef6723 44%,transparent 72%);box-shadow:0 0 18px #ff5c1c7a}.skill-note.freeze:after{background:linear-gradient(90deg,transparent 45%,#e6fbff 45% 55%,transparent 55%),linear-gradient(30deg,transparent 45%,#c6f4ff 45% 55%,transparent 55%),linear-gradient(-30deg,transparent 45%,#c6f4ff 45% 55%,transparent 55%);box-shadow:0 0 16px #78dcff8a}.skill-note.haste:after{border-radius:7px;background:#d2ff7f;clip-path:polygon(50% 0,100% 55%,68% 55%,68% 100%,32% 100%,32% 55%,0 55%);box-shadow:0 0 16px #9bff5b73}.skill-note.shield:after{border-radius:12px 12px 18px 18px;background:linear-gradient(#fff2a2,#d99018);clip-path:polygon(50% 0,96% 22%,78% 78%,50% 100%,22% 78%,4% 22%);box-shadow:0 0 16px #ffdc547a}.skill-note.shield{grid-column:1 / -1}.skill-note strong{position:relative;z-index:1;display:block;font-size:.7rem}.skill-note>div>span{position:relative;z-index:1;display:block;color:#65431e;max-height:1.2em;overflow:hidden;font-size:.55rem;font-weight:700;line-height:1.2}.battle-command-bar{grid-area:bottom;display:grid;grid-template-columns:180px 260px 230px minmax(360px,1fr);grid-template-rows:minmax(0,1fr);align-items:center;gap:8px;padding:8px 10px;border:7px solid #120805;border-radius:12px;background:url(/assets/ui/wood_panel_horizontal.png) center / 100% 100% no-repeat,linear-gradient(90deg,rgba(255,221,119,.08) 1px,transparent 1px),linear-gradient(180deg,rgba(255,229,135,.15),transparent 36%),linear-gradient(180deg,#5e3519,#231108 48%,#100704);background-size:100% 100%,34px 100%,auto,auto;box-shadow:inset 0 0 0 2px #ffda8040,inset 0 -8px #00000040,0 7px #090403;color:#fff1bd}.resource-strip,.command-group{display:flex;align-items:center;gap:7px;min-width:0}.resource-strip{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));align-content:center;gap:4px 6px}.resource-pill{min-height:29px;display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:3px 7px;border:4px solid #130804;border-radius:8px;background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.42),transparent 26%),linear-gradient(#f8d56d,#9a631d 62%,#5b3211);color:#211207;font-weight:950;box-shadow:inset 0 1px #ffffff59,inset 0 -3px #0003}.resource-icon{width:20px;height:20px;display:inline-block;flex:0 0 auto;background-position:center;background-repeat:no-repeat;background-size:contain;filter:drop-shadow(0 2px 0 rgba(20,8,3,.45))}.energy-icon{background-image:url(/assets/ui/energy_icon.png)}.gold-icon{background-image:url(/assets/ui/gold_icon.png)}.star-icon{background-image:url(/assets/ui/star_icon.png)}.resource-pill.energy{grid-column:1 / -1;background:linear-gradient(#8ddfff,#2478bc);color:#fff;text-shadow:0 2px #123b78}.resource-pill.stars{color:#fff0a6;text-shadow:0 2px #4b260d;gap:1px}.resource-pill.stars .resource-icon{width:17px;height:17px}.medieval-button{position:relative;min-height:42px;border:4px solid #130804;border-radius:8px;background:linear-gradient(180deg,rgba(255,255,255,.32),transparent 38%),linear-gradient(#7c522b,#2a160b);color:#fff1bd;font-weight:950;text-shadow:0 2px #130804;box-shadow:inset 0 0 0 2px #ffda804d,inset 0 -5px #0000004d,0 3px #0b0503}.medieval-button:hover:not(:disabled),.medieval-button.selected{filter:brightness(1.12);box-shadow:0 0 14px #ffd85c8c,inset 0 0 0 2px #ffeb9180,inset 0 -4px #00000042,0 3px #0b0503}.medieval-button.selected{background:linear-gradient(180deg,rgba(255,255,255,.38),transparent 38%),linear-gradient(#ffd96a,#a76d1f);color:#211207;text-shadow:0 1px rgba(255,255,255,.42)}.medieval-button:disabled{filter:saturate(.68) brightness(.8);opacity:.9}.is-selected{outline:0}.is-locked,.is-disabled{position:relative}.is-locked:after{pointer-events:none}.is-ready{filter:none}.percent-buttons{justify-content:center}.percent-button{min-width:56px;padding:7px 10px;background:radial-gradient(circle at 34% 20%,rgba(255,255,255,.42),transparent 24%),linear-gradient(#7a4a22,#221007 66%,#0f0603)}.action-buttons{justify-content:center}.icon-command{width:46px;padding:0}.icon-command.upgrade{background:linear-gradient(180deg,rgba(255,255,255,.32),transparent 38%),linear-gradient(#64b84b,#205a1d)}.speed-button{min-width:70px;display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:7px 9px}.skill-dock{display:grid;grid-template-columns:repeat(5,minmax(64px,1fr));gap:7px}.battle-tactics-panel{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:7px;min-width:0}.tactic-card{position:relative;min-width:0;min-height:78px;display:grid;grid-template-columns:34px minmax(0,1fr);align-items:center;gap:7px;overflow:hidden;padding:8px;border:3px solid #130704;border-radius:11px;background:radial-gradient(circle at 32% 18%,rgba(255,245,184,.32),transparent 23%),linear-gradient(180deg,rgba(255,224,129,.18),transparent 36%),linear-gradient(180deg,#70411e,#3b1c0d 58%,#170905);color:#fff0bd;text-align:left;text-shadow:0 2px #130804;box-shadow:inset 0 0 0 2px #ffda803b,inset 0 -7px #0000003d,0 3px #090403}.tactic-card:before{content:"";position:absolute;top:5px;right:5px;bottom:5px;left:5px;border:1px solid rgba(255,220,114,.24);border-radius:8px;pointer-events:none}.tactic-card svg{position:relative;z-index:1;width:30px;height:30px;padding:4px;border:2px solid rgba(255,220,114,.58);border-radius:9px;background:linear-gradient(#f8d16a,#8a561d);color:#2a1609;filter:drop-shadow(0 2px 0 rgba(10,4,2,.5))}.tactic-card span{position:relative;z-index:1;min-width:0;display:grid;gap:2px}.tactic-card small,.tactic-card strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tactic-card small{color:#f7c86a;font-size:.62rem;font-weight:900}.tactic-card strong{color:#fff4cb;font-size:.88rem;font-weight:950}.tactic-card.pending{box-shadow:0 0 16px #71cfff7a,inset 0 0 0 2px #9cdcff47,inset 0 -7px #0000003d,0 3px #090403}.tactic-card.pending svg{background:linear-gradient(#8be8ff,#2373c8);color:#081c36}.mobile-inline-panel{display:none}.skill-button{position:relative;min-width:0;min-height:78px;display:grid;grid-template-rows:1fr auto auto;place-items:center;gap:1px;overflow:hidden;padding:6px 5px 4px;border:3px solid #140704;border-radius:10px;background:radial-gradient(circle at 36% 18%,rgba(255,245,178,.46),transparent 19%),linear-gradient(180deg,rgba(255,223,124,.22),transparent 34%),linear-gradient(180deg,#8d5827,#5b3014 52%,#2b1208);color:#fff1bd;box-shadow:inset 0 0 0 2px #ffe28438,inset 0 -8px #2c130738,0 3px #090403;text-shadow:0 2px #130804}.skill-button:before{content:"";position:absolute;inset:5px 6px auto;height:24px;border-radius:8px 8px 14px 14px;background:linear-gradient(180deg,#fff6b242,#fff6b200);pointer-events:none}.skill-button:after{content:"";position:absolute;z-index:1;top:9px;right:8px;bottom:22px;left:8px;border:2px solid rgba(255,219,102,.58);border-radius:12px;background:radial-gradient(circle at 50% 38%,#ffe88f94,#b76c278c 44%,#5d301157 76%),linear-gradient(180deg,#fff4b14d,#5d301129);box-shadow:inset 0 2px #fffcca3d,inset 0 -4px #50210b33;pointer-events:none}.skill-button:hover:not(:disabled),.skill-button.selected{filter:brightness(1.08);box-shadow:0 0 18px #ffd85c7a,inset 0 0 0 2px #ffefa461,0 3px #090403}.skill-button .skill-icon{position:relative;z-index:2;width:54px;height:54px;display:grid;place-items:center;border:0;border-radius:50%;overflow:visible;background:transparent;box-shadow:none}.skill-glyph-canvas{position:relative;z-index:2;width:54px!important;height:54px!important;display:block;object-fit:contain;filter:drop-shadow(0 3px 0 rgba(0,0,0,.45))}.skill-note .skill-glyph-canvas{width:28px!important;height:28px!important}.skill-glyph{position:relative;width:30px;height:30px;display:block;border:3px solid #130804;border-radius:50%;background:radial-gradient(circle at 35% 25%,rgba(255,255,255,.55),transparent 22%),radial-gradient(circle at 50% 55%,#2f82d8,#123f76 72%);box-shadow:inset 0 0 0 2px #ffda8057,0 2px #00000047}.skill-icon .skill-glyph{width:30px;height:30px;border:0;box-shadow:none;background:transparent}.glyph-core,.glyph-mark{position:absolute;display:block}.glyph-core{top:7px;right:7px;bottom:7px;left:7px;border-radius:50%}.skill-glyph.reinforce{background:radial-gradient(circle at 35% 25%,#dff8ff,#2f82d8 48%,#123f76)}.skill-glyph.reinforce .glyph-core{border:3px solid #e8fbff;border-top-color:transparent}.skill-glyph.reinforce .glyph-mark{bottom:7px;width:4px;height:13px;border-radius:4px;background:#e8fbff}.skill-glyph.reinforce .glyph-mark.a{left:9px}.skill-glyph.reinforce .glyph-mark.b{left:14px;height:17px}.skill-glyph.reinforce .glyph-mark.c{left:19px}.skill-glyph.fireball{background:radial-gradient(circle at 35% 25%,#ffe9a2,#ef6723 48%,#84220e)}.skill-glyph.fireball .glyph-core{top:6px;right:8px;bottom:5px;left:8px;border-radius:65% 35%;background:linear-gradient(135deg,#fff3a4,#ff7b23 45%,#b9260f);transform:rotate(36deg)}.skill-glyph.fireball .glyph-mark{left:3px;top:14px;width:15px;height:4px;border-radius:4px;background:#ffe780db;transform:rotate(-28deg)}.skill-glyph.freeze{background:radial-gradient(circle at 35% 25%,#e6fbff,#38a7e8 48%,#125179)}.skill-glyph.freeze .glyph-core{top:5px;right:13px;bottom:5px;left:13px;border-radius:4px;background:#e6fbff}.skill-glyph.freeze .glyph-mark{left:6px;top:13px;width:18px;height:4px;border-radius:4px;background:#e6fbff}.skill-glyph.freeze .glyph-mark.a{transform:rotate(0)}.skill-glyph.freeze .glyph-mark.b{transform:rotate(60deg)}.skill-glyph.freeze .glyph-mark.c{transform:rotate(-60deg)}.skill-glyph.haste{background:radial-gradient(circle at 35% 25%,#e7ff9b,#6fc240 48%,#245b21)}.skill-glyph.haste .glyph-core,.skill-glyph.haste .glyph-mark{width:6px;height:17px;bottom:6px;border-radius:4px;background:#e9ff8c}.skill-glyph.haste .glyph-core{left:7px}.skill-glyph.haste .glyph-mark.a{left:13px;height:21px}.skill-glyph.haste .glyph-mark.b{left:19px}.skill-glyph.haste .glyph-mark.c{left:9px;top:6px;width:13px;height:13px;clip-path:polygon(50% 0,100% 68%,67% 68%,67% 100%,33% 100%,33% 68%,0 68%)}.skill-glyph.shield{background:radial-gradient(circle at 35% 25%,#fff7b8,#efbd35 50%,#8c5b13)}.skill-glyph.shield .glyph-core{top:6px;right:8px;bottom:5px;left:8px;border-radius:8px 8px 12px 12px;background:linear-gradient(#fff2a2,#d99018);clip-path:polygon(50% 0,96% 22%,78% 78%,50% 100%,22% 78%,4% 22%)}.skill-glyph.shield .glyph-mark{left:14px;top:8px;width:3px;height:18px;border-radius:3px;background:#ffffff9e}.skill-button.fireball .skill-icon{background:radial-gradient(circle at 35% 25%,#ffd96a,#ef6723 48%,#84220e)}.skill-button.freeze .skill-icon{background:radial-gradient(circle at 35% 25%,#c6f4ff,#38a7e8 50%,#125179)}.skill-button.haste .skill-icon{background:radial-gradient(circle at 35% 25%,#d2ff7f,#6fc240 50%,#245b21)}.skill-button.shield .skill-icon{background:radial-gradient(circle at 35% 25%,#fff2a2,#efbd35 50%,#8c5b13)}.skill-button:disabled{filter:brightness(.9);opacity:.94}.skill-button:disabled .skill-glyph-canvas{filter:drop-shadow(0 3px 0 rgba(0,0,0,.45)) saturate(.92) brightness(.9)}.skill-button strong{position:relative;z-index:2;font-size:.78rem}.skill-button small{position:relative;z-index:2;color:#ffd96a;font-size:.7rem;font-weight:950}.skill-button>i{position:absolute;z-index:4;inset:auto 0 0;display:block;background:radial-gradient(circle at 50% 8%,rgba(255,224,126,.16),transparent 22%),#411f0cb3;border-top:2px solid rgba(255,226,132,.28)}.skill-button.selected{box-shadow:0 0 18px #8fd7ffd9,0 0 7px #ffefa4b8,inset 0 0 0 2px #ffffff57,0 3px #090403}.command-message{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}.rotate-overlay{display:none}.rotate-card{width:min(360px,calc(100vw - 36px));display:grid;place-items:center;gap:10px;padding:24px;border:6px solid #1c1008;border-radius:14px;background:linear-gradient(#f6e6bd,#d8b879);color:#29170b;text-align:center;box-shadow:0 18px 40px #00000073}.rotate-card svg{color:#c58a24}.tech-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.tech-card,.settings-list,.help-content{display:grid;gap:12px;padding:16px}.tech-card-top{display:grid;grid-template-columns:50px minmax(0,1fr) auto;align-items:center;gap:10px}.tech-card h2,.help-content h2{margin:0}.tech-card h2{overflow:hidden;font-size:1.35rem;line-height:1.1;text-overflow:ellipsis;white-space:nowrap}.tech-card p,.help-content p{margin:0;color:#5d4528;line-height:1.6}.tech-card{position:relative;overflow:hidden;border-width:5px;background:linear-gradient(180deg,#ffffff57,#f4d99a57 42%,#b17c352e),url(/assets/ui/parchment_panel.png) center / cover no-repeat,linear-gradient(#fff0c5,#d2a65d)}.tech-card:before{content:"";position:absolute;top:8px;right:8px;bottom:8px;left:8px;border:2px solid rgba(96,55,20,.28);border-radius:6px;pointer-events:none}.tech-card>*{position:relative;z-index:1}.tech-icon-frame{background:radial-gradient(circle at 36% 22%,rgba(255,255,255,.42),transparent 24%),linear-gradient(#2d7de0,#123b78);color:#ffe08a}.tech-level-badge{min-width:58px;padding:4px 7px;border:3px solid #130804;border-radius:8px;background:radial-gradient(circle at 35% 24%,rgba(255,255,255,.36),transparent 24%),linear-gradient(#ffe08a,#9b651d);color:#211207;font-size:.78rem;font-weight:950;text-align:center;box-shadow:inset 0 0 0 2px #ffefa46b,0 3px #00000047}.tech-card small{min-height:20px;display:block;color:#68431e;font-size:.76rem;font-weight:900}.tech-card small.ok{color:#2c5e28}.tech-card small.locked-text{color:#8a2d22}.tech-card .medieval-button{justify-self:stretch;display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:44px}.help-content{grid-template-columns:repeat(2,minmax(0,1fr))}.help-topic-card{display:grid;grid-template-columns:50px minmax(0,1fr);gap:10px;min-height:116px;padding:12px;border:3px solid rgba(75,45,18,.58);border-radius:10px;background:radial-gradient(circle at 20% 0%,rgba(255,255,255,.42),transparent 28%),linear-gradient(#fff2cb,#dab877);box-shadow:inset 0 0 0 2px #fff4be61,0 3px #00000038}.help-topic-card .icon-frame{color:#fff1bd;background:radial-gradient(circle at 36% 22%,rgba(255,255,255,.36),transparent 24%),linear-gradient(#7c522b,#2a160b)}.help-topic-card h2{color:#241208;font-size:1.18rem;line-height:1.1}.help-topic-card p{margin-top:6px;font-size:.84rem;font-weight:800;line-height:1.48}.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px;border:2px solid rgba(77,51,22,.35);border-radius:8px;background:#fff8dd8c;font-weight:900}.settings-list,.help-content,.chapter-list,.tech-grid{max-height:calc(100svh - 128px);overflow:auto;overscroll-behavior:contain}.toggle-row span{display:inline-flex;align-items:center;gap:9px}.toggle-row input[type=checkbox]{-webkit-appearance:none;-moz-appearance:none;appearance:none;position:relative;width:58px;min-width:58px;height:32px;border:3px solid #2b1a0f;border-radius:999px;background:radial-gradient(circle at 35% 22%,rgba(255,255,255,.28),transparent 24%),linear-gradient(#5a351b,#1f1007);box-shadow:inset 0 0 0 2px #ffda802e,inset 0 -4px #00000047,0 3px #00000052;cursor:pointer}.toggle-row input[type=checkbox]:before{content:"";position:absolute;top:3px;left:4px;width:20px;height:20px;border:2px solid #130804;border-radius:50%;background:radial-gradient(circle at 35% 24%,rgba(255,255,255,.46),transparent 24%),linear-gradient(#ffe08a,#9b651d);box-shadow:0 2px #00000059;transition:transform .14s ease}.toggle-row input[type=checkbox]:checked{background:radial-gradient(circle at 35% 22%,rgba(255,255,255,.28),transparent 24%),linear-gradient(#1f6fd1,#123b78)}.toggle-row input[type=checkbox]:checked:before{transform:translate(25px)}.toggle-row select{-webkit-appearance:none;-moz-appearance:none;appearance:none;min-width:128px;min-height:44px;padding:8px 36px 8px 12px;border:4px solid #2b1a0f;border-radius:8px;background:linear-gradient(135deg,transparent calc(100% - 28px),rgba(43,26,15,.18) calc(100% - 27px)),radial-gradient(circle at 34% 20%,rgba(255,255,255,.42),transparent 24%),linear-gradient(#ffe08a,#b77822 66%,#6d3f10);color:#2b1a0f;font-weight:900;box-shadow:inset 0 0 0 2px #fff0a673,inset 0 -4px #49270a38,0 3px #00000052}.settings-confirm-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;display:grid;place-items:center;padding:max(env(safe-area-inset-top),10px) max(env(safe-area-inset-right),10px) max(env(safe-area-inset-bottom),10px) max(env(safe-area-inset-left),10px);background:radial-gradient(circle at 50% 42%,rgba(255,213,91,.12),transparent 30%),#0b07049e;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.settings-confirm-popover{position:relative;width:min(348px,calc(100vw - 28px));max-height:calc(100svh - 24px);padding:6px;overflow:hidden;animation:popover-open .15s ease-out both}.settings-confirm-body{display:grid;grid-template-columns:52px 1fr;gap:8px 10px;align-items:center;padding:9px;border:3px solid rgba(75,45,18,.58);border-radius:10px;background:radial-gradient(circle at 50% 0%,rgba(255,255,255,.28),transparent 30%),linear-gradient(#f9e8bd,#d9b471)}.settings-confirm-body p{margin:0;color:#4d2d13;font-size:.82rem;font-weight:900;line-height:1.42}.settings-confirm-emblem{grid-row:1 / span 2;display:grid;place-items:center;width:52px;height:58px;border:4px solid #130804;border-radius:10px 10px 18px 18px;background:radial-gradient(circle at 34% 20%,rgba(255,255,255,.42),transparent 24%),linear-gradient(#d95a4d,#6a1b14);color:#fff1bd;box-shadow:inset 0 0 0 2px #ffe89447,0 4px #0000005c}.settings-confirm-actions{grid-column:2;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px}.settings-confirm-actions .medieval-button{min-width:0;padding:5px 8px}.level-card.is-locked,.tech-card.is-locked{filter:saturate(.86) brightness(.9);opacity:1}.level-card.is-locked:after,.tech-card.is-locked:after{content:"";position:absolute;top:6px;right:6px;bottom:6px;left:6px;border-radius:7px;background:repeating-linear-gradient(-45deg,rgba(38,25,14,.12) 0 7px,transparent 7px 14px),#2a1a0c14;pointer-events:none}.tech-card.is-selected,.level-card.is-selected:not(.is-locked){box-shadow:0 0 18px #ffdc6652,0 0 0 2px #130c07,inset 0 0 0 2px #fff8cc73,0 12px 28px #00000047}.level-select-screen{min-height:100svh}.level-select-screen .chapter-list{padding-bottom:max(env(safe-area-inset-bottom),14px)}@media (orientation: portrait),(max-width: 720px){.level-select-screen{width:100%;max-width:480px;min-height:100svh;padding:max(env(safe-area-inset-top),14px) clamp(14px,4vw,20px) max(env(safe-area-inset-bottom),16px)}.level-select-screen .page-header{align-items:center;gap:12px;margin-bottom:12px}.level-select-screen .page-header .icon-button{width:52px;min-width:52px;height:52px;min-height:52px;border-width:4px}.level-select-screen .eyebrow{margin-bottom:2px;font-size:.78rem}.level-select-screen .page-header h1{font-size:clamp(2.08rem,8.8vw,2.72rem);line-height:.98;text-shadow:0 3px #180d06,0 7px 14px rgba(0,0,0,.34)}.level-select-screen .chapter-list{max-height:calc(100svh - 108px);gap:14px;padding:2px 2px max(env(safe-area-inset-bottom),12px)}.level-select-screen .chapter-section{padding:clamp(11px,3.5vw,15px);border-width:4px;border-radius:12px}.level-select-screen .chapter-title{gap:10px;margin-bottom:10px}.level-select-screen .chapter-title>span{width:50px;height:50px;border-width:4px;border-radius:10px;font-size:1.35rem;box-shadow:inset 0 0 0 2px #ffe28438,0 4px #0d06038f}.level-select-screen .chapter-title h2{font-size:clamp(1.45rem,6.4vw,2rem);line-height:1.05}.level-select-screen .chapter-title p{font-size:clamp(.92rem,3.8vw,1.08rem);line-height:1.22}.level-select-screen .level-grid{grid-template-columns:1fr;gap:12px}.level-select-screen .level-card{min-height:clamp(142px,22svh,174px);padding:14px 15px 12px;border:4px solid #241106;border-radius:13px;background:linear-gradient(180deg,#fffada94,#fffada00 28%),linear-gradient(#ffe6a8,#d9a85d 58%,#a86f2f);box-shadow:inset 0 0 0 2px #fffad794,inset 0 -7px #48260e42,0 4px #120804}.level-select-screen .level-card h3{margin:10px 0 7px;font-size:clamp(1.18rem,5.2vw,1.52rem);line-height:1.05}.level-select-screen .level-card p{min-height:0;max-width:92%;color:#5e4221;font-size:clamp(.88rem,3.6vw,1rem);line-height:1.35}.level-select-screen .level-card-top strong{width:42px;height:42px;border:3px solid #140804;border-radius:10px;font-size:1.3rem;box-shadow:inset 0 0 0 2px #ffe68e38}.level-select-screen .difficulty{padding:6px 10px;border:2px solid rgba(19,8,4,.46);border-radius:9px;font-size:.88rem;box-shadow:inset 0 1px #ffffff47,0 2px #10070347}.level-select-screen .stars{margin-top:14px}.level-select-screen .level-action{right:14px;bottom:13px}.level-select-screen .level-card.is-locked{filter:saturate(.82) brightness(.94)}.level-select-screen .level-card.is-locked:after{top:8px;right:8px;bottom:8px;left:8px;border-radius:10px;background:repeating-linear-gradient(-45deg,#3627141a 0,#3627141a 8px,#fff5c90d 8px,#fff5c90d 16px),#2a1c0d17}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:grid;place-items:center;padding:18px;background:radial-gradient(circle at 50% 42%,rgba(255,213,91,.16),transparent 28%),#0b0704b8;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.result-modal{position:relative;width:min(560px,100%);max-height:calc(100svh - 24px);overflow:hidden;padding:74px 26px 24px;border:8px solid #1c1008;border-radius:14px;background:radial-gradient(circle at 50% 0%,rgba(255,255,255,.38),transparent 27%),linear-gradient(180deg,#fff0c5,#e4c278 54%,#b17c35);color:var(--ink);text-align:center;box-shadow:inset 0 0 0 3px #fff2b87a,inset 0 -12px #4f2d1229,0 22px 54px #00000094}.result-modal:before,.result-modal:after{content:"";position:absolute;top:10px;right:10px;bottom:10px;left:10px;border:3px solid rgba(96,55,20,.52);border-radius:9px;pointer-events:none}.result-modal:after{top:20px;right:20px;bottom:20px;left:20px;border-color:#ffec976b}.result-ribbon{position:absolute;top:16px;left:50%;min-width:220px;padding:9px 24px 10px;transform:translate(-50%);border:4px solid #160b05;border-radius:9px;background:linear-gradient(180deg,rgba(255,255,255,.32),transparent 42%),linear-gradient(90deg,#123b78,#1f6fd1);color:#fff4c8;font-size:1.1rem;font-weight:950;letter-spacing:0;text-shadow:0 2px #130804;box-shadow:inset 0 0 0 2px #ffda8052,0 4px #090403}.result-modal.defeat .result-ribbon{background:linear-gradient(180deg,rgba(255,255,255,.28),transparent 42%),linear-gradient(90deg,#5c1512,#b22b25)}.result-emblem{position:relative;z-index:1;width:146px;height:106px;display:grid;place-items:center;margin:0 auto 4px}.result-shield{position:relative;z-index:2;width:86px;height:98px;display:grid;place-items:center;border:5px solid #160b05;border-radius:16px 16px 34px 34px;background:radial-gradient(circle at 35% 22%,rgba(255,255,255,.42),transparent 20%),linear-gradient(180deg,#2e78da,#123b6d);color:#ffd96a;box-shadow:inset 0 0 0 3px #ffee9861,inset 0 -10px #00000040,0 7px #00000061}.result-modal.defeat .result-shield{background:radial-gradient(circle at 35% 22%,rgba(255,255,255,.28),transparent 20%),linear-gradient(180deg,#7b45b5,#24102f 56%,#171017);color:#fff1de}.result-shield svg{width:48px;height:48px;filter:drop-shadow(0 3px #160b05)}.result-laurel{position:absolute;top:31px;width:66px;height:50px;border-top:12px solid #c58a24;border-radius:50%;filter:drop-shadow(0 3px #160b05)}.result-laurel.left{left:0;transform:rotate(-28deg)}.result-laurel.right{right:0;transform:scaleX(-1) rotate(-28deg)}.result-modal h2{position:relative;z-index:1;margin:0;font-size:3.15rem;line-height:.95;text-shadow:0 3px #160b05,0 7px 16px rgba(0,0,0,.28)}.result-modal.victory h2{color:#fff5c9}.result-modal.defeat h2{color:#ffe1d4}.result-modal p{position:relative;z-index:1;margin:8px 0 0;color:#5d3518;font-weight:950;text-shadow:0 1px rgba(255,255,255,.4)}.result-stars{position:relative;z-index:1;display:flex;justify-content:center;gap:4px;margin:14px 0 18px;color:#ffd55a;filter:drop-shadow(0 3px #6b3b10)}.result-stars svg{width:38px;height:38px}.result-grid{position:relative;z-index:1;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:12px;border:4px solid #2b1a0f;border-radius:10px;background:linear-gradient(180deg,#fff9dfc7,#d2a65dbd),radial-gradient(circle at 20% 0%,rgba(255,255,255,.52),transparent 24%);text-align:left;box-shadow:inset 0 0 0 2px #fff1b66b,inset 0 -6px #5b37171f}.result-stat{min-height:62px;display:grid;align-content:center;padding:8px 10px;border:2px solid rgba(42,25,13,.36);border-radius:8px;background:#fff4d280}.result-stat span{color:#68431e;font-size:.78rem;font-weight:950}.result-stat strong{color:#241208;font-size:1.34rem;line-height:1.1;text-shadow:0 1px rgba(255,255,255,.5)}.result-stat.reward strong{color:#a46113}.modal-actions{position:relative;z-index:1;display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin-top:18px}.modal-actions button{border:4px solid #130804;border-radius:10px;background:linear-gradient(180deg,rgba(255,255,255,.32),transparent 38%),linear-gradient(#7c522b,#2a160b);color:#fff1bd;font-weight:950;text-shadow:0 2px #130804;box-shadow:inset 0 0 0 2px #ffda8040,inset 0 -4px #00000047,0 4px #0b0503}.modal-actions .primary-action{background:linear-gradient(180deg,rgba(255,255,255,.36),transparent 38%),linear-gradient(#ffd96a,#a76d1f);color:#211207;text-shadow:0 1px rgba(255,255,255,.48)}@media (orientation: portrait) and (max-width: 900px){.battle-screen.landscape-game:not(.portrait-game)>*:not(.rotate-overlay){filter:blur(4px) brightness(.55);pointer-events:none}.rotate-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:grid;place-items:center;background:#110804c7}}@media (max-height: 430px) and (orientation: landscape){.modal-backdrop{padding:max(env(safe-area-inset-top),6px) max(env(safe-area-inset-right),8px) max(env(safe-area-inset-bottom),6px) max(env(safe-area-inset-left),8px)}.result-modal{width:min(560px,calc(100vw - 24px));max-height:calc(100svh - 16px);padding:46px 14px 12px;border-width:6px;overflow:auto}.result-ribbon{top:8px;min-width:176px;padding:5px 18px 6px;border-width:3px;font-size:.9rem}.result-emblem{width:82px;height:46px;margin-bottom:0}.result-shield{width:46px;height:52px;border-width:3px;border-radius:10px 10px 18px 18px}.result-shield svg{width:28px;height:28px}.result-laurel{top:17px;width:34px;height:26px;border-top-width:7px}.result-modal h2{font-size:2.15rem}.result-modal p{margin-top:2px;font-size:.88rem}.result-stars{margin:5px 0 7px}.result-stars svg{width:26px;height:26px}.result-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;padding:6px;border-width:3px}.result-stat{min-height:48px;padding:5px 6px}.result-stat span{font-size:.65rem}.result-stat strong{font-size:1rem}.modal-actions{gap:6px;margin-top:8px}.modal-actions button{min-height:40px;padding:5px 8px;border-width:3px;font-size:.8rem}}@media (max-width: 1120px){.battle-screen.landscape-game{min-width:0;grid-template-columns:minmax(0,1fr) 280px;grid-template-rows:72px minmax(0,1fr) 112px}.battle-topbar{grid-template-columns:48px 1fr 110px 1fr 48px}.battle-command-bar{grid-template-columns:150px 220px 200px minmax(300px,1fr)}.side-unit-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.unit-token{min-height:56px}}@media (max-height: 620px){.battle-screen.landscape-game{grid-template-rows:66px minmax(0,1fr) 102px}.battle-command-bar{padding:6px 8px}.skill-button{min-height:66px}.battle-side-panel{gap:6px}.side-skill-list{display:none}}@media (max-width: 840px){.menu-screen,.tech-grid,.level-grid,.menu-stats{grid-template-columns:1fr}}.battle-screen.landscape-game{position:fixed;top:0;right:0;bottom:0;left:0;width:100vw;height:100svh;min-width:0;min-height:0;display:block;padding:0;overflow:hidden;background:#110805}@supports (height: 100dvh){.battle-screen.landscape-game{height:100dvh}}.battle-screen.landscape-game:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:4;pointer-events:none;background:linear-gradient(180deg,rgba(8,4,2,.54),transparent 18%,transparent 74%,rgba(8,4,2,.56)),linear-gradient(90deg,rgba(8,4,2,.34),transparent 12%,transparent 88%,rgba(8,4,2,.34))}.battle-map-panel{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;min-width:0;min-height:0;padding:0;border:0;border-radius:0;background:#78994e;box-shadow:none}.game-canvas{width:100%;height:100%;border:0;border-radius:0}.battle-topbar{position:absolute;top:var(--safe-top);right:var(--safe-right);left:var(--safe-left);z-index:30;height:var(--top-hud-height);display:grid;grid-template-columns:var(--touch-target) minmax(148px,1fr) clamp(92px,13vw,138px) minmax(148px,1fr) var(--touch-target);align-items:center;gap:clamp(3px,.58vw,9px);padding:4px clamp(5px,.9vw,10px);border:4px solid #120805;border-radius:0 0 16px 16px;background:url(/assets/ui/wood_panel_horizontal.png) center / 100% 100% no-repeat,linear-gradient(180deg,rgba(255,231,154,.16),transparent 38%),linear-gradient(180deg,#1e1008f5,#0c0603e6);box-shadow:inset 0 0 0 2px #ffde8047,inset 0 -7px #00000047,0 8px 22px #00000070}.battle-topbar:before,.battle-topbar:after{display:none}.game-icon-button{width:var(--touch-target);height:var(--touch-target);min-width:var(--touch-target);min-height:var(--touch-target);border-width:3px}.faction-plaque{height:calc(var(--top-hud-height) - 12px);gap:6px;padding:4px 8px;border-width:3px;border-radius:10px}.faction-plaque svg{width:clamp(18px,3.4svh,28px);height:clamp(18px,3.4svh,28px);flex:0 0 auto}.faction-plaque strong{font-size:var(--font-md)}.faction-plaque span{font-size:var(--font-xs)}.faction-progress{height:6px;margin-top:2px;border-width:1px}.center-battle-badge{position:relative;align-self:stretch;display:grid;place-items:center;padding:2px 8px 4px;border:4px solid #120805;border-radius:5px 5px 18px 18px;background:radial-gradient(circle at 50% 10%,rgba(255,238,167,.34),transparent 32%),linear-gradient(#74471f,#261108 58%,#100604);box-shadow:inset 0 0 0 2px #ffda8047,0 4px #0000007a;color:#ffe6a4;text-align:center;text-shadow:0 2px #130804}.center-battle-badge span,.center-battle-badge em{display:block;max-width:100%;overflow:hidden;color:#ffd96a;font-size:var(--font-xs);font-style:normal;font-weight:950;line-height:1;text-overflow:ellipsis;white-space:nowrap}.center-battle-badge strong{display:block;color:#fff2bd;font-size:clamp(1.3rem,5svh,2rem);font-weight:950;line-height:.95}.top-stars svg{width:clamp(14px,2.6svh,18px);height:clamp(14px,2.6svh,18px)}.floating-info-dock{position:absolute;top:50%;right:var(--safe-right);z-index:32;display:flex;flex-direction:column;gap:clamp(7px,1.6svh,12px);transform:translateY(-50%)}.floating-info-button{width:clamp(52px,12svh,64px);min-width:var(--touch-target);height:clamp(52px,12svh,64px);min-height:var(--touch-target);display:grid;place-items:center;gap:1px;padding:3px;border:4px solid #120805;border-radius:50%;background:radial-gradient(circle at 36% 20%,rgba(255,244,181,.4),transparent 24%),linear-gradient(#8a5a2a,#211008 65%,#0e0502);color:#fff2bd;font-size:var(--font-xs);font-weight:950;text-shadow:0 2px #130804;box-shadow:inset 0 0 0 2px #ffda8057,0 5px #00000073,0 0 18px #00000042}.floating-info-button svg{width:clamp(20px,4.4svh,28px);height:clamp(20px,4.4svh,28px);color:#ffd96a;filter:drop-shadow(0 2px #120805)}.floating-info-button.active{filter:brightness(1.12);box-shadow:0 0 16px #ffdc668c,inset 0 0 0 2px #fff0a673,0 5px #00000073}.floating-info-popover{position:absolute;z-index:31;padding:clamp(5px,1.1svh,9px);overflow:visible;animation:popover-open .15s ease-out both}.medieval-popover{border-width:5px;background:linear-gradient(180deg,rgba(255,241,174,.2),transparent 32%),url(/assets/ui/parchment_panel.png) center / cover no-repeat,linear-gradient(#f3dcaa,#c99a54);box-shadow:inset 0 0 0 2px #fff4be80,inset 0 0 0 7px #623a182e,0 0 0 2px #ffcd5c57,0 10px #080302d1,0 18px 34px #00000075}.medieval-popover:before,.medieval-popover:after{content:"";position:absolute;top:12px;width:18px;height:18px;border:3px solid #130804;border-radius:50%;background:radial-gradient(circle at 34% 28%,rgba(255,255,255,.45),transparent 28%),linear-gradient(#ffe08a,#9b651d);box-shadow:inset 0 0 0 2px #ffe59061;pointer-events:none}.medieval-popover:before{left:12px}.medieval-popover:after{right:12px}.medieval-popover.units{right:calc(var(--safe-right) + clamp(62px,14svh,76px) + 8px);bottom:calc(var(--safe-bottom) + var(--bottom-hud-height) + 8px);width:min(432px,calc(100vw - var(--safe-left) - var(--safe-right) - 92px));max-height:calc(100svh - var(--top-hud-height) - var(--bottom-hud-height) - var(--safe-top) - var(--safe-bottom) - 18px)}.medieval-popover.castle{top:calc(var(--safe-top) + var(--top-hud-height) + 8px);right:calc(var(--safe-right) + clamp(62px,14svh,76px) + 8px);width:clamp(276px,29vw,320px);max-width:calc(100vw - var(--safe-left) - var(--safe-right) - 92px)}.medieval-popover.skills{right:calc(var(--safe-right) + clamp(62px,14svh,76px) + 8px);bottom:calc(var(--safe-bottom) + var(--bottom-hud-height) + 8px);width:min(482px,calc(100vw - var(--safe-left) - var(--safe-right) - 96px))}.pause-popover{position:absolute;right:calc(var(--safe-right) + clamp(62px,14svh,76px) + 8px);bottom:calc(var(--safe-bottom) + var(--bottom-hud-height) + 8px);z-index:31;width:min(306px,calc(100vw - var(--safe-left) - var(--safe-right) - 96px));padding:clamp(5px,1.1svh,9px);animation:popover-open .15s ease-out both}.pause-popover .floating-popover-title{background:radial-gradient(circle at 22% 18%,rgba(255,232,148,.3),transparent 26%),linear-gradient(90deg,#5b351b,#9b651d 58%,#3a1e0c)}.pause-actions{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:5px;padding:5px;border:3px solid rgba(75,45,18,.58);border-radius:10px;background:radial-gradient(circle at 50% 0%,rgba(255,255,255,.28),transparent 30%),linear-gradient(#f9e8bd,#d9b471)}.pause-actions .medieval-button{min-width:0;min-height:var(--touch-target);padding:4px 5px;font-size:var(--font-xs)}@keyframes popover-open{0%{opacity:0;transform:translateY(8px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}.floating-popover-title{min-height:var(--touch-target);display:flex;align-items:center;justify-content:space-between;gap:7px;margin:0 0 6px;padding:4px 4px 4px 42px;border:3px solid #130804;border-radius:8px;background:radial-gradient(circle at 22% 18%,rgba(255,232,148,.3),transparent 26%),linear-gradient(90deg,#123b78,#1f6fd1 58%,#0d2d55);color:#fff1bd;text-shadow:0 2px #130804;box-shadow:inset 0 0 0 2px #ffda8052,inset 0 -6px #0000003d,0 3px #00000057}.medieval-popover.castle .floating-popover-title{background:radial-gradient(circle at 22% 18%,rgba(255,232,148,.3),transparent 26%),linear-gradient(90deg,#6f1a14,#c0392c 58%,#5d1511)}.medieval-popover.skills .floating-popover-title{background:radial-gradient(circle at 22% 18%,rgba(255,232,148,.3),transparent 26%),linear-gradient(90deg,#38194c,#7740ad 58%,#261236)}.floating-popover-title span,.floating-popover-title strong,.floating-popover-title small{min-width:0}.floating-popover-title span{display:grid;gap:1px}.floating-popover-title strong{display:block;overflow:hidden;color:#fff4c8;font-size:var(--font-sm);font-weight:950;text-overflow:ellipsis;white-space:nowrap}.floating-popover-title small{display:block;overflow:hidden;color:#ffe08a;font-size:10px;font-weight:950;letter-spacing:.04em;text-overflow:ellipsis;text-transform:uppercase;white-space:nowrap}.floating-popover-close,.medieval-close-button{width:var(--touch-target);min-width:var(--touch-target);height:var(--touch-target);min-height:var(--touch-target);display:grid;place-items:center;padding:0;border:4px solid #130804;border-radius:10px;background:radial-gradient(circle at 36% 20%,rgba(255,255,255,.42),transparent 25%),linear-gradient(#ffe18a,#b77822 64%,#6d3f10);color:#2a1608;box-shadow:inset 0 0 0 2px #fff0a673,inset 0 -4px #49270a47,0 3px #090403}.game-scroll-area{scrollbar-width:none;-ms-overflow-style:none;overscroll-behavior:contain}.game-scroll-area::-webkit-scrollbar,.floating-info-popover::-webkit-scrollbar,.medieval-popover::-webkit-scrollbar,.result-modal::-webkit-scrollbar{display:none;width:0;height:0}.result-modal{scrollbar-width:none;-ms-overflow-style:none}.unit-drawer{position:relative;padding:4px;overflow:hidden;border:3px solid rgba(75,45,18,.58);border-radius:10px;background:linear-gradient(90deg,rgba(91,55,22,.08) 1px,transparent 1px),radial-gradient(circle at 50% 0%,rgba(255,255,255,.42),transparent 30%),linear-gradient(#f9e8bd,#d9b471);background-size:18px 18px,auto,auto;box-shadow:inset 0 0 0 2px #fff8d861,inset 0 -8px #5b37171a}.unit-drawer:before,.unit-drawer:after{content:"";position:absolute;top:7px;bottom:7px;z-index:4;width:18px;pointer-events:none}.unit-drawer:before{left:6px;background:linear-gradient(90deg,rgba(105,66,28,.32),transparent)}.unit-drawer:after{right:6px;background:linear-gradient(270deg,rgba(105,66,28,.32),transparent)}.unit-drawer__list{position:relative;z-index:1;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:4px;overflow:hidden;touch-action:pan-x}.unit-card{position:relative;min-width:0;min-height:clamp(84px,20svh,104px);display:grid;grid-template-rows:minmax(42px,1fr) auto auto;place-items:center;gap:1px;padding:4px 3px;overflow:hidden;border:4px solid #130804;border-radius:11px;background:radial-gradient(circle at 38% 12%,rgba(255,245,190,.44),transparent 27%),linear-gradient(180deg,rgba(255,255,255,.16),transparent 42%),linear-gradient(#8c5a2b,#35190a 72%,#130704);color:#fff1bd;text-align:center;text-shadow:0 2px #130804;box-shadow:inset 0 0 0 2px #ffda8040,inset 0 -8px #0000003d,0 4px #090402b8}.unit-card:before{content:"";position:absolute;top:5px;right:5px;bottom:5px;left:5px;border:1px solid rgba(255,224,138,.26);border-radius:7px;pointer-events:none}.unit-card:hover:not(:disabled){filter:brightness(1.08);transform:translateY(-1px)}.unit-card:active:not(:disabled){transform:translateY(2px);box-shadow:inset 0 0 0 2px #ffda8033,inset 0 4px 9px #00000052,0 1px #090402b8}.unit-card--selected{background:radial-gradient(circle at 50% 18%,rgba(105,190,255,.46),transparent 29%),linear-gradient(180deg,rgba(255,255,255,.2),transparent 42%),linear-gradient(#1d6ecf,#153963 70%,#0c1625);box-shadow:0 0 22px #ffdc66b3,0 0 14px #56b5ff8c,inset 0 0 0 3px #ffe08a,inset 0 -8px #0000003d,0 4px #090402b8}.battle-screen.landscape-game .unit-card:disabled{cursor:not-allowed;filter:none;opacity:1}.unit-card--locked{background:radial-gradient(circle at 42% 12%,rgba(255,239,178,.24),transparent 26%),linear-gradient(180deg,rgba(255,255,255,.08),transparent 42%),linear-gradient(#61513b,#2c2116 72%,#120b06)}.unit-card--locked:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#19110a2e;pointer-events:none}.unit-card__portrait{position:relative;z-index:2;width:min(104px,100%);height:clamp(42px,10.5svh,56px);display:grid;place-items:center;margin-bottom:1px;border:3px solid #130804;border-radius:12px;background:radial-gradient(circle at 48% 82%,rgba(52,22,9,.48),transparent 32%),radial-gradient(circle at 38% 22%,rgba(255,245,190,.38),transparent 26%),linear-gradient(#f4d891,#8b5724);box-shadow:inset 0 0 0 2px #ffe28459,0 4px #0000006b}.unit-card__portrait:after{content:"";position:absolute;right:8px;bottom:6px;left:8px;height:8px;border-radius:50%;background:#0f080457;filter:blur(1px)}.unit-card__portrait--infantry{background-image:url(/assets/units/infantry_blue_sheet.png),radial-gradient(circle at 48% 82%,rgba(52,22,9,.48),transparent 32%),radial-gradient(circle at 38% 22%,rgba(255,245,190,.38),transparent 26%),linear-gradient(#f4d891,#8b5724);background-position:0% center,center,center,center;background-repeat:no-repeat,no-repeat,no-repeat,no-repeat;background-size:600% auto,auto,auto,auto}.unit-card__portrait--runner{background-image:url(/assets/units/runner_blue_sheet.png),radial-gradient(circle at 48% 82%,rgba(52,22,9,.48),transparent 32%),radial-gradient(circle at 38% 22%,rgba(255,245,190,.38),transparent 26%),linear-gradient(#f4d891,#8b5724);background-position:0% center,center,center,center;background-repeat:no-repeat,no-repeat,no-repeat,no-repeat;background-size:600% auto,auto,auto,auto}.unit-card__portrait--guard{background-image:url(/assets/units/guard_blue_sheet.png),radial-gradient(circle at 48% 82%,rgba(52,22,9,.48),transparent 32%),radial-gradient(circle at 38% 22%,rgba(255,245,190,.38),transparent 26%),linear-gradient(#f4d891,#8b5724);background-position:0% center,center,center,center;background-repeat:no-repeat,no-repeat,no-repeat,no-repeat;background-size:600% auto,auto,auto,auto}.unit-card__portrait--rider{background-image:url(/assets/units/rider_blue_sheet.png),radial-gradient(circle at 48% 82%,rgba(52,22,9,.48),transparent 32%),radial-gradient(circle at 38% 22%,rgba(255,245,190,.38),transparent 26%),linear-gradient(#f4d891,#8b5724);background-position:0% center,center,center,center;background-repeat:no-repeat,no-repeat,no-repeat,no-repeat;background-size:600% auto,auto,auto,auto}.unit-card__portrait--engineer{background-image:url(/assets/units/engineer_blue_sheet.png),radial-gradient(circle at 48% 82%,rgba(52,22,9,.48),transparent 32%),radial-gradient(circle at 38% 22%,rgba(255,245,190,.38),transparent 26%),linear-gradient(#f4d891,#8b5724);background-position:0% center,center,center,center;background-repeat:no-repeat,no-repeat,no-repeat,no-repeat;background-size:600% auto,auto,auto,auto}.unit-card .unit-portrait-canvas{display:none}.unit-card--locked .unit-portrait-canvas{filter:drop-shadow(0 3px 0 rgba(0,0,0,.55)) saturate(.78) brightness(.86)}.unit-card--locked .unit-card__portrait{filter:saturate(.82) brightness(.88)}.unit-card__name,.unit-card__count,.unit-card__traits,.unit-card__lock{position:relative;z-index:3;max-width:100%}.unit-card__name{overflow:hidden;color:#fff4c8;font-size:clamp(10px,2.25svh,13px);font-weight:950;line-height:1.05;text-overflow:ellipsis;white-space:nowrap}.unit-card__count{min-height:13px;padding:1px 4px;border:1px solid rgba(255,224,138,.45);border-radius:7px;background:#0d060385;color:#ffe08a;font-size:9px;font-weight:950;line-height:1.2}.unit-card__traits{display:none;justify-content:center;gap:3px;width:100%}.unit-card__traits b{min-width:0;padding:1px 3px;border-radius:5px;background:#ffeeb229;color:#ffecc0;font-size:9px;line-height:1.25;white-space:nowrap}.unit-card__lock{position:absolute;right:4px;bottom:4px;display:inline-flex;align-items:center;gap:2px;padding:2px 4px;border:2px solid #130804;border-radius:8px;background:radial-gradient(circle at 36% 22%,rgba(255,255,255,.34),transparent 24%),linear-gradient(#ffe08a,#9b651d);color:#211207;font-size:9px;font-weight:950;text-shadow:0 1px rgba(255,255,255,.4)}.unit-card__lock svg{width:12px;height:12px}.floating-castle-card{min-height:0;overflow:hidden}.popover-upgrade{grid-column:2;min-height:var(--touch-target);justify-self:start;padding:4px 10px}.floating-skill-list{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:5px;padding:5px;overflow:hidden;border:3px solid rgba(75,45,18,.58);border-radius:10px;background:radial-gradient(circle at 50% 0%,rgba(255,255,255,.28),transparent 30%),linear-gradient(#3f2514,#140804)}.floating-skill-card{min-width:0;min-height:clamp(66px,15.5svh,84px);display:grid;grid-template-rows:minmax(38px,1fr) auto auto;place-items:center;gap:1px;padding:4px 3px;overflow:hidden;border:4px solid #130804;border-radius:12px;background:radial-gradient(circle at 34% 18%,rgba(255,244,181,.28),transparent 24%),linear-gradient(#6e401e,#1e0d06 72%);color:#fff1bd;text-align:center;text-shadow:0 2px #130804;box-shadow:inset 0 0 0 2px #ffda8038,inset 0 -7px #00000042,0 4px #090402b3}.floating-skill-card .skill-glyph-canvas{width:clamp(38px,8.2svh,52px)!important;height:clamp(38px,8.2svh,52px)!important}.floating-skill-card strong,.floating-skill-card small,.floating-skill-card em{display:block;overflow:hidden;max-width:100%;text-overflow:ellipsis}.floating-skill-card strong{white-space:nowrap;font-size:var(--font-xs)}.floating-skill-card small{white-space:nowrap;color:#ffd96a;font-size:9px}.floating-skill-card em{display:-webkit-box;min-height:18px;color:#f8ddb0;font-size:8px;font-style:normal;font-weight:850;line-height:1.15;text-shadow:0 1px #130804;-webkit-box-orient:vertical;-webkit-line-clamp:2}.floating-skill-card:disabled{opacity:1;filter:brightness(.88) saturate(.82)}.floating-skill-card.selected{box-shadow:0 0 18px #8fd7ffb8,0 0 9px #ffefa494,inset 0 0 0 3px #ffe08a,0 4px #090402b3}.battle-command-bar{position:absolute;right:var(--safe-right);bottom:var(--safe-bottom);left:var(--safe-left);z-index:30;height:var(--bottom-hud-height);display:grid;grid-template-columns:minmax(104px,150px) minmax(318px,.92fr) minmax(280px,1.08fr);grid-template-rows:1fr;align-items:center;gap:clamp(5px,.8vw,10px);padding:6px clamp(7px,1vw,12px);border:5px solid #120805;border-radius:18px 18px 0 0;background:url(/assets/ui/wood_panel_horizontal.png) center / 100% 100% no-repeat,linear-gradient(180deg,rgba(255,229,135,.15),transparent 36%),linear-gradient(180deg,#30180af5,#0a0502eb);box-shadow:inset 0 0 0 2px #ffda8042,inset 0 -8px #00000045,0 -8px 20px #0000006b}.control-cluster{min-width:0;display:grid;gap:4px}.percent-buttons,.action-buttons{display:grid;gap:4px;justify-content:center}.percent-buttons{grid-template-columns:repeat(4,minmax(42px,1fr))}.action-buttons{grid-template-columns:repeat(6,minmax(42px,1fr))}.resource-strip{align-content:center;grid-template-columns:1fr;gap:5px}.resource-pill.energy{grid-column:auto}.resource-pill.stars{display:none}.medieval-button{min-height:clamp(34px,7.6svh,var(--touch-target));border-width:3px}.percent-button,.speed-button,.icon-command{min-width:0;width:100%;padding:3px 4px;font-size:var(--font-xs)}.speed-button{gap:2px}.speed-button svg{width:14px;height:14px}.skill-dock{display:grid;grid-template-columns:repeat(5,minmax(52px,1fr));justify-content:end;gap:clamp(4px,.7vw,8px)}.skill-button{width:100%;min-height:clamp(58px,10svh,82px);height:clamp(58px,10svh,82px);padding:4px 3px 3px;border-radius:12px}.skill-button .skill-icon{width:clamp(38px,7.2svh,54px);height:clamp(38px,7.2svh,54px)}.skill-glyph-canvas{width:clamp(38px,7.2svh,54px)!important;height:clamp(38px,7.2svh,54px)!important}.skill-button strong{max-width:100%;overflow:hidden;font-size:var(--font-xs);line-height:1;text-overflow:ellipsis;white-space:nowrap}.skill-button small{font-size:10px;line-height:1}@media (max-width: 980px) and (orientation: landscape){.battle-topbar{grid-template-columns:var(--touch-target) minmax(120px,1fr) clamp(86px,13vw,116px) minmax(120px,1fr) var(--touch-target);gap:3px;padding-inline:4px}.faction-plaque{padding-inline:5px}.faction-plaque strong{font-size:var(--font-sm)}.faction-plaque span{display:none}.battle-command-bar{grid-template-columns:minmax(92px,112px) minmax(424px,1fr) minmax(258px,1fr);gap:4px;padding:5px 6px}.resource-pill{min-height:28px;padding:2px 5px;border-width:3px;font-size:var(--font-xs)}.resource-icon{width:18px;height:18px}.control-cluster{display:flex;align-items:center;justify-content:center;gap:4px}.percent-buttons,.action-buttons{display:flex;align-items:center;gap:4px}.action-buttons .upgrade{display:none}.percent-button,.speed-button,.icon-command{flex:0 0 var(--touch-target);width:var(--touch-target);min-width:var(--touch-target);min-height:var(--touch-target)}.speed-button svg{display:none}.skill-dock{grid-template-columns:repeat(5,minmax(50px,1fr));gap:4px}.skill-button{min-height:58px;height:58px}.skill-button strong{display:none}.skill-button small{position:absolute;right:8px;bottom:4px;padding:0 3px;border-radius:6px;background:#0d0603b8}.medieval-popover.units{right:calc(var(--safe-right) + 58px);bottom:calc(var(--safe-bottom) + var(--bottom-hud-height) + 6px);left:auto;width:min(404px,calc(100vw - var(--safe-left) - var(--safe-right) - 78px))}.medieval-popover.castle{width:min(294px,calc(100vw - var(--safe-left) - var(--safe-right) - 86px))}.medieval-popover.skills{width:min(446px,calc(100vw - var(--safe-left) - var(--safe-right) - 86px))}.pause-popover{width:min(292px,calc(100vw - var(--safe-left) - var(--safe-right) - 86px))}}@media (max-height: 410px) and (orientation: landscape){.battle-screen.landscape-game{--top-hud-height: 54px;--bottom-hud-height: 76px}.battle-command-bar{grid-template-columns:104px minmax(424px,1fr) minmax(260px,1fr)}.medieval-button,.icon-command{min-height:var(--touch-target)}.floating-info-button{width:50px;height:50px;font-size:10px}.medieval-popover.units{right:calc(var(--safe-right) + 58px);bottom:calc(var(--safe-bottom) + var(--bottom-hud-height) + 6px)}.unit-drawer{padding:4px}.unit-card{min-height:84px;padding:4px 3px}.unit-card__portrait{height:42px}.unit-card__traits b{font-size:8px}}@media (orientation: portrait),(max-width: 700px){.battle-screen.portrait-game{--top-hud-height: auto;--bottom-hud-height: clamp(208px, 24.5svh, 226px);--portrait-dock-height: 50px;--touch-target: 44px;position:fixed;top:0;right:0;bottom:0;left:0;width:100vw;height:100svh;min-width:0;min-height:0;display:grid;grid-template-columns:minmax(0,1fr);grid-template-areas:"top" "map" "middle" "bottom";grid-template-rows:auto auto minmax(0,1fr) auto;gap:6px;padding:max(env(safe-area-inset-top),6px) max(env(safe-area-inset-right),8px) max(env(safe-area-inset-bottom),6px) max(env(safe-area-inset-left),8px);overflow:hidden;justify-items:stretch;align-items:stretch;background:linear-gradient(90deg,rgba(255,226,132,.05) 1px,transparent 1px),linear-gradient(rgba(255,226,132,.04) 1px,transparent 1px),radial-gradient(circle at 50% 8%,#5b351b 0,#160905 66%);background-size:28px 28px,28px 28px,cover}@supports (height: 100dvh){.battle-screen.portrait-game{height:100dvh}}.battle-screen.portrait-game:after{background:linear-gradient(180deg,rgba(8,4,2,.36),transparent 20%,transparent 74%,rgba(8,4,2,.46)),linear-gradient(90deg,rgba(8,4,2,.26),transparent 14%,transparent 86%,rgba(8,4,2,.26))}.battle-screen.portrait-game .rotate-overlay{display:none!important}.battle-screen.portrait-game>*{filter:none!important;pointer-events:auto!important}.battle-screen.portrait-game .battle-topbar{grid-area:top;position:relative;top:auto;right:auto;left:auto;height:auto;min-height:0;display:grid;grid-template-columns:var(--touch-target) minmax(0,1fr) minmax(0,1fr) var(--touch-target);grid-template-areas:"back timer timer settings" "player player enemy enemy";gap:5px;padding:5px;border-width:4px;border-radius:14px;box-shadow:inset 0 0 0 2px #ffde8047,inset 0 -5px #00000047,0 5px 14px #00000061}.battle-screen.portrait-game .battle-topbar>.game-icon-button:first-child{grid-area:back}.battle-screen.portrait-game .settings-top-button{grid-area:settings}.battle-screen.portrait-game .center-battle-badge{grid-area:timer;min-height:var(--touch-target);padding:2px 8px 4px;border-width:3px;border-radius:8px 8px 14px 14px}.battle-screen.portrait-game .center-battle-badge strong{font-size:clamp(1.25rem,5.8vw,1.72rem)}.battle-screen.portrait-game .center-battle-badge em{max-width:160px}.battle-screen.portrait-game .faction-plaque{height:36px;min-width:0;gap:4px;padding:3px 5px;border-width:3px;border-radius:9px}.battle-screen.portrait-game .faction-plaque.player{grid-area:player}.battle-screen.portrait-game .faction-plaque.enemy{grid-area:enemy}.battle-screen.portrait-game .faction-plaque svg{width:18px;height:18px}.battle-screen.portrait-game .faction-plaque strong{overflow:hidden;font-size:clamp(11px,3.2vw,13px);line-height:1.05;text-overflow:ellipsis;white-space:nowrap}.battle-screen.portrait-game .faction-plaque span{display:none}.battle-screen.portrait-game .faction-progress{height:4px;margin-top:1px}.battle-screen.portrait-game .top-stars{display:flex;gap:1px}.battle-screen.portrait-game .top-stars svg{width:13px;height:13px}.battle-screen.portrait-game .battle-map-panel{grid-area:map;position:relative;inset:auto;z-index:5;width:100%;max-height:min(34svh,300px);aspect-ratio:16 / 9;min-width:0;min-height:0;justify-self:stretch;overflow:hidden;padding:0;border:5px solid #120805;border-radius:15px;background:radial-gradient(circle at 48% 20%,rgba(255,230,145,.2),transparent 34%),#78994e;box-shadow:inset 0 0 0 2px #ffe28447,0 0 0 2px #ffcd5c2e,0 10px 24px #0006}.battle-screen.portrait-game .game-canvas{display:block;width:100%;height:100%}.battle-screen.portrait-game .floating-info-dock{display:none!important}.battle-screen.portrait-game:has(.mobile-inline-panel) .floating-info-dock{display:none!important}.battle-screen.portrait-game .floating-info-button{width:100%;height:var(--portrait-dock-height);min-height:var(--touch-target);display:flex;flex-direction:row;justify-content:center;gap:5px;border-width:3px;border-radius:12px;font-size:12px}.battle-screen.portrait-game .floating-info-button svg{width:21px;height:21px}.battle-screen.portrait-game .battle-command-bar{grid-area:bottom;position:relative;right:auto;bottom:auto;left:auto;z-index:30;height:var(--bottom-hud-height);display:grid;grid-template-columns:1fr;grid-template-rows:auto auto minmax(58px,1fr) auto;align-items:stretch;gap:6px;padding:7px;border-width:5px;border-radius:16px}.battle-screen.portrait-game .battle-command-bar:has(.mobile-inline-panel){height:clamp(220px,26svh,238px);grid-template-rows:auto auto minmax(82px,1fr)}.battle-screen.portrait-game .battle-command-bar:has(.mobile-inline-panel) .battle-tactics-panel{display:none}.battle-screen.portrait-game .battle-command-bar:has(.mobile-inline-panel) .command-message{display:none}.battle-screen.portrait-game .resource-strip{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.battle-screen.portrait-game .resource-pill{min-height:30px;padding:4px 6px;border-width:3px;font-size:12px}.battle-screen.portrait-game .resource-icon{width:18px;height:18px}.battle-screen.portrait-game .control-cluster{display:grid;grid-template-columns:1fr;gap:5px}.battle-screen.portrait-game .percent-buttons{grid-template-columns:repeat(4,minmax(0,1fr));gap:5px}.battle-screen.portrait-game .action-buttons{grid-template-columns:repeat(6,minmax(0,1fr));gap:5px}.battle-screen.portrait-game .percent-button,.battle-screen.portrait-game .speed-button,.battle-screen.portrait-game .icon-command{min-height:34px;padding:3px 2px;border-width:3px;font-size:11px}.battle-screen.portrait-game .speed-button svg{display:none}.battle-screen.portrait-game .skill-dock{grid-template-columns:repeat(5,minmax(0,1fr));gap:5px}.battle-screen.portrait-game .battle-tactics-panel{grid-template-columns:repeat(3,minmax(0,1fr));gap:5px}.battle-screen.portrait-game .tactic-card{min-height:58px;grid-template-columns:26px minmax(0,1fr);gap:5px;padding:5px 6px;border-width:3px;border-radius:10px}.battle-screen.portrait-game .tactic-card svg{width:25px;height:25px;padding:3px;border-radius:8px}.battle-screen.portrait-game .tactic-card small{font-size:9px}.battle-screen.portrait-game .tactic-card strong{font-size:11px}.battle-screen.portrait-game .mobile-inline-panel{grid-row:3;min-height:82px;display:grid;grid-template-rows:22px minmax(0,1fr);gap:5px;overflow:hidden;padding:5px;border:3px solid #130704;border-radius:12px;background:radial-gradient(circle at 20% 0%,rgba(255,238,156,.28),transparent 34%),linear-gradient(180deg,rgba(255,226,128,.18),transparent 40%),linear-gradient(180deg,#70401d,#35180b 72%,#150704);box-shadow:inset 0 0 0 2px #ffde8438,inset 0 -7px #0000003d}.battle-screen.portrait-game .mobile-inline-panel__head{min-width:0;display:grid;grid-template-columns:minmax(0,1fr) 28px;align-items:center;gap:6px;padding:0 2px 0 6px}.battle-screen.portrait-game .mobile-inline-panel__head strong{overflow:hidden;color:#ffe58b;font-size:12px;font-weight:950;text-overflow:ellipsis;text-shadow:0 2px #130704;white-space:nowrap}.battle-screen.portrait-game .mobile-inline-panel__head button{width:28px;min-width:28px;height:24px;min-height:24px;padding:0;border-width:2px;border-radius:7px}.battle-screen.portrait-game .mobile-inline-panel__head svg{width:15px;height:15px}.battle-screen.portrait-game .mobile-unit-strip,.battle-screen.portrait-game .mobile-skill-strip{min-width:0;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:4px}.battle-screen.portrait-game .mobile-unit-chip,.battle-screen.portrait-game .mobile-skill-chip{min-width:0;min-height:52px;display:grid;place-items:center;gap:1px;padding:3px 2px;border:2px solid #140704;border-radius:9px;background:radial-gradient(circle at 38% 20%,rgba(255,245,184,.34),transparent 24%),linear-gradient(#7c4a22,#2a1108);color:#fff1bd;text-shadow:0 2px #130704;box-shadow:inset 0 0 0 1px #ffde8438,0 2px #080302b3}.battle-screen.portrait-game .mobile-unit-chip.selected,.battle-screen.portrait-game .mobile-skill-chip.selected{box-shadow:0 0 12px #8fd7ff9e,inset 0 0 0 2px #ffefa45c,0 2px #080302b3}.battle-screen.portrait-game .mobile-unit-chip.locked{filter:saturate(.75) brightness(.82)}.battle-screen.portrait-game .mobile-unit-chip .unit-portrait-canvas{width:34px;height:34px}.battle-screen.portrait-game .mobile-unit-chip span{max-width:100%;overflow:hidden;font-size:9px;font-weight:950;line-height:1;text-overflow:ellipsis;white-space:nowrap}.battle-screen.portrait-game .mobile-skill-chip .skill-glyph-canvas{width:34px!important;height:34px!important}.battle-screen.portrait-game .mobile-skill-chip span{min-width:22px;padding:0 4px;border-radius:7px;background:#2a1207b8;color:#ffd96a;font-size:10px;font-weight:950;line-height:1.25}.battle-screen.portrait-game .mobile-castle-strip{min-width:0;display:grid;grid-template-columns:58px minmax(0,1fr) 64px;align-items:center;gap:7px;min-height:58px;padding:4px 6px;border:2px solid rgba(255,220,114,.24);border-radius:10px;background:#f4cd7a1a}.battle-screen.portrait-game .mobile-castle-strip .castle-portrait-canvas{width:56px;height:56px}.battle-screen.portrait-game .mobile-castle-strip span{min-width:0;display:grid;gap:3px}.battle-screen.portrait-game .mobile-castle-strip strong,.battle-screen.portrait-game .mobile-castle-strip small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.battle-screen.portrait-game .mobile-castle-strip strong{color:#fff3c2;font-size:13px;text-shadow:0 2px #130704}.battle-screen.portrait-game .mobile-castle-strip small,.battle-screen.portrait-game .mobile-castle-strip p{margin:0;color:#f4d28b;font-size:10px;font-weight:800}.battle-screen.portrait-game .mobile-upgrade-button{min-width:0;min-height:40px;display:inline-flex;align-items:center;justify-content:center;gap:2px;padding:2px 4px;border-width:2px;font-size:11px}.battle-screen.portrait-game .mobile-upgrade-button svg{width:15px;height:15px}.battle-screen.portrait-game .skill-button{min-height:72px;height:100%;padding:4px 2px 3px;border-width:3px;border-radius:11px}.battle-screen.portrait-game .skill-button .skill-icon{width:clamp(44px,13.2vw,54px);height:clamp(44px,13.2vw,54px)}.battle-screen.portrait-game .skill-glyph-canvas{width:clamp(44px,13.2vw,54px)!important;height:clamp(44px,13.2vw,54px)!important}.battle-screen.portrait-game .skill-button strong{display:none}.battle-screen.portrait-game .skill-button small{position:absolute;right:6px;bottom:4px;padding:0 4px;border-radius:6px;background:#0d0603b8;font-size:10px}.battle-screen.portrait-game .command-message{min-height:22px;padding:3px 8px;overflow:hidden;border-radius:8px;font-size:11px;text-align:center;text-overflow:ellipsis;white-space:nowrap}.battle-screen.portrait-game .floating-info-popover{display:none!important}.battle-screen.portrait-game .pause-popover{position:absolute;right:max(env(safe-area-inset-right),8px);bottom:calc(max(env(safe-area-inset-bottom),6px) + var(--bottom-hud-height) + var(--portrait-dock-height) + 16px);left:max(env(safe-area-inset-left),8px);width:auto;max-width:none;max-height:min(34svh,260px);padding:6px;overflow:hidden}.battle-screen.portrait-game .medieval-popover.units,.battle-screen.portrait-game .medieval-popover.castle,.battle-screen.portrait-game .medieval-popover.skills{top:auto;right:max(env(safe-area-inset-right),8px);bottom:calc(max(env(safe-area-inset-bottom),6px) + var(--bottom-hud-height) + var(--portrait-dock-height) + 16px);left:max(env(safe-area-inset-left),8px);width:auto;max-width:none}.battle-screen.portrait-game .floating-popover-title{min-height:38px;margin-bottom:5px;padding:3px 3px 3px 36px;border-width:3px}.battle-screen.portrait-game .floating-popover-title strong{font-size:12px}.battle-screen.portrait-game .floating-popover-close,.battle-screen.portrait-game .medieval-close-button{width:38px;min-width:38px;height:38px;min-height:38px;border-width:3px}.battle-screen.portrait-game .unit-drawer{padding:4px}.battle-screen.portrait-game .unit-drawer__list{grid-template-columns:repeat(5,minmax(0,1fr));gap:4px}.battle-screen.portrait-game .unit-card{min-height:86px;padding:4px 2px;border-width:3px;border-radius:10px}.battle-screen.portrait-game .unit-card__portrait{height:42px;border-width:2px}.battle-screen.portrait-game .unit-card__name{font-size:10px}.battle-screen.portrait-game .unit-card__count{font-size:8px}.battle-screen.portrait-game .unit-card__lock{right:2px;bottom:2px;padding:1px 3px;font-size:8px}.battle-screen.portrait-game .floating-skill-list{grid-template-columns:repeat(5,minmax(0,1fr));gap:4px;padding:4px}.battle-screen.portrait-game .floating-skill-card{min-height:82px;padding:4px 2px;border-width:3px}.battle-screen.portrait-game .floating-skill-card .skill-glyph-canvas{width:38px!important;height:38px!important}.battle-screen.portrait-game .floating-skill-card em{display:none}.battle-screen.portrait-game .castle-info-card{grid-template-columns:88px 1fr;gap:5px 8px;padding:7px}.battle-screen.portrait-game .castle-portrait-canvas{width:84px;height:84px}.battle-screen.portrait-game .castle-stat-bar{padding:2px 6px;font-size:10px}.battle-screen.portrait-game .popover-upgrade{min-height:38px;padding:4px 8px}.battle-screen.portrait-game .pause-actions{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (orientation: portrait) and (max-width: 380px){.battle-screen.portrait-game{--bottom-hud-height: 204px}.battle-screen.portrait-game .battle-map-panel{aspect-ratio:16 / 9}.battle-screen.portrait-game .skill-button{min-height:64px}.battle-screen.portrait-game .unit-card__lock{display:none}}
