*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:#f7f7f8;color:#333;min-height:100dvh;padding:1rem 1rem 3rem;max-width:760px;margin:0 auto}.toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.6rem;margin-bottom:.6rem}h1{font-size:1.1rem;font-weight:700;letter-spacing:.02em}.toolbar-actions{display:flex;gap:.4rem}.btn{display:inline-flex;align-items:center;gap:.3rem;padding:.35rem .75rem;border:1px solid #ccc;border-radius:6px;background:#fff;color:#333;font-size:.78rem;cursor:pointer;transition:background .15s,border-color .15s;user-select:none}.btn:hover{background:#eee;border-color:#aaa}.btn--primary{background:#333;color:#fff;border-color:#333}.btn--primary:hover{background:#555}.playback-bar{display:flex;align-items:center;gap:.7rem;margin-bottom:.8rem;flex-wrap:wrap}.play-btn{width:36px;height:36px;border-radius:50%;border:2px solid #333;background:#fff;color:#333;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s;flex-shrink:0}.play-btn svg{width:16px;height:16px}.play-btn:hover{background:#333;color:#fff}.play-btn.playing{background:#fe6e6c;border-color:#fe6e6c;color:#fff}.play-btn.playing:hover{background:#e34a4a}.bpm-group{display:flex;align-items:center;gap:.3rem}.bpm-label{font-size:.75rem;color:#888;font-weight:600}.bpm-input{width:52px;border:1px solid #ddd;border-radius:5px;padding:.25rem .3rem;font-size:.8rem;text-align:center;font-family:inherit;color:#333}.bpm-input:focus{outline:none;border-color:#888}.metro-btn{width:34px;height:34px;border-radius:7px;border:1.5px solid #ccc;background:#fff;color:#aaa;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s,border-color .15s}.metro-btn:hover{border-color:#999;color:#666}.metro-btn.on{background:#333;border-color:#333;color:#fff}.metro-btn.on:hover{background:#555}.metro-pendulum{transition:transform .15s;transform-origin:12px 22px}.sig-group{display:flex;align-items:center;gap:3px;margin-left:5px}.sig-input{width:36px;border:1px solid #ddd;border-radius:5px;padding:.2rem .15rem;font-size:.78rem;text-align:center;font-family:inherit;color:#333;font-weight:600}.sig-input:focus{outline:none;border-color:#888}.sig-lbl{font-size:.68rem;font-weight:600;color:#888}.sig-times{font-size:.72rem;font-weight:600;color:#aaa;margin:0 1px}.bar-group{display:flex;align-items:center;gap:3px;margin-left:auto}.bar-group-lbl{font-size:.75rem;color:#888;font-weight:600;margin-right:2px}.bar-adj{width:26px;height:26px;border-radius:5px;border:1px solid #ddd;background:#fff;color:#666;font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,border-color .12s;line-height:1}.bar-adj:hover{background:#f0f0f0;border-color:#bbb}.bar-count{font-size:.85rem;font-weight:600;min-width:18px;text-align:center;color:#333}:root{--cell-h: 26px;--lw: 60px;--rm-w: 20px;--bar-h: 18px;--group-band: 24px;--beat-h: 16px}.grid-area.has-multi-groups{--group-band: 32px}.chunk-outer{display:flex;flex:1;min-width:0;align-items:stretch;gap:4px}.chunk-add-rail{flex-shrink:0;display:flex;flex-direction:column;align-items:center;width:3rem;box-sizing:border-box}.chunk-add-bar-slot,.chunk-add-beat-slot{flex-shrink:0;width:100%}.chunk-add-group-slot{flex-shrink:0;width:100%;display:flex;align-items:center;justify-content:center;min-height:0;padding:0 1px;box-sizing:border-box}.grp-add-link{padding:0;border:none;background:none;font-size:.62rem;color:#777;cursor:pointer;text-decoration:underline;text-underline-offset:2px;font-family:inherit;line-height:1.25;text-align:left;max-width:100%;word-break:keep-all}.grp-add-link:hover{color:#333}.row-drag-indicator{position:fixed;z-index:99999;pointer-events:none;height:2px;background:#7c3aedf2;box-shadow:0 0 0 3px #a78bfa40;border-radius:999px;left:0;width:100px;transform:translateY(-1px)}.grid-help{margin-top:4px;margin-bottom:10px;font-size:.7rem;color:#999}.chunk-wrap{display:flex;margin-bottom:10px}.chunk-side{display:flex;flex-direction:column;flex-shrink:0;padding-right:4px}.side-spacer{flex-shrink:0;min-height:calc(var(--bar-h) + var(--group-band) + var(--beat-h) + 6px)}.side-row{height:var(--cell-h);display:flex;align-items:center;gap:2px}.rm-spacer{width:var(--rm-w);flex-shrink:0}.side-label{width:var(--lw);min-width:0;overflow:hidden;display:flex;align-items:center;gap:4px}.side-label input{width:auto;flex:1 1 auto;border:none;border-bottom:1px solid transparent;background:transparent;font-size:.65rem;padding:1px 2px;color:#333;font-family:inherit;min-width:0}.side-label input:focus{outline:none;border-bottom-color:#aaa}.side-label input::placeholder{color:#ccc}.row-drag-handle{width:16px;height:16px;flex:0 0 auto;border:none;background:transparent;color:#0000006b;cursor:grab;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:4px;user-select:none}.row-drag-handle:hover{background:#0f172a0f;color:#000000a6}.row-drag-handle:active{cursor:grabbing;background:#0f172a14}.side-label-ro{font-size:.58rem;color:#888}.side-label-ro span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:0 2px}.instrument-picker-host{position:fixed;z-index:10000;overflow-y:auto;background:#fff;border:1px solid #bbb;border-radius:6px;box-shadow:0 10px 28px #00000024;padding:4px 0}.instrument-picker-host[hidden]{display:none!important}.instrument-opt{display:block;width:100%;text-align:left;padding:6px 10px;border:none;background:transparent;font-size:.72rem;cursor:pointer;color:#333;font-family:inherit}.instrument-opt:hover,.instrument-opt:focus-visible{background:#eef6ff;outline:none}.row-rm{width:var(--rm-w);height:var(--rm-w);border:none;background:none;color:#fe6e6c;font-size:.65rem;cursor:pointer;border-radius:3px;display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s;padding:0;flex-shrink:0}.row-rm:hover{color:#c33;background:#fef0f0}.chunk{border:2px solid #888;border-radius:6px;flex:1;min-width:0;overflow:hidden;background:#fff}.chunk-hdr{background:#f9f9f9;border-bottom:1px solid #bbb}.hdr-cells{display:grid;min-width:0}.hdr-cells.bar-hdr,.hdr-cells.group-hdr{border-bottom:1px solid #ddd}.bar-lbl{height:var(--bar-h);display:flex;align-items:center;justify-content:center;font-size:.58rem;font-weight:700;color:#666}.bar-lbl.bar-sep{box-shadow:inset 2px 0 #888}.group-lbl{min-height:var(--group-band);display:flex;flex-direction:column;align-items:stretch;justify-content:center;gap:4px;font-size:.56rem;font-weight:600;color:#666;padding:4px 3px;box-sizing:border-box}.group-lbl-inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:4px 6px;row-gap:4px;width:100%}.group-lbl-tools{display:inline-flex;flex-wrap:nowrap;align-items:center;gap:3px;flex-shrink:0}.group-lbl.bar-sep{box-shadow:inset 2px 0 #888}.group-lbl.group-sep{box-shadow:inset 2px 0 #bbb}.grp-beats{font-size:.56rem;font-weight:700;color:#555;max-width:100%;text-align:center}.grp-beats-line{display:inline-flex;flex-wrap:wrap;justify-content:center;align-items:baseline;gap:0 .2em;max-width:100%}.grp-beats-name,.grp-beats-meta{white-space:nowrap}.grp-adj{width:16px;height:16px;border-radius:3px;border:1px solid #ccc;background:#fff;color:#666;font-size:.6rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;line-height:1;padding:0;flex-shrink:0;transition:background .1s}.grp-adj:hover{background:#eee;border-color:#999}.grp-rm{width:16px;height:16px;border-radius:3px;border:1px solid #e8c0c0;background:#fff;color:#e66;font-size:.55rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;line-height:1;padding:0;flex-shrink:0;transition:background .1s}.grp-rm:hover{background:#fee;border-color:#c88}.beat-lbl{height:var(--beat-h);display:flex;align-items:center;justify-content:center;font-size:.56rem;font-weight:600;color:#777}.beat-lbl.bar-sep{box-shadow:inset 2px 0 #888}.beat-lbl.group-sep{box-shadow:inset 2px 0 #bbb}.beat-lbl.beat-sep{box-shadow:inset 1px 0 #ddd}.chunk-cells{display:grid;min-width:0}.cell{height:var(--cell-h);cursor:pointer;background:#fff;transition:background .08s}.cell:hover{background:#f0f0f0}.cell.active{background:var(--rg-active)}.cell.active:hover{background:var(--rg-active-hover)}.cell.bar-sep{box-shadow:inset 2px 0 0 0 var(--rg-bar-sep)}.cell.group-sep{box-shadow:inset 2px 0 #bbb}.cell.beat-sep{box-shadow:inset 1px 0 0 0 var(--rg-beat-sep)}.chunk-cells>.cell{border-right:1px solid var(--rg-cell-border);border-bottom:1px solid var(--rg-cell-border)}.chunk-cells>.cell:last-child{border-right:none}.chunk-body>.chunk-cells:last-child .cell{border-bottom:none}.cell.playhead{background:var(--rg-playhead)}.cell.active.playhead{background:var(--rg-active-playhead)}.add-row-btn{display:inline-flex;align-items:center;justify-content:center;border:1.5px dashed #d0d0d0;border-radius:5px;background:none;color:#bbb;cursor:pointer;user-select:none;transition:border-color .15s,color .15s;height:26px;padding:0 20px;margin-top:5px;font-size:.78rem}.add-row-btn:hover{border-color:#999;color:#666;background:#fafafa}.embed-overlay{position:fixed;inset:0;z-index:900;display:flex;align-items:center;justify-content:center;padding:1rem}.embed-overlay[hidden]{display:none}.embed-backdrop{position:absolute;inset:0;background:#00000073;cursor:pointer}.embed-dialog{position:relative;background:#fff;border-radius:10px;padding:1.25rem;max-width:520px;width:100%;box-shadow:0 8px 30px #00000026}.embed-title{font-size:.95rem;font-weight:600;margin-bottom:.75rem}.embed-code{width:100%;border:1px solid #ddd;border-radius:6px;padding:.6rem;font-family:monospace;font-size:.75rem;resize:vertical;color:#333;background:#f9f9f9}.embed-actions{display:flex;gap:.5rem;margin-top:.75rem;justify-content:flex-end}.tuplet-bar{display:flex;align-items:center;gap:.5rem;margin-bottom:.6rem;padding:.4rem .6rem;background:#eef;border:1px solid #ccd;border-radius:6px;flex-wrap:wrap}.tuplet-bar[hidden]{display:none}.tuplet-info{font-size:.72rem;color:#555;font-weight:600;margin-right:auto}.tbtn{padding:.25rem .55rem;border:1px solid #bbc;border-radius:5px;background:#fff;color:#444;font-size:.72rem;cursor:pointer;transition:background .12s,border-color .12s}.tbtn:hover{background:#ddf;border-color:#99b}.beat-lbl{cursor:pointer;user-select:none;transition:background .1s}.beat-lbl:hover{background:#eef}.beat-lbl.selected{background:#cdf;box-shadow:inset 0 -2px #57a}.beat-lbl.tuplet-lbl{background:#f0eaff}.beat-lbl.tuplet-lbl.selected{background:#c8bfff}.tp-badge{font-weight:700;color:#7c4dff;font-size:.52rem}@media(max-width:600px){body{padding:.5rem .5rem 2rem}:root{--cell-h: 22px;--lw: 46px;--rm-w: 16px;--bar-h: 16px;--group-band: 26px;--beat-h: 14px}.grid-area.has-multi-groups{--group-band: 40px}.side-label input{font-size:.58rem}.playback-bar{gap:.5rem}.toolbar{gap:.4rem}h1{font-size:1rem}.btn{padding:.3rem .55rem;font-size:.72rem}.bar-lbl,.group-lbl{font-size:.52rem}.grp-beats{font-size:.52rem;line-height:1.35}.grp-add-link{font-size:.62rem}.grid-area.has-multi-groups .grp-adj,.grid-area.has-multi-groups .grp-rm{width:22px;height:22px;font-size:.68rem}.beat-lbl{font-size:.48rem}}
