*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #080c14;--bg-secondary: #0e1525;--bg-surface: #141d30;--bg-card: rgba(20, 29, 48, .7);--border-color: rgba(100, 140, 255, .12);--border-glow: rgba(100, 140, 255, .25);--accent-primary: #6c8cff;--accent-secondary: #a78bfa;--accent-cyan: #22d3ee;--accent-green: #34d399;--safe-bg: rgba(52, 211, 153, .15);--safe-border: rgba(52, 211, 153, .5);--safe-text: #34d399;--danger-bg: rgba(239, 68, 68, .15);--danger-border: rgba(239, 68, 68, .5);--danger-text: #f87171;--unknown-bg: rgba(100, 116, 139, .12);--unknown-border: rgba(100, 116, 139, .3);--agent-glow: rgba(250, 204, 21, .5);--agent-border: #facc15;--text-primary: #e2e8f0;--text-secondary: #94a3b8;--text-dim: #64748b;--font-main: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--transition: all .25s cubic-bezier(.4, 0, .2, 1)}html{font-size:15px}body{font-family:var(--font-main);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.5;background-image:radial-gradient(ellipse 80% 50% at 50% -10%,rgba(108,140,255,.08),transparent),radial-gradient(ellipse 60% 40% at 80% 100%,rgba(167,139,250,.06),transparent)}.app{max-width:1440px;margin:0 auto;padding:1rem;display:flex;flex-direction:column;gap:1rem}.header{text-align:center;padding:1.5rem 1rem}.header h1{font-size:2.2rem;font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header .accent{background:linear-gradient(135deg,var(--accent-cyan),var(--accent-green));-webkit-background-clip:text;background-clip:text}.header .subtitle{color:var(--text-secondary);font-size:.9rem;margin-top:.3rem;font-weight:400}.panel{background:var(--bg-card);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.25rem}.panel-title{font-size:1rem;font-weight:700;margin-bottom:1rem;color:var(--text-primary)}.main-layout{display:grid;grid-template-columns:260px 1fr 280px;gap:1rem;align-items:start}.controls-panel{display:flex;flex-direction:column;gap:.75rem}.control-row{display:flex;gap:.5rem}.control-group{display:flex;flex-direction:column;gap:.25rem;flex:1}.control-group label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.control-group input{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:.5rem .75rem;color:var(--text-primary);font-family:var(--font-main);font-size:.9rem;font-weight:500;transition:var(--transition);width:100%}.control-group input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #6c8cff26}.button-group{display:flex;flex-direction:column;gap:.4rem}.btn{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.6rem 1rem;border:none;border-radius:var(--radius-sm);font-family:var(--font-main);font-size:.85rem;font-weight:600;cursor:pointer;transition:var(--transition)}.btn:hover{transform:translateY(-1px);filter:brightness(1.15)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-primary{background:linear-gradient(135deg,#3b82f6,#6366f1);color:#fff}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-accent{background:linear-gradient(135deg,#06b6d4,#3b82f6);color:#fff}.btn-accent.active{background:linear-gradient(135deg,#f59e0b,#ef4444)}.btn-warning{background:#f59e0b26;color:#f59e0b;border:1px solid rgba(245,158,11,.3)}.btn-danger{background:#ef44441f;color:var(--danger-text);border:1px solid rgba(239,68,68,.25)}.legend{margin-top:.5rem}.legend h3{font-size:.8rem;color:var(--text-secondary);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.legend-items{display:flex;flex-direction:column;gap:.35rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text-secondary)}.swatch{width:18px;height:18px;border-radius:4px;flex-shrink:0}.swatch-safe{background:var(--safe-bg);border:1.5px solid var(--safe-border)}.swatch-unknown{background:var(--unknown-bg);border:1.5px solid var(--unknown-border)}.swatch-danger{background:var(--danger-bg);border:1.5px solid var(--danger-border)}.swatch-agent{background:#facc1533;border:1.5px solid var(--agent-border)}.grid-section{display:flex;align-items:center;justify-content:center;min-height:400px}.grid{display:grid;gap:4px;width:100%;max-width:600px;aspect-ratio:1}.cell{position:relative;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:2px;border-radius:var(--radius-sm);border:1.5px solid var(--border-color);background:var(--bg-secondary);transition:var(--transition);padding:4px;min-height:50px;overflow:hidden}.cell.safe{background:var(--safe-bg);border-color:var(--safe-border)}.cell.danger{background:var(--danger-bg);border-color:var(--danger-border);animation:dangerPulse 2s ease-in-out infinite}.cell.unknown{background:var(--unknown-bg);border-color:var(--unknown-border)}.cell.agent-cell{border-color:var(--agent-border)!important;box-shadow:0 0 16px var(--agent-glow),inset 0 0 12px #facc1514;z-index:2}.cell.visited{opacity:1}.icon{font-size:1.2rem;line-height:1;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.agent-icon{font-size:1.5rem;animation:agentBounce 1.5s ease-in-out infinite}.death-icon{font-size:1.5rem;animation:shake .5s ease-in-out}.percept-icon{font-size:.85rem;opacity:.8}.hazard-icon{font-size:1rem}.gold-icon{font-size:1rem;animation:sparkle 1s ease-in-out infinite}.cell-coord{position:absolute;bottom:2px;right:4px;font-size:.55rem;color:var(--text-dim);font-weight:600;opacity:.6}.metrics-panel{display:flex;flex-direction:column;gap:.5rem}.metric-card{background:#0e152599;border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:.6rem .75rem;display:flex;flex-direction:column;gap:.15rem}.metric-card.highlight-card{border-color:var(--accent-primary);background:#6c8cff0f}.metric-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary)}.metric-value{font-size:1rem;font-weight:700;color:var(--text-primary)}.metric-value.mono{font-variant-numeric:tabular-nums}.metric-value.safe-val{color:var(--safe-text)}.metric-value.danger-val{color:var(--danger-text)}.status-alive{color:var(--accent-green)}.status-dead{color:var(--danger-text)}.status-won{color:#facc15}.status-stuck{color:#f97316}.metric-row{display:flex;gap:.5rem}.metric-card.mini{flex:1}.progress-bar{height:4px;background:var(--bg-secondary);border-radius:2px;margin-top:.3rem;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-cyan));border-radius:2px;width:0%;transition:width .4s ease}.log-panel{max-height:200px;overflow:hidden}.log-container{max-height:140px;overflow-y:auto;display:flex;flex-direction:column;gap:.2rem;font-size:.78rem;color:var(--text-secondary)}.log-container::-webkit-scrollbar{width:4px}.log-container::-webkit-scrollbar-track{background:transparent}.log-container::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.log-entry{padding:.2rem 0;border-bottom:1px solid rgba(100,140,255,.05);animation:fadeIn .3s ease}.log-time{color:var(--text-dim);font-size:.7rem}.footer{text-align:center;padding:1rem;font-size:.75rem;color:var(--text-dim)}@keyframes agentBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@keyframes dangerPulse{0%,to{box-shadow:inset 0 0 8px #ef44441a}50%{box-shadow:inset 0 0 16px #ef444433}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}@keyframes sparkle{0%,to{filter:drop-shadow(0 0 4px rgba(250,204,21,.5))}50%{filter:drop-shadow(0 0 10px rgba(250,204,21,.8))}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1024px){.main-layout{grid-template-columns:1fr}.grid-section{order:-1}.grid{max-width:500px}.controls-panel .button-group{flex-direction:row;flex-wrap:wrap}.btn{flex:1;min-width:100px}}@media (max-width: 600px){html{font-size:13px}.header h1{font-size:1.6rem}.grid{max-width:100%}.cell{min-height:40px}.icon{font-size:1rem}.agent-icon{font-size:1.2rem}}
