:root{color:#f3e5c0;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#07060a;font-family:Hiragino Mincho ProN,Yu Mincho,Georgia,Times New Roman,serif}*{box-sizing:border-box}html,body,#app{overscroll-behavior:none;width:100%;height:100%;margin:0;overflow:hidden}body{touch-action:none;-webkit-user-select:none;user-select:none;background:radial-gradient(circle at 50% 20%,#58332447,#0000 42%),linear-gradient(#0b0710 0%,#050407 100%)}#app{place-items:center;display:grid;position:fixed;inset:0}#game-host{place-items:center;width:100%;height:100%;display:grid}canvas{image-rendering:auto;display:block}#mobile-hud,#mobile-controls{display:none}@media (orientation:portrait),(width<=720px){#app{padding:max(10px, env(safe-area-inset-top)) max(10px, env(safe-area-inset-right)) max(10px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-left));grid-template-rows:minmax(118px,16svh) minmax(260px,50svh) minmax(230px,34svh);grid-template-columns:100%;place-items:stretch stretch;gap:8px}#game-host{background:#050407;border:2px solid #dbaa58d1;border-radius:8px;grid-row:2;align-self:center;width:100%;height:100%;min-height:0;overflow:hidden;box-shadow:inset 0 0 0 1px #ffefb41f,0 12px 28px #00000070}#game-host canvas{place-self:center;width:100%!important;max-width:100%!important;height:auto!important;max-height:100%!important}#mobile-hud,#mobile-controls{opacity:0;pointer-events:none;transition:opacity .12s;display:flex}body.game-active #mobile-hud,body.game-active #mobile-controls{opacity:1;pointer-events:auto}#mobile-hud{background:linear-gradient(135deg,#2a1c18f5,#0a0810f5),radial-gradient(circle at 18% 20%,#f0ae4c2e,#0000 45%);border:1px solid #e6b85bbd;border-radius:8px;grid-row:1;align-items:stretch;gap:9px;min-height:0;padding:8px;box-shadow:inset 0 0 0 1px #fff2b914,0 10px 24px #00000059}.mobile-hud__portrait{background:linear-gradient(#1f151cf2,#07060af2);border:1px solid #ffda7ab8;border-radius:7px;flex:0 0 64px;place-items:center;display:grid;overflow:hidden}.mobile-hud__portrait img{object-fit:contain;width:58px;height:72px}.mobile-hud__main{flex:auto;grid-template-rows:auto 1fr 1fr 1fr auto auto;gap:3px;min-width:0;display:grid}.mobile-hud__topline,.mobile-hud__meta{justify-content:space-between;align-items:center;gap:8px;min-width:0;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:11px;line-height:1.1;display:flex}.mobile-hud__topline strong,#mobile-stage-label{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.mobile-hud__topline strong{color:#ffe7a3;flex:none;font-size:13px}#mobile-stage-label{color:#f5dcc0;text-align:right;flex:auto}.mobile-hud__meta{color:#d9e8ff;font-size:10px}.mobile-meter{background:#09070ad1;border:1px solid #ffeaac61;border-radius:3px;min-height:12px;position:relative;overflow:hidden}.mobile-meter span{z-index:2;color:#fff7d5;text-shadow:0 1px 2px #000;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:9px;position:absolute;top:50%;left:5px;transform:translateY(-50%)}.mobile-meter i{width:100%;height:100%;transition:width .12s;display:block}.mobile-meter--hp i{background:linear-gradient(90deg,#8b1f22,#ef4c38,#ffad67)}.mobile-meter--mp i{background:linear-gradient(90deg,#203386,#337eef,#8bdcff)}.mobile-meter--exp i{background:linear-gradient(90deg,#557a28,#c3bf36,#ffe083)}.mobile-boss{color:#ffd6d6;align-items:center;gap:7px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:10px;display:none}.mobile-boss.is-visible{display:flex}.mobile-boss span{text-overflow:ellipsis;white-space:nowrap;flex:none;max-width:42%;overflow:hidden}.mobile-boss b{background:#140708e6;border:1px solid #ffe0838c;border-radius:2px;flex:auto;height:9px;overflow:hidden}.mobile-boss i{background:linear-gradient(90deg,#6a1024,#e13746,#ffe083);height:100%;display:block}#mobile-controls{background:linear-gradient(#0b090fe0,#140c12f0);border:1px solid #e6b85b7a;border-radius:10px;grid-row:3;justify-content:space-between;align-items:center;gap:12px;min-height:0;padding:10px 8px 4px}.mobile-dpad,.mobile-actions{flex:1 1 0;height:min(30svh,250px);min-height:204px;position:relative}.touch-button{color:#fff6d6;touch-action:none;background:radial-gradient(circle at 35% 28%,#ffffff2e,#0000 35%),linear-gradient(#362b30eb,#0f0c12f0);border:2px solid #ffe086cc;border-radius:999px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-weight:800;position:absolute;box-shadow:0 5px #00000073,0 0 18px #ffd06529}.touch-button.is-pressed,.touch-button:active{filter:brightness(1.4);transform:translateY(4px)scale(.97);box-shadow:0 1px #0009,0 0 22px #ffe68f61}.mobile-dpad .touch-button{width:74px;height:74px;font-size:28px}.touch-button--up{top:0;left:50%;transform:translate(-50%)}.touch-button--left{top:50%;left:7%;transform:translateY(-50%)}.touch-button--right{top:50%;right:7%;transform:translateY(-50%)}.touch-button--down{bottom:0;left:50%;transform:translate(-50%)}.touch-button--attack{background:radial-gradient(circle at 35% 28%,#fff3,#0000 35%),linear-gradient(#713124f5,#231011f5);border-color:#ffdd71f2;width:118px;height:118px;font-size:18px;bottom:2px;right:0}.touch-button--skill1,.touch-button--skill2,.touch-button--ultimate{width:76px;height:76px;font-size:16px}.touch-button--skill1{top:66px;right:104px}.touch-button--skill2{border-color:#89dbffeb;top:42px;right:22px}.touch-button--ultimate{background:radial-gradient(circle at 35% 28%,#ffffff2e,#0000 35%),linear-gradient(#5c1c2bf5,#1c0c1af5);border-color:#ff7094f0;top:-10px;right:104px}}
