*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg:#0d0f18;--color-surface:#141722;--color-surface-alt:#1a1e2e;--color-surface-hi:#222840;--color-border:#252c42;--color-border-hi:#313d5c;--color-accent:#6c8ef5;--color-accent-glow:#6c8ef526;--color-accent-hover:#859af7;--color-text:#dde4f0;--color-text-muted:#7a8499;--color-text-dim:#46506a;--color-danger:#f56565;--color-success:#68d391;--color-warning:#f6ad55;--color-status-idle:var(--color-text-dim);--color-status-running:var(--color-warning);--color-status-playing:var(--color-success);--color-status-paused:var(--color-warning);--color-status-stopped:var(--color-danger);--color-status-completed:var(--color-accent);--color-status-error:var(--color-danger);--color-cat-basics:#6c8ef5;--color-cat-timing:#b47cf8;--color-cat-editing:#f6ad55;--color-cat-cursor:#4dd0e1;--color-cat-styling:#56c798;--color-cat-callbacks:#f472b6;--color-cat-audio:#34d399;--color-cat-effects:#fb923c;--color-cat-advanced:#f56565;--radius:10px;--radius-sm:6px;--font-sans:"Noto Sans", system-ui, sans-serif;--font-mono:"Noto Sans Mono", "JetBrains Mono", "Fira Code", monospace;--transition:.12s ease}html,body{height:100%;overflow:hidden}body{background:var(--color-bg);color:var(--color-text);font-family:var(--font-sans);font-size:13px;line-height:1.5}#app{justify-content:center;align-items:flex-start;height:100vh;padding:0;display:flex;overflow:hidden}.shell{grid-template-rows:auto auto 1fr;gap:.5rem;width:100%;max-width:1440px;height:100vh;padding:.625rem .875rem 0;display:grid;overflow:hidden}.header{border-bottom:1px solid var(--color-border);flex-shrink:0;align-items:center;gap:.75rem;padding-bottom:.5rem;display:flex}.header__brand{flex:1;align-items:center;gap:.45rem;min-width:0;display:flex}.header__logo{object-fit:contain;flex-shrink:0}.header__title{letter-spacing:-.02em;font-size:.875rem;font-weight:700;font-family:var(--font-mono);white-space:nowrap}.header__version{font-family:var(--font-mono);color:var(--color-text-muted);white-space:nowrap;font-size:.68rem}.header__badge{letter-spacing:.1em;text-transform:uppercase;background:var(--color-accent);color:#fff;white-space:nowrap;border-radius:999px;padding:.1em .5em;font-size:.58rem;font-weight:700}.header__meta{flex-shrink:0;align-items:center;gap:.75rem;display:flex}.repo-link{color:var(--color-text-muted);border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface-hi);transition:color var(--transition), border-color var(--transition);align-items:center;gap:.3rem;padding:.2em .5em;font-size:.72rem;font-weight:600;text-decoration:none;display:flex}.repo-link:hover{color:var(--color-text);border-color:var(--color-border-hi)}.preview-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.preview-section__toolbar{border-bottom:1px solid var(--color-border);background:var(--color-surface-alt);flex-shrink:0;align-items:center;gap:.75rem;padding:.5rem .875rem;display:flex}.toolbar-label{color:var(--color-text-muted);flex-shrink:0;font-size:.68rem;font-weight:600}.renderer-select{background:var(--color-surface-hi);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font-sans);cursor:pointer;transition:border-color var(--transition);outline:none;padding:.25rem .6rem;font-size:.75rem}.renderer-select:focus{border-color:var(--color-accent)}.transport{align-items:center;gap:.3rem;margin-left:.25rem;display:flex}.transport-btn{border:1px solid var(--color-border);background:var(--color-surface-hi);width:28px;height:28px;color:var(--color-text-muted);cursor:pointer;transition:color var(--transition), background var(--transition), border-color var(--transition);border-radius:50%;justify-content:center;align-items:center;display:flex}.transport-btn:hover:not(:disabled){color:var(--color-text);border-color:var(--color-border-hi)}.transport-btn:active:not(:disabled){transform:scale(.92)}.transport-btn:disabled{opacity:.22;cursor:not-allowed;pointer-events:none}.transport-btn--active{color:var(--color-accent-hover);border-color:color-mix(in srgb, var(--color-accent) 60%, transparent);background:color-mix(in srgb, var(--color-accent) 12%, var(--color-surface-hi))}.transport-btn--primary{background:var(--color-accent);border-color:var(--color-accent);color:#fff;box-shadow:0 0 8px var(--color-accent-glow)}.transport-btn--primary:hover:not(:disabled){background:var(--color-accent-hover);border-color:var(--color-accent-hover);color:#fff}.timeline-row{flex:1;align-items:center;gap:.5rem;min-width:0;display:flex}.seek-slider{appearance:none;background:var(--color-surface-hi);cursor:pointer;min-width:0;height:3px;accent-color:var(--color-accent);border-radius:999px;outline:none;flex:1}.seek-slider:disabled{opacity:.3;cursor:not-allowed}.time-label{font-family:var(--font-mono);color:var(--color-text-muted);white-space:nowrap;flex-shrink:0;font-size:.68rem}.rate-row{flex-shrink:0;align-items:center;gap:.4rem;display:flex}.rate-label{color:var(--color-text-dim);font-size:.65rem}.audio-row{flex-shrink:0;align-items:center;gap:.4rem;display:flex}.rate-slider{appearance:none;background:var(--color-surface-hi);cursor:pointer;width:90px;height:3px;accent-color:var(--color-accent);border-radius:999px;outline:none}.rate-value{font-family:var(--font-mono);color:var(--color-accent);text-align:right;min-width:2.2em;font-size:.68rem}.preview-output{scrollbar-width:thin;scrollbar-color:var(--color-border) transparent;flex:1;min-height:100px;max-height:180px;position:relative;overflow:auto}.preview-pane{min-height:100%;padding:1rem 1.25rem}.preview-pane--dom{font-family:var(--font-mono);white-space:pre-wrap;word-break:break-word;color:var(--color-text);font-size:1rem;line-height:1.6}.preview-pane--string{font-family:var(--font-mono);white-space:pre-wrap;color:var(--color-text-muted);font-size:1rem}.typewriter-cursor{font-style:normal;animation:1s step-end infinite blink;display:inline}.tw-cursor-blink{animation:1s step-end infinite blink}.tw-cursor-accent{color:#b47cf8;vertical-align:-.05em;font-size:1.15em;font-weight:900}.tw-cursor-glow{text-shadow:0 0 6px #b47cf8,0 0 14px #b47cf8,0 0 28px #b47cf8;animation:.75s step-end infinite glowBlink}.tw-cursor-block{opacity:.85;font-style:normal}@keyframes glowBlink{0%,to{opacity:1}50%{opacity:.15}}.typewriter-selection{background:color-mix(in srgb, var(--color-accent) 28%, transparent);color:inherit;border-radius:2px}.tw-highlight{background:color-mix(in srgb, var(--color-warning) 35%, transparent);color:inherit;border-radius:2px}.tw-mark{background:color-mix(in srgb, var(--color-success) 30%, transparent);color:inherit;border-radius:2px}.tw-accent{color:var(--color-accent-hover);font-style:italic;font-weight:700}.tw-danger{color:var(--color-danger);opacity:.8;text-decoration:line-through}.tw-success{color:var(--color-success);font-weight:600}.tw-pill{background:color-mix(in srgb, var(--color-accent) 20%, transparent);border:1px solid color-mix(in srgb, var(--color-accent) 40%, transparent);color:var(--color-accent-hover);border-radius:999px;padding:0 .4em;font-weight:600}.tw-gradient{background:linear-gradient(90deg, var(--color-accent), #b47cf8, #f6ad55);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:700}.tw-code{font-family:var(--font-mono);background:color-mix(in srgb, var(--color-success) 12%, var(--color-surface-hi));border:1px solid color-mix(in srgb, var(--color-success) 25%, var(--color-border));color:var(--color-success);border-radius:3px;padding:0 .35em;font-size:.9em}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes tw-cursor-pulse{0%{opacity:1}to{opacity:.1}}.error-panel{background:color-mix(in srgb, var(--color-danger) 10%, var(--color-surface));border-top:1px solid color-mix(in srgb, var(--color-danger) 30%, var(--color-border));flex-shrink:0;align-items:flex-start;gap:.5rem;padding:.5rem .875rem;display:flex}.error-panel__icon{color:var(--color-danger);flex-shrink:0;margin-top:1px}.error-panel__msg{font-family:var(--font-mono);color:var(--color-danger);white-space:pre-wrap;word-break:break-word;font-size:.75rem;line-height:1.5}.bottom-row{grid-template-columns:260px 1fr;gap:.5rem;min-height:0;padding-bottom:.625rem;transition:grid-template-columns .2s;display:grid;overflow:hidden}.panel-header{border-bottom:1px solid var(--color-border);background:var(--color-surface-alt);flex-shrink:0;align-items:center;gap:.5rem;padding:.45rem .75rem;display:flex}.panel-title{letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted);flex:1;font-size:.65rem;font-weight:700}.panel-toggle-btn{border-radius:var(--radius-sm);border:1px solid var(--color-border);width:20px;height:20px;color:var(--color-text-muted);cursor:pointer;transition:color var(--transition), border-color var(--transition), background var(--transition);background:0 0;flex-shrink:0;justify-content:center;align-items:center;display:flex}.panel-toggle-btn svg{transition:transform .15s}.panel-toggle-btn:hover{color:var(--color-text);border-color:var(--color-border-hi);background:var(--color-surface-hi)}.recipes-panel .panel-header{cursor:pointer;-webkit-user-select:none;user-select:none}.recipes-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);flex-direction:column;min-height:0;display:flex;overflow:hidden}.recipes-body{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.recipes-panel--collapsed .recipes-body{display:none}.recipes-panel--collapsed .panel-toggle-btn svg{transform:rotate(180deg)}.search-row{border-bottom:1px solid var(--color-border);flex-shrink:0;padding:.5rem .75rem;position:relative}.search-icon{color:var(--color-text-dim);pointer-events:none;position:absolute;top:50%;left:1.2rem;transform:translateY(-50%)}.search-input{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;color:var(--color-text);font-family:var(--font-sans);transition:border-color var(--transition);outline:none;padding:.3rem .5rem .3rem 1.75rem;font-size:.78rem}.search-input:focus{border-color:var(--color-accent)}.search-input::placeholder{color:var(--color-text-dim)}.cat-filter{border-bottom:1px solid var(--color-border);flex-wrap:wrap;flex-shrink:0;gap:.25rem;padding:.45rem .75rem;display:flex}.cat-chip{border:1px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;font-size:.64rem;font-weight:600;font-family:var(--font-sans);transition:color var(--transition), border-color var(--transition), background var(--transition);background:0 0;border-radius:999px;padding:.18em .55em}.cat-chip:hover{color:var(--color-text);border-color:var(--color-border-hi)}.cat-chip--active{background:var(--color-accent-glow);border-color:var(--color-accent);color:var(--color-accent-hover)}.cat-chip[data-cat=basics].cat-chip--active{border-color:var(--color-cat-basics);color:var(--color-cat-basics);background:color-mix(in srgb, var(--color-cat-basics) 15%, transparent)}.cat-chip[data-cat=timing].cat-chip--active{border-color:var(--color-cat-timing);color:var(--color-cat-timing);background:color-mix(in srgb, var(--color-cat-timing) 15%, transparent)}.cat-chip[data-cat=editing].cat-chip--active{border-color:var(--color-cat-editing);color:var(--color-cat-editing);background:color-mix(in srgb, var(--color-cat-editing) 15%, transparent)}.cat-chip[data-cat=cursor].cat-chip--active{border-color:var(--color-cat-cursor);color:var(--color-cat-cursor);background:color-mix(in srgb, var(--color-cat-cursor) 15%, transparent)}.cat-chip[data-cat=styling].cat-chip--active{border-color:var(--color-cat-styling);color:var(--color-cat-styling);background:color-mix(in srgb, var(--color-cat-styling) 15%, transparent)}.cat-chip[data-cat=callbacks].cat-chip--active{border-color:var(--color-cat-callbacks);color:var(--color-cat-callbacks);background:color-mix(in srgb, var(--color-cat-callbacks) 15%, transparent)}.cat-chip[data-cat=audio].cat-chip--active{border-color:var(--color-cat-audio);color:var(--color-cat-audio);background:color-mix(in srgb, var(--color-cat-audio) 15%, transparent)}.cat-chip[data-cat=effects].cat-chip--active{border-color:var(--color-cat-effects);color:var(--color-cat-effects);background:color-mix(in srgb, var(--color-cat-effects) 15%, transparent)}.cat-chip[data-cat=advanced].cat-chip--active{border-color:var(--color-cat-advanced);color:var(--color-cat-advanced);background:color-mix(in srgb, var(--color-cat-advanced) 15%, transparent)}.recipe-list{scrollbar-width:thin;scrollbar-color:var(--color-border) transparent;flex-direction:column;flex:1;gap:.25rem;padding:.5rem .75rem;display:flex;overflow-y:auto}.recipe-empty{color:var(--color-text-muted);text-align:center;padding:.75rem 0;font-size:.75rem}.recipe-item{text-align:left;background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;width:100%;font-family:var(--font-sans);transition:border-color var(--transition), background var(--transition);flex-direction:column;gap:.18rem;padding:.45rem .65rem;display:flex}.recipe-item:hover{background:var(--color-surface-hi);border-color:var(--color-border-hi)}.recipe-item--active{border-color:var(--color-accent);background:color-mix(in srgb, var(--color-accent) 7%, var(--color-surface-alt))}.recipe-item__top{flex-wrap:wrap;align-items:center;gap:.35rem;display:flex}.recipe-item__title{color:var(--color-text);flex:1;font-size:.78rem;font-weight:600}.recipe-item__desc{color:var(--color-text-muted);font-size:.7rem;line-height:1.4}.recipe-item__cat{letter-spacing:.05em;text-transform:uppercase;border:1px solid;border-radius:999px;padding:.08em .4em;font-size:.58rem;font-weight:700}.recipe-item__cat--basics{color:var(--color-cat-basics);background:color-mix(in srgb, var(--color-cat-basics) 12%, transparent)}.recipe-item__cat--timing{color:var(--color-cat-timing);background:color-mix(in srgb, var(--color-cat-timing) 12%, transparent)}.recipe-item__cat--editing{color:var(--color-cat-editing);background:color-mix(in srgb, var(--color-cat-editing) 12%, transparent)}.recipe-item__cat--cursor{color:var(--color-cat-cursor);background:color-mix(in srgb, var(--color-cat-cursor) 12%, transparent)}.recipe-item__cat--styling{color:var(--color-cat-styling);background:color-mix(in srgb, var(--color-cat-styling) 12%, transparent)}.recipe-item__cat--callbacks{color:var(--color-cat-callbacks);background:color-mix(in srgb, var(--color-cat-callbacks) 12%, transparent)}.recipe-item__cat--audio{color:var(--color-cat-audio);background:color-mix(in srgb, var(--color-cat-audio) 12%, transparent)}.recipe-item__cat--effects{color:var(--color-cat-effects);background:color-mix(in srgb, var(--color-cat-effects) 12%, transparent)}.recipe-item__cat--advanced{color:var(--color-cat-advanced);background:color-mix(in srgb, var(--color-cat-advanced) 12%, transparent)}.editor-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);flex-direction:column;min-height:0;display:flex;overflow:hidden}.panel-hint{align-items:center;gap:.15rem;display:flex}kbd{font-family:var(--font-mono);background:var(--color-surface-hi);border:1px solid var(--color-border-hi);color:var(--color-text-muted);border-radius:3px;padding:.05em .35em;font-size:.6rem}.editor-actions{align-items:center;gap:.3rem;margin-left:auto;display:flex}.action-btn{border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface-hi);color:var(--color-text-muted);cursor:pointer;font-size:.68rem;font-weight:600;font-family:var(--font-sans);transition:color var(--transition), border-color var(--transition), background var(--transition);white-space:nowrap;padding:.22em .65em}.action-btn:hover:not(:disabled){color:var(--color-text);border-color:var(--color-border-hi)}.action-btn--primary{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.action-btn--primary:hover:not(:disabled){background:var(--color-accent-hover);border-color:var(--color-accent-hover)}.action-btn:disabled{opacity:.4;cursor:not-allowed}.editor-container{flex:1;min-height:0;overflow:hidden}.editor-container .cm-editor{height:100%}.editor-context-hint{color:var(--color-text-dim);border-top:1px solid var(--color-border);background:var(--color-surface-alt);flex-shrink:0;justify-content:space-between;align-items:center;gap:.5rem;padding:.3rem .75rem;font-size:.65rem;display:flex}.editor-shortcut-hint{color:var(--color-text-dim);flex-shrink:0;align-items:center;gap:.15rem;font-size:.62rem;display:flex}.editor-help-btn{color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;font-size:.65rem;font-weight:600;font-family:var(--font-sans);transition:color var(--transition), border-color var(--transition);white-space:nowrap;background:0 0;flex-shrink:0;align-items:center;gap:.25rem;padding:.18em .5em;display:flex}.editor-help-btn:hover{color:var(--color-text);border-color:var(--color-border-hi)}.help-dialog-backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:1000;background:#0009;justify-content:center;align-items:center;padding:1.25rem;display:flex;position:fixed;inset:0}.help-dialog{background:var(--color-surface);border:1px solid var(--color-border-hi);border-radius:var(--radius);grid-template-rows:auto 1fr;width:100%;max-width:680px;max-height:82vh;display:grid;overflow:hidden;box-shadow:0 32px 80px #0009}.help-dialog__header{border-bottom:1px solid var(--color-border);background:var(--color-surface-alt);justify-content:space-between;align-items:center;padding:.7rem 1rem;display:flex}.help-dialog__title{color:var(--color-text);letter-spacing:-.01em;font-size:.78rem;font-weight:700}.help-dialog__close{border:1px solid var(--color-border);border-radius:var(--radius-sm);width:22px;height:22px;color:var(--color-text-muted);cursor:pointer;transition:color var(--transition), border-color var(--transition), background var(--transition);background:0 0;justify-content:center;align-items:center;font-size:13px;line-height:1;display:flex}.help-dialog__close:hover{color:var(--color-text);border-color:var(--color-border-hi);background:var(--color-surface-hi)}.help-dialog__body{scrollbar-width:thin;scrollbar-color:var(--color-border) transparent;grid-template-columns:140px 1fr;min-height:0;display:grid;overflow-y:auto}.help-dialog__nav{border-right:1px solid var(--color-border);background:var(--color-surface-alt);scrollbar-width:none;flex-direction:column;gap:.1rem;padding:.5rem 0;display:flex;overflow-y:auto}.help-nav-btn{text-align:left;width:100%;color:var(--color-text-muted);cursor:pointer;font-size:.7rem;font-weight:500;font-family:var(--font-sans);transition:color var(--transition), background var(--transition);background:0 0;border:none;border-left:2px solid #0000;padding:.35rem .75rem;display:block}.help-nav-btn:hover{color:var(--color-text);background:var(--color-surface-hi)}.help-nav-btn--active{color:var(--color-accent-hover);border-left-color:var(--color-accent);background:color-mix(in srgb, var(--color-accent) 6%, var(--color-surface-alt))}.help-dialog__content{scrollbar-width:thin;scrollbar-color:var(--color-border) transparent;padding:0;overflow-y:auto}.help-section{flex-direction:column;gap:.6rem;padding:.875rem 1rem;display:none}.help-section--active{display:flex}.help-section__title{color:var(--color-text);margin-bottom:.1rem;font-size:.7rem;font-weight:700}.help-section__desc{color:var(--color-text-muted);margin-bottom:.1rem;font-size:.7rem;line-height:1.5}.help-table{border-collapse:collapse;width:100%;font-size:.72rem}.help-table tr:first-child td{border-top:1px solid var(--color-border)}.help-table tr td{border-bottom:1px solid var(--color-border);vertical-align:top;padding:.32rem .4rem;line-height:1.5}.help-table td:first-child{white-space:nowrap;width:1%;color:var(--color-text);padding-right:1rem}.help-table td:last-child{color:var(--color-text-muted)}.help-table code{font-family:var(--font-mono);color:var(--color-accent-hover);background:color-mix(in srgb, var(--color-accent) 10%, var(--color-surface-hi));border-radius:3px;padding:.07em .35em;font-size:.7rem}.help-subsection{flex-direction:column;gap:.3rem;display:flex}.help-subsection__label{letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-dim);padding-top:.15rem;font-size:.6rem;font-weight:700}@media (width<=1100px){.bottom-row{grid-template-columns:220px 1fr}}.bottom-row--recipes-collapsed{grid-template-columns:38px 1fr}.bottom-row--recipes-collapsed .recipes-panel{min-width:0}.bottom-row--recipes-collapsed .panel-title{display:none}.bottom-row--recipes-collapsed .recipes-panel .panel-header{justify-content:center;padding-inline:0}@media (width<=900px){.recipes-panel .panel-toggle-btn svg{transform:rotate(-90deg)}.recipes-panel--collapsed .panel-toggle-btn svg{transform:rotate(90deg)}.bottom-row--recipes-collapsed .panel-title{display:revert}.bottom-row--recipes-collapsed .recipes-panel .panel-header{justify-content:flex-start;padding-inline:.75rem}.recipes-body{max-height:350px;transition:max-height .2s;overflow:hidden}.recipes-panel--collapsed .recipes-body{max-height:0;display:flex}html,body{height:auto;overflow:auto}#app{height:auto;overflow:visible}.shell{gap:.5rem;height:auto;padding:.5rem .625rem .75rem;overflow:visible}.bottom-row{grid-template-columns:1fr;overflow:visible}.recipes-panel{max-height:340px}.recipe-list{max-height:200px}.editor-panel{min-height:320px}.preview-output{max-height:150px}.preview-section__toolbar{flex-wrap:wrap;row-gap:.5rem;padding:.5rem .75rem}.timeline-row{flex:100%;order:10}.rate-row{flex-shrink:1;order:11}.audio-row{flex-shrink:1;order:12}}@media (width<=600px){.shell{padding:.375rem .5rem .5rem}.header__version,.header__badge,.repo-link span,.repo-link svg+*{display:none}.repo-link{gap:0;padding:.2em .4em}.preview-section__toolbar{gap:.5rem;padding:.4rem .625rem}.transport{gap:.2rem;margin-left:0}.transport-btn{width:26px;height:26px}.rate-slider{width:72px}.preview-output{max-height:120px}.recipes-panel{max-height:280px}.recipe-list{max-height:160px}}@media (height<=700px) and (width>=901px){.preview-output{max-height:130px}.shell{gap:.375rem;padding-top:.375rem}}
