:root{--bg-0: #0b1020;--bg-1: #111733;--bg-2: #1a2148;--panel: rgba(255, 255, 255, .04);--panel-border: rgba(255, 255, 255, .09);--text: #eaf0ff;--text-dim: #9aa4c4;--accent: #6366f1;--accent-2: #22d3ee;--accent-3: #f472b6;--good: #22c55e;--warn: #f59e0b;--bad: #ef4444;--cell-bg: #1b2447;--cell-border: #2a3566;--cell-active: #6366f1;--shadow: 0 10px 30px rgba(0, 0, 0, .35);--radius: 14px;--font: "Inter", "Segoe UI", system-ui, -apple-system, sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%}body{font-family:var(--font);color:var(--text);background:radial-gradient(1200px 800px at 80% -10%,rgba(99,102,241,.25),transparent 60%),radial-gradient(900px 600px at 10% 110%,rgba(34,211,238,.18),transparent 60%),linear-gradient(180deg,var(--bg-0) 0%,var(--bg-1) 100%);min-height:100vh;-webkit-font-smoothing:antialiased}code{background:#6366f126;padding:1px 6px;border-radius:4px;font-size:.9em;color:#c7d2fe}.app-shell{max-width:1400px;margin:0 auto;padding:32px 24px 48px}.app-header{text-align:center;margin-bottom:28px}.app-header h1{margin:0;font-size:clamp(1.6rem,2.4vw,2.4rem);letter-spacing:-.02em;display:inline-flex;align-items:center;gap:12px}.logo-dot{width:14px;height:14px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 0 20px var(--accent);display:inline-block}.subtitle{color:var(--text-dim);margin:10px auto 0;max-width:760px;font-size:.98rem}.grid-layout{display:grid;gap:20px;grid-template-columns:minmax(300px,1fr) minmax(0,2fr);grid-template-areas:"controls  mesh" "steps     steps" "complexity complexity"}.control-panel{grid-area:controls}.mesh-panel{grid-area:mesh}.steps-panel{grid-area:steps}.complexity-panel{grid-area:complexity}@media (max-width: 900px){.grid-layout{grid-template-columns:1fr;grid-template-areas:"controls" "mesh" "steps" "complexity"}}.panel{background:var(--panel);border:1px solid var(--panel-border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.panel-title{margin:0 0 14px;font-size:1.05rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim);border-left:3px solid var(--accent);padding-left:10px}.empty-state{padding:20px 10px;color:var(--text-dim);text-align:center;border:1px dashed var(--panel-border);border-radius:10px}.control-grid{display:grid;gap:14px}.field label{display:block;font-size:.9rem;color:var(--text-dim);margin-bottom:6px}.field input[type=number]{width:100%;padding:10px 12px;background:#0d1430;border:1px solid var(--panel-border);color:var(--text);border-radius:10px;font-size:1rem;font-family:inherit;transition:border-color .12s ease,box-shadow .12s ease}.field input[type=number]:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #6366f140}.field input[type=number]:disabled{opacity:.6;cursor:not-allowed}.hint{color:var(--text-dim);font-size:.8rem}.chip-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.chip{padding:4px 10px;border-radius:999px;border:1px solid var(--panel-border);background:transparent;color:var(--text-dim);font-size:.8rem;cursor:pointer;transition:all .12s ease}.chip:hover:not(:disabled){border-color:var(--accent);color:var(--text)}.chip-active{background:var(--accent);color:#fff;border-color:var(--accent)}.chip:disabled{opacity:.5;cursor:not-allowed}.btn-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}.btn{padding:10px 16px;border-radius:10px;border:1px solid transparent;font-size:.95rem;font-weight:600;cursor:pointer;font-family:inherit;transition:transform 80ms ease,box-shadow .12s ease,background .12s ease}.btn:active{transform:translateY(1px)}.btn-primary{background:linear-gradient(135deg,var(--accent),#8b5cf6);color:#fff;box-shadow:0 6px 18px #6366f159}.btn-primary:hover:not(:disabled){filter:brightness(1.08)}.btn-secondary{background:#0d1430;color:var(--text);border-color:var(--panel-border)}.btn-secondary:hover:not(:disabled){border-color:var(--accent)}.btn-ghost{background:transparent;color:var(--text-dim);border-color:var(--panel-border)}.btn-ghost:hover:not(:disabled){color:var(--text);border-color:var(--accent)}.btn:disabled{opacity:.5;cursor:not-allowed}.error-box{margin-top:12px;padding:10px 12px;background:#ef44441f;border:1px solid rgba(239,68,68,.4);color:#fecaca;border-radius:10px;font-size:.9rem}.speed-field{margin-top:18px}.speed-field input[type=range]{width:100%;accent-color:var(--accent)}.mesh-grid{display:grid;gap:8px;justify-content:center;margin:8px auto 16px;padding:14px;background:#0003;border-radius:12px;border:1px solid var(--panel-border)}.cell{position:relative;background:var(--cell-bg);border:1px solid var(--cell-border);border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:transform .3s ease,background .3s ease,border-color .3s ease,box-shadow .3s ease}.cell-index{position:absolute;top:3px;left:6px;font-size:.68rem;color:var(--text-dim);font-variant-numeric:tabular-nums}.cell-value{font-size:1.2rem;font-weight:700;color:#fff;font-variant-numeric:tabular-nums}.cell-arrow{position:absolute;bottom:2px;right:6px;font-size:.95rem;color:var(--accent-2);animation:pulse .9s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.6;transform:translate(0)}50%{opacity:1;transform:translate(2px)}}.cell-active{background:linear-gradient(135deg,#4f46e5,#7c3aed);border-color:var(--accent-2);box-shadow:0 0 0 2px #22d3ee59,0 8px 22px #6366f173;transform:scale(1.05)}.phase-column .cell-active{background:linear-gradient(135deg,#0891b2,#6366f1)}.legend{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;color:var(--text-dim);font-size:.85rem}.legend-item{display:inline-flex;align-items:center;gap:6px}.legend-swatch{width:14px;height:14px;border-radius:4px;border:1px solid var(--panel-border);display:inline-block}.swatch-idx{background:transparent}.swatch-val{background:var(--cell-bg)}.swatch-active{background:linear-gradient(135deg,#4f46e5,#7c3aed)}.steps-grid{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:18px}.step-card{background:#0003;border:1px solid var(--panel-border);border-radius:12px;padding:14px;display:flex;flex-direction:column;align-items:center;gap:10px;min-width:180px}.step-heading{font-size:.85rem;color:var(--text-dim);letter-spacing:.05em;text-transform:uppercase}.step-arrow{font-size:1.6rem;color:var(--accent-2)}.mini-grid{display:grid;gap:4px}.mini-cell{background:var(--cell-bg);border:1px solid var(--cell-border);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:600;font-variant-numeric:tabular-nums}.formula-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:18px}.formula{background:#0003;border:1px solid var(--panel-border);border-radius:10px;padding:12px 14px}.formula-label{color:var(--text-dim);font-size:.8rem;margin-bottom:4px}.formula-value{font-size:1rem;font-variant-numeric:tabular-nums}.chart{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}.chart-row{display:flex;align-items:center;gap:10px}.chart-label{width:60px;color:var(--text-dim);font-size:.9rem}.chart-track{flex:1;height:28px;background:#00000040;border:1px solid var(--panel-border);border-radius:999px;overflow:hidden;position:relative}.chart-bar{height:100%;border-radius:999px;display:flex;align-items:center;justify-content:flex-end;padding-right:10px;min-width:34px;transition:width .6s cubic-bezier(.2,.8,.2,1)}.chart-bar.ring{background:linear-gradient(90deg,#f472b6,#ef4444)}.chart-bar.mesh{background:linear-gradient(90deg,var(--accent-2),var(--accent))}.chart-bar-label{color:#fff;font-weight:700;font-size:.85rem;text-shadow:0 1px 2px rgba(0,0,0,.35)}.bar-winner{box-shadow:0 0 0 2px #22c55e8c;outline:none}.verdict{padding:12px 14px;border-radius:10px;font-weight:600;text-align:center}.verdict-mesh{background:#22c55e1f;border:1px solid rgba(34,197,94,.35);color:#bbf7d0}.verdict-ring{background:#f472b61f;border:1px solid rgba(244,114,182,.35);color:#fbcfe8}.verdict-tie{background:#f59e0b1f;border:1px solid rgba(245,158,11,.35);color:#fde68a}.app-footer{text-align:center;color:var(--text-dim);padding:30px 0 0;font-size:.85rem}
