:root{font-family:system-ui,-apple-system,sans-serif;line-height:1.5;color:#e0e0e0;background-color:#1a1a1a}*{margin:0;padding:0;box-sizing:border-box}body{background:#c8c5bc;margin:0}#root{width:100%}.mobile-gate{display:none}.desktop-only{display:contents}@media(max-width:1024px){.mobile-gate{display:flex;align-items:center;justify-content:center;min-height:100dvh;background:#e8e3d9;padding:40px 24px}.desktop-only{display:none}}.mobile-gate__inner{display:flex;flex-direction:column;align-items:center;gap:20px;text-align:center;max-width:320px}.mobile-gate__wordmark{font-family:Söhne,Sohne,system-ui,sans-serif;font-weight:600;font-size:13px;letter-spacing:6px;color:#2a2926;opacity:.5}.mobile-gate__message{font-family:Söhne,Sohne,system-ui,sans-serif;font-weight:500;font-size:22px;line-height:1.3;letter-spacing:-.01em;color:#2a2926;margin:0}.mobile-gate__sub{font-family:monospace;font-size:11px;letter-spacing:.08em;color:#2a2926;opacity:.45;margin:0}.fm-canvas-wrapper{display:flex;flex-direction:column;align-items:center;gap:36px}.fm-canvas{display:flex;justify-content:center;align-items:center;background:#1f1e1c;border:1px solid #2a2a3a;border-radius:12px;overflow:visible;touch-action:none;-webkit-user-select:none;user-select:none}.fm-canvas-svg{pointer-events:none}.operator-node{transition:box-shadow .15s ease}.operator-node:hover{box-shadow:0 0 12px #67c6}.operator-node:active{cursor:grabbing}.connection-line:hover line:not([stroke=transparent]){stroke-width:3;filter:drop-shadow(0 0 4px currentColor)}.self-loop:hover circle{filter:drop-shadow(0 0 4px #ff9966)}.operator-detail-panel{box-shadow:0 4px 20px #00000080}.fm-canvas-status{display:flex;gap:16px;font-size:12px;color:#666;font-family:monospace}@keyframes spin-dash{0%{stroke-dashoffset:0}to{stroke-dashoffset:-20}}.ring-targetable{animation:spin-dash .6s linear infinite}.ratio-ring{pointer-events:auto}.ratio-ring:hover circle:last-of-type{fill:#89d}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}@font-face{font-family:PP Fraktion Mono;src:url(/assets/PPFraktionMono-Bold-DhBXD8re.otf) format("opentype");font-weight:700}@font-face{font-family:PP Mori;src:url(/assets/PPMori-Semibold-CWU3sXjU.otf) format("opentype");font-weight:600}.app{display:flex;flex-direction:column;align-items:center;min-height:100vh;padding:30px 20px}.landing{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;background:#1c1a18;outline:none}.landing__graphic{width:220px;height:auto;opacity:.85}.landing__title{font-family:PP Mori,system-ui,sans-serif;font-weight:600;font-size:108px;letter-spacing:.04em;color:#e8e3d9;line-height:1;margin:0;-webkit-user-select:none;user-select:none}.landing__subtitle{font-family:PP Fraktion Mono,monospace;font-weight:700;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:#504d46;margin:0;-webkit-user-select:none;user-select:none}.landing__cta{margin-top:16px;padding:14px 40px;font-family:PP Fraktion Mono,monospace;font-weight:700;font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:#e8e3d9;background:transparent;border:1px solid #504D46;border-radius:100px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:border-color .15s,color .15s}.landing__cta:hover:not(:disabled){border-color:#a8a49a;color:#f7f5f0}.landing__cta:disabled{opacity:.4;cursor:not-allowed}.keyboard-container{display:flex;flex-direction:column;align-items:center;margin-bottom:24px}.keyboard{position:relative;display:inline-block}.white-keys{display:flex}.black-keys{position:absolute;top:0;left:0}.key{-webkit-user-select:none;user-select:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;font-size:11px;box-sizing:border-box}.key.white{width:44px;height:150px;background:#f0f0f0;border:1px solid #aaa;border-radius:0 0 6px 6px;padding-bottom:8px;color:#666}.key.white.active{background:#c8c8ff}.key.black{position:absolute;width:28px;height:95px;background:#222;border:1px solid #000;border-radius:0 0 4px 4px;z-index:2;padding-bottom:6px;color:#888}.key.black.active{background:#55a}.key-note{font-size:10px;opacity:.6}.key-bind{font-weight:700;font-size:12px}.keyboard-hint{margin-top:12px;color:#666;font-size:13px}.test-panel{width:100%;max-width:700px;display:grid;grid-template-columns:1fr 1fr;gap:12px}.section{background:#252525;border:1px solid #333;border-radius:6px;overflow:hidden}.section-header{padding:8px 12px;font-size:13px;font-weight:600;color:#aaa;background:#2a2a2a;cursor:pointer;-webkit-user-select:none;user-select:none}.section-header:hover{background:#303030}.section-body{padding:8px 12px 12px;display:flex;flex-direction:column;gap:4px}.slider-row{display:flex;align-items:center;gap:8px;font-size:12px;color:#ccc}.slider-label{width:100px;flex-shrink:0;text-align:right}.slider-row input[type=range]{flex:1;height:4px;accent-color:#6677cc;cursor:pointer}.slider-row select{flex:1;background:#333;color:#ccc;border:1px solid #555;border-radius:3px;padding:2px 4px;font-size:12px}.slider-value{width:44px;text-align:right;font-family:monospace;font-size:11px;color:#888}.toggle-row{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:#ccc;padding:2px 0}.toggle-row input[type=checkbox]{accent-color:#6677cc;cursor:pointer}.menu-list{list-style:none;background:#e8e3d9;color:#1c1a18;font-size:12px;border-radius:12px;padding:8px 12px;position:absolute;top:calc(100% + 6px);left:50%;transform:translate(-50%);z-index:100;min-width:100px;margin:0}.menu-list li{padding:6px 0;cursor:pointer;white-space:nowrap}.menu-list li:hover{opacity:.6}.modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#0006;z-index:999}.modal-content{display:flex;flex-direction:column;justify-content:space-between;align-items:center;background:#e8e3d9;color:#1c1a18;padding:24px;border-radius:24px;min-width:424px;height:364px}.modal-dots-top,.modal-dots-bottom{display:flex;justify-content:space-between;width:100%;height:8px}.modal-form-section{display:flex;flex-direction:column;justify-content:center;gap:48px;align-items:stretch;width:80%;flex:1}.modal-title{display:flex;justify-content:space-between;width:100%;padding-bottom:16px}.modal-input{width:100%;display:flex;gap:16px;flex-direction:column}.modal-button-section button{background-color:transparent;border:none}.modal-button-section{display:flex;gap:16px}.modal-input input,.modal-input select{border:none;border-bottom:1px solid grey;outline:none;padding-bottom:4px;height:44px;width:100%;background:transparent}.modal-button-section{display:flex;justify-content:flex-end}.dropdown{width:128px;height:32px;border-bottom:1px solid grey}.dropdown button{text-align:left;width:100%;padding-left:4px;height:100%;border:none;font-size:12px;padding-bottom:32px;background-color:transparent;cursor:pointer}.dropdown-list{list-style:none;background:#e8e3d9;color:#1c1a18;font-size:12px;border-radius:0 0 12px 12px;padding-left:4px;position:relative;z-index:10}.dropdown-list li{padding-bottom:8px;cursor:pointer}
