:root{color-scheme:dark;--bg: #0f1115;--panel: #151a22;--text: #e6e6e6;--muted: #a7b0c0;--border: #2a3242}html,body{height:100%;margin:0;background:var(--bg);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";overscroll-behavior:none}#root{height:100%}*{box-sizing:border-box}a{color:inherit}.container{height:100vh;display:grid;grid-template-rows:auto auto 1fr;gap:12px;padding:12px}.panel{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:10px 12px}.row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.muted{color:var(--muted)}.badge{display:inline-flex;align-items:center;gap:8px;padding:4px 10px;border-radius:999px;border:1px solid var(--border);background:#ffffff08;font-size:12px}.dot{width:8px;height:8px;border-radius:999px;background:#666}.dot.ok{background:#2ecc71}.dot.bad{background:#e74c3c}.boardPanel{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:8px 12px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.boardPanelGroup{display:flex;align-items:center;gap:6px}.boardPanelDivider{width:1px;height:20px;background:var(--border);flex-shrink:0}.boardPanelLabel{font-size:12px;color:var(--muted);white-space:nowrap}.boardPanelInput{background:#0000004d;border:1px solid var(--border);border-radius:6px;padding:4px 8px;color:var(--text);font-size:12px;outline:none}.boardPanelInput:focus{border-color:#2ecc7199}.boardPanelInputNum{width:52px}.boardPanelInputName{width:130px}.boardPanelSelect{background:#0000004d;border:1px solid var(--border);border-radius:6px;padding:4px 8px;color:var(--text);font-size:12px;outline:none;cursor:pointer}.boardPanelSelect:focus{border-color:#2ecc7199}.boardPanelBtnActive{background:#2ecc7138!important;border-color:#2ecc71b3!important}.boardPanelBtnDanger{background:#e74c3c1f!important;border-color:#e74c3c66!important;color:#e74c3c!important}.boardPanelBtnDanger:hover:not(:disabled){background:#e74c3c38!important}.boardPanelError{font-size:11px;color:#e74c3c}.phaserWrap{min-height:0;width:100%;height:100%;position:relative;border:1px solid var(--border);border-radius:10px;overflow:hidden}.phaserRoot{width:100%;height:100%}.phaserRoot canvas{display:block;width:100%!important;height:100%!important}.gameHud{position:absolute;top:12px;right:12px;display:flex;align-items:center;gap:8px;pointer-events:auto}.gameHudBtn{cursor:pointer;background:#2ecc711f;border-color:#2ecc7166;color:var(--text)}.gameHudBtn:hover:not(:disabled){background:#2ecc7138}.gameHudBtn:disabled{opacity:.4;cursor:not-allowed}.unitSelector{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:max-content;max-width:calc(100% - 24px);margin-bottom:12px;padding:10px 10px calc(10px + env(safe-area-inset-bottom,0px));background:#151a22d9;border:1px solid var(--border);border-radius:14px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:auto}.unitSelector.sidePanel{left:unset;transform:none;bottom:unset;top:50%;transform:translateY(-50%);width:fit-content;max-height:calc(100% - 24px);overflow-y:auto;overflow-x:hidden}.unitSelector.sidePanelPlayer{left:12px}.unitSelector.sidePanelEnemy{right:12px;top:56px;transform:none;max-height:calc(100% - 68px)}.unitSelectorInner{display:flex;gap:10px;overflow-x:auto;overflow-y:hidden;padding-bottom:4px}.sidePanel .unitSelectorInner{display:grid;grid-template-columns:repeat(2,72px);overflow-x:unset;overflow-y:unset}.sidePanel .unitSelectorItem{width:100%}.unitSelectorItem{flex:0 0 auto;display:grid;justify-items:center;gap:6px;padding:8px;border-radius:10px;border:1px solid var(--border);background:#ffffff08;color:var(--text);cursor:pointer}.unitSelectorItem:hover{background:#ffffff0f}.unitSelectorItem:active{transform:translateY(1px)}.unitSelectorItem.selected{border-color:#2ecc71e6;box-shadow:0 0 0 2px #2ecc712e}.unitSelectorItem.selectedDanger{border-color:#e74c3ce6!important;box-shadow:0 0 0 2px #e74c3c2e!important}.unitSelectorThumb{width:44px;height:44px;border-radius:8px;background:#00000040;border:1px solid rgba(255,255,255,.06);overflow:hidden}.unitSelectorImg{height:100%;width:auto;display:block;image-rendering:pixelated}.unitSelectorLabel{font-size:11px;color:var(--muted);line-height:1;white-space:nowrap}.modalOverlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modalContent{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:24px;width:340px;max-width:calc(100vw - 32px);max-height:calc(100vh - 32px);overflow-y:auto}.modalContent h2{margin:0 0 16px;font-size:16px;font-weight:600}.formField{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.formField label{font-size:12px;color:var(--muted)}.formField input[type=text],.formField input[type=number]{background:#0000004d;border:1px solid var(--border);border-radius:6px;padding:6px 10px;color:var(--text);font-size:14px;outline:none}.formField input:focus{border-color:#2ecc7199}.formField input[type=file]{font-size:12px;color:var(--muted)}.formActions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.formActions button{padding:6px 16px;border-radius:6px;border:1px solid var(--border);background:#ffffff0d;color:var(--text);cursor:pointer;font-size:13px}.formActions button:hover{background:#ffffff1a}.formActions button[type=submit]{background:#2ecc7126;border-color:#2ecc7166}.formActions button[type=submit]:hover{background:#2ecc7140}.formActions button:disabled{opacity:.5;cursor:not-allowed}.formError{color:#e74c3c;font-size:12px;margin-bottom:8px}.behaviorPanel{position:absolute;top:0;right:0;bottom:0;width:380px;max-width:calc(100% - 48px);z-index:900;display:flex;flex-direction:column;background:#0f1115f5;border-left:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:auto}.behaviorPanelHeader{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:16px 16px 12px;border-bottom:1px solid var(--border);flex-shrink:0}.behaviorPanelTitle{font-size:15px;font-weight:600;line-height:1.2}.behaviorPanelMeta{font-size:12px;color:var(--muted);margin-top:4px}.behaviorPanelClose{flex-shrink:0;background:none;border:none;color:var(--muted);font-size:14px;cursor:pointer;padding:2px 4px;border-radius:4px;line-height:1}.behaviorPanelClose:hover{color:var(--text);background:#ffffff12}.behaviorPanelScriptLabel{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#ffffff59;padding:8px 16px 6px;flex-shrink:0}.behaviorPanelBody{flex:1;overflow-y:auto;padding:0 16px 16px}.behaviorPanelCode{margin:0;font-family:ui-monospace,SF Mono,Menlo,Consolas,Courier New,monospace;font-size:12px;line-height:1.6;color:var(--text);white-space:pre;tab-size:4}.behaviorPanelLoading,.behaviorPanelError{font-size:13px;color:var(--muted);padding-top:8px}.behaviorPanelError{color:#e74c3c}.unitTypePopover{position:fixed;z-index:1100;background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:4px;min-width:160px;box-shadow:0 4px 16px #00000080}.unitTypePopoverItem{display:block;width:100%;padding:8px 12px;border:none;background:none;border-radius:5px;font-size:13px;text-align:left;cursor:pointer;color:var(--text)}.unitTypePopoverItem:hover{background:#ffffff12}.unitTypePopoverItem.danger{color:#e74c3c}.unitTypePopoverItem.danger:hover{background:#e74c3c1f}.btnDanger{background:#e74c3c26!important;border-color:#e74c3c66!important;color:#e74c3c!important}.btnDanger:hover:not(:disabled){background:#e74c3c40!important}.deleteWarning{font-size:13px;color:var(--muted);margin:0 0 16px;line-height:1.5}.formSectionLabel{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#fff6;margin:10px 0 4px}.spritePreview{width:44px;height:44px;border-radius:8px;background:#00000040;border:1px solid rgba(255,255,255,.06);overflow:hidden;margin-top:4px}.spritePreview img{height:100%;width:auto;display:block;image-rendering:pixelated}.phaseIndicator{display:flex;align-items:center;gap:0}.phaseIndicatorStep{display:flex;align-items:center;gap:6px}.phaseIndicatorConnector{width:24px;height:1px;background:var(--border);margin-right:6px;flex-shrink:0}.phaseIndicatorConnector.done{background:#ffffff4d}.phaseIndicatorDot{width:8px;height:8px;border-radius:50%;flex-shrink:0;background:var(--border)}.phaseIndicatorDot.active{background:#e6e6e6;box-shadow:0 0 0 2px #e6e6e633}.phaseIndicatorDot.done{background:#ffffff4d}.phaseIndicatorLabel{font-size:12px;color:var(--border);white-space:nowrap}.phaseIndicatorLabel.active{color:var(--text);font-weight:600}.phaseIndicatorLabel.done{color:#ffffff4d}.roundTableView{position:absolute;inset:0;z-index:500;background:var(--bg);display:flex;flex-direction:column;align-items:center;padding:24px 20px 16px;gap:20px;overflow:hidden}.roundTableHeader{text-align:center;flex-shrink:0}.roundTableTitle{margin:0 0 6px;font-size:22px;font-weight:700;letter-spacing:.02em;color:var(--text)}.roundTableSubtitle{margin:0;font-size:13px;color:var(--muted)}.roundTableMain{display:grid;grid-template-columns:150px 1fr 150px;gap:16px;flex:1;min-height:0}.commanderColumn{display:flex;flex-direction:column;align-items:center;overflow:hidden;gap:8px;padding-top:12px}.commanderSprite{display:flex;align-items:center;justify-content:center;min-height:144px}.commanderSpritePlaceholder{width:144px;height:144px;border-radius:8px;background:var(--panel);border:1px dashed var(--border)}.commanderGroupLabel{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.commanderGroupDot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.commanderCrown{font-size:18px;line-height:1}.commanderName{font-size:14px;font-weight:600;color:var(--text);text-align:center}.commanderEmpty{font-size:12px;color:var(--muted);font-style:italic;text-align:center}.roundTableChat{display:flex;flex-direction:column;min-height:0;background:var(--panel);border:1px solid var(--border);border-radius:10px;overflow:hidden}.roundTableMessages{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:10px}.messageBubble{display:flex;flex-direction:column;gap:3px;max-width:85%}.messageBubblePlayer{align-self:flex-end;align-items:flex-end}.messageBubbleCommander{align-self:flex-start;align-items:flex-start}.messageSender{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.messageBubbleText{font-size:13px;line-height:1.5;padding:8px 11px;border-radius:8px;border:1px solid var(--border);background:#ffffff0a;color:var(--text)}.messageBubblePlayer .messageBubbleText{background:#ffffff12}.roundTableInputRow{display:flex;gap:8px;padding:10px;border-top:1px solid var(--border);flex-shrink:0}.roundTableInput{flex:1;background:#ffffff0d;border:1px solid var(--border);border-radius:6px;padding:7px 10px;font-size:13px;color:var(--text);outline:none}.roundTableInput:focus{border-color:#fff3}.roundTableInput::placeholder{color:var(--muted);opacity:.6}.roundTableSendBtn{padding:7px 14px;border-radius:6px;border:1px solid var(--border);background:#ffffff0f;color:var(--text);font-size:13px;cursor:pointer;flex-shrink:0}.roundTableSendBtn:hover:not(:disabled){background:#ffffff1a}.roundTableSendBtn:disabled{opacity:.35;cursor:not-allowed}.roundTableActions{display:flex;gap:12px;flex-shrink:0}.roundTableBtn{padding:9px 22px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid var(--border);transition:background .15s,opacity .15s}.roundTableBtnBack{background:#ffffff0a;color:var(--muted)}.roundTableBtnBack:hover{background:#ffffff14;color:var(--text)}.roundTableBtnStart{background:#2ecc7126;border-color:#2ecc7166;color:#2ecc71}.roundTableBtnStart:hover:not(:disabled){background:#2ecc7140}.roundTableBtnStart:disabled{opacity:.4;cursor:not-allowed}.roundTableWarning{font-size:12px;color:var(--muted);text-align:center;margin:0;flex-shrink:0}.strategyPreview{flex:1;display:flex;flex-direction:column;gap:8px;overflow:hidden;min-width:0}.strategyPreviewHeader{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);text-align:center;flex-shrink:0}.strategyPreviewPanes{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:8px;overflow:hidden;min-height:0}.strategyPane{display:flex;flex-direction:column;gap:6px;overflow:hidden;min-height:0}.strategyPaneLabel{font-size:12px;font-weight:600;display:flex;align-items:center;gap:6px;flex-shrink:0}.strategyLineChanged{display:block;background:#ffd20021;border-left:2px solid rgba(255,210,0,.6);margin-left:-12px;padding-left:10px}.strategyCode{flex:1;margin:0;padding:10px 12px;background:#0a0d12;border:1px solid var(--border);border-radius:6px;font-family:ui-monospace,Cascadia Code,Fira Code,monospace;font-size:11px;line-height:1.6;color:#c9d1d9;overflow-y:auto;white-space:pre;min-height:0}.typingIndicator{display:flex;gap:5px;padding:10px 12px;align-self:flex-start}.typingIndicator span{width:7px;height:7px;border-radius:50%;background:var(--muted);animation:typingBounce 1.2s infinite}.typingIndicator span:nth-child(2){animation-delay:.2s}.typingIndicator span:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-5px);opacity:1}}.rtColumns{display:flex;gap:0;flex:1;min-height:0;width:100%;max-width:960px;overflow:hidden}.rtDivider{width:1px;background:var(--border);flex-shrink:0;margin:0 16px}.rtGroupCol{flex:1;display:flex;flex-direction:column;gap:12px;overflow:hidden;min-height:0}.rtCommanderHeader{display:flex;flex-direction:column;align-items:center;gap:6px;flex-shrink:0;padding-bottom:8px;border-bottom:1px solid var(--border)}.rtStrategyList{flex:1;display:flex;flex-direction:column;gap:10px;overflow-y:auto;min-height:0}.rtStatusMsg{font-size:13px;color:var(--muted);text-align:center;padding:24px 0;font-style:italic}.rtErrorMsg{font-size:13px;color:#e74c3c;display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;text-align:center}.rtRetryBtn{padding:5px 14px;border-radius:6px;border:1px solid rgba(231,76,60,.4);background:#e74c3c1a;color:#e74c3c;font-size:12px;cursor:pointer}.rtRetryBtn:hover{background:#e74c3c33}.rtStrategyCard{border:1px solid var(--border);border-radius:8px;padding:12px;cursor:pointer;background:#ffffff05;transition:border-color .15s,background .15s;display:flex;flex-direction:column;gap:6px}.rtStrategyCard:hover{background:#ffffff0d}.rtStrategyCardSelected{background:#ffffff0a}.rtStrategyCardHeader{display:flex;align-items:center;justify-content:space-between}.rtStrategyTitle{font-size:13px;font-weight:600;color:var(--text)}.rtStrategyCheck{font-size:14px;font-weight:700}.rtStrategyDesc{font-size:12px;color:var(--muted);line-height:1.5}.rtStrategyCode{max-height:160px;flex-shrink:0}.rtSimContainer{display:flex;flex-direction:column;align-items:center;gap:4px}.rtSimCanvas{image-rendering:pixelated;border:1px solid var(--border);border-radius:4px}.rtSimLoading,.rtSimError{font-size:11px;color:var(--muted);text-align:center;padding:20px;font-style:italic}.rtSimLegend{display:flex;gap:10px;font-size:10px;color:var(--muted);align-items:center}.rtSimDot{display:inline-block;width:6px;height:6px;border-radius:50%}.genModal{width:560px;max-width:calc(100vw - 32px)}.genPromptArea{background:#0000004d;border:1px solid var(--border);border-radius:6px;padding:8px 10px;color:var(--text);font-size:13px;resize:vertical;outline:none;font-family:inherit;width:100%;box-sizing:border-box}.genPromptArea:focus{border-color:#2ecc7199}.genStepList{display:flex;flex-direction:column;gap:10px;margin-top:4px}.genStepCard{border:1px solid var(--border);border-radius:8px;overflow:hidden}.genStepHeader{display:flex;align-items:center;gap:8px;padding:8px 10px;background:#ffffff08;flex-wrap:wrap}.genPhaseBadge{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:2px 7px;border-radius:4px;color:#fff}.genStepIteration{font-size:11px;color:var(--muted)}.genStepProgress{font-size:12px;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.genStepFiles{display:flex;flex-direction:column;gap:1px;background:var(--border)}.genFileBlock{background:var(--panel)}.genFileBlockHeader{display:flex;align-items:center;justify-content:space-between;width:100%;padding:5px 10px;background:#ffffff05;border:none;cursor:pointer;color:var(--muted);font-size:11px;text-align:left}.genFileBlockHeader:hover{background:#ffffff0d}.genFileBlockName{font-family:monospace;color:var(--text)}.genFileBlockToggle{font-size:10px}.genFileBlockBody{margin:0;padding:8px 10px;font-size:11px;font-family:monospace;color:var(--text);background:#0003;overflow-x:auto;white-space:pre-wrap;word-break:break-word;max-height:220px;overflow-y:auto}.genThinking{display:flex;align-items:center;gap:5px;padding:8px 4px}.genThinkingDot{width:6px;height:6px;border-radius:50%;background:var(--muted);animation:genPulse 1.2s ease-in-out infinite}.genThinkingDot:nth-child(2){animation-delay:.2s}.genThinkingDot:nth-child(3){animation-delay:.4s}@keyframes genPulse{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}.genFinalCard{margin-top:12px;border:1px solid rgba(46,204,113,.4);border-radius:8px;overflow:hidden}.genFinalTitle{padding:6px 10px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#2ecc71e6;background:#2ecc7112}.genSpriteSection{margin-top:14px;border:1px solid var(--border);border-radius:8px;overflow:hidden}.genSpriteLabel{padding:6px 10px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#e67e22e6;background:#e67e2212}.genSpritePreview{padding:12px;display:flex;justify-content:center;background:#0000004d}.genSpriteImg{image-rendering:pixelated;max-width:100%;max-height:180px;object-fit:contain}
