:root{--c-bg: #fafaf7;--c-surface: #ffffff;--c-text: #1a1a1a;--c-text-soft: #555;--c-border: #e5e5e0;--c-gray-100: #f3f3ef;--c-gray-200: #e4e4dd;--c-gray-300: #c9c9bf;--c-yellow-300: #f4d166;--c-green-400: #7fc97f;--c-green-500: #4caf50;--c-green-600: #2e7d32;--c-red-400: #e57373;--c-primary: #1e6f5c;--c-primary-hover: #2a8a73;--c-primary-soft: #eef6f3;--c-accent: #c9a45a;--c-danger: #b3261e;--c-danger-soft: #fdf0ee;--font-display: "Lora", Georgia, "Times New Roman", serif;--font-arabic: "Amiri", "Scheherazade New", serif;--r: 8px;--shadow: 0 1px 3px rgba(0,0,0,.08);--shadow-lift: 0 4px 12px rgba(0,0,0,.1)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--c-bg: #15211d;--c-surface: #1d2b26;--c-text: #ece9e2;--c-text-soft: #a8b0ab;--c-border: #32413b;--c-gray-100: #243430;--c-gray-200: #2c3e38;--c-gray-300: #3c4f48;--c-yellow-300: #8a6d1f;--c-green-400: #3f7a42;--c-green-500: #2e6b31;--c-green-600: #57a05b;--c-red-400: #8c3a36;--c-primary: #4fae93;--c-primary-hover: #63c2a7;--c-primary-soft: #21352f;--c-accent: #d8b878;--c-danger: #e0726a;--c-danger-soft: #3a2422;--shadow: 0 1px 3px rgba(0,0,0,.4);--shadow-lift: 0 4px 12px rgba(0,0,0,.45)}}:root[data-theme=dark]{--c-bg: #15211d;--c-surface: #1d2b26;--c-text: #ece9e2;--c-text-soft: #a8b0ab;--c-border: #32413b;--c-gray-100: #243430;--c-gray-200: #2c3e38;--c-gray-300: #3c4f48;--c-yellow-300: #8a6d1f;--c-green-400: #3f7a42;--c-green-500: #2e6b31;--c-green-600: #57a05b;--c-red-400: #8c3a36;--c-primary: #4fae93;--c-primary-hover: #63c2a7;--c-primary-soft: #21352f;--c-accent: #d8b878;--c-danger: #e0726a;--c-danger-soft: #3a2422;--shadow: 0 1px 3px rgba(0,0,0,.4);--shadow-lift: 0 4px 12px rgba(0,0,0,.45)}html[data-theme=dark]{color-scheme:dark}html[data-theme=light]{color-scheme:light}*{box-sizing:border-box}html{color-scheme:light dark}html,body{margin:0;padding:0;background:var(--c-bg);color:var(--c-text);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased}html{-webkit-text-size-adjust:100%}body{overflow-x:hidden}img,audio,video{max-width:100%}input,select,textarea{font-size:16px}a{color:var(--c-primary);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3{font-family:var(--font-display);letter-spacing:-.01em}:focus-visible{outline:2px solid var(--c-primary);outline-offset:2px}.app-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--c-surface);border-bottom:1px solid var(--c-border);position:sticky;top:0;z-index:10;flex-wrap:wrap;gap:8px}.brand{font-size:20px;font-weight:700;color:var(--c-primary);font-family:var(--font-display);display:inline-flex;align-items:center;gap:8px}.brand-logo{width:26px;height:26px;flex-shrink:0}.app-nav{display:flex;gap:16px;align-items:center;flex-wrap:wrap}.app-nav a{color:var(--c-text);font-weight:500;min-height:44px;display:inline-flex;align-items:center}.link-btn{background:none;border:none;color:var(--c-text);cursor:pointer;font:inherit;min-height:44px}.lang-switcher{padding:6px 8px;border-radius:6px;border:1px solid var(--c-border);background:var(--c-surface);color:var(--c-text);min-height:44px;font-size:14px}.theme-toggle{background:none;border:none;cursor:pointer;font-size:1.2rem;min-height:44px;min-width:44px;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;color:var(--c-text);transition:background .15s}.theme-toggle:hover{background:var(--c-gray-100)}.btn{display:inline-block;padding:10px 16px;border-radius:var(--r);border:none;font-size:15px;font-weight:500;cursor:pointer;min-height:44px;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease,transform .06s ease}.btn:not(:disabled):hover{box-shadow:var(--shadow)}.btn:not(:disabled):active{transform:scale(.97);box-shadow:none}.btn-primary{background:var(--c-primary);color:#fff}.btn-primary:hover{background:var(--c-primary-hover)}.btn-secondary{background:var(--c-gray-100);color:var(--c-text);border:1px solid var(--c-border)}.btn-secondary:hover{border-color:var(--c-gray-300)}.btn-danger{background:var(--c-danger);color:#fff}.btn:disabled{opacity:.5;cursor:not-allowed}.landing{max-width:860px;margin:0 auto;padding:72px 16px 64px;text-align:center;position:relative}.landing:before{content:"";position:absolute;inset:-40px 0 auto;height:420px;z-index:-1;background:radial-gradient(ellipse 70% 60% at 50% 0%,color-mix(in srgb,var(--c-primary) 12%,transparent),transparent 70%),radial-gradient(ellipse 40% 35% at 80% 10%,color-mix(in srgb,var(--c-accent) 10%,transparent),transparent 70%);pointer-events:none}.landing h1{font-size:clamp(28px,5.5vw + 8px,52px);color:var(--c-primary);margin:0}.landing .tagline{font-size:19px;color:var(--c-text-soft);margin:14px 0 28px}.landing-verse{font-family:var(--font-arabic);font-size:clamp(26px,5.5vw,38px);line-height:2;color:var(--c-text);margin:0 0 36px}.cta-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.cta-row .btn{padding:12px 28px;font-size:16px}.landing-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-top:56px;text-align:center}.landing-feature{background:var(--c-surface);border:1px solid var(--c-border);border-radius:12px;padding:24px 18px;box-shadow:var(--shadow)}.landing-feature-icon{font-size:30px;display:block;margin-bottom:10px}.landing-feature h2{font-size:17px;margin:0 0 6px;color:var(--c-primary)}.landing-feature p{font-size:14px;color:var(--c-text-soft);margin:0;line-height:1.5}.auth-page{max-width:480px;margin:40px auto;padding:24px;background:var(--c-surface);border-radius:var(--r);box-shadow:var(--shadow)}.auth-page h1{margin-top:0}.auth-page form{display:flex;flex-direction:column;gap:16px}.auth-page label{display:flex;flex-direction:column;font-weight:500;gap:4px}.auth-page input,.auth-page select,.auth-page textarea{padding:10px;border-radius:6px;border:1px solid var(--c-border);font-size:16px}.auth-page small{color:var(--c-text-soft);font-weight:400}.error{color:var(--c-danger)}.success{color:var(--c-green-600)}.account-banner{background:var(--c-gray-100);border:1px solid var(--c-border);padding:12px 16px;border-radius:var(--r);margin-bottom:16px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.account-banner p{margin:0}.account-banner .link-btn{color:var(--c-primary);text-decoration:underline}.invite-code-display{margin-top:24px;padding:16px;background:var(--c-gray-100);border-radius:var(--r)}.invite-code-display code{display:block;font-size:clamp(20px,6vw,32px);text-align:center;letter-spacing:4px;padding:12px;background:var(--c-surface);border-radius:6px;margin-bottom:12px;overflow-wrap:anywhere;word-break:break-all}.invite-code-display .btn-copy-code{display:block;width:100%;margin-bottom:12px}.invite-code-display p{margin:0 0 12px;color:var(--c-text-soft);font-size:.95rem;line-height:1.5}.dashboard{max-width:1200px;margin:24px auto;padding:0 16px}.dashboard h1{margin:0 0 16px}.tabs{display:flex;gap:8px;margin-bottom:16px;border-bottom:1px solid var(--c-border)}.tab{background:none;border:none;padding:10px 16px;cursor:pointer;font-size:15px;color:var(--c-text-soft);border-bottom:2px solid transparent;min-height:44px}.tab.active{color:var(--c-primary);border-bottom-color:var(--c-primary);font-weight:600}.toggle-row{display:flex;gap:8px;align-items:center;margin:12px 0}.toggle-inline{display:inline-flex;gap:6px;align-items:center}.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:24px}.stat{background:var(--c-surface);padding:16px;border-radius:var(--r);box-shadow:var(--shadow);text-align:center;border-top:3px solid var(--c-primary)}.stat-icon{font-size:20px;display:block;margin-bottom:6px}.stat-value{font-size:clamp(20px,4vw,28px);font-weight:700;color:var(--c-primary);font-variant-numeric:tabular-nums}.stat-label{font-size:13px;color:var(--c-text-soft);margin-top:4px}.sourate-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.sourate-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px 8px;border-radius:var(--r);color:var(--c-text);text-align:center;min-height:130px;transition:transform .1s,box-shadow .1s;border:2px solid transparent;cursor:pointer;text-decoration:none;position:relative}.sourate-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);text-decoration:none}.sourate-card.has-pending{border-color:var(--c-accent);box-shadow:0 0 0 2px #c9a45a66;animation:pulse 2s ease-in-out infinite}.sourate-rec-badge{position:absolute;top:4px;right:4px;background:color-mix(in srgb,var(--c-surface) 88%,transparent);color:var(--c-text);font-size:11px;font-weight:600;line-height:1;padding:3px 6px;border-radius:10px;border:1px solid rgba(0,0,0,.08);font-variant-numeric:tabular-nums}.sourate-num{font-size:12px;opacity:.8}.sourate-name-translit{font-weight:600;margin-top:4px}.sourate-name-ar{font-size:20px;margin-top:4px;font-family:var(--font-arabic)}.sourate-progress{font-size:12px;margin-top:6px;opacity:.85}.sourate-progress-track{width:80%;height:5px;margin-top:8px;border-radius:99px;background:#0000001f;overflow:hidden}.sourate-progress-fill{height:100%;border-radius:99px;background:var(--c-primary);transition:width .4s ease}.sourate-progress-fill.complete{background:var(--c-accent)}.sourate-progress-count{font-size:11px;margin-top:4px;opacity:.8;font-variant-numeric:tabular-nums}@keyframes pulse{0%,to{box-shadow:0 0 0 2px #c9a45a66}50%{box-shadow:0 0 0 4px #c9a45ab3}}.verse-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(44px,1fr));gap:6px;margin:16px 0}.verse-cell{min-height:44px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;color:var(--c-text);display:flex;align-items:center;justify-content:center}.verse-cell.selected{outline:3px solid var(--c-primary)}.verse-cell.pending{box-shadow:inset 0 0 0 2px var(--c-accent)}.sourate-page{max-width:900px;margin:24px auto;padding:0 16px}.sourate-page header{margin-bottom:16px}.back-link{display:inline-block;margin-bottom:12px;color:var(--c-text-soft)}.ar-title{font-size:28px;font-family:var(--font-arabic);color:var(--c-primary);margin:0}.controls{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:12px}.verse-detail{background:var(--c-surface);padding:20px;border-radius:var(--r);box-shadow:var(--shadow);margin-top:16px}.verse-ar{font-size:32px;font-family:var(--font-arabic);line-height:1.8;margin:12px 0}.verse-translit{color:var(--c-text-soft);font-style:italic}.verse-translation{color:var(--c-text)}.test-hint{background:var(--c-gray-100);padding:12px;border-radius:6px}.actions{display:flex;gap:8px;flex-wrap:wrap;margin:16px 0}.encouragement{color:var(--c-text-soft);font-size:14px}.recording-list{list-style:none;padding:0}.recording-list li{display:flex;gap:12px;justify-content:space-between;padding:8px;border-bottom:1px solid var(--c-border);flex-wrap:wrap}.pending-label{color:var(--c-accent);font-weight:600}.rec-feedback{display:flex;flex-direction:column;gap:6px;align-items:flex-end;max-width:100%}.rec-comment{color:var(--c-text-soft);font-size:.9em;text-align:right;overflow-wrap:anywhere}.rec-audio{display:flex;flex-direction:column;gap:4px;align-items:flex-end;max-width:100%}.rec-audio-label{font-size:.8em;color:var(--c-text-soft)}.rec-audio audio{height:36px;max-width:100%}.version-tabs{display:flex;gap:6px;margin:8px 0 12px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px}.version-tab{display:inline-flex;flex-direction:column;align-items:center;gap:2px;padding:8px 14px;border:1px solid var(--c-border);border-radius:8px;background:var(--c-surface);cursor:pointer;font:inherit;min-width:80px;white-space:nowrap;transition:border-color .15s,background .15s}.version-tab:hover{border-color:var(--c-primary)}.version-tab.active{border-color:var(--c-primary);background:var(--c-primary);color:#fff}.version-tab-label{font-weight:700;font-size:.95rem}.version-tab-score{font-size:.85rem;font-variant-numeric:tabular-nums;opacity:.9}.version-tab-badge{font-size:.75rem;color:var(--c-accent)}.version-tab.active .version-tab-badge{color:#fff}.version-detail{margin-top:8px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r);padding:12px}.version-detail-meta{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;color:var(--c-text-soft);font-size:.9rem}.version-detail-date{font-variant-numeric:tabular-nums}.review-split{display:grid;grid-template-columns:minmax(240px,320px) 1fr;gap:16px;align-items:start}@media(max-width:900px){.review-split{grid-template-columns:1fr}}.annotation-summary{background:var(--c-bg);border:1px solid var(--c-border);border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:8px}.annotation-score{display:flex;align-items:baseline;gap:4px;font-weight:700;color:var(--c-primary)}.annotation-score-value{font-size:1.8rem;line-height:1}.annotation-score-max{font-size:1rem;color:var(--c-text-soft);font-weight:600}.annotation-text{margin:0;font-size:.95rem;color:var(--c-text);white-space:pre-wrap}.queue{list-style:none;padding:0}.queue li{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:8px;align-items:center;padding:12px;border-bottom:1px solid var(--c-border)}.queue li>.btn{white-space:nowrap;min-height:44px}@media(max-width:720px){.queue li{grid-template-columns:1fr 1fr;gap:6px}.queue li>.btn{grid-column:1 / -1;justify-self:stretch;text-align:center}}.students{list-style:none;padding:0}.students li{padding:12px;border-bottom:1px solid var(--c-border)}.students small{display:block;color:var(--c-text-soft);overflow-wrap:anywhere}.teacher-section{background:var(--c-surface);padding:16px;border-radius:var(--r);box-shadow:var(--shadow);margin-bottom:16px}.teacher-section h2{margin:0 0 12px;font-size:1.1rem}.teacher-list{list-style:none;padding:0;margin:0 0 12px;display:flex;flex-wrap:wrap;gap:8px}.teacher-name{background:var(--c-gray-100);border:1px solid var(--c-border);padding:6px 10px;border-radius:99px;font-size:.9rem}.join-form{display:flex;flex-direction:column;gap:12px;max-width:420px}.join-form label{display:flex;flex-direction:column;gap:4px;font-weight:500}.join-form input{padding:10px;border-radius:6px;border:1px solid var(--c-border);font-size:16px;min-height:44px}.invite-section{display:flex;flex-direction:column;gap:12px;margin-bottom:12px}.recording-page{max-width:720px;margin:24px auto;padding:0 16px}.recording-page audio{width:100%;margin:12px 0}.recording-page--split{max-width:1200px}.recording-page-header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:8px}.recording-page-header h1{margin:0}.btn-finish-review{white-space:nowrap}.recording-split{display:grid;grid-template-columns:minmax(260px,360px) 1fr;gap:24px;align-items:start}.player-section--vertical{position:sticky;top:16px}.player-section--vertical .waveform-wrapper{height:calc(100vh - 240px);min-height:380px;overflow-y:auto;border:1px solid var(--c-border);border-radius:var(--r);background:var(--c-surface);overscroll-behavior:contain}.waveform--vertical{border:none;border-radius:0;display:block}.markers-panel{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r);padding:16px;display:flex;flex-direction:column;gap:10px;min-height:200px}.markers-panel-title{margin:0 0 4px;font-size:1rem}.markers-panel-empty{color:var(--c-text-soft);font-size:.9rem;margin:0}@media(max-width:900px){.recording-split{grid-template-columns:1fr}.player-section--vertical{position:static}.player-section--vertical .waveform-wrapper{height:calc(100vh - 280px);min-height:320px;width:calc(100% - 32px);margin-left:auto;margin-right:auto}}.btn-text{background:none;border:none;color:var(--c-accent);cursor:pointer;padding:4px 0;font:inherit}.btn-text-danger{color:var(--c-danger)}.btn-text-danger:disabled{opacity:.5;cursor:not-allowed}.loading{padding:40px;text-align:center;color:var(--c-text-soft)}.waveform-wrapper{position:relative}.waveform{width:100%;min-height:80px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r);display:block;cursor:pointer;touch-action:pan-y;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.player-controls{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:12px}.btn-icon{background:none;border:1px solid var(--c-border);border-radius:6px;width:44px;height:44px;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.btn-play{background:var(--c-primary);color:#fff;border-color:var(--c-primary);width:56px;height:56px;font-size:1.4rem;border-radius:50%}.time-display{margin-top:8px;font-variant-numeric:tabular-nums;color:var(--c-text-soft);text-align:center}.teacher-instructions{display:flex;justify-content:center;gap:24px;margin:8px 0 12px;flex-wrap:wrap}.teacher-instr-item{display:flex;flex-direction:column;align-items:center;gap:4px;font-size:.8rem;color:var(--c-text-soft)}.teacher-instr-primary{color:var(--c-primary);font-weight:600}.tap-hint{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:color-mix(in srgb,var(--c-surface) 70%,transparent);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);border-radius:var(--r);z-index:10;pointer-events:none;animation:hintFadeInOut 1.6s ease-out forwards}@keyframes hintFadeInOut{0%{opacity:0}30%{opacity:1}80%{opacity:1}to{opacity:0}}.tap-hint-finger{position:relative;color:var(--c-primary);animation:tapBounce 1.8s ease-in-out infinite}@keyframes tapBounce{0%,to{transform:translateY(0)}30%{transform:translateY(6px) scale(.95)}50%{transform:translateY(0)}}.longpress-ring{position:absolute;bottom:-2px;left:50%;width:28px;height:28px;margin-left:-14px;border-radius:50%;background:var(--c-primary);opacity:0;animation:rippleOut 1.8s ease-out infinite}@keyframes rippleOut{0%{transform:scale(.3);opacity:.4}30%{transform:scale(1);opacity:.25}60%{transform:scale(1.8);opacity:0}to{opacity:0}}.tap-hint-label{font-size:.9rem;font-weight:600;color:var(--c-primary);text-align:center}.markers-list{margin-top:20px;display:flex;flex-direction:column;gap:10px}.annotation-item{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r);padding:12px 16px;transition:border-color .15s}.annotation-item.expandable{cursor:pointer}.annotation-item.expandable:hover,.annotation-item.open{border-color:var(--c-primary)}.ann-summary{display:flex;align-items:center;gap:10px}.ann-seek{background:var(--c-bg);border:1px solid var(--c-border);border-radius:6px;padding:2px 8px;font-size:.82rem;color:var(--c-text-soft);font-variant-numeric:tabular-nums;cursor:pointer;white-space:nowrap;flex-shrink:0}.ann-seek:hover{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}.annotation-label{font-size:1.3rem;flex-shrink:0}.annotation-text-preview{font-size:.9rem;color:var(--c-text-soft);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ann-chevron{font-size:.75rem;color:var(--c-text-soft);flex-shrink:0;transition:transform .2s}.ann-detail{margin-top:12px;display:flex;flex-direction:column;gap:10px;border-top:1px solid var(--c-border);padding-top:12px}.ann-full-text{font-size:.95rem;line-height:1.5;color:var(--c-text);white-space:pre-wrap}.ann-audio{width:100%;height:40px;border-radius:6px}.btn-delete-ann,.btn-edit-ann{background:none;border:none;cursor:pointer;font-size:1.1rem;padding:4px 6px;border-radius:6px;color:var(--c-text-soft);flex-shrink:0;line-height:1}.btn-edit-ann{margin-left:auto}.btn-edit-ann:hover{color:var(--c-primary);background:var(--c-primary-soft)}.btn-delete-ann:hover{color:var(--c-danger);background:var(--c-danger-soft)}.btn-delete-ann:disabled,.btn-edit-ann:disabled{opacity:.4;cursor:not-allowed}.popover-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:199;background:#00000026;animation:backdropIn .15s ease-out}@keyframes backdropIn{0%{opacity:0}to{opacity:1}}.annotation-popover{position:fixed;z-index:200;width:340px;max-width:calc(100vw - 24px);max-height:calc(100vh - 24px);overflow-y:auto;background:var(--c-surface);border:2px solid var(--c-primary);border-radius:var(--r);padding:16px;display:flex;flex-direction:column;gap:14px;box-shadow:0 8px 32px #0000002e;transform:translate(-50%,8px);animation:popoverIn .2s ease-out}@keyframes popoverIn{0%{opacity:0;transform:translate(-50%,-4px)}to{opacity:1;transform:translate(-50%,8px)}}.annotation-panel-header{display:flex;align-items:center;justify-content:space-between}.annotation-panel-header h2{font-size:1rem;font-weight:700;color:var(--c-primary);margin:0}.btn-close-panel{background:none;border:none;font-size:1.2rem;color:var(--c-text-soft);cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%}.btn-close-panel:hover{background:var(--c-bg);color:var(--c-text)}.finish-modal{top:50%;left:50%;transform:translate(-50%,-50%)!important;animation:finishModalIn .2s ease-out}@keyframes finishModalIn{0%{opacity:0;transform:translate(-50%,-52%)}to{opacity:1;transform:translate(-50%,-50%)}}.finish-modal-form{display:flex;flex-direction:column;gap:14px}.finish-modal-label{font-weight:600;color:var(--c-text)}.finish-mark-row{display:flex;align-items:baseline;gap:8px}.finish-mark-input{flex:1;font-size:1.5rem;font-weight:700;text-align:center;padding:10px 12px;border:2px solid var(--c-border);border-radius:8px;font-variant-numeric:tabular-nums}.finish-mark-input:focus{outline:none;border-color:var(--c-primary)}.finish-mark-suffix{font-size:1.1rem;color:var(--c-text-soft);font-weight:600}.finetune-row{display:flex;align-items:center;gap:10px}.btn-preview-play{width:36px;height:36px;border-radius:50%;border:2px solid var(--c-accent);background:var(--c-surface);color:var(--c-accent);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,color .15s}.btn-preview-play:active{background:var(--c-accent);color:#fff}.finetune{display:flex;align-items:center;gap:6px;flex:1;min-width:140px}.finetune input[type=range]{flex:1;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--c-border);border-radius:3px;outline:none;padding:0;border:none}.finetune input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--c-primary);cursor:pointer}.finetune input[type=range]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--c-primary);cursor:pointer;border:none}.btn-finetune{width:32px;height:32px;border-radius:50%;border:1px solid var(--c-border);background:var(--c-surface);font-size:1.1rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--c-text-soft);flex-shrink:0;line-height:1}.btn-finetune:hover{border-color:var(--c-primary);color:var(--c-primary)}.annotation-fields{display:flex;flex-direction:column;gap:14px}.annotation-fields textarea{width:100%;padding:8px 10px;border-radius:6px;border:1px solid var(--c-border);background:var(--c-bg);color:var(--c-text);font:inherit;font-size:16px;resize:vertical;min-height:64px}.field-group{display:flex;flex-direction:column;gap:6px}.field-label{font-size:.85rem;font-weight:600;color:var(--c-text-soft)}.optional-tag{font-weight:400;font-size:.8rem;color:var(--c-text-soft);opacity:.7}.emoji-row{display:flex;gap:16px;justify-content:center;margin:4px 0}.btn-emoji{width:52px;height:52px;font-size:1.6rem;border:2px solid var(--c-border);border-radius:var(--r);background:none;cursor:pointer;transition:border-color .15s,background .15s}.btn-emoji.active{border-color:var(--c-primary);background:var(--c-primary-soft)}.voice-note-row{display:flex;align-items:center;gap:10px}.btn-voice-rec{background:var(--c-bg);border:2px solid var(--c-border);border-radius:99px;min-height:44px;padding:0 16px;display:inline-flex;align-items:center;gap:8px;cursor:pointer;transition:border-color .15s}.btn-voice-rec:hover{border-color:var(--c-primary)}.btn-voice-rec.recording{border-color:var(--c-danger);background:var(--c-danger-soft)}.rec-timer{font-variant-numeric:tabular-nums;font-size:.9rem;color:var(--c-danger)}.voice-preview{width:100%;height:36px;border-radius:6px}.annotation-panel-actions{display:flex;gap:12px}.annotation-panel-actions .btn{flex:1}.marker-feedback-panel{margin-top:10px}.danger-zone{margin-top:40px;padding:16px;border:1px solid var(--c-danger);border-radius:8px}.danger-zone h2{color:var(--c-danger)}.danger-zone p{margin:8px 0 12px}@media(max-width:768px){.annotation-popover{width:100%;max-width:100%;padding:20px 16px;padding-bottom:max(20px,calc(env(safe-area-inset-bottom) + 12px));gap:16px;left:0!important;right:0!important;bottom:0!important;top:auto!important;transform:none!important;border-radius:16px 16px 0 0;border:2px solid var(--c-primary);border-bottom:none;max-height:85vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.annotation-popover .btn-close-panel{position:absolute;top:8px;right:8px;width:30px;height:30px;font-size:1rem}.annotation-popover .finetune-row{flex-direction:column;align-items:center;gap:8px;width:100%}.annotation-popover .finetune{min-width:0;width:100%;justify-content:center}.annotation-popover .annotation-panel-actions{flex-direction:column-reverse;gap:8px;width:100%}}@media(max-width:480px){.landing{margin:40px auto}.stats{grid-template-columns:repeat(2,1fr)}.sourate-grid{grid-template-columns:repeat(2,1fr);gap:8px}.sourate-page{padding:0 12px}.sourate-page h1{font-size:1.4rem}.verse-detail{padding:16px 12px}.verse-ar{font-size:26px;line-height:1.7}.ar-title{font-size:24px}.actions{gap:6px}.actions .btn{flex:1 1 calc(50% - 6px);text-align:center}.actions .toggle-inline{flex:1 1 100%}.recording-list li{flex-direction:column;align-items:stretch}.rec-feedback,.rec-audio{align-items:stretch}.rec-comment{text-align:left}.rec-audio audio{width:100%}.auth-page{margin:16px auto;padding:16px;border-radius:0;box-shadow:none}.dashboard{padding:0 12px;margin:16px auto}.app-header{padding:10px 12px}.brand{font-size:18px}.app-nav{gap:10px}.recording-page-header{gap:8px}.btn-finish-review{width:100%}.teacher-instructions{gap:12px}.version-detail-meta{flex-direction:column;align-items:flex-start;gap:6px}}@media(max-width:360px){.stats{grid-template-columns:1fr 1fr}.stat-value{font-size:24px}.verse-grid{grid-template-columns:repeat(auto-fill,minmax(40px,1fr));gap:4px}.verse-cell{font-size:13px}}.confirm-modal{position:fixed;z-index:300;top:50%;left:50%;transform:translate(-50%,-50%);width:400px;max-width:calc(100vw - 32px);background:var(--c-surface);border:1px solid var(--c-border);border-radius:12px;padding:20px;box-shadow:var(--shadow-lift);animation:finishModalIn .18s ease-out}.confirm-modal h2{margin:0 0 10px;font-size:1.1rem}.confirm-modal p{margin:0 0 18px;color:var(--c-text);line-height:1.5}.confirm-actions{display:flex;gap:10px;justify-content:flex-end}.confirm-actions .btn{flex:0 1 auto}.toast-host{position:fixed;z-index:400;bottom:16px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:8px;align-items:center;width:max-content;max-width:calc(100vw - 32px);pointer-events:none}.toast{display:flex;align-items:center;gap:10px;background:var(--c-surface);color:var(--c-text);border:1px solid var(--c-border);border-left:4px solid var(--c-primary);border-radius:10px;padding:10px 14px;box-shadow:var(--shadow-lift);font-size:.95rem;max-width:100%;pointer-events:auto;animation:toastIn .2s ease-out}.toast-error{border-left-color:var(--c-danger)}.toast-success{border-left-color:var(--c-green-600)}.toast-dismiss{background:none;border:none;color:var(--c-text-soft);cursor:pointer;font-size:1rem;padding:2px 4px;line-height:1;flex-shrink:0}@keyframes toastIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.skeleton{position:relative;overflow:hidden;background:var(--c-gray-100);border-radius:6px}.skeleton:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--c-surface) 60%,transparent),transparent);animation:shimmer 1.4s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.skeleton-text{height:14px}.skeleton-title{height:24px;width:40%}.skeleton-block{height:96px}.skeleton-row{height:44px}.page-skeleton{max-width:900px;margin:24px auto;padding:0 16px;display:flex;flex-direction:column;gap:14px}.skeleton-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.empty-state{text-align:center;padding:28px 16px;color:var(--c-text-soft);background:var(--c-gray-100);border:1px dashed var(--c-border);border-radius:12px}.empty-state-icon{font-size:34px;display:block;margin-bottom:8px}.empty-state-message{margin:0;font-weight:600;color:var(--c-text)}.empty-state-hint{margin:6px 0 0;font-size:.9rem}.celebration{position:fixed;z-index:500;top:45%;left:50%;width:0;height:0;pointer-events:none}.celebration-check{position:absolute;transform:translate(-50%,-50%);width:76px;height:76px;border-radius:50%;background:var(--c-primary);color:#fff;font-size:40px;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lift);animation:celebratePop 1.3s cubic-bezier(.2,1.4,.4,1) forwards}@keyframes celebratePop{0%{transform:translate(-50%,-50%) scale(0);opacity:0}18%{transform:translate(-50%,-50%) scale(1.1);opacity:1}30%{transform:translate(-50%,-50%) scale(1)}80%{opacity:1}to{transform:translate(-50%,-50%) scale(.9);opacity:0}}.confetti{position:absolute;width:9px;height:9px;border-radius:2px;transform:translate(-50%,-50%);animation:confettiFly 1.1s ease-out forwards;opacity:0}@keyframes confettiFly{0%{transform:translate(-50%,-50%) rotate(0);opacity:1}to{transform:translate(calc(-50% + var(--dx)),calc(-50% + var(--dy))) rotate(540deg);opacity:0}}@media(prefers-reduced-motion:reduce){.confetti{display:none}.celebration-check{animation-duration:.8s}.skeleton:after{animation:none}.btn,.sourate-card{transition:none}}
