@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;700&family=JetBrains+Mono:wght@400;600&display=swap";:root{font-family:Space Grotesk,Trebuchet MS,sans-serif;line-height:1.45;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body,#root{height:100%;display:flex;justify-content:center;align-items:center;overflow:hidden}body{margin:0;min-width:320px;overflow:hidden;background:radial-gradient(circle at 12% 10%,rgba(54,210,198,.18),transparent 42%),radial-gradient(circle at 85% 15%,rgba(255,209,102,.16),transparent 40%),linear-gradient(140deg,#03101d,#10283e 45%,#133341);background-attachment:fixed}:root{--bg-0: #061425;--bg-1: #0f233b;--bg-2: #143a47;--panel: rgba(11, 26, 45, .82);--panel-border: rgba(148, 186, 212, .24);--text: #e8f7ff;--text-soft: #9ec5da;--brand: #36d2c6;--brand-2: #ffd166;--danger: #ff7a8a;--viewport-min-width: 980px;--viewport-min-height: 620px}*{box-sizing:border-box}.fit-viewport{width:calc(100vw - .5rem);height:95vh;min-width:min(var(--viewport-min-width),calc(100vw - .5rem));min-height:min(var(--viewport-min-height),95vh);max-width:100vw;max-height:95vh;overflow:hidden;padding:.5rem;display:flex;justify-content:center;align-items:flex-start;margin:0 auto}.app-shell{width:min(1500px,calc(100vw - 1rem));min-width:var(--viewport-min-width);min-height:var(--viewport-min-height);margin:0;padding:.5rem;color:var(--text);transform-origin:top center;will-change:transform}.hero{margin-bottom:.5rem}.hero-top{display:flex;align-items:center;justify-content:space-between;gap:.6rem}.hero-actions{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap;justify-content:flex-end}.hero-tag{margin:0 0 .25rem;color:var(--brand);text-transform:uppercase;letter-spacing:.08em;font-size:.72rem}.external-link{display:inline-flex;align-items:center;gap:.3rem;color:var(--text-soft);text-decoration:none;border:1px solid rgba(174,227,255,.3);background:#06111fa6;border-radius:999px;padding:.2rem .45rem;font-size:.68rem;transition:border-color .16s ease,color .16s ease,background .16s ease}.external-link svg,.external-link img{width:12px;height:12px}.github-link svg{fill:currentColor}.vivgrid-link img{filter:invert(1)}.external-link:hover{color:var(--text);border-color:#ffd16699;background:#144057b3}.hero h1{margin:0;font-size:clamp(1.05rem,1.5vw,1.45rem);line-height:1.15}.hero p{margin:.18rem 0 0;color:var(--text-soft);max-width:60rem;font-size:.84rem}.panel{background:linear-gradient(150deg,#122a42e6,#0a1a2be6);border:1px solid var(--panel-border);border-radius:1rem;box-shadow:0 12px 34px #02081261;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.controls{margin-bottom:.5rem;padding:.65rem}.input-row{display:grid;gap:.5rem;grid-template-columns:180px 1fr}.input-row label{display:flex;flex-direction:column;gap:.35rem;color:var(--text-soft);font-size:.78rem}input,textarea,select,button{font:inherit}select,textarea,input[type=range]{width:100%}select,textarea{border:1px solid rgba(175,219,240,.22);background:#06111fcc;color:var(--text);border-radius:.45rem;padding:.44rem .52rem}textarea{resize:vertical;min-height:56px;max-height:76px}.buttons-row{margin-top:.5rem;display:flex;flex-wrap:wrap;gap:.34rem;align-items:center}button{border:1px solid rgba(174,227,255,.32);background:#144057d9;color:var(--text);border-radius:.44rem;padding:.28rem .52rem;cursor:pointer;transition:transform .16s ease,background .18s ease,border-color .18s ease;font-size:.8rem}button:hover:enabled{transform:translateY(-1px);background:#22667be6;border-color:#e7fcff8c}button:disabled{cursor:not-allowed;opacity:.5}.speed-control{margin-left:auto;min-width:190px;display:flex;align-items:center;gap:.35rem;color:var(--text-soft);font-size:.75rem}.progress-row{margin-top:.45rem}.progress-header{display:flex;justify-content:space-between;gap:.45rem;font-size:.72rem;color:var(--text-soft)}.progress-track{margin-top:.3rem;height:8px;border-radius:999px;overflow:hidden;background:#94c3de24;border:1px solid rgba(175,225,250,.22)}.progress-fill{height:100%;background:linear-gradient(90deg,var(--brand),var(--brand-2));transition:width .16s linear}.error-box{margin-top:.45rem;border:1px solid rgba(255,148,163,.5);background:#3e0c1a73;color:#ffd7de;border-radius:.45rem;padding:.4rem .5rem;font-size:.74rem}.panel-grid{display:grid;grid-template-columns:repeat(3,minmax(190px,1fr));gap:.5rem}.panel-grid .panel{padding:.55rem}.panel-message{grid-column:1 / -1;grid-row:1}.panel-explainer{grid-column:1;grid-row:2}.panel-round{grid-column:2;grid-row:2}.panel-register{grid-column:3;grid-row:2}.panel h2{margin:0;font-size:.88rem}.panel h3{margin:.45rem 0 .28rem;font-size:.68rem;color:var(--text-soft);text-transform:uppercase;letter-spacing:.04em}.subtitle{margin:.24rem 0;color:var(--text-soft);font-size:.74rem}.kv-list{display:grid;gap:.26rem}.kv-list>div{display:grid;gap:.1rem}.kv-list span{color:var(--text-soft);font-size:.64rem;text-transform:uppercase;letter-spacing:.05em}code,pre{margin:0;white-space:pre-wrap;word-break:break-word;font-family:JetBrains Mono,Menlo,monospace;color:#f2ffac;background:#060f1eb8;border:1px solid rgba(174,216,242,.18);border-radius:.35rem;padding:.22rem .3rem;font-size:.62rem}pre{line-height:1.2}.word-grid{margin-top:.24rem;display:grid;grid-template-columns:repeat(8,minmax(70px,1fr));gap:.22rem}.word-item{border-radius:.35rem;border:1px solid rgba(173,212,235,.22);background:#09182699;padding:.2rem;display:flex;flex-direction:column;gap:.14rem}.word-item span{font-size:.6rem;color:var(--text-soft)}.word-item code{width:100%}.word-item.active{border-color:#ffd166d9;box-shadow:inset 0 0 0 1px #ffd16659,0 0 20px #ffbf4933}.constants-grid .word-item code{color:#c9f6ff}.equation{margin-top:.25rem}.equation p{margin:.2rem 0;color:var(--text-soft);font-size:.7rem}.register-box{margin-top:.32rem}.register-box h4{margin:0 0 .22rem;font-size:.66rem;color:var(--text-soft)}.register-grid{display:grid;grid-template-columns:repeat(4,minmax(70px,1fr));gap:.2rem}.register-item{display:flex;flex-direction:column;gap:.08rem}.register-item .label{font-size:.6rem;color:var(--text-soft)}.hint{margin:.25rem 0;color:var(--text-soft);font-size:.68rem}.digest-box{margin-top:.3rem;border:1px dashed rgba(201,246,255,.4);border-radius:.45rem;padding:.3rem;background:#07141f73}.digest-box h3{margin-top:0}.digest-box.final{border-color:#ffd16699}
