:root{font-synthesis:none;text-rendering:optimizeLegibility}body{margin:0;min-width:320px;min-height:100vh}button{font:inherit;color:inherit}button:focus-visible{outline:2px solid #b75c2a;outline-offset:2px}:root{--bg: #f6f1e7;--paper: #fcfaf4;--ink: #2a2520;--ink-soft: #6c635a;--accent: #8a4b2b;--accent-soft: #d8b89c;--tonic: #b75c2a;--highlight: #f5d97f;--rule: #d8cfbe;--shadow: 0 1px 0 rgba(0, 0, 0, .06), 0 6px 18px rgba(60, 40, 20, .08)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--ink);font-family:Iowan Old Style,Palatino Linotype,Palatino,Georgia,serif;-webkit-font-smoothing:antialiased}.app{min-height:100%;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.4rem;border-bottom:1px solid var(--rule);background:var(--paper)}.brand{display:flex;align-items:baseline;gap:.7rem}.brand-en{font-size:1.4rem;font-weight:600;letter-spacing:.02em}.brand-ar{font-size:1.2rem;color:var(--ink-soft);font-family:Geeza Pro,Scheherazade New,Times New Roman,serif}.topbar-controls{display:flex;align-items:center;gap:1rem;font-size:.95rem}.topbar-controls label{display:inline-flex;align-items:center;gap:.45rem;color:var(--ink-soft)}.topbar-controls select{font:inherit;padding:.25rem .5rem;border:1px solid var(--rule);background:var(--paper);border-radius:4px}.loading{font-style:italic;color:var(--accent)}.drone-controls{display:inline-flex;align-items:center;gap:.5rem;padding:.2rem .5rem;border:1px solid var(--rule);border-radius:6px;background:var(--paper);flex-wrap:wrap}.drone-toggle{display:inline-flex;align-items:center;gap:.4rem;font-size:.95rem;color:var(--ink-soft);cursor:pointer;-webkit-user-select:none;user-select:none}.drone-controls:has(.drone-toggle input:checked){background:#b75c2a1f;border-color:var(--tonic)}.drone-degree,.drone-volume{display:inline-flex;align-items:center;gap:.35rem;font-size:.85rem;color:var(--ink-soft)}.drone-degree select{font:inherit;padding:.15rem .35rem;border:1px solid var(--rule);background:var(--bg);border-radius:4px;font-size:.85rem}.drone-volume input[type=range]{width:70px}.snippet-tempo{display:inline-flex;align-items:center;gap:.45rem;font-size:.85rem;color:var(--ink-soft);margin-left:.6rem}.snippet-tempo-label{font-family:ui-monospace,SF Mono,Menlo,monospace;min-width:2.6rem;text-align:right}.snippet-tempo input[type=range]{width:100px}.snippet-loop{display:inline-flex;align-items:center;gap:.3rem;font-size:.85rem;color:var(--ink-soft);cursor:pointer;-webkit-user-select:none;user-select:none}.snippet-actions{margin-top:.6rem;display:flex;gap:.7rem;align-items:center}.show-score-toggle{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--ink-soft);cursor:pointer;-webkit-user-select:none;user-select:none}.score-view{margin-top:.6rem;padding:.6rem;background:var(--paper);border:1px solid var(--rule);border-radius:6px;overflow-x:auto}.score-view svg{display:block}.instrument-diagram{margin-top:1.4rem;padding:.9rem 1.1rem;background:var(--paper);border:1px solid var(--rule);border-radius:8px;box-shadow:var(--shadow)}.instrument-diagram-title{margin:0 0 .3rem;font-size:.95rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);font-weight:600}.instrument-diagram-svg{display:block;width:100%;max-width:760px;height:auto}.instrument-diagram-legend{margin:.5rem 0 0;font-size:.82rem;color:var(--ink-soft);line-height:1.5}.recorder{margin-top:1.4rem;padding:.9rem 1.1rem;background:var(--paper);border:1px solid var(--rule);border-radius:8px;box-shadow:var(--shadow)}.recorder-controls{display:flex;align-items:center;gap:.9rem;flex-wrap:wrap}.btn-record{background:#c0392b;border-color:#c0392b;color:var(--paper)}.btn-record:hover{filter:brightness(1.05)}.recorder-elapsed{display:inline-flex;align-items:center;gap:.45rem;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.95rem;color:#c0392b;font-variant-numeric:tabular-nums}.recorder-pulse{display:inline-block;width:10px;height:10px;border-radius:50%;background:#c0392b;animation:recorder-pulse 1s ease-in-out infinite}@keyframes recorder-pulse{0%,to{opacity:.3}50%{opacity:1}}.recorder-mic-toggle{display:inline-flex;align-items:center;gap:.4rem;font-size:.88rem;color:var(--ink-soft);cursor:pointer;-webkit-user-select:none;user-select:none}.recorder-meta{font-size:.8rem;color:var(--ink-soft);margin-left:auto}.recorder-list{list-style:none;margin:.8rem 0 0;padding:0;display:flex;flex-direction:column;gap:.55rem}.recorder-item{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:.6rem;padding:.5rem .7rem;background:var(--bg);border:1px solid var(--rule);border-radius:6px}.recorder-item audio{grid-column:1;width:100%;max-width:380px;height:32px}.recorder-item-label{grid-column:1 / -1;display:flex;align-items:baseline;gap:.7rem;font-size:.85rem;color:var(--ink-soft)}.recorder-item-when{font-family:ui-monospace,SF Mono,Menlo,monospace;color:var(--ink)}.recorder-item-name{font:inherit;background:transparent;border:1px dashed transparent;padding:.1rem .4rem;border-radius:4px;color:var(--ink);font-weight:600;cursor:text}.recorder-item-name:hover{border-color:var(--rule);background:var(--paper)}.recorder-item-name-edit{font:inherit;font-weight:600;padding:.1rem .4rem;border-radius:4px;border:1px solid var(--accent);background:var(--paper);color:var(--ink);min-width:12rem}.recorder-empty{margin:.7rem 0 0;font-size:.85rem;color:var(--ink-soft);font-style:italic}.recorder-item-context{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recorder-item-duration{font-family:ui-monospace,SF Mono,Menlo,monospace}.recorder-item-download{font-size:.85rem;color:var(--accent);text-decoration:none;white-space:nowrap}.recorder-item-download:hover{text-decoration:underline}.recorder-item-remove{font:inherit;width:26px;height:26px;padding:0;border-radius:4px;border:1px solid var(--rule);background:var(--paper);color:var(--ink-soft);cursor:pointer}.recorder-item-remove:hover{background:#fdecea;color:#c0392b;border-color:#c0392b}.layout{display:grid;grid-template-columns:220px 1fr;flex:1;min-height:0}@media (max-width: 720px){.layout{grid-template-columns:1fr}}.sidebar{border-right:1px solid var(--rule);padding:1.2rem .6rem;background:var(--paper)}.sidebar-title{margin:0 0 .5rem .6rem;font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-soft)}.traditions{display:flex;flex-direction:column;gap:.4rem}.tradition-section>.tradition-name{display:flex;justify-content:space-between;align-items:center;padding:.5rem .7rem;cursor:pointer;font-weight:600;font-size:.9rem;color:var(--ink);list-style:none;border-radius:6px;-webkit-user-select:none;user-select:none}.tradition-section>.tradition-name::-webkit-details-marker{display:none}.tradition-section>.tradition-name::marker{content:""}.tradition-section>.tradition-name:before{content:"▸";display:inline-block;margin-right:.45rem;color:var(--accent);transition:transform .12s;font-size:.8em}.tradition-section[open]>.tradition-name:before{transform:rotate(90deg)}.tradition-section>.tradition-name:hover{background:#8a4b2b0f}.tradition-count{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.72rem;color:var(--ink-soft);background:var(--bg);padding:.05rem .4rem;border-radius:8px}.maqam-families{display:flex;flex-direction:column;gap:.7rem;padding-left:.5rem;margin-top:.3rem}.maqam-list-flat{padding-left:.5rem;margin-top:.3rem}.maqam-family>.maqam-family-name{display:flex;justify-content:space-between;align-items:center;margin:.2rem .6rem .1rem;padding:.25rem .3rem;font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);font-weight:600;cursor:pointer;list-style:none;border-radius:4px;-webkit-user-select:none;user-select:none}.maqam-family>.maqam-family-name::-webkit-details-marker{display:none}.maqam-family>.maqam-family-name::marker{content:""}.maqam-family>.maqam-family-name:before{content:"▸";display:inline-block;margin-right:.4rem;color:var(--accent);transition:transform .12s;font-size:.85em;opacity:.7}.maqam-family[open]>.maqam-family-name:before{transform:rotate(90deg)}.maqam-family>.maqam-family-name:hover{background:#8a4b2b0f}.maqam-family-count{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.7rem;color:var(--ink-soft);margin-left:auto}.maqam-list{list-style:none;margin:0;padding:0}.maqam-list-item{width:100%;display:flex;justify-content:space-between;align-items:baseline;padding:.55rem .7rem;background:transparent;border:0;border-radius:6px;font:inherit;color:var(--ink);cursor:pointer;text-align:left}.maqam-list-item:hover{background:#8a4b2b14}.maqam-list-item.is-selected{background:var(--accent);color:var(--paper)}.maqam-list-item.is-selected .maqam-list-arabic{color:var(--accent-soft)}.maqam-list-name{font-size:1.05rem}.maqam-list-arabic{font-family:Geeza Pro,Scheherazade New,Times New Roman,serif;font-size:1rem;color:var(--ink-soft)}.main{padding:1.6rem 2rem;max-width:980px}.maqam-header{display:flex;align-items:flex-start;justify-content:space-between;gap:2rem;flex-wrap:wrap;border-bottom:1px solid var(--rule);padding-bottom:1rem}.maqam-name{margin:0;font-size:2rem;font-weight:600;letter-spacing:.005em}.maqam-name-arabic{font-family:Geeza Pro,Scheherazade New,Times New Roman,serif;color:var(--accent);margin-left:.4rem}.maqam-tonic{margin:.3rem 0 0;color:var(--ink-soft);font-size:.95rem}.scale-strip{display:flex;gap:.35rem;flex-wrap:wrap;align-items:center}.scale-strip-note{font-family:ui-monospace,SF Mono,Menlo,monospace;background:var(--paper);border:1px solid var(--rule);padding:.3rem .55rem;border-radius:4px;font-size:.95rem;box-shadow:var(--shadow)}.scale-strip-octave{opacity:.55}.maqam-meta{margin-top:1.2rem;display:grid;grid-template-columns:1fr auto;gap:1.5rem;align-items:start}.maqam-desc{margin:0;font-size:1.02rem;line-height:1.55;color:var(--ink)}.ajnas-block{display:flex;flex-direction:column;gap:.5rem;background:var(--paper);border:1px solid var(--rule);border-radius:6px;padding:.7rem .9rem}.ajnas-header{display:flex;justify-content:space-between;align-items:center;gap:.7rem}.ajnas-list-title{margin:0;font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-soft);font-weight:600}.show-ajnas-toggle{display:inline-flex;align-items:center;gap:.35rem;font-size:.78rem;color:var(--ink-soft);cursor:pointer;-webkit-user-select:none;user-select:none}.ajnas{list-style:none;margin:0;padding:0;font-size:.9rem;color:var(--ink-soft)}.ajnas li{padding:.15rem 0}.jins-view{margin-top:.5rem;padding-top:.6rem;border-top:1px dashed var(--rule)}.jins-view-title{margin:0 0 .5rem;font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);font-weight:600}.jins-view-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem}.jins-view-chip{display:flex;flex-direction:column;gap:.15rem;padding:.45rem .6rem;border:1px solid var(--rule);border-radius:6px;font-size:.85rem}.jins-view-chip-name{font-weight:600;color:var(--ink)}.jins-view-chip-range{font-size:.78rem;color:var(--ink-soft);font-family:ui-monospace,SF Mono,Menlo,monospace}.jins-view-chip-notes{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.85rem;color:var(--ink);letter-spacing:.04em}.jins-view-chip--text{font-style:italic}.learning-section{margin-top:1.4rem;padding:.9rem 1.1rem;background:var(--paper);border:1px solid var(--rule);border-radius:8px;box-shadow:var(--shadow)}.learning-header{display:flex;justify-content:space-between;align-items:center;gap:.7rem;margin-bottom:.5rem;flex-wrap:wrap}.learning-title{margin:0;font-size:1rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);font-weight:600}.learning-toggle{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--ink-soft);cursor:pointer;-webkit-user-select:none;user-select:none;padding:.2rem .55rem;border:1px solid var(--rule);border-radius:5px;background:var(--bg)}.learning-toggle:has(input:checked){background:var(--accent);color:var(--paper);border-color:var(--accent)}.learning-blurb{margin:0 0 .7rem;font-size:.9rem;color:var(--ink);line-height:1.55}.practice-section{margin-top:1.4rem;padding:.9rem 1.1rem;background:var(--paper);border:1px solid var(--rule);border-radius:8px;box-shadow:var(--shadow)}.practice-title{margin:0 0 .6rem;font-size:1rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);font-weight:600}.practice-row{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}.practice-row label{color:var(--ink-soft)}.practice-row select{font:inherit;padding:.3rem .5rem;border:1px solid var(--rule);background:var(--bg);border-radius:4px;max-width:60ch}.practice-description{margin:.7rem 0 .2rem;font-size:.9rem;color:var(--ink);line-height:1.55}.practice-meta{margin:0;font-size:.82rem;color:var(--ink-soft)}.beat-track{margin-top:1.4rem;padding:.9rem 1.1rem;background:var(--paper);border:1px solid var(--rule);border-radius:8px;box-shadow:var(--shadow)}.beat-track-header{display:flex;justify-content:space-between;align-items:center;gap:.7rem;margin-bottom:.5rem;flex-wrap:wrap}.beat-track-title{margin:0;font-size:1rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);font-weight:600}.beat-track-toggle{display:inline-flex;align-items:center;gap:.4rem;font-size:.95rem;color:var(--ink-soft);padding:.25rem .65rem;border:1px solid var(--rule);border-radius:6px;background:var(--paper);cursor:pointer;-webkit-user-select:none;user-select:none}.beat-track-toggle:has(input:checked){background:var(--accent);color:var(--paper);border-color:var(--accent)}.beat-track-row{display:flex;gap:1rem;align-items:center;flex-wrap:wrap;margin-bottom:.4rem}.beat-track-row label{display:inline-flex;align-items:center;gap:.4rem;color:var(--ink-soft);font-size:.9rem}.beat-track-row select{font:inherit;padding:.3rem .5rem;border:1px solid var(--rule);background:var(--bg);border-radius:4px}.beat-track-bpm input[type=range]{width:140px}.beat-track-bpm-val{font-family:ui-monospace,SF Mono,Menlo,monospace;min-width:2.4rem;text-align:right;color:var(--ink)}.beat-track-gain input[type=range]{width:80px}.beat-track-desc{margin:.4rem 0;font-size:.85rem;color:var(--ink-soft);line-height:1.5}.beat-seq{position:relative;margin-top:.6rem;height:64px;background:var(--bg);border:1px solid var(--rule);border-radius:6px;overflow:hidden}.beat-seq-grid{position:absolute;top:0;right:0;bottom:0;left:0;display:grid}.beat-seq-grid-cell{border-right:1px solid rgba(216,184,156,.3)}.beat-seq-grid-cell:last-child{border-right:0}.beat-seq-grid-cell.is-downbeat{background:#b75c2a0d;border-left:2px solid var(--accent)}.beat-seq-grid-cell.is-half{border-left:1px solid var(--accent-soft)}.beat-seq-grid-cell.is-group-start{border-left:3px double var(--tonic);background:#b75c2a14}.beat-seq-num.is-group-start{color:var(--tonic);font-weight:700}.beat-seq-grid-cell.is-measure-start{border-left:4px solid #c0392b;background:#c0392b1f;box-shadow:inset 1px 0 #c0392b80}.beat-seq-num.is-measure-start{color:#c0392b;font-weight:800;text-decoration:underline;text-underline-offset:2px}.beat-seq-hits{position:absolute;left:0;right:0;top:8px;bottom:22px;pointer-events:none}.beat-seq-hit{position:absolute;top:0;bottom:0;display:flex;align-items:center;justify-content:center;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.8rem;font-weight:700;border-radius:3px}.beat-seq-hit.is-d{background:var(--accent);color:var(--paper)}.beat-seq-hit.is-t{background:var(--accent-soft);color:var(--ink)}.beat-seq-hit.is-k{background:var(--accent-soft);color:var(--ink);opacity:.7!important}.beat-seq-hit.is-s{background:#b75c2a;color:var(--paper)}.beat-seq-hit.is-b{background:#6a3a25;color:var(--paper)}.beat-seq-hit.is-x{background:#d4af6a;color:var(--ink)}.beat-seq-hit.is-m{background:#888;color:var(--paper);font-size:.6rem}.beat-seq-hit.is-accent{outline:2px solid var(--tonic);outline-offset:1px}.beat-seq-playhead{position:absolute;top:0;bottom:0;width:2px;background:#c0392b;box-shadow:0 0 6px #c0392bb3;pointer-events:none;z-index:2}.beat-seq-numbers{position:absolute;left:0;right:0;bottom:0;display:grid;padding:0;pointer-events:none}.beat-seq-num{text-align:left;padding-left:3px;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.7rem;color:var(--ink-soft);padding-top:2px}.beat-seq-num.is-downbeat{color:var(--accent);font-weight:700}.beat-seq-num.is-and{opacity:.6}.beat-seq-num.is-sub{opacity:.3;font-size:.6rem}.beat-track-mode{display:flex;gap:4px;margin-top:.4rem;background:var(--bg);padding:3px;border-radius:6px;border:1px solid var(--rule);width:fit-content}.beat-track-mode-btn{border:0;background:transparent;color:var(--ink-soft);padding:4px 12px;font-size:.85rem;border-radius:4px;cursor:pointer;font-family:inherit}.beat-track-mode-btn.is-active{background:var(--accent);color:var(--paper);font-weight:600}.beat-track-edit-bar{display:flex;align-items:center;gap:6px;margin-top:.4rem;flex-wrap:wrap}.beat-track-edit-bar .btn.is-active{background:var(--accent);color:var(--paper);border-color:var(--accent)}.beat-track-edit-hint{font-size:.75rem;color:var(--ink-soft);font-style:italic}.beat-seq-edit-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;z-index:3}.beat-seq-edit-cell{background:transparent;border:0;border-right:1px dashed rgba(183,92,42,.25);cursor:pointer;padding:0;margin:0;transition:background .08s ease}.beat-seq-edit-cell:hover{background:#b75c2a2e}.beat-seq-edit-cell:last-child{border-right:0}.beat-seq--row.is-editing{outline:1px dashed var(--accent);outline-offset:-1px}.beat-seq-full{margin-top:.6rem;display:flex;flex-direction:column;gap:4px}.beat-seq-full-header,.beat-seq-full-row{display:grid;grid-template-columns:100px 1fr 130px;align-items:center;gap:6px}.beat-seq-full .beat-seq--row{height:36px;margin-top:0}.beat-seq-full .beat-seq--header{height:22px;margin-top:0;background:transparent;border:0}.beat-seq-full .beat-seq--header .beat-seq-grid{display:none}.beat-seq-full .beat-seq--header .beat-seq-numbers{position:static}.beat-seq-full .beat-seq--row .beat-seq-hits{bottom:4px;top:4px}.beat-seq-full .beat-seq--row .beat-seq-numbers{display:none}.beat-seq-full-labelcol{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--ink);min-width:0}.beat-seq-full-icon{font-size:1.1rem;width:18px;text-align:center;color:var(--accent)}.beat-seq-full-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.beat-seq-full-controlcol{display:flex;align-items:center;gap:6px;justify-content:flex-end}.beat-seq-full-mute{display:inline-flex;align-items:center;cursor:pointer;font-size:.95rem}.beat-seq-full-mute input{display:none}.beat-seq-full-vol{width:80px}.beat-seq-full-row.is-empty{opacity:.4}.beat-seq-full-row.is-muted .beat-seq-hits{opacity:.3;filter:grayscale(.6)}@media (max-width: 600px){.beat-seq-full-header,.beat-seq-full-row{grid-template-columns:70px 1fr 100px;gap:4px}.beat-seq-full-name{font-size:.75rem}.beat-seq-full-vol{width:60px}}.step-seq-lanes{margin-top:1rem;border-top:1px dashed var(--rule);padding-top:.8rem}.step-seq-lanes-header{display:flex;justify-content:space-between;align-items:center;gap:.6rem;margin-bottom:.5rem}.step-seq-lanes-header h3{margin:0;font-size:.95rem;color:var(--ink)}.step-seq-lanes-grid{display:grid;row-gap:6px;align-items:center}.step-seq-lane-label{display:flex;align-items:center;font-size:.8rem;padding-right:6px}.step-seq-lane-label select{font-size:.8rem;max-width:140px}.step-seq-lane-track{position:relative;height:36px;background:var(--bg);border:1px solid var(--rule);border-radius:4px;overflow:hidden}.step-seq-lane-tick{position:absolute;top:0;bottom:0;width:1px;background:#d8b89c59;pointer-events:none}.step-seq-lane-tick.is-downbeat{background:#b75c2a66}.step-seq-lane-tick.is-current{background:#c0392b;width:2px;box-shadow:0 0 4px #c0392b99;z-index:2}.step-seq-lane-block{position:absolute;top:3px;bottom:3px;background:linear-gradient(180deg,var(--accent) 0%,#8c4520 100%);color:var(--paper);border-radius:4px;padding:0 6px;display:flex;align-items:center;gap:6px;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;box-shadow:0 1px 2px #0003;overflow:hidden;font-size:.75rem;z-index:3}.step-seq-lane-block:active{cursor:grabbing}.step-seq-lane-block-name{font-weight:600;white-space:nowrap}.step-seq-lane-block-glyphs{font-family:ui-monospace,SF Mono,Menlo,monospace;opacity:.85;letter-spacing:1px;white-space:nowrap;overflow:hidden;text-overflow:clip;flex:1;min-width:0}.step-seq-lane-block-start{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.7rem;opacity:.85;white-space:nowrap}.step-seq-lane-controls{display:flex;align-items:center;gap:4px;padding-left:6px}.step-seq-lane-vol{width:70px}.step-seq-lane-remove{padding:.2rem .5rem;font-size:.85rem}@media (max-width: 600px){.step-seq-lane-label select{max-width:90px;font-size:.7rem}.step-seq-lane-vol{width:50px}.step-seq-lane-block{font-size:.65rem}}.step-seq{margin-top:1.4rem;padding:.9rem 1.1rem;background:var(--paper);border:1px solid var(--rule);border-radius:8px;box-shadow:var(--shadow)}.step-seq-summary{display:flex;align-items:center;justify-content:space-between;gap:.8rem;cursor:pointer;font-size:1rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);-webkit-user-select:none;user-select:none;list-style:none}.step-seq-summary::-webkit-details-marker{display:none}.step-seq-summary::marker{content:""}.step-seq-summary:before{content:"▸";display:inline-block;margin-right:.45rem;color:var(--accent);transition:transform .12s}.step-seq[open]>.step-seq-summary:before{transform:rotate(90deg)}.step-seq-summary-meta{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.78rem;color:var(--ink-soft);font-weight:400;letter-spacing:normal}.step-seq-controls{display:flex;align-items:center;gap:.9rem;flex-wrap:wrap;margin-top:.7rem}.step-seq-controls label{display:inline-flex;align-items:center;gap:.4rem;color:var(--ink-soft);font-size:.9rem}.step-seq-controls select{font:inherit;padding:.3rem .5rem;border:1px solid var(--rule);background:var(--bg);border-radius:4px}.step-seq-bpm input[type=range]{width:110px}.step-seq-bpm-val{font-family:ui-monospace,SF Mono,Menlo,monospace;min-width:2.4rem;text-align:right;color:var(--ink)}.step-seq-hint{margin:.5rem 0;font-size:.83rem;color:var(--ink-soft);line-height:1.5}.step-seq-grid{display:grid;gap:2px;margin-top:.4rem;padding:.4rem;background:var(--bg);border:1px solid var(--rule);border-radius:6px}.step-seq-header{text-align:center;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.7rem;color:var(--ink-soft);padding:.15rem 0;background:var(--paper);border-radius:3px;-webkit-user-select:none;user-select:none}.step-seq-header.is-downbeat{background:#b75c2a1a;color:var(--accent);font-weight:700}.step-seq-header.is-active{background:var(--accent);color:var(--paper)}.step-seq-rowlabel{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.78rem;color:var(--ink-soft);padding:.25rem .5rem;display:flex;align-items:center;white-space:nowrap}.step-seq-rowlabel.is-tonic{color:var(--tonic);font-weight:700}.step-seq-rowlabel.is-octave{color:var(--accent);font-weight:600}.step-seq-cell{font:inherit;position:relative;overflow:hidden;min-height:24px;background:var(--paper);border:1px solid var(--rule);border-radius:3px;cursor:pointer;padding:0;-webkit-tap-highlight-color:transparent;transition:background 80ms}.step-seq-cell:hover{background:#d8b89c4d}.step-seq-cell.is-downbeat{border-left:2px solid var(--accent-soft)}.step-seq-cell-bar{position:absolute;top:1px;bottom:1px;left:0;border-radius:2px;pointer-events:none}.step-seq-cell-bar.is-binary{background:var(--accent)}.step-seq-cell-bar.is-triplet{background:#2f8a4a;background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.18) 0,rgba(255,255,255,.18) 3px,transparent 3px,transparent 6px)}.step-seq-cell-bar.is-dotted{background:#c97a2a;background-image:radial-gradient(circle at 90% 50%,rgba(255,255,255,.5) 1.5px,transparent 2px);background-size:8px 100%;background-repeat:repeat-x}.step-seq-cell.is-active{border-color:var(--accent)}.step-seq-cell.is-active:hover{background:#d8b89c66}.step-seq-cell.is-playhead{outline:2px solid #c0392b;outline-offset:-2px;z-index:1}.step-seq-cell.is-active.is-playhead .step-seq-cell-bar.is-binary{background:var(--tonic)}@media (max-width: 720px){.step-seq-rowlabel{font-size:.7rem;padding:.15rem .3rem}.step-seq-cell{min-height:20px}}.liturgy-section{margin-top:1.4rem;padding:.9rem 1.1rem;background:var(--paper);border:1px solid var(--rule);border-radius:8px;box-shadow:var(--shadow)}.liturgy-title{margin:0 0 .4rem;font-size:1rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);font-weight:600}.liturgy-blurb{margin:0 0 .9rem;font-size:.9rem;color:var(--ink);line-height:1.5}.liturgy-faith{margin-top:.8rem;padding-top:.6rem;border-top:1px dashed var(--rule)}.liturgy-faith:first-of-type{border-top:0;padding-top:0;margin-top:0}.liturgy-faith-name{margin:0 0 .4rem;font-size:.95rem;color:var(--accent);font-weight:600}.liturgy-resources{list-style:none;margin:0 0 .7rem;padding:0;display:flex;flex-direction:column;gap:.3rem}.liturgy-resources li{font-size:.88rem;line-height:1.5}.liturgy-resources a{color:var(--accent);text-decoration:none;font-weight:500}.liturgy-resources a:hover{text-decoration:underline}.liturgy-resource-note{color:var(--ink-soft)}.liturgy-entries{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.7rem}.liturgy-entry{display:grid;grid-template-columns:1fr auto;gap:1rem;padding:.7rem .85rem;background:var(--bg);border:1px solid var(--rule);border-radius:6px}@media (max-width: 720px){.liturgy-entry{grid-template-columns:1fr}}.liturgy-entry-community{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);font-weight:600;margin-bottom:.25rem}.liturgy-entry-use{margin:0 0 .4rem;font-size:.92rem;line-height:1.55;color:var(--ink)}.liturgy-entry-examples{list-style:none;margin:0 0 .4rem;padding:0;display:flex;flex-wrap:wrap;gap:.4rem}.liturgy-entry-examples li{font-size:.82rem;padding:.15rem .5rem;background:var(--paper);border:1px solid var(--rule);border-radius:12px;color:var(--ink);font-family:ui-monospace,SF Mono,Menlo,monospace}.liturgy-entry-chips{display:flex;flex-wrap:wrap;align-items:center;gap:.3rem;margin:0 0 .4rem;font-size:.78rem}.liturgy-entry-chips-label{color:var(--ink-soft);text-transform:uppercase;letter-spacing:.06em;font-size:.7rem;margin-right:.2rem}.liturgy-entry-chip{padding:.1rem .5rem;border-radius:10px;font-size:.78rem;border:1px solid var(--rule);background:var(--paper);color:var(--ink)}.liturgy-entry-chip.is-parasha{background:#b75c2a14;border-color:#b75c2a4d;color:var(--accent)}.liturgy-entry-chip.is-occasion{background:#2f8a4a14;border-color:#2f8a4a4d;color:#2f8a4a}.liturgy-entry-source{font-size:.82rem;color:var(--accent);text-decoration:none}.liturgy-entry-source:hover{text-decoration:underline}.liturgy-entry-video iframe{display:block;border:1px solid var(--rule);border-radius:6px;background:#000;box-shadow:var(--shadow)}.liturgy-entry-video-caption{margin-top:.3rem;font-size:.78rem;color:var(--ink-soft);font-style:italic;max-width:280px}.liturgy-empty{margin:0;font-size:.85rem;color:var(--ink-soft);font-style:italic}.snippet-section{margin-top:1.6rem;padding:1rem 1.1rem;background:var(--paper);border:1px solid var(--rule);border-radius:8px;box-shadow:var(--shadow)}.snippet-section h2{margin:0 0 .6rem;font-size:1rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);font-weight:600}.snippet-row{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}.snippet-row label{color:var(--ink-soft)}.snippet-row select{font:inherit;padding:.3rem .5rem;border:1px solid var(--rule);background:var(--bg);border-radius:4px}.snippet-meta{margin:0;font-size:.85rem;color:var(--ink-soft)}.snippet-body{display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:start;margin-top:.6rem}.snippet-info{display:flex;flex-direction:column;gap:.35rem}.yt-search-link{font-size:.85rem;color:var(--accent);text-decoration:none;align-self:flex-start}.yt-search-link:hover{text-decoration:underline}.yt-embed iframe{display:block;border:1px solid var(--rule);border-radius:6px;background:#000;box-shadow:var(--shadow)}@media (max-width: 720px){.snippet-body{grid-template-columns:1fr}.yt-embed iframe{width:100%;height:auto;aspect-ratio:16 / 9}}.btn{font:inherit;padding:.35rem .85rem;border-radius:6px;border:1px solid var(--accent);background:var(--accent);color:var(--paper);cursor:pointer}.btn:hover{filter:brightness(1.05)}.btn-stop{background:#555;border-color:#555}.btn-secondary{background:var(--paper);color:var(--accent);border-color:var(--accent)}.btn-danger{background:#c0392b;color:var(--paper);border-color:#c0392b}.tuning-explanation{margin-top:1rem;padding:.7rem .9rem;background:var(--paper);border:1px solid var(--rule);border-radius:6px;font-size:.9rem;color:var(--ink-soft);line-height:1.5}.tuning-explanation strong{color:var(--accent)}.auth-bar{display:flex;align-items:center;gap:.5rem;margin-left:auto}.auth-bar-email{font-size:.8rem;color:var(--ink-soft);font-family:ui-monospace,SF Mono,Menlo,monospace;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auth-bar-tier-pro{display:inline-block;margin-left:6px;padding:.05rem .35rem;background:var(--accent);color:var(--paper);font-size:.65rem;font-weight:700;border-radius:3px;letter-spacing:.05em;text-transform:uppercase}.auth-bar-btn{font-size:.8rem;padding:.25rem .7rem}.login-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:flex-start;justify-content:center;padding-top:10vh;z-index:1000;overflow-y:auto}.login-modal,.submit-modal{background:var(--paper);border-radius:10px;padding:1.6rem 1.6rem 1.4rem;max-width:460px;width:90%;box-shadow:0 20px 60px #0006;position:relative;margin-bottom:4rem}.submit-modal{max-width:640px}.login-modal h2,.submit-modal h2{margin:0 0 .5rem;font-size:1.2rem}.login-modal-close{position:absolute;top:8px;right:12px;background:none;border:0;font-size:1.6rem;color:var(--ink-soft);cursor:pointer;line-height:1}.login-modal-close:hover{color:var(--ink)}.login-modal-hint,.submit-form-hint{font-size:.85rem;color:var(--ink-soft);margin:.4rem 0 .8rem;line-height:1.45}.login-modal-field,.submit-form>label{display:flex;flex-direction:column;gap:.2rem;margin-bottom:.7rem}.login-modal-field span,.submit-form>label>span{font-size:.78rem;color:var(--ink-soft);font-weight:600}.submit-form>label>span em{color:var(--accent);font-style:normal;font-size:.7rem;font-weight:400;margin-left:4px}.login-modal-field input,.submit-form input,.submit-form select,.submit-form textarea{font:inherit;padding:.45rem .6rem;border:1px solid var(--rule);border-radius:5px;background:#fff}.submit-form textarea{resize:vertical;font-family:inherit}.login-modal-sent{background:#2f8a4a14;border:1px solid rgba(47,138,74,.3);border-radius:6px;padding:.8rem;margin-top:.4rem}.login-modal-error,.submit-form-error{color:#c0392b;font-size:.85rem;margin:.4rem 0 0}.submit-form-row{display:flex;gap:.6rem}.submit-form-narrow{flex:0 0 100px}.submit-form-grow{flex:1}.submit-form-buttons{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem}.submit-form-preview{margin-top:.8rem;padding:.5rem;background:var(--bg);border:1px solid var(--rule);border-radius:5px}.submit-form-preview strong{display:block;font-size:.78rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.4rem}.submit-form-preview iframe{display:block;border:0;border-radius:4px}.community-subs{margin-top:1rem;padding:.9rem 1.1rem;background:var(--paper);border:1px solid var(--rule);border-left:3px solid #2f8a4a;border-radius:6px}.community-subs-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem;gap:.6rem;flex-wrap:wrap}.community-subs-title{margin:0;font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);font-weight:600}.community-subs-loading,.community-subs-empty{margin:0;font-size:.85rem;color:var(--ink-soft);font-style:italic}.community-subs-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1rem}.community-sub{border-top:1px dashed var(--rule);padding-top:.8rem}.community-sub:first-child{border-top:0;padding-top:0}.community-sub-head{font-size:.95rem;margin-bottom:.3rem}.community-sub-year,.community-sub-album{color:var(--ink-soft);font-weight:400}.community-sub-note{margin:0 0 .5rem;font-size:.85rem;color:var(--ink);line-height:1.45}.community-sub iframe{display:block;border:0;border-radius:4px;width:100%}.community-sub-meta{margin-top:.4rem;font-size:.75rem;color:var(--ink-soft);font-style:italic}.recorder-item-actions{display:flex;align-items:center;flex-wrap:wrap;gap:6px;margin-top:4px}.recorder-item-share,.recorder-item-share-url,.recorder-item-share-toggle{font:inherit;font-size:.78rem;padding:.2rem .55rem;border-radius:4px;border:1px solid var(--rule);background:var(--paper);color:var(--ink);cursor:pointer}.recorder-item-share:hover,.recorder-item-share-url:hover,.recorder-item-share-toggle:hover{background:#d8b89c4d}.recorder-item-share.is-uploading{background:#b75c2a1a;color:var(--accent);font-style:italic;cursor:wait;border-style:dashed}.recorder-item-share.is-error{background:#c0392b1a;color:#c0392b;border-color:#c0392b66}.recorder-item-share-result{display:inline-flex;align-items:center;gap:4px}.recorder-item-share-url{background:#2f8a4a1a;border-color:#2f8a4a66;color:#2f8a4a;font-weight:600}.recorder-item-share-url.is-private{background:var(--bg);color:var(--ink-soft);font-weight:400;cursor:default}.public-rec-app{min-height:100vh;background:var(--bg);display:flex;flex-direction:column}.public-rec-header{background:var(--paper);border-bottom:1px solid var(--rule);padding:1rem 1.5rem;box-shadow:var(--shadow)}.public-rec-brand{text-decoration:none;display:inline-flex;align-items:baseline;gap:.6rem}.public-rec-brand .brand-en{font-size:1.15rem;font-weight:700;color:var(--ink)}.public-rec-brand .brand-ar{font-size:1.05rem;color:var(--accent)}.public-rec-main{flex:1;padding:2rem 1.5rem;display:flex;justify-content:center}.public-rec,.public-rec-error{max-width:640px;width:100%;background:var(--paper);border:1px solid var(--rule);border-radius:10px;padding:2rem;box-shadow:var(--shadow)}.public-rec-title{margin:0 0 .6rem;font-size:1.5rem}.public-rec-context{font-size:.9rem;color:var(--ink-soft);margin:0 0 1.2rem;line-height:1.5}.public-rec-context a{color:var(--accent)}.public-rec-audio{width:100%;display:block;margin:1rem 0}.public-rec-meta{font-size:.78rem;color:var(--ink-soft);font-style:italic;margin:.4rem 0 1.4rem}.public-rec-cta{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:1rem}.public-rec-cta .btn{text-decoration:none;display:inline-block}.public-rec-loading,.public-rec-error h1{text-align:center;color:var(--ink)}.public-rec-error h1{margin-top:0;color:#c0392b}.public-rec-error-hint{font-size:.85rem;color:var(--ink-soft);margin-top:1rem}.cultural-refs{margin-top:1rem;padding:.8rem 1rem;background:var(--paper);border:1px solid var(--rule);border-left:3px solid var(--accent);border-radius:6px}.cultural-refs-title{margin:0 0 .6rem;font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);font-weight:600}.cultural-refs-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.7rem}.cultural-ref{border-top:1px dashed var(--rule);padding-top:.6rem}.cultural-ref:first-child{border-top:0;padding-top:0}.cultural-ref-head{font-size:.95rem;color:var(--ink);margin-bottom:.25rem}.cultural-ref-year{color:var(--ink-soft);font-weight:400}.cultural-ref-album{color:var(--ink-soft)}.cultural-ref-note{margin:.25rem 0 .4rem;font-size:.85rem;color:var(--ink);line-height:1.45}.cultural-ref-meta{display:flex;flex-wrap:wrap;gap:.6rem;align-items:baseline;font-size:.78rem}.cultural-ref-link{color:var(--accent);text-decoration:none}.cultural-ref-link:hover{text-decoration:underline}.cultural-ref-source,.cultural-ref-source a{color:var(--ink-soft);font-style:italic;text-decoration:none}.cultural-ref-source a:hover{text-decoration:underline}.pitch-section{background:linear-gradient(180deg,var(--paper) 0%,#fff8e6 100%)}.pitch-vis-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.7rem}.pitch-vis-header h2{margin:0;font-size:1rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);font-weight:600}.pitch-vis-error{color:#b03a2e;font-size:.9rem;margin:.4rem 0}.pitch-vis-readout{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin:.4rem 0 .6rem}.pitch-vis-note{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:2.6rem;font-weight:600;line-height:1;color:var(--ink-soft);transition:color 80ms}.pitch-vis-note.is-in-tune{color:#2e8b57}.pitch-vis-note.is-near{color:#d4a72b}.pitch-vis-note.is-off{color:#c0392b}.pitch-vis-detail{display:flex;flex-direction:column;align-items:flex-end;gap:.2rem;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.95rem;color:var(--ink-soft)}.pitch-vis-cents{font-size:1.05rem;color:var(--ink)}.pitch-vis-meter{margin-top:.4rem}.pitch-vis-meter-track{position:relative;height:18px;background:linear-gradient(90deg,#c0392b2e,#d4a72b2e 30%,#2e8b572e,#d4a72b2e 70%,#c0392b2e);border:1px solid var(--rule);border-radius:4px}.pitch-vis-meter-target{position:absolute;left:50%;top:-2px;bottom:-2px;width:2px;background:var(--ink);transform:translate(-50%)}.pitch-vis-meter-needle{position:absolute;top:-4px;bottom:-4px;width:4px;border-radius:2px;transform:translate(-50%);background:var(--ink-soft);transition:left 60ms linear}.pitch-vis-meter-needle.is-in-tune{background:#2e8b57}.pitch-vis-meter-needle.is-near{background:#d4a72b}.pitch-vis-meter-needle.is-off{background:#c0392b}.pitch-vis-meter-labels{display:flex;justify-content:space-between;font-size:.72rem;color:var(--ink-soft);margin-top:.3rem;font-family:ui-monospace,SF Mono,Menlo,monospace}.pitch-vis-header-controls{display:flex;align-items:center;gap:.7rem}.view-toggle{display:inline-flex;border:1px solid var(--rule);border-radius:6px;overflow:hidden;background:var(--bg)}.view-toggle-btn{font:inherit;font-size:.85rem;padding:.3rem .7rem;background:transparent;border:0;color:var(--ink-soft);cursor:pointer}.view-toggle-btn+.view-toggle-btn{border-left:1px solid var(--rule)}.view-toggle-btn.is-active{background:var(--accent);color:var(--paper)}.vert-scale{margin-top:.6rem;padding:0 3.4rem}.vert-scale-track{position:relative;height:520px;background:var(--paper);border:1px solid var(--rule);border-radius:8px;box-shadow:var(--shadow);overflow:visible}.vert-scale-center{position:absolute;left:50%;top:6px;bottom:6px;width:2px;margin-left:-1px;background:linear-gradient(180deg,transparent 0%,rgba(138,75,43,.1) 15%,rgba(138,75,43,.1) 85%,transparent 100%)}.vert-scale-rail{position:absolute;left:0;right:0;height:1px;display:flex;align-items:center;pointer-events:none}.vert-scale-line{flex:1;height:1px;background:var(--rule);opacity:.7}.vert-scale-label-left,.vert-scale-label-right{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.72rem;color:var(--ink-soft);white-space:nowrap;transform:translateY(-50%);position:absolute;top:50%}.vert-scale-label-left{right:calc(100% + 8px);text-align:right}.vert-scale-label-right{left:calc(100% + 8px)}.vert-scale-rail.is-tonic .vert-scale-line{background:var(--tonic);height:2px;opacity:1}.vert-scale-rail.is-tonic .vert-scale-label-left,.vert-scale-rail.is-tonic .vert-scale-label-right{color:var(--tonic);font-weight:600}.vert-scale-rail.is-octave .vert-scale-line{background:var(--accent-soft);height:1.5px;opacity:.9}.vert-scale-rail.is-octave .vert-scale-label-left,.vert-scale-rail.is-octave .vert-scale-label-right{color:var(--accent)}.vert-scale-rail.is-in-trajectory .vert-scale-line{background:var(--accent-soft);height:2px;opacity:.85}.vert-scale-rail.is-in-trajectory .vert-scale-label-left,.vert-scale-rail.is-in-trajectory .vert-scale-label-right{color:var(--accent)}.vert-scale-rail.is-snippet-current .vert-scale-line{background:var(--accent);height:3px;opacity:1;box-shadow:0 0 6px #8a4b2b73}.vert-scale-rail.is-in-tune .vert-scale-line{background:#2e8b57;height:3px;opacity:1;box-shadow:0 0 8px #2e8b5780}.vert-scale-rail.is-near .vert-scale-line{background:#d4a72b;height:2px;opacity:1}.vert-scale-rail.is-off .vert-scale-line{background:#c0392b;opacity:.85}.vert-scale-ball{position:absolute;left:50%;width:22px;height:22px;margin-left:-11px;margin-top:-11px;border-radius:50%;background:var(--ink-soft);box-shadow:0 2px 6px #0000002e;transition:top 40ms linear,background 80ms;z-index:2;display:flex;align-items:center;justify-content:center}.vert-scale-ball.is-in-tune{background:#2e8b57;box-shadow:0 0 14px #2e8b57b3,0 2px 6px #0000002e}.vert-scale-ball.is-near{background:#d4a72b}.vert-scale-ball.is-off{background:#c0392b}.vert-scale-ball-cents{position:absolute;left:calc(100% + 8px);font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.75rem;color:var(--ink);background:var(--paper);border:1px solid var(--rule);padding:.05rem .35rem;border-radius:3px;white-space:nowrap}.keyboard-section{margin-top:1.4rem}.kbd-rows{display:flex;flex-direction:column;gap:.45rem;align-items:stretch}.kbd-row{display:flex;gap:.35rem;align-items:stretch}.kbd-row-label{width:1.4rem;display:flex;align-items:center;justify-content:center;color:var(--ink-soft);font-size:.95rem}.kbd-key{flex:1;min-height:3.4rem;display:flex;flex-direction:column;justify-content:space-between;align-items:center;padding:.35rem .25rem;background:var(--paper);border:1px solid var(--rule);border-radius:6px;box-shadow:var(--shadow);font:inherit;cursor:pointer;-webkit-user-select:none;user-select:none;transition:transform 80ms,background .12s}.kbd-key:hover{background:#fff8e6}.kbd-key.is-active{background:var(--accent);color:var(--paper);transform:translateY(1px)}.kbd-key.is-lit{background:var(--highlight);border-color:#d4a72b}.kbd-key.is-tonic{border-color:var(--tonic);border-width:2px}.kbd-key.is-tonic .kbd-degree{color:var(--tonic);font-weight:700}.kbd-key.is-active.is-tonic{background:var(--tonic);color:var(--paper)}.kbd-key.is-active .kbd-degree,.kbd-key.is-active .kbd-note{color:inherit}.kbd-letter{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.78rem;color:var(--ink-soft);letter-spacing:.04em}.kbd-note{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.95rem;font-weight:500}.kbd-degree{font-size:.7rem;color:var(--ink-soft);font-variant-numeric:tabular-nums}.kbd-cents{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.65rem;color:var(--ink-soft);opacity:.75}.kbd-key.is-active .kbd-cents{color:inherit;opacity:.85}.kbd-key.lower,.kbd-key.upper,.kbd-key.highest{background:#f0ebde}.kbd-key.has-tint{background:var(--jins-tint-bg),var(--paper);border-color:var(--jins-tint-border)}.kbd-key.has-tint.lower,.kbd-key.has-tint.upper,.kbd-key.has-tint.highest{background:var(--jins-tint-bg),#f0ebde}.kbd-key.has-tint.is-active,.kbd-key.has-tint.is-lit{background:inherit}.kbd-key.has-tint.is-active{background:var(--accent)}.kbd-key.has-tint.is-lit{background:var(--highlight)}.kbd-key.has-tint.is-active.is-tonic{background:var(--tonic)}.hint{margin:.7rem 0 0;font-size:.88rem;color:var(--ink-soft);line-height:1.5}.hint kbd{font-family:ui-monospace,SF Mono,Menlo,monospace;border:1px solid var(--rule);background:var(--paper);padding:.05rem .35rem;border-radius:3px;font-size:.85em}.hint-keys{margin-top:.6rem}.hint-ornaments{margin-top:.3rem;font-size:.83rem;padding:.5rem .7rem;background:var(--paper);border:1px solid var(--rule);border-left:3px solid var(--accent);border-radius:4px}.hint-ornaments kbd{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.85em;padding:.05rem .35rem;border:1px solid var(--rule);background:var(--bg);border-radius:3px}.snippet-empty{color:var(--ink-soft);font-style:italic}.mob-kbd{width:100%;display:flex;flex-direction:column;gap:.6rem;align-items:stretch}.mob-kbd-shift{display:flex;justify-content:space-between;align-items:center;gap:.5rem;padding:.2rem .1rem}.mob-kbd-shift-btn{font:inherit;font-size:.95rem;padding:.55rem .95rem;border:1px solid var(--rule);border-radius:6px;background:var(--paper);color:var(--ink);cursor:pointer;min-width:4.5rem;-webkit-tap-highlight-color:transparent}.mob-kbd-shift-btn:disabled{opacity:.4}.mob-kbd-shift-label{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.85rem;color:var(--ink-soft);text-align:center;flex:1}.mob-kbd-row{display:grid;grid-template-columns:repeat(8,1fr);gap:.4rem}.mob-kbd-key{font:inherit;display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:4.5rem;padding:.4rem .1rem;background:var(--paper);border:1px solid var(--rule);border-radius:8px;box-shadow:var(--shadow);cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation;transition:transform 80ms,background .12s}.mob-kbd-key:active{background:var(--accent);color:var(--paper);transform:translateY(1px)}.mob-kbd-key.is-tonic{border-color:var(--tonic);border-width:2px}.mob-kbd-key.is-octave-tonic{border-color:var(--accent-soft);background:#d8b89c2e}.mob-kbd-key.is-lit{background:var(--highlight);border-color:#d4a72b}.mob-kbd-key.has-tint{background:var(--jins-tint-bg),var(--paper);border-color:var(--jins-tint-border)}.mob-kbd-key-degree{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:1.4rem;font-weight:600;color:inherit}.mob-kbd-key.is-tonic .mob-kbd-key-degree{color:var(--tonic)}.mob-kbd-key:active .mob-kbd-key-degree{color:inherit}.mob-kbd-key-note{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.7rem;color:var(--ink-soft);margin-top:.15rem}.mob-kbd-key:active .mob-kbd-key-note{color:inherit}.mob-kbd-hint{margin:.5rem 0 0;font-size:.78rem;color:var(--ink-soft);text-align:center}.mobile-maqam-pick{margin:.4rem .6rem}.mobile-maqam-pick select{width:100%;padding:.6rem .7rem;font:inherit;font-size:1rem;border:1px solid var(--rule);border-radius:6px;background:var(--paper);color:var(--ink);-webkit-appearance:menulist}.is-hidden-mobile{display:none}@media (min-width: 721px){.mobile-maqam-pick{display:none}.is-hidden-mobile{display:flex}}@media (max-width: 720px){.topbar{flex-wrap:wrap;padding:.7rem .9rem;gap:.5rem}.topbar-controls{gap:.5rem;flex-wrap:wrap}.brand-en{font-size:1.2rem}.sidebar{border-right:0;border-bottom:1px solid var(--rule);padding:.6rem 0;max-height:none}.sidebar-title{margin:0 .6rem .2rem;font-size:.7rem}.main{padding:1rem .9rem}.maqam-name{font-size:1.5rem}.snippet-row{gap:.4rem}.snippet-tempo{margin-left:0}.score-view svg{width:auto}.recorder-controls{gap:.6rem}.recorder-item-label{flex-wrap:wrap}}.tuner{margin-top:1.4rem;padding:.9rem 1.1rem;background:var(--paper);border:1px solid var(--rule);border-radius:8px;box-shadow:var(--shadow)}.tuner-header{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap;margin-bottom:.8rem}.tuner-title{margin:0;font-size:1rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);font-weight:600}.tuner-mode{display:flex;gap:4px;background:var(--bg);padding:3px;border-radius:6px;border:1px solid var(--rule)}.tuner-mode-btn{border:0;background:transparent;color:var(--ink-soft);padding:4px 12px;font-size:.85rem;border-radius:4px;cursor:pointer;font-family:inherit}.tuner-mode-btn.is-active{background:var(--accent);color:var(--paper);font-weight:600}.tuner-error{background:#c0392b14;border:1px solid rgba(192,57,43,.4);color:#c0392b;padding:.4rem .6rem;border-radius:4px;font-size:.85rem;margin:0 0 .6rem}.tuner-display{display:flex;justify-content:space-between;align-items:baseline;padding:.6rem .8rem;background:var(--bg);border-radius:6px;margin-bottom:.6rem;border:2px solid transparent;transition:border-color .12s ease}.tuner-display.is-perfect{border-color:#2f8a4a}.tuner-display.is-close{border-color:#c97a2a}.tuner-display.is-off{border-color:#c0392b}.tuner-target{display:flex;flex-direction:column;gap:2px}.tuner-target-name{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:2rem;font-weight:700;color:var(--ink);line-height:1}.tuner-target-meta{font-size:.8rem;color:var(--ink-soft);font-family:ui-monospace,SF Mono,Menlo,monospace}.tuner-cents{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:1.6rem;font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums}.tuner-display.is-perfect .tuner-cents{color:#2f8a4a}.tuner-display.is-close .tuner-cents{color:#c97a2a}.tuner-display.is-off .tuner-cents{color:#c0392b}.tuner-bar{position:relative;height:50px;background:var(--bg);border-radius:4px;overflow:hidden;margin-bottom:.5rem}.tuner-bar-zone{position:absolute;top:0;bottom:18px;opacity:.18}.tuner-bar-zone.is-green{left:45%;width:10%;background:#2f8a4a}.tuner-bar-zone.is-yellow.is-left{left:30%;width:15%;background:#c97a2a}.tuner-bar-zone.is-yellow.is-right{left:55%;width:15%;background:#c97a2a}.tuner-bar-zone.is-red.is-left{left:0;width:30%;background:#c0392b}.tuner-bar-zone.is-red.is-right{left:70%;width:30%;background:#c0392b}.tuner-bar-center{position:absolute;left:50%;top:0;bottom:18px;width:2px;background:var(--ink);transform:translate(-50%);z-index:2}.tuner-needle{position:absolute;top:0;bottom:18px;width:4px;background:var(--accent);border-radius:2px;transform:translate(-50%);transition:left 80ms ease-out,background .12s ease;box-shadow:0 0 6px #0000004d;z-index:3}.tuner-needle.is-perfect{background:#2f8a4a}.tuner-needle.is-close{background:#c97a2a}.tuner-needle.is-off{background:#c0392b}.tuner-bar-labels{position:absolute;left:0;right:0;bottom:2px;display:flex;justify-content:space-between;padding:0 4px;font-size:.7rem;color:var(--ink-soft);font-family:ui-monospace,SF Mono,Menlo,monospace;pointer-events:none}.tuner-hint{margin:0;font-size:.8rem;color:var(--ink-soft);font-style:italic}.tuner-diagram-toggle.is-active,.tuner-debug-toggle.is-active{background:var(--accent);color:var(--paper);border-color:var(--accent)}.tuner-debug{margin-top:.8rem;padding:.6rem .8rem;background:#1f1f1f;color:#e0e0e0;border-radius:6px;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.78rem;display:grid;grid-template-columns:repeat(2,1fr);column-gap:1.2rem;row-gap:.2rem}.tuner-debug-row{display:flex;justify-content:space-between;align-items:baseline;border-bottom:1px dotted rgba(255,255,255,.1);padding:.1rem 0}.tuner-debug-label{color:#999}.tuner-debug-val{color:#66d9a8;font-variant-numeric:tabular-nums}.tuner-diagram{margin-top:.8rem;padding-top:.8rem;border-top:1px dashed var(--rule)}.tuner-diagram .instrument-diagram{margin-top:0;padding:0;background:transparent;border:0;box-shadow:none}
