*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:#0d0d1a;color:#e0e0e0;min-height:100vh;min-height:100dvh;display:flex;justify-content:center;padding:4px 8px;-webkit-text-size-adjust:100%;overscroll-behavior-y:contain}#app{max-width:760px;width:100%;overflow-x:hidden}header{margin-bottom:4px}#header-content{display:flex;align-items:center;gap:6px}#shared-maqam-controls{display:flex;align-items:center;gap:4px;margin-left:auto}#shared-maqam-controls select{width:auto;padding:3px 6px;font-size:.75rem}#oud-image{width:28px;height:28px;object-fit:contain;filter:drop-shadow(0 0 8px rgba(0,255,136,.3))}#oud-image:hover{filter:drop-shadow(0 0 14px rgba(0,255,136,.6))}header h1{font-size:1.1rem;color:#0f8;letter-spacing:1px;white-space:nowrap}.title-ar{font-family:Amiri,Traditional Arabic,serif;font-size:1rem;opacity:.85;margin-left:2px}.subtitle{display:none}#mode-tabs{display:flex;gap:2px;margin-bottom:4px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}#mode-tabs::-webkit-scrollbar{display:none}.tab{flex:1;padding:8px 4px;background:#16162a;border:1px solid #222;border-radius:6px 6px 0 0;color:#888;font-size:.72rem;font-weight:600;cursor:pointer;transition:background .2s,color .2s,border-color .2s;text-align:center;white-space:nowrap;min-height:36px}.tab.active{background:#1a1a2e;color:#0f8;border-color:#0f8;border-bottom-color:#1a1a2e}.mode-panel{display:none;background:#16162a;border-radius:0 0 8px 8px;padding:6px 8px;margin-bottom:3px}.mode-panel.active{display:block}#scale-keyboard{display:flex;gap:2px;margin-bottom:4px;justify-content:center}.scale-key{width:34px;height:28px;border-radius:4px;background:#224;border:1px solid #333;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:.6rem;color:#888;transition:background .15s,border-color .15s,color .15s}.scale-key .key-note{font-weight:600;font-size:.7rem;line-height:1}.scale-key .key-degree{font-size:.55rem;opacity:.6;line-height:1}.scale-key.active{background:#032;border-color:#0f8;color:#0f8}#pitch-section{background:#1a1a2e;border-radius:8px;padding:6px 8px;margin-bottom:4px}#shared-maqam-controls{margin-bottom:4px;padding-bottom:4px;border-bottom:1px solid #2a2a4a}#shared-maqam-controls .control-group{min-width:80px}.maqam-label{font-size:.75rem;font-weight:700;color:#0f8;white-space:nowrap}#pitch-info{display:flex;gap:10px;align-items:baseline;margin-bottom:4px;flex-wrap:wrap}#note-name{font-size:1.4rem;font-weight:700;color:#0f8;min-width:50px;transition:color .2s}#note-name.silent{color:#444}#degree-label{font-size:.85rem;color:#aaa}#freq-display{font-size:.75rem;color:#666;font-family:monospace}#transpose-display{font-size:.75rem;color:orange;font-family:monospace;margin-left:auto}#maqam-scale-canvas{width:100%;max-width:100%;height:80px;border-radius:6px;display:block;background:#0f0f22;margin-bottom:4px}#pitch-canvas{width:100%;max-width:100%;height:80px;border-radius:6px;display:block}.control-row{display:flex;gap:8px;margin-bottom:6px;flex-wrap:wrap;align-items:center}.control-row:last-child{margin-bottom:0}.control-group{flex:1;min-width:100px}.control-group label{display:block;font-size:.7rem;color:#999;margin-bottom:2px}select,input[type=range]{width:100%;max-width:100%}select{background:#224;color:#e0e0e0;border:1px solid #333;border-radius:4px;padding:6px 8px;font-size:.8rem;cursor:pointer;min-height:34px}select:focus{border-color:#0f8;outline:none}input[type=range]{-webkit-appearance:none;appearance:none;height:6px;background:#333;border-radius:3px;outline:none;padding:0}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:22px;height:22px;background:#0f8;border-radius:50%;cursor:pointer;border:2px solid #0d0d1a}input[type=range]::-moz-range-thumb{width:22px;height:22px;background:#0f8;border-radius:50%;cursor:pointer;border:2px solid #0d0d1a}button{padding:8px 16px;border:none;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;transition:opacity .2s,transform .1s;min-height:36px}button:active:not(:disabled){transform:scale(.97)}button:disabled{opacity:.4;cursor:not-allowed}#start-btn,#karaoke-play{background:#0f8;color:#0d0d1a}#stop-btn,#karaoke-stop{background:#f44;color:#fff}#karaoke-pause{background:orange;color:#0d0d1a}.file-row{gap:8px}.file-group{flex:1;min-width:180px}.file-group label{display:block;font-size:.7rem;color:#999;margin-bottom:2px}.file-group input[type=file]{width:100%;font-size:.75rem;color:#ccc;padding:3px 0}.file-group input[type=file]::file-selector-button{background:#224;color:#e0e0e0;border:1px solid #444;border-radius:4px;padding:6px 10px;font-size:.7rem;cursor:pointer;margin-right:6px;min-height:32px}.file-name{display:block;font-size:.65rem;color:#666;margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.time-display{font-family:monospace;font-size:.8rem;color:#aaa;margin-left:auto}.toggle-label{display:flex;align-items:center;gap:6px;font-size:.75rem;color:#aaa;cursor:pointer;min-height:36px}.toggle-label input[type=checkbox]{width:20px;height:20px;accent-color:#00ff88;cursor:pointer}#lyrics-container{max-height:200px;overflow-y:auto;margin:6px 0;padding:10px 12px;background:#0a0a1a;border-radius:8px;border:1px solid #1a1a2e;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}#lyrics-container:empty{display:none}.lyric-line{padding:5px 8px;font-size:.95rem;color:#444;border-radius:4px;transition:color .3s,background .3s,font-size .3s,opacity .3s;line-height:1.5;margin-bottom:2px}.lyric-line.past{color:#666;opacity:.7}.lyric-line.active{color:#fff;background:#00ff8814;font-size:1.05rem;font-weight:600;padding:6px 10px}.lyric-line.upcoming{color:#888;opacity:.9}.lyric-word{transition:color .15s ease}.lyric-line.active .lyric-word{color:#556}.lyric-line.active .lyric-word.sung{color:#0f8;text-shadow:0 0 8px rgba(0,255,136,.4)}.lyric-line.past .lyric-word{color:#666}.lyric-line.past .lyric-word.sung{color:#666;text-shadow:none}#pdf-container{margin:6px 0;text-align:center;min-height:0}#pdf-container:empty{display:none}.pdf-canvas{max-width:100%;border-radius:6px;background:#fff;cursor:pointer}.pdf-page-label{font-size:.65rem;color:#666;margin-top:4px}.karaoke-hero{text-align:center;padding:8px 4px 6px}.hero-text{font-size:.8rem;color:#0f8;font-weight:600;letter-spacing:.5px}.hero-ar{font-family:Amiri,Traditional Arabic,serif;font-size:.85rem;color:#00cc6a;opacity:.8;margin-top:2px}.karaoke-search-bar{margin-bottom:6px}.karaoke-search-bar input[type=text]{font-size:16px;padding:10px 12px;min-height:44px}.karaoke-search-bar button{min-height:44px;padding:10px 18px;font-size:.85rem}.search-bar{display:flex;gap:4px}.search-bar input[type=text]{flex:1;background:#224;color:#e0e0e0;border:1px solid #333;border-radius:4px;padding:8px 10px;font-size:16px;min-height:40px}.search-bar input[type=text]:focus{border-color:#0f8;outline:none}.search-bar button{padding:8px 14px;font-size:.8rem;background:#0f8;color:#0d0d1a;min-height:40px}#search-results,#stored-songs-list{max-height:40vh;overflow-y:auto;margin-bottom:6px;-webkit-overflow-scrolling:touch}#search-results:empty,#stored-songs-list:empty{display:none}.search-result-item,.stored-song-item{display:flex;align-items:center;gap:8px;padding:8px;border-radius:6px;cursor:pointer;transition:background .15s;font-size:.78rem;color:#ccc;border-bottom:1px solid #1a1a2e;min-height:48px}.search-result-item:hover,.stored-song-item:hover{background:#1a1a3a}.search-result-item:active,.stored-song-item:active{background:#224}.search-result-item .result-name,.stored-song-item .stored-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-result-item .result-artist,.stored-song-item .stored-artist{font-size:.7rem;color:#777;white-space:nowrap}.search-result-item .result-source{font-size:.6rem;color:#555;text-transform:uppercase;background:#222;padding:1px 4px;border-radius:3px}.search-result-item .result-badges{display:flex;gap:2px}.badge{font-size:.55rem;padding:2px 5px;border-radius:3px;text-transform:uppercase;font-weight:600}.badge-midi{background:#032;color:#0f8}.badge-audio{background:#220;color:#fa0}.badge-lyrics{background:#202;color:#f8f}.result-artwork{width:44px;height:44px;border-radius:6px;object-fit:cover;flex-shrink:0}.stored-song-item .result-artwork{width:36px;height:36px}.result-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.result-info .result-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.result-info .result-artist{font-size:.65rem;color:#777}.result-download-btn,.result-play-btn,.result-save-btn{padding:6px 10px;font-size:.75rem;border-radius:6px;border:none;cursor:pointer;font-weight:600;flex-shrink:0;min-height:32px;min-width:32px}.result-download-btn{background:#0f8;color:#0d0d1a}.result-play-btn{background:#0af;color:#fff;font-size:.9rem;padding:6px 12px;border-radius:50%;min-width:36px;min-height:36px}.result-save-btn{background:transparent;color:#0f8;border:1px solid #00ff88;font-size:.85rem;padding:4px 8px;border-radius:4px}.result-save-btn:disabled{border-color:#555;color:#555}.accomp-label{font-size:.72rem;color:#888;margin-bottom:4px;display:block}.inst-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:6px}.inst-card{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 4px;background:#12122a;border:1px solid #2a2a44;border-radius:8px;cursor:pointer;transition:all .2s ease;min-height:64px}.inst-card:hover{background:#1a1a3a;border-color:#444}.inst-card:active{transform:scale(.95)}.inst-card.active{background:#0a1f0a;border-color:#0f8;box-shadow:0 0 8px #00ff8826}.inst-icon{width:36px;height:36px;opacity:.7;transition:opacity .2s,filter .2s}.inst-card:hover .inst-icon{opacity:.9}.inst-card.active .inst-icon{opacity:1;filter:drop-shadow(0 0 4px rgba(0,255,136,.3))}.inst-name{font-size:.6rem;font-weight:600;color:#777;line-height:1}.inst-name-ar{font-size:.55rem;color:#555;font-family:Amiri,serif;line-height:1}.inst-card.active .inst-name{color:#0f8}.inst-card.active .inst-name-ar{color:#00cc6a}#accomp-controls{gap:8px;padding:2px 0}.stored-song-item .stored-delete{color:#f44;cursor:pointer;font-size:1rem;padding:4px 6px;opacity:.5;transition:opacity .15s;min-width:32px;min-height:32px;display:flex;align-items:center;justify-content:center}.stored-song-item .stored-delete:hover,.stored-song-item .stored-delete:active{opacity:1}.search-loading{text-align:center;padding:12px;color:#888;font-size:.78rem}.section-label{font-size:.7rem;color:#666;padding:4px 0 2px;border-bottom:1px solid #222;margin-bottom:2px}#audio-source-panel,#midi-source-panel{margin-bottom:4px}.info-text{font-size:.7rem;color:#888;padding:2px 0}.info-text:empty{display:none}#song-library{background:#112;border-radius:6px;padding:8px;margin-bottom:6px}#song-library:empty{display:none}.library-header{display:flex;align-items:center;gap:6px;margin-bottom:4px}.library-header h3{font-size:.8rem;color:#aaa;margin:0;flex:1}#library-search{background:#224;color:#e0e0e0;border:1px solid #333;border-radius:4px;padding:6px 8px;font-size:16px;width:150px;min-height:34px}#library-search:focus{border-color:#0f8;outline:none}.song-list{max-height:150px;overflow-y:auto;-webkit-overflow-scrolling:touch}.song-item{display:flex;align-items:center;gap:6px;padding:8px 6px;border-radius:4px;cursor:pointer;transition:background .15s;font-size:.78rem;color:#ccc;min-height:40px}.song-item:hover{background:#1a1a3a}.song-item:active{background:#224}.song-item.active{background:#032;color:#0f8}.song-item .song-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-item .song-type{font-size:.65rem;color:#666;text-transform:uppercase}.song-item .song-remove{color:#f44;cursor:pointer;font-size:1rem;padding:4px 6px;opacity:.5;transition:opacity .15s;min-width:32px;min-height:32px;display:flex;align-items:center;justify-content:center}.song-item .song-remove:hover,.song-item .song-remove:active{opacity:1}#error-banner{display:none;background:#411;border:1px solid #ff4444;border-radius:6px;padding:8px 12px;margin-bottom:6px;font-size:.78rem;color:#f88}#error-banner.visible{display:block}#bottom-bar{display:flex;align-items:center;gap:8px;background:#16162a;border-radius:6px;padding:4px 8px;margin-top:4px;flex-wrap:wrap}#recording-controls{display:flex;align-items:center;gap:4px;white-space:nowrap}.rec-btn{padding:6px 12px;font-size:.75rem;border-radius:4px;cursor:pointer;border:1px solid #444;background:#1a1a2e;color:#ccc;min-height:34px}.rec-btn:disabled{opacity:.4;cursor:not-allowed}#rec-start{border-color:#c33;color:#f44}#rec-start:hover:not(:disabled){background:#2a1a1a}#rec-stop{border-color:#666}.rec-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#444;vertical-align:middle}.rec-dot.recording{background:#f44;animation:rec-pulse 1s infinite}@keyframes rec-pulse{0%,to{opacity:1}50%{opacity:.3}}.rec-timer{font-family:monospace;color:#888;font-size:.75rem}.rec-list{max-height:120px;overflow-y:auto;margin-top:4px}.rec-empty{color:#555;font-size:.7rem;text-align:center;padding:4px}.rec-item{display:flex;justify-content:space-between;align-items:center;padding:6px;border-bottom:1px solid #1a1a2e;font-size:.75rem;min-height:40px}.rec-item:hover{background:#1a1a3a}.rec-item-info{display:flex;flex-direction:column;gap:1px}.rec-item-name{color:#ccc}.rec-item-meta{color:#666;font-size:.65rem}.rec-item-actions{display:flex;gap:4px}.rec-play-btn,.rec-delete-btn{background:none;border:1px solid #444;color:#aaa;border-radius:4px;padding:4px 8px;cursor:pointer;font-size:.7rem;min-height:30px}.rec-play-btn:hover,.rec-play-btn:active{border-color:#0f8;color:#0f8}.rec-delete-btn:hover,.rec-delete-btn:active{border-color:#f44;color:#f44}#transcription-canvas{width:100%;border-radius:6px;margin-top:4px;background:#0d0d1a}#status{display:flex;gap:8px;font-size:.65rem;font-family:monospace;color:#555;margin-left:auto;flex-wrap:wrap}#mic-status{color:#f44}@media (max-width: 600px){html,body{overflow-x:hidden}body{padding:2px 3px}#app{max-width:100%}header{margin-bottom:2px}#header-content{gap:4px}header h1{font-size:.85rem}.title-ar{font-size:.75rem}#oud-image{width:22px;height:22px}#shared-maqam-controls{gap:3px;margin-bottom:2px;padding-bottom:2px}#shared-maqam-controls select{padding:3px 4px;font-size:.65rem;min-height:28px}#maqam-label{font-size:.65rem}.lang-toggle{padding:4px 8px;font-size:.68rem;min-height:28px}.tab{padding:7px 2px;font-size:.6rem;min-height:36px}.mode-panel{padding:4px 6px;margin-bottom:2px}.control-group{min-width:0;flex:1}.file-group{min-width:100%}.control-row{gap:5px;margin-bottom:4px}.karaoke-hero{padding:4px 2px 3px}.hero-text{font-size:.72rem}.hero-ar{font-size:.75rem;margin-top:1px}.karaoke-search-bar input[type=text]{font-size:16px;padding:8px 10px;min-height:42px}.karaoke-search-bar button{min-height:42px;padding:8px 14px;font-size:.8rem}#karaoke-play,#karaoke-pause,#karaoke-stop{flex:1;min-height:40px;font-size:.82rem;padding:6px 8px}input[type=range]::-webkit-slider-thumb{width:26px;height:26px}input[type=range]::-moz-range-thumb{width:26px;height:26px}input[type=range]{height:8px}.inst-grid{grid-template-columns:repeat(4,1fr);gap:4px}.inst-card{padding:5px 2px 4px;min-height:60px;border-radius:6px}.inst-icon{width:32px;height:32px}.inst-name{font-size:.52rem}.inst-name-ar{font-size:.48rem}.accomp-label{font-size:.65rem;margin-bottom:2px}#lyrics-container{max-height:150px;padding:8px;margin:4px 0}.lyric-line{font-size:.82rem;padding:3px 5px}.lyric-line.active{font-size:.92rem;padding:4px 6px}#pitch-section{padding:4px 6px}#pitch-info{gap:6px;margin-bottom:2px}#note-name{font-size:1.1rem;min-width:36px}#degree-label{font-size:.75rem}#freq-display,#transpose-display{font-size:.65rem}#scale-keyboard{gap:1px;margin-bottom:2px}.scale-key{flex:1;min-width:0;height:24px;font-size:.5rem}.scale-key .key-note{font-size:.55rem}.scale-key .key-degree{font-size:.45rem}#maqam-scale-canvas{height:65px;margin-bottom:2px}#pitch-canvas{height:60px}#practice-notation{height:70px}.maqam-pill{padding:5px 7px;font-size:.6rem;min-height:28px}.root-pill{padding:4px 7px;font-size:.58rem;min-height:26px}.style-select{font-size:.7rem;min-height:34px}.taq-row{margin-bottom:3px}.taq-ctrl-row{gap:4px}.taq-mini-select{font-size:.68rem;min-height:30px}.taq-vol-slider{min-width:50px;max-width:100px}.taqasim-badge{font-size:.68rem}.search-result-item,.stored-song-item{padding:6px;gap:6px;min-height:44px}.result-artwork{width:38px;height:38px}.practice-score-box{padding:5px 6px;min-width:50px}.practice-score-value{font-size:1.05rem}.practice-score-detail{font-size:.8rem}#bottom-bar{flex-wrap:wrap;gap:4px;padding:4px 6px;margin-top:2px}#status{gap:4px;font-size:.58rem}#instrument-visual{max-width:260px}#instrument-visual-section{margin:2px 0;max-height:140px}}@media (max-width: 400px){body{padding:1px 2px}header h1{font-size:.75rem}.title-ar{font-size:.65rem}#shared-maqam-controls{gap:2px}#shared-maqam-controls select{font-size:.58rem;padding:2px 3px;min-height:26px}#maqam-label{font-size:.58rem}.tab{font-size:.55rem;padding:6px 1px;min-height:34px}.maqam-pill .pill-ar{display:none}.maqam-pill{padding:4px 5px;font-size:.55rem;min-height:26px}.root-pill{padding:3px 5px;font-size:.52rem;min-height:24px}.taq-root-row{gap:2px}.time-display{width:100%;text-align:center;margin-left:0;font-size:.72rem}#maqam-scale-canvas{height:55px}#pitch-canvas{height:50px}.scale-key{height:22px}.inst-grid{gap:3px}.inst-card{padding:4px 1px 3px;min-height:54px;border-radius:5px}.inst-icon{width:28px;height:28px}.inst-name{font-size:.48rem}.inst-name-ar{display:none}#instrument-visual{max-width:220px}#instrument-visual-section{max-height:120px}.hero-text{font-size:.65rem}.hero-ar{font-size:.68rem}}@media (max-width: 340px){header h1{font-size:.65rem}.title-ar,#shared-maqam-controls{display:none}.tab{font-size:.5rem;min-height:32px}.inst-icon{width:24px;height:24px}.inst-card{min-height:48px}}@supports (padding: env(safe-area-inset-top)){body{padding-top:calc(4px + env(safe-area-inset-top));padding-bottom:calc(4px + env(safe-area-inset-bottom));padding-left:calc(4px + env(safe-area-inset-left));padding-right:calc(4px + env(safe-area-inset-right))}}button,.tab,select,input[type=file]::file-selector-button,.maqam-pill,.root-pill,.inst-card{-webkit-tap-highlight-color:transparent;touch-action:manipulation;user-select:none;-webkit-user-select:none}input[type=range]{touch-action:none}#app{overscroll-behavior:contain}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}#speed-display{font-size:.7rem;color:#aaa;font-family:monospace}.taq-row{display:flex;align-items:center;gap:3px;margin-bottom:4px}.taq-row:last-child{margin-bottom:0}.taq-maqam-row{flex-wrap:wrap;gap:4px}.maqam-pill{padding:5px 10px;font-size:.68rem;font-weight:600;background:#1a1a2e;border:1px solid #2a2a44;border-radius:20px;color:#999;cursor:pointer;transition:all .2s ease;white-space:nowrap;min-height:28px}.maqam-pill .pill-ar{font-size:.58rem;opacity:.5;font-family:Amiri,serif;margin-left:2px}.maqam-pill:hover{background:#224;border-color:#444;color:#ccc}.maqam-pill:active{transform:scale(.95)}.maqam-pill.active{background:#002a44;border-color:#0af;color:#0cf}.maqam-pill.active .pill-ar{opacity:.8}.taq-root-row{flex-wrap:wrap;gap:3px}.root-pill{padding:4px 8px;font-size:.65rem;font-weight:600;background:transparent;border:1px solid #2a2a44;border-radius:12px;color:#777;cursor:pointer;transition:all .2s ease;min-height:26px}.root-pill:hover{border-color:#555;color:#aaa}.root-pill:active{transform:scale(.95)}.root-pill.active{background:#002a44;border-color:#0af;color:#0cf}.style-select{flex:1;background:#111125;color:#e0e0e0;border:1px solid #2a2a44;border-radius:6px;padding:6px 10px;font-size:.78rem;cursor:pointer;transition:border-color .2s;min-width:0;min-height:36px}.style-select:focus{border-color:#0f8;outline:none}.style-select optgroup{color:#0f8;font-size:.7rem;font-weight:700;font-style:normal}.style-select option{color:#e0e0e0;background:#16162a;padding:4px 8px;font-size:.78rem}.taq-main-row{gap:4px;flex-wrap:wrap}#taqasim-start{background:#00cc6a;color:#fff;font-weight:600;padding:8px 16px;border-radius:6px;white-space:nowrap;min-height:38px}#taqasim-start:hover{background:#0f8;color:#0d0d1a}.taq-ctrl-row{gap:6px;flex-wrap:wrap}.taq-mini-select{background:#111125;color:#e0e0e0;border:1px solid #2a2a44;border-radius:4px;padding:5px 8px;font-size:.72rem;cursor:pointer;width:auto;min-height:32px}.taq-mini-select:focus{border-color:#0f8;outline:none}.taq-octave{display:flex;align-items:center;gap:2px}.taq-tiny-btn{padding:4px 8px;font-size:.65rem;background:#1a1a2e;color:#999;border:1px solid #2a2a44;border-radius:4px;cursor:pointer;line-height:1;min-width:28px;min-height:28px;display:flex;align-items:center;justify-content:center}.taq-tiny-btn:hover{border-color:#0f8;color:#0f8}.taq-tiny-btn:active{background:#0f8;color:#0d0d1a;transform:scale(.93)}.taq-oct-val{font-size:.7rem;color:#aaa;font-family:monospace;min-width:12px;text-align:center}.taq-vol-slider{flex:1;min-width:60px;max-width:120px}.taq-vol-label{font-size:.65rem;color:#666;font-family:monospace;white-space:nowrap}.taqasim-badge{font-size:.78rem;font-weight:700;color:#0f8;margin-left:auto;white-space:nowrap}#instrument-visual-section{margin:4px 0;overflow:hidden;transition:max-height .4s ease,opacity .3s ease;max-height:180px;opacity:1}#instrument-visual-section.hidden{max-height:0;opacity:0;margin:0}#instrument-visual{max-width:340px;margin:0 auto;position:relative}.instrument-svg{width:100%;height:auto;display:block;transition:opacity .3s ease,transform .3s ease}.instrument-svg.switching-out{opacity:0;transform:scale(.95)}#instrument-visual:not(.instrument-playing) .instrument-svg{animation:instrument-breathe 4s ease-in-out infinite}#instrument-visual.instrument-playing .instrument-svg{animation:none;filter:drop-shadow(0 0 8px rgba(0,255,136,.3))}@keyframes instrument-breathe{0%{filter:drop-shadow(0 0 2px rgba(0,255,136,.05))}50%{filter:drop-shadow(0 0 6px rgba(0,255,136,.15))}to{filter:drop-shadow(0 0 2px rgba(0,255,136,.05))}}.inst-string{transition:stroke .1s,filter .1s}.inst-string.vibrating{animation:string-vibrate .4s ease-out}@keyframes string-vibrate{0%{transform:translateY(0)}10%{transform:translateY(-2px)}20%{transform:translateY(2px)}30%{transform:translateY(-1.5px)}40%{transform:translateY(1.5px)}50%{transform:translateY(-1px)}60%{transform:translateY(1px)}70%{transform:translateY(-.5px)}80%{transform:translateY(.5px)}to{transform:translateY(0)}}.piano-white.vibrating{animation:key-press .3s ease-out;fill:#0f8!important}.piano-black.vibrating{animation:key-press .3s ease-out;fill:#00cc6a!important}@keyframes key-press{0%{transform:translateY(0)}30%{transform:translateY(2px)}to{transform:translateY(0)}}.violin-bow{transition:opacity .2s}.instrument-playing .violin-bow{animation:bow-move 2s ease-in-out infinite}@keyframes bow-move{0%{transform:translateY(0) rotate(0)}50%{transform:translateY(5px) rotate(1deg)}to{transform:translateY(0) rotate(0)}}#taqasim-stop{background:#c33;color:#fff;min-height:38px}#taqasim-stop:hover:not(:disabled){background:#f44}#practice-notation{width:100%;height:100px;border-radius:6px;display:block;background:#0f0f22;margin-bottom:6px}.practice-score-row{justify-content:center;gap:6px;margin-bottom:6px}.practice-score-box{display:flex;flex-direction:column;align-items:center;background:#112;border-radius:6px;padding:6px 10px;min-width:60px}.practice-score-label{font-size:.6rem;color:#666;text-transform:uppercase;margin-bottom:2px}.practice-score-value{font-size:1.3rem;font-weight:700;color:#0f8;font-family:monospace}.practice-score-detail{font-size:.9rem;font-weight:600;color:#aaa;font-family:monospace}.practice-status-inline{font-size:.72rem;color:#888;margin-left:auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}#practice-load-pattern{background:#224;color:#e0e0e0;border:1px solid #444}#practice-load-pattern:hover:not(:disabled){border-color:#0f8;color:#0f8}#practice-start{background:#00cc6a;color:#fff;font-weight:600}#practice-start:hover:not(:disabled){background:#0f8;color:#0d0d1a}#practice-stop{background:#c33;color:#fff}#practice-stop:hover:not(:disabled){background:#f44}.editor-btn{padding:6px 12px;font-size:.75rem;border-radius:4px;cursor:pointer;border:1px solid #444;background:#1a1a2e;color:#ccc;min-height:34px}.editor-btn:hover:not(:disabled){border-color:#0f8;color:#0f8}.editor-btn:disabled{opacity:.4;cursor:not-allowed}.editor-select{padding:4px 8px;font-size:.75rem;border-radius:4px;border:1px solid #444;background:#224;color:#e0e0e0;min-height:34px}.editor-info{font-size:.7rem;color:#888;font-family:monospace;margin-left:auto}.taqasim-editor-controls{display:flex;gap:6px;align-items:center;margin-top:4px;flex-wrap:wrap}.ensemble-controls{margin-top:4px}.ensemble-controls .control-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap;margin-bottom:4px}.ensemble-parts-list{margin-top:4px}.ensemble-part-item{display:flex;align-items:center;gap:6px;padding:6px;border-radius:4px;font-size:.78rem;min-height:36px}.ensemble-part-item.selected{background:#1a1a3a}.ensemble-part-item .part-name{font-weight:600;min-width:50px}.ensemble-part-item .part-notes{color:#666;font-size:.65rem;margin-left:auto}.part-mute,.part-solo,.part-delete{background:none;border:1px solid #333;color:#666;border-radius:3px;padding:4px 8px;font-size:.65rem;cursor:pointer;min-width:28px;min-height:28px}.part-mute.active{border-color:#f44;color:#f44}.part-solo.active{border-color:#fa0;color:#fa0}.part-delete:hover{border-color:#f44;color:#f44}.lang-toggle{padding:6px 10px;font-size:.75rem;border-radius:4px;cursor:pointer;border:1px solid #333;background:#16162a;color:#0f8;font-weight:600;white-space:nowrap;margin-left:auto;min-height:32px}.lang-toggle:hover{border-color:#0f8;background:#1a2a1a}[dir=rtl] body{font-family:Noto Naskh Arabic,Amiri,Traditional Arabic,Segoe UI,system-ui,sans-serif}[dir=rtl] .lang-toggle{margin-left:0;margin-right:auto}[dir=rtl] #header-content,[dir=rtl] #pitch-info{direction:rtl}[dir=rtl] .control-group label{text-align:right}[dir=rtl] .control-row{direction:rtl}[dir=rtl] .time-display,[dir=rtl] #transpose-display{margin-left:0;margin-right:auto}[dir=rtl] .search-bar{direction:rtl}[dir=rtl] .file-group input[type=file]::file-selector-button{margin-right:0;margin-left:6px}[dir=rtl] .taqasim-editor-controls{direction:rtl}[dir=rtl] .editor-info,[dir=rtl] .ensemble-part-item .part-notes{margin-left:0;margin-right:auto}
