*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #1a1a1a;--surface: #242424;--surface2: #2e2e2e;--border: #404040;--text: #e8e8e8;--text-dim: #888;--accent: #4a9eff;--accent-hover: #6ab4ff;--danger: #e05555;--success: #4caf50;--warn: #e0a030;--tab-active: #4a9eff}html,body{height:100%;background:var(--bg);color:var(--text);font-family:Segoe UI,system-ui,sans-serif;font-size:13px;overflow:hidden}#app{display:flex;flex-direction:column;height:100vh}.storage-error-banner{background:#5a1a1a;border-bottom:1px solid #a03030;color:#ff9090;font-size:12px;padding:5px 14px;flex-shrink:0}#app-header{display:flex;align-items:center;gap:16px;padding:0 12px;height:40px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.app-title{font-weight:600;color:var(--text-dim);letter-spacing:.04em}.mode-tabs{display:flex;gap:4px}.mode-tab{padding:4px 14px;border:1px solid var(--border);background:transparent;color:var(--text-dim);border-radius:4px;cursor:pointer;font-size:13px;transition:color .15s,border-color .15s}.mode-tab:hover{color:var(--text);border-color:var(--text-dim)}.mode-tab.active{color:var(--tab-active);border-color:var(--tab-active);background:#4a9eff14}#app-main{display:flex;flex:1;overflow:hidden}#canvas-container{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg);overflow:hidden}#canvas-container canvas{display:block}#side-panel{width:200px;flex-shrink:0;background:var(--surface);border-left:1px solid var(--border);overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:0}.panel{display:none;flex-direction:column;gap:8px}.panel.active{display:flex}.panel h2{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);margin-bottom:2px}.panel h3{font-size:11px;font-weight:600;color:var(--text-dim)}.panel hr{border:none;border-top:1px solid var(--border);margin:4px 0}.hint{color:var(--text-dim);line-height:1.5;font-size:12px}.tool-group{display:flex;flex-direction:column;gap:4px}.tool-btn{padding:6px 10px;background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:4px;cursor:pointer;text-align:left;font-size:13px;transition:background .1s,border-color .1s}.tool-btn:hover{background:var(--border)}.tool-btn.active{border-color:var(--accent);color:var(--accent);background:#4a9eff1a}.action-group{display:flex;flex-direction:column;gap:4px}.action-group button,button#btn-restart,button#btn-generate,button#btn-apply,button#btn-discard{padding:6px 10px;background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:4px;cursor:pointer;font-size:13px;transition:background .1s}.action-group button:hover,button#btn-restart:hover,button#btn-generate:hover{background:var(--border)}button#btn-apply{border-color:var(--success);color:var(--success)}button#btn-apply:hover{background:#4caf501f}button#btn-discard{border-color:var(--danger);color:var(--danger)}button#btn-discard:hover{background:#e055551f}.field-group{display:flex;flex-direction:column;gap:6px}.field-group label{display:flex;justify-content:space-between;align-items:center;color:var(--text-dim);font-size:12px}.field-group input[type=number]{width:60px;background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:3px;padding:3px 6px;font-size:12px}.validation-msg{font-size:12px;color:var(--warn);min-height:16px}.validation-msg.error-msg{color:#f55}.play-status{font-size:13px;font-weight:600;color:var(--success);min-height:20px;text-align:center}.candidate-panel{display:flex;flex-direction:column;gap:6px;border:1px solid var(--border);border-radius:4px;padding:8px;background:var(--surface2)}.candidate-panel pre{font-size:10px;color:var(--text-dim);overflow:auto;max-height:120px;white-space:pre-wrap;word-break:break-all}.hidden{display:none!important}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100}.overlay-box{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:20px;display:flex;flex-direction:column;gap:10px;width:440px;max-width:90vw}.overlay-box h2{font-size:14px}.overlay-box textarea{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:4px;padding:8px;font-family:Consolas,monospace;font-size:11px;resize:vertical}.error-msg{font-size:12px;color:var(--danger);min-height:16px}.level-name-row{display:flex;flex-direction:column;gap:3px}.level-name-input{width:100%;background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:4px;padding:5px 8px;font-size:13px;font-family:Consolas,monospace;outline:none;transition:border-color .15s}.level-name-input:focus{border-color:var(--accent)}.level-name-input.error{border-color:var(--danger)}.name-error{font-size:11px;color:var(--danger);min-height:14px}.lineup-list{display:flex;flex-direction:column;gap:2px;max-height:320px;overflow-y:auto;overflow-x:hidden}.lineup-item{display:flex;align-items:center;gap:6px;padding:4px 6px;border-radius:3px;cursor:default;border:1px solid transparent;transition:background .1s}.lineup-item:hover{background:var(--surface2)}.lineup-item.active{background:#4a9eff1a;border-color:var(--accent)}.lineup-item.missing{opacity:.55}.lineup-item.level-new{border-color:#50c86499;background:#50c86412}.lineup-item.level-dirty{border-color:#ffc83299;background:#ffc83212}.lineup-item.active.level-new{border-color:#50c864e6}.lineup-item.active.level-dirty{border-color:#ffc832e6}.lineup-pos{width:32px;flex-shrink:0;background:var(--surface2);border:1px solid var(--border);color:var(--text-dim);border-radius:3px;padding:2px 4px;font-size:11px;text-align:center}.lineup-pos:focus{outline:none;border-color:var(--accent);color:var(--text)}.lineup-pos::-webkit-inner-spin-button,.lineup-pos::-webkit-outer-spin-button{-webkit-appearance:none}.lineup-pos{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.lineup-name{flex:1;font-size:12px;font-family:Consolas,monospace;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;-webkit-user-select:none;user-select:none}.lineup-textarea{width:100%;background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:4px;padding:6px 8px;font-family:Consolas,monospace;font-size:11px;resize:vertical;outline:none;line-height:1.6}.lineup-textarea:focus{border-color:var(--accent)}.lineup-validation{display:flex;flex-direction:column;gap:2px;font-size:11px}.lineup-warn{color:var(--warn)}.lineup-info{color:var(--text-dim)}button#btn-apply-lineup{padding:6px 10px;background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:4px;cursor:pointer;font-size:13px;transition:background .1s}button#btn-apply-lineup:hover{background:var(--border)}
