.gw-root{--gw-panel: var(--surface);--gw-border: var(--border);--gw-text: var(--text-strong);--gw-muted: var(--text-muted);--gw-mutedL: var(--text-faint);--gw-brand: var(--brand);--gw-teal: #0ea5e9;--gw-amber: #d97706;--gw-red: #dc2626;--gw-pos: #059669;--gw-neg: #dc2626;--gw-cell: var(--surface-alt);--gw-grid: var(--surface-alt);--gw-wall: #374151;display:flex;flex-direction:column;align-items:center;padding:16px 12px;margin:1.5rem 0;background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--gw-text);font-family:var(--font-ui)}.gw-root *{box-sizing:border-box;margin:0;padding:0}.gw-root .sc-row{display:flex;gap:6px;margin-bottom:6px;flex-wrap:wrap;justify-content:center}.gw-root .sc-btn{padding:5px 12px;border-radius:16px;border:1px solid var(--gw-border);background:var(--gw-panel);color:var(--gw-muted);font-size:11.5px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}.gw-root .sc-btn:hover{color:var(--gw-text);border-color:var(--gw-brand)}.gw-root .sc-btn.active{background:var(--gw-brand);color:#fff;border-color:var(--gw-brand)}.gw-root .sc-desc{font-size:11px;color:var(--gw-muted);text-align:center;max-width:600px;margin-bottom:10px;line-height:1.5;min-height:26px}.gw-root .layout{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;align-items:flex-start;max-width:1000px;width:100%}.gw-root .grid-wrap{display:flex;flex-direction:column;align-items:center}.gw-root .grid{display:grid;gap:2px;padding:5px;background:var(--gw-grid);border-radius:10px;border:1px solid var(--gw-border);box-shadow:0 1px 3px #0000000a}.gw-root .cell{position:relative;display:flex;align-items:center;justify-content:center;border-radius:6px;background:var(--gw-cell);border:1px solid rgba(0,0,0,.04);transition:background .45s ease,box-shadow .45s ease;overflow:hidden}.gw-root .cell.goal{background:linear-gradient(135deg,#d1fae5,#00ab6b);border-color:#00ab6b;box-shadow:0 0 0 1px #00ab6b}.gw-root .cell.pit{background:linear-gradient(135deg,#fee2e2,#dc2626);border-color:#dc2626;box-shadow:0 0 0 1px #dc2626}.gw-root .cell.wall{background:var(--gw-wall);border-color:var(--gw-wall)}.gw-root .cell.agent-here{box-shadow:0 0 0 2.5px #d97706,0 0 12px #d9770673!important}.gw-root .cell-emoji{position:absolute;z-index:2;line-height:1;user-select:none;pointer-events:none;filter:drop-shadow(0 1px 2px rgba(0,0,0,.2))}.gw-root .cell-badge{position:absolute;bottom:3px;right:5px;z-index:3;font-size:9.5px;font-weight:800;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.4);letter-spacing:-.3px;user-select:none}.gw-root .wall-lines{width:55%;height:55%;background:repeating-linear-gradient(45deg,transparent,transparent 4px,rgba(255,255,255,.15) 4px,rgba(255,255,255,.15) 5px);border-radius:3px}.gw-root .arrow{position:absolute;color:var(--gw-text);opacity:0;transition:opacity .45s;z-index:2;pointer-events:none;user-select:none;line-height:1;font-weight:600}.gw-root .arrow.on{opacity:.72}.gw-root .agent-dot{position:absolute;z-index:3;display:none;align-items:center;justify-content:center;line-height:1;user-select:none;pointer-events:none;filter:drop-shadow(0 0 6px rgba(217,119,6,.6)) drop-shadow(0 1px 2px rgba(0,0,0,.25));animation:gwAgentPulse .9s ease-in-out infinite alternate}@keyframes gwAgentPulse{0%{filter:drop-shadow(0 0 4px rgba(217,119,6,.4)) drop-shadow(0 1px 2px rgba(0,0,0,.25))}to{filter:drop-shadow(0 0 10px rgba(217,119,6,.8)) drop-shadow(0 1px 2px rgba(0,0,0,.25))}}.gw-root .legend{display:flex;gap:10px;margin-top:6px;flex-wrap:wrap;justify-content:center}.gw-root .leg{display:flex;align-items:center;gap:4px;font-size:10.5px;color:var(--gw-muted)}.gw-root .leg-sw{width:11px;height:11px;border-radius:2px;border:1px solid rgba(0,0,0,.06)}.gw-root .leg-dot{font-size:12px;line-height:1}.gw-root .side{display:flex;flex-direction:column;gap:8px;min-width:220px;max-width:240px}.gw-root .card{background:var(--gw-panel);border:1px solid var(--gw-border);border-radius:8px;padding:10px 12px}.gw-root .btn-row{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap}.gw-root button{padding:6px 12px;border-radius:5px;border:0;font-weight:700;font-size:11.5px;cursor:pointer;font-family:inherit;line-height:1;transition:opacity .15s,transform .1s}.gw-root button:hover{opacity:.85}.gw-root button:active{transform:translateY(1px)}.gw-root .btn-brand{background:var(--gw-brand);color:#fff}.gw-root .btn-teal{background:var(--gw-teal);color:#fff}.gw-root .btn-red{background:var(--gw-red);color:#fff}.gw-root .btn-ghost{background:var(--gw-panel);color:var(--gw-muted);border:1px solid var(--gw-border)}.gw-root .sl-block{margin-bottom:6px}.gw-root .sl-head{display:flex;justify-content:space-between;font-size:10px;color:var(--gw-muted);margin-bottom:2px}.gw-root .sl-head .v{color:var(--gw-brand);font-family:ui-monospace,SF Mono,Consolas,monospace;font-weight:600}.gw-root input[type=range]{width:100%;accent-color:var(--gw-brand);height:3px;cursor:pointer}.gw-root .params{display:grid;grid-template-columns:1fr 1fr;gap:5px 10px}.gw-root .stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.gw-root .stat{text-align:center}.gw-root .stat .num{font-size:20px;font-weight:700;font-family:ui-monospace,SF Mono,Consolas,monospace;line-height:1.1}.gw-root .stat.a .num{color:var(--gw-brand)}.gw-root .stat.t .num{color:var(--gw-teal)}.gw-root .stat .lbl{font-size:8.5px;color:var(--gw-muted);text-transform:uppercase;letter-spacing:1.2px;margin-top:2px}.gw-root .trace{margin-top:8px;padding:6px 8px;background:var(--gw-grid);border-radius:5px;border:1px solid var(--gw-border);font-family:ui-monospace,SF Mono,Consolas,monospace;font-size:10.5px;color:var(--gw-mutedL);line-height:1.6;min-height:32px}.gw-root .trace .st{color:var(--gw-teal)}.gw-root .trace .ac{color:var(--gw-amber)}.gw-root .trace .pos{color:var(--gw-pos)}.gw-root .trace .neg{color:var(--gw-neg)}.gw-root .chart-head{font-size:8.5px;color:var(--gw-muted);text-transform:uppercase;letter-spacing:1.1px;margin:8px 0 3px}.gw-root #chart{background:var(--gw-grid);border:1px solid var(--gw-border);border-radius:5px}
