*{box-sizing:border-box}html{color-scheme:light}:root{--color-page: #f9f9f9;--color-surface: #ffffff;--color-surface-muted: #f3f4f6;--color-border: #e8e8ec;--color-text: #1f2937;--color-text-secondary: #6b7280;--color-primary: #1b4332;--color-primary-hover: #2d6a4f;--color-primary-pressed: #14362a;--color-primary-muted: rgba(27, 67, 50, .1);--color-danger: #dc2626;--color-danger-muted: #fef2f2;--text-primary: #1f2937;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 8px 24px rgba(0, 0, 0, .08);--shadow-nav: 0 1px 0 rgba(0, 0, 0, .06);--radius-card: 12px;--radius-control: 8px;--radius-pill: 8px}body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--color-page);color:var(--color-text)}#root{min-height:100vh}.app-nav{position:sticky;top:0;z-index:200;background:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-nav)}.app-nav-inner{max-width:90rem;margin:0 auto;padding:.65rem 1.25rem;display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1.25rem}.app-nav-brand{flex-shrink:0;padding-top:.15rem}.app-nav-logo{font-size:1rem;font-weight:700;letter-spacing:-.02em;color:var(--color-primary);text-decoration:none;padding:.4rem .55rem;border-radius:var(--radius-pill);transition:background .15s ease,color .15s ease}.app-nav-logo:hover{background:var(--color-primary-muted);color:var(--color-primary-hover)}.app-nav-logo--active{background:var(--color-primary-muted);color:var(--color-primary)}.app-nav-menus{flex:1;min-width:0;display:flex;flex-wrap:wrap;align-items:stretch;justify-content:flex-end;gap:0}.app-nav-dropdown{position:relative;border-right:1px solid var(--color-border);padding:0 .15rem}.app-nav-dropdown--last{border-right:none;padding-right:0}.app-nav-dropdown--last .app-nav-dropdown-panel{left:auto;right:0}.app-nav-category{-webkit-appearance:none;-moz-appearance:none;appearance:none;margin:0;padding:.55rem .75rem .55rem .85rem;font:inherit;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--color-text-secondary);background:transparent;border:none;border-radius:var(--radius-pill);cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;white-space:nowrap;transition:color .15s ease,background .15s ease}.app-nav-category:after{content:"";width:.32rem;height:.32rem;margin-top:-.12rem;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg);opacity:.55;flex-shrink:0;transition:transform .16s ease,margin-top .16s ease}.app-nav-dropdown:hover .app-nav-category:after,.app-nav-dropdown:focus-within .app-nav-category:after{transform:rotate(225deg);margin-top:.06rem}.app-nav-category:hover,.app-nav-dropdown:hover .app-nav-category,.app-nav-dropdown:focus-within .app-nav-category{color:var(--color-text);background:var(--color-surface-muted)}.app-nav-category:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.app-nav-category--mixed{text-transform:none;letter-spacing:.04em;font-size:.72rem;font-weight:600}.app-nav-dropdown-panel{position:absolute;top:100%;left:0;min-width:12rem;padding-top:.35rem;z-index:300;opacity:0;visibility:hidden;transform:translateY(.35rem);transition:opacity .16s ease,transform .16s ease,visibility .16s;pointer-events:none}.app-nav-dropdown:hover .app-nav-dropdown-panel,.app-nav-dropdown:focus-within .app-nav-dropdown-panel{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto}.app-nav-dropdown-surface{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);box-shadow:var(--shadow-md);padding:.35rem;display:flex;flex-direction:column;gap:.1rem}.app-nav-dropdown-surface .app-nav-link{display:block;width:100%;text-align:left;box-sizing:border-box}.app-nav-link{display:inline-block;padding:.4rem .7rem;border-radius:var(--radius-pill);font-size:.8125rem;font-weight:500;color:var(--color-text);text-decoration:none;line-height:1.25;border:1px solid transparent;transition:background .15s ease,color .15s ease,border-color .15s ease}.app-nav-link:hover{background:var(--color-surface-muted);color:var(--color-primary)}.app-nav-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.app-nav-link--active{background:var(--color-primary-muted);color:var(--color-primary);border-color:#1b43322e;font-weight:600}.app-nav-link--featured{font-weight:600;background:var(--color-primary);border-color:var(--color-primary);color:#fff}.app-nav-link--featured:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover);color:#fff}.app-nav-link--featured.app-nav-link--active{background:var(--color-primary-pressed);border-color:var(--color-primary-pressed);color:#fff}@media (max-width: 768px){.app-nav-inner{flex-direction:column;align-items:stretch;padding:.65rem 1rem;gap:.75rem}.app-nav-menus{flex-direction:column;justify-content:flex-start;width:100%}.app-nav-dropdown{width:100%;border-right:none;border-bottom:1px solid var(--color-border);padding:0}.app-nav-dropdown--last{border-bottom:none}.app-nav-category{width:100%;justify-content:space-between;padding:.65rem .5rem .65rem .25rem;border-radius:0}.app-nav-category:after{margin-top:0}.app-nav-dropdown-panel{position:static;min-width:0;padding:0 0 .85rem .35rem;opacity:1;visibility:visible;transform:none;pointer-events:auto}.app-nav-dropdown-surface{box-shadow:none;border:none;background:transparent;padding:.15rem 0 0;gap:.2rem}.app-nav-dropdown-surface .app-nav-link{padding-left:.65rem;padding-right:.65rem}}.memorize-nav{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.75rem 1rem;margin-bottom:1rem}.memorize-ayah-label{font-size:.95rem;color:var(--color-text-secondary);min-width:8rem;text-align:center}.app{min-height:100vh;background:var(--color-page);color:var(--color-text)}.header{padding:1.75rem 1.25rem;text-align:center;border-bottom:1px solid var(--color-border);background:var(--color-surface)}.header h1{font-size:1.375rem;font-weight:700;margin:0;letter-spacing:-.02em;color:var(--color-text)}.surah-title{margin:.5rem 0 0;font-size:.9375rem;color:var(--color-text-secondary);font-weight:400}.surah-select{margin-top:.5rem;padding:.5rem .85rem;border-radius:var(--radius-control);background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);font-size:.9rem;cursor:pointer}.main{max-width:42rem;margin:0 auto;padding:1.5rem 1.25rem 2.5rem}.ayah-card{background:var(--color-surface);border-radius:var(--radius-card);padding:1.5rem;border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.recite-layout{display:flex;flex-direction:column;gap:1.25rem}.recite-section{margin:0}.recite-section-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary);margin:0 0 .5rem}.recite-transcription{font-size:1.15rem;line-height:1.7;color:var(--color-text);margin:0;min-height:1.5em}.recite-transcription:empty:before{content:"—";color:var(--color-text-secondary);opacity:.5}.recite-match-message{font-size:.95rem;margin:0}.recite-match-message.match-full{color:var(--color-primary);font-weight:600}.recite-match-message.match-partial{color:#d97706;font-weight:500}.ayah-expected{margin-bottom:0}.main-surah{padding-bottom:4rem}.transcription-sticky{position:sticky;top:0;z-index:1;background:#f9f9f9eb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding-bottom:.5rem;margin-bottom:.5rem;border-bottom:1px solid var(--color-border)}.surah-full{margin:0 0 1.5rem}.surah-full .recite-section-title{margin-bottom:.75rem}.ayah-block{display:flex;flex-wrap:wrap;align-items:baseline;gap:.25rem .35em;padding:.5rem .6rem;margin-bottom:.35rem;border-radius:8px;border-left:3px solid transparent}.ayah-block{border-left-color:var(--color-border);background:var(--color-surface-muted)}.ayah-block.complete{border-left-color:#15803d;background:#15803d0f}.ayah-block.has-error{border-left-color:var(--color-danger);background:var(--color-danger-muted)}.ayah-number{font-size:.85rem;color:var(--color-text-secondary);margin-left:.25rem}.ayah-inline{margin:0;display:inline}.ayah-inline .word,.ayah-inline .word-cell{margin-left:.25em}.ayah-display{font-size:1.75rem;line-height:2.2;text-align:right;margin:0 0 1.5rem;font-weight:500;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.ayah-display .word-cell{display:inline-flex;flex-direction:column;align-items:flex-end;margin-left:.35em;vertical-align:top}.ayah-display:not(.ayah-display--alignment-debug) .word-cell{display:inline;margin-left:.35em}.ayah-display:not(.ayah-display--alignment-debug) .word-cell .word{margin-left:0}.ayah-display .word{display:inline;margin-left:.35em;padding:.15em .25em;border-radius:6px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.ayah-display--alignment-debug .word-cell .word{margin-left:0}.word-alignment-debug{display:block;margin-top:.2em;margin-bottom:.35em;font-size:.38em;line-height:1.35;font-weight:400;color:var(--color-text-secondary);opacity:.85;text-align:right;max-width:14em}.word-alignment-debug .wad-line{display:block}.word-alignment-debug .wad-label{font-family:Segoe UI,system-ui,sans-serif;font-size:.95em;opacity:.85;unicode-bidi:isolate}.word-alignment-debug .wad-ar{font-size:1.05em;color:var(--color-text)}.word-alignment-debug .wad-sub{display:block;margin-top:.08em;opacity:.9}.ayah-display .word.hidden{color:#d1d5db;-webkit-user-select:none;user-select:none;font-size:.85em;letter-spacing:.05em}.ayah-display .word.revealed{color:#10b981;background:#10b98126;font-weight:500;animation:reveal-word .4s ease-out}.ayah-display .word.close{color:#f59e0b;background:#f59e0b2e;font-weight:500;animation:reveal-word .4s ease-out;box-shadow:0 0 0 1px #f59e0b4d}.ayah-display .word.missed{color:#ef4444;background:#ef444426;text-decoration:line-through;text-decoration-color:#ef444499;text-decoration-thickness:2px;opacity:.7;animation:shake-word .4s ease-out}@keyframes reveal-word{0%{opacity:0;transform:scale(.95)}50%{transform:scale(1.05)}to{opacity:1;transform:scale(1)}}@keyframes shake-word{0%,to{transform:translate(0)}25%{transform:translate(-3px)}75%{transform:translate(3px)}}.live-transcript{font-size:1rem;color:var(--color-text-secondary);margin:0 0 1rem;min-height:1.5em}.debug-transcription{font-size:.8rem;color:var(--color-text-secondary);margin:0 0 .75rem;padding:.5rem .65rem;background:var(--color-surface-muted);border:1px solid var(--color-border);border-radius:var(--radius-control);word-break:break-word}.ayah-actions{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.btn{padding:.75rem 1.25rem;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;border:none;transition:background .2s,transform .1s}.btn:disabled{opacity:.7;cursor:not-allowed}.btn-record{background:var(--color-primary);color:#fff}.btn-record:hover:not(:disabled){background:var(--color-primary-hover)}.btn-record:active:not(:disabled){transform:scale(.98)}.btn-record.recording{background:#b91c1c;animation:pulse-rec 1.2s ease-in-out infinite}.btn-stop{background:#b91c1c;color:#fff}.btn-stop:hover:not(:disabled){background:#991b1b}.btn-stop:active:not(:disabled){transform:scale(.98)}.whisper-record-hint{margin:0 0 1rem;font-size:.95rem;opacity:.9;min-height:1.5rem}.whisper-recording-dot{color:#f87171;animation:pulse-rec 1.2s ease-in-out infinite}.whisper-record-actions{margin-top:.5rem}@keyframes pulse-rec{0%,to{opacity:1;box-shadow:0 0 #b91c1c80}50%{opacity:.95;box-shadow:0 0 0 8px #b91c1c00}}.transcription-sticky{transition:all .3s ease}.recite-section-title{transition:color .3s ease}.transcription-section.processing{box-shadow:0 0 0 2px #1b43321f;border-radius:var(--radius-control)}.upload-card form{margin-bottom:1rem}.upload-label{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.upload-label input[type=file]{color:var(--color-text);font-size:.875rem}.file-name{font-size:.9rem;color:var(--color-text-secondary);margin:0 0 .5rem}.transcribe-result{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--color-border)}.transcribe-result h3{margin:0 0 .5rem;font-size:1rem;font-weight:600}.transcribe-text{font-size:1.25rem;line-height:1.8;margin:0;color:var(--color-text)}.transcribe-filename{font-size:.85rem;color:var(--color-text-secondary);margin-top:.5rem}.upload-section{background:var(--color-surface);border-radius:var(--radius-card);padding:1rem 1.25rem;margin-bottom:1rem;border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.upload-form{display:flex;flex-direction:column;gap:.75rem}.upload-form .ayah-actions{margin-top:.5rem}.btn-over{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.btn-over:hover{background:var(--color-surface-muted)}.error{color:var(--color-danger);text-align:center;padding:.5rem 1rem;margin:0;font-weight:500}.tts-main{max-width:36rem;margin:0 auto;padding:0 1rem 2rem}.tts-link{color:var(--color-primary);text-decoration:underline;text-underline-offset:2px;font-weight:500}.tts-controls{margin-bottom:1rem}.tts-label{display:block;font-size:.9rem;opacity:.85;margin-bottom:.35rem}.tts-select{width:100%;max-width:100%;padding:.5rem .75rem;border-radius:var(--radius-control);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font-size:.9rem}.tts-textarea{width:100%;box-sizing:border-box;padding:.85rem 1rem;font-size:1.2rem;line-height:1.6;border-radius:var(--radius-control);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);resize:vertical;min-height:8rem;font-family:inherit}.tts-textarea:focus{outline:2px solid rgba(27,67,50,.35);outline-offset:1px;border-color:var(--color-primary)}.tts-hint{font-size:.8rem;opacity:.65;margin:.5rem 0 1rem}.tts-actions{justify-content:center}.tts-player-section{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--color-border)}.kokoro-speed{width:100%;max-width:24rem;display:block;margin-top:.25rem}.tts-audio{width:100%;margin-top:.5rem}.mistake-detection-main{max-width:52rem;margin:0 auto}.md-report{margin-top:1.5rem;padding:1rem 0}.md-report-meta{display:flex;flex-wrap:wrap;gap:.75rem 1.25rem;font-size:.85rem;opacity:.85;margin-bottom:1rem}.md-report-meta code{font-size:.8rem;background:var(--color-surface-muted);padding:.15rem .4rem;border-radius:4px;border:1px solid var(--color-border);color:var(--color-text)}.md-text-block{background:var(--color-surface);border-radius:var(--radius-card);padding:1rem;margin-bottom:.75rem;border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.md-text-block-trans{background:#eff6ff;border-color:#bfdbfe}.md-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;opacity:.65;margin-bottom:.35rem}.md-arabic{margin:0;font-size:1.35rem;line-height:1.9;font-family:Traditional Arabic,Amiri,Segoe UI,serif}.live-align-target-wrap{box-sizing:border-box;width:100%;max-width:100%;min-width:0;overflow-x:hidden;overflow-y:auto;white-space:normal;overflow-wrap:anywhere;word-wrap:break-word;word-break:normal}.md-summary-cards{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin:1rem 0}.md-summary-card{border-radius:.5rem;padding:.5rem .85rem;min-width:6.5rem;text-align:center;font-size:.8rem;font-weight:600}.md-summary-card.md-row-correct{background:#ecfdf5;color:#047857;border:1px solid #a7f3d0}.md-summary-card.md-row-sub{background:#fffbeb;color:#b45309;border:1px solid #fde68a}.md-summary-card.md-row-del{background:var(--color-danger-muted);color:#b91c1c;border:1px solid #fecaca}.md-summary-card.md-row-ins{background:#f5f3ff;color:#6d28d9;border:1px solid #ddd6fe}.md-summary-emoji{display:block;font-size:1.1rem;margin-bottom:.15rem}.md-summary-n{display:block;font-size:1.5rem;font-weight:700;margin-top:.2rem}.md-accuracy-bar-wrap{margin:1rem 0 1.25rem}.md-accuracy-labels{display:flex;justify-content:space-between;font-size:.9rem;margin-bottom:.35rem}.md-accuracy-track{height:14px;background:var(--color-surface-muted);border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.md-accuracy-fill{height:100%;border-radius:8px;transition:width .35s ease}.md-table-wrap{overflow-x:auto;border-radius:var(--radius-card);border:1px solid var(--color-border);background:var(--color-surface)}.md-table{width:100%;border-collapse:collapse;font-size:.9rem}.md-table thead{background:var(--color-surface-muted)}.md-table th,.md-table td{padding:.6rem .5rem;text-align:left;border-bottom:1px solid var(--color-border)}.md-table .md-cell-ar{font-size:1.1rem;font-family:Traditional Arabic,Amiri,Segoe UI,serif}.md-table tbody tr.md-row-correct{background:#ecfdf5cc}.md-table tbody tr.md-row-sub{background:#fffbebcc}.md-table tbody tr.md-row-del{background:#fef2f2cc}.md-table tbody tr.md-row-ins{background:#f5f3ffcc}.follow-along-controls{display:flex;flex-wrap:wrap;align-items:center;gap:1rem 1.5rem}.follow-along-label select{margin-left:.5rem;padding:.35rem .6rem;border-radius:var(--radius-control);background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.follow-along-server-hint{margin-top:1rem;padding:.75rem 1rem;border-radius:var(--radius-card);background:#f8fafc;border:1px solid var(--color-border);font-size:.92rem;line-height:1.5;color:var(--color-text)}.follow-along-pre{margin:.5rem 0 0;padding:.65rem .75rem;border-radius:var(--radius-control);background:var(--color-surface-muted);border:1px solid var(--color-border);font-size:.8rem;overflow-x:auto;color:var(--color-text)}.follow-along-ws-url{margin:.5rem 0 0;font-size:.85rem;opacity:.9}.follow-along-ws-url code{font-size:.8rem;word-break:break-all}.follow-along-transcript{margin-top:1.25rem}.follow-along-live-text{min-height:3.5rem;max-height:22vh;overflow-y:auto;line-height:1.85;margin-top:.35rem}.follow-along-mushaf{margin-top:1.5rem;max-height:min(68vh,42rem);overflow-y:auto;padding:.75rem .5rem;border-radius:var(--radius-card);background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.follow-along-ayah{margin:0 0 1.1rem;line-height:2.1;font-size:1.35rem;font-family:Traditional Arabic,Amiri,Segoe UI,serif}.follow-along-ayah-num{display:inline-block;margin-left:.35rem;font-size:.7rem;font-family:system-ui,sans-serif;color:var(--color-text-secondary);vertical-align:super}.follow-along-word{display:inline;margin-left:.28em;border-radius:3px;padding:.06em .1em;transition:background .15s ease,color .15s ease}.follow-along-word--past{color:#9ca3af}.follow-along-word--current{color:var(--color-primary);background:var(--color-primary-muted);font-weight:600;box-shadow:0 0 0 1px #1b433233}.follow-along-word--ahead{color:var(--color-text)}.pipeline-debug-row{padding:.5rem .75rem;border-radius:var(--radius-control);background:var(--color-surface-muted);border:1px solid var(--color-border)}.pipeline-debug-row strong{color:var(--color-text);font-size:.8rem}.pipeline-debug-pre{margin:0;padding:.5rem .75rem;border-radius:var(--radius-control);background:var(--color-surface-muted);border:1px solid var(--color-border);font-size:.75rem;overflow:auto;max-height:14rem;color:var(--color-text)}
