: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-vis{display:flex;gap:.25rem;margin-top:.5rem}.beat-vis-cell{flex:1;min-height:32px;display:flex;align-items:center;justify-content:center;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.85rem;color:var(--ink-soft);background:var(--bg);border:1px solid var(--rule);border-radius:4px;font-weight:600;transition:background 80ms}.beat-vis-cell.is-downbeat{border-left:2px solid var(--accent-soft)}.beat-vis-cell.is-d{background:#8a4b2b1f;color:var(--accent)}.beat-vis-cell.is-t{background:#d8b89c40;color:var(--ink)}.beat-vis-cell.is-active{background:var(--accent);color:var(--paper);border-color:var(--accent)}.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-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)}.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)}.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}}
