:root{--purple-main: #6658E8;--purple-deep: #5F55D6;--purple-bg: #F5F2FF;--purple-border: #E2DFFF;--primary: var(--purple-main);--primary-light: var(--purple-main);--primary-dark: var(--purple-deep);--primary-hover: var(--purple-deep);--secondary: #F472B6;--accent: #F59E0B;--danger: #EF4444;--warning: #F59E0B;--success: #10B981;--bg-app: #F9FAFC;--bg-card: #FFFFFF;--bg-hover: var(--purple-bg);--bg-sidebar: #F8FAFC;--highlight-bg: var(--purple-bg);--text-primary: #0F172A;--text-secondary: #334155;--text-muted: #64748B;--border: rgba(148, 163, 184, .2);--border-light: rgba(226, 232, 240, .9);--shadow-soft: 0 12px 28px -12px rgba(15, 23, 42, .12), 0 10px 18px -14px rgba(15, 23, 42, .1);--shadow-hover: 0 18px 36px -16px rgba(15, 23, 42, .18), 0 14px 24px -18px rgba(15, 23, 42, .12);--shadow-card: 0 2px 10px rgba(15, 23, 42, .05);--radius-sm: 10px;--radius: 12px;--radius-lg: 18px;--radius-full: 9999px;--transition: all .3s cubic-bezier(.4, 0, .2, 1);--sidebar-width: 300px;--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-right: env(safe-area-inset-right, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px);--safe-area-left: env(safe-area-inset-left, 0px)}html.dark-mode{--bg-app: #0F172A;--bg-card: #111827;--bg-hover: rgba(109, 93, 246, .18);--bg-sidebar: #111827;--highlight-bg: rgba(109, 93, 246, .2);--text-primary: #F8FAFC;--text-secondary: #CBD5E1;--text-muted: #94A3B8;--border: rgba(148, 163, 184, .28);--border-light: rgba(51, 65, 85, .86);--shadow-soft: 0 16px 34px -18px rgba(0, 0, 0, .62);--shadow-hover: 0 22px 44px -20px rgba(0, 0, 0, .72);--shadow-card: 0 2px 14px rgba(0, 0, 0, .32)}html.dark-mode .sidebar{background:radial-gradient(circle at top left,rgba(109,93,246,.16),transparent 30%),linear-gradient(180deg,#111827,#0f172a);border-right-color:#94a3b838}html.dark-mode .sidebar:after{background:linear-gradient(180deg,#0f172a00,#0f172af0 58%,#0f172a)}html.dark-mode .nav-section-title,html.dark-mode .nav-item,html.dark-mode .menu-toggle,html.dark-mode .toast,html.dark-mode .dialog-container,html.dark-mode .modal-container,html.dark-mode .settings-card,html.dark-mode .stat-card,html.dark-mode .sentence-favorite-card,html.dark-mode .review-group-card,html.dark-mode .player-capsule,html.dark-mode .transcript-container,html.dark-mode .transcript-bubble{background-color:var(--bg-card);border-color:var(--border)}html.dark-mode .nav-section-name,html.dark-mode .nav-year-title,html.dark-mode .nav-month-title,html.dark-mode .nav-item-title,html.dark-mode .brand-title,html.dark-mode .audio-title,html.dark-mode .sentence-favorite-text,html.dark-mode .review-group-title{color:var(--text-primary)}html.dark-mode .loading-overlay{background:#0f172adb}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,PingFang SC,Helvetica Neue,sans-serif;background-color:var(--bg-app);color:var(--text-primary);line-height:1.7;overflow-x:hidden}.main-body{min-height:100vh}.app-container{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:radial-gradient(circle at top left,rgba(96,165,250,.1),transparent 28%),linear-gradient(180deg,#f8fafd,#f4f5fb 52%,#fbfcfe);display:flex;flex-direction:column;height:100vh;position:fixed;left:0;top:0;z-index:100;overflow-x:hidden;overflow-y:auto;overscroll-behavior:contain;scrollbar-width:none;-ms-overflow-style:none;border-right:1px solid rgba(148,163,184,.18);box-shadow:8px 0 24px #0f172a0d}.sidebar::-webkit-scrollbar{display:none}.sidebar:hover{scrollbar-width:overlay;-ms-overflow-style:-ms-autohiding-scrollbar}.sidebar:hover::-webkit-scrollbar{display:block;width:6px}.sidebar:hover::-webkit-scrollbar-track{background:transparent}.sidebar:hover::-webkit-scrollbar-thumb{background-color:#94a3b84d;border-radius:3px}.sidebar:hover::-webkit-scrollbar-thumb:hover{background-color:#94a3b880}.sidebar:after{content:"";position:fixed;left:0;bottom:0;width:var(--sidebar-width);height:72px;pointer-events:none;background:linear-gradient(180deg,#f8fafd00,#f4f5fbe6 58%,#f4f5fbfa);z-index:101}.sidebar-header{padding:28px 22px 20px}.brand-logo{display:flex;align-items:center;gap:12px;text-decoration:none;transition:transform .3s cubic-bezier(.175,.885,.32,1.275)}.brand-logo:hover{transform:scale(1.05) rotate(-3deg)}.brand-icon-cute{position:relative;width:42px;height:42px;background:linear-gradient(135deg,#6d5df6,#6d5df6);border-radius:14px;display:flex;justify-content:center;align-items:center;color:#fff;box-shadow:0 4px 12px #6d5df659}.cute-note{position:absolute;top:-6px;right:-6px;color:#f472b6;animation:float-bounce 2.5s infinite ease-in-out}@keyframes float-bounce{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-4px) rotate(15deg)}}.brand-text{display:flex;flex-direction:column;justify-content:center}.brand-title{font-size:16px;font-weight:800;color:#334155;letter-spacing:0;line-height:1.1}.brand-subtitle{font-size:12px;font-weight:700;color:#6d5df6;letter-spacing:2px;line-height:1.2}.sidebar-nav{flex:1;padding:0 14px 24px}.nav-section{margin-bottom:16px}.nav-changelog-section .nav-section-title{text-decoration:none;color:inherit}.nav-changelog-section .nav-section-title:hover{transform:translateY(-1px);box-shadow:0 16px 28px #6d5df61f;background:linear-gradient(135deg,#eff6fffa,#f3f1ff);border-color:#dcd7ff}.nav-changelog-section .nav-section-title.active{background:#f3f1ff;border-color:#dcd7ff;color:#4f46e5;box-shadow:0 18px 34px #6d5df61f}.nav-section-title{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 14px;margin-bottom:10px;border:0;background:#ffffffeb;border-radius:11px;border:1px solid rgba(226,232,240,.96);box-shadow:none;color:var(--text-primary);text-align:left}.nav-review-title{position:relative;overflow:hidden;padding:14px;background:linear-gradient(135deg,#f5f3ff,#eef2ff 58%,#fff);border-color:#e2dfff;box-shadow:0 16px 34px #6358dc1a;text-decoration:none}.nav-review-title:after{content:"";position:absolute;inset:auto -28px -40px auto;width:96px;height:96px;border-radius:50%;background:#6358dc1a;pointer-events:none}.nav-review-title:hover{transform:translateY(-1px);box-shadow:0 20px 40px #6358dc24}.nav-review-main{position:relative;z-index:1;flex:1;min-width:0;color:inherit;text-decoration:none}.nav-review-title .nav-section-icon{width:38px;height:38px;background:linear-gradient(135deg,#6658e8,#7c6ff0);color:#fff;box-shadow:0 12px 24px #4f46e538}.nav-review-title:hover .nav-section-icon{transform:translateY(-1px) rotate(6deg) scale(1.04)}.nav-review-title .nav-section-name{color:#312e81}.nav-review-meta{display:block;margin-top:3px;color:#6358dc;font-size:.75rem;font-weight:700;line-height:1.25}.nav-review-cta{position:relative;z-index:1;flex-shrink:0;padding:7px 11px;border-radius:999px;background:linear-gradient(135deg,#6658e8,#7c6ff0);color:#fff;font-size:.75rem;font-weight:800;box-shadow:0 10px 20px #4f46e53d;text-decoration:none;transition:transform .18s ease,box-shadow .18s ease,filter .18s ease}.nav-review-cta:hover{transform:translateY(-1px);filter:brightness(1.03);box-shadow:0 14px 24px #4f46e54d}.nav-section-title.collapsible{cursor:pointer;-webkit-user-select:none;user-select:none;transition:var(--transition)}.nav-section-title.collapsible:hover{transform:none;box-shadow:none;border-color:#94a3b86b;background:#fffffffa}.nav-static-title{cursor:default}.nav-section-heading{display:flex;align-items:center;gap:12px;min-width:0}.nav-section-icon{width:34px;height:34px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f7f5ff,#ece9ff);color:#6358dc;flex-shrink:0;box-shadow:inset 0 0 0 1px #6358dc0f;transition:transform .18s ease,color .18s ease,background .18s ease,box-shadow .18s ease}.nav-section-svg{width:18px;height:18px}.nav-section-text{display:flex;flex-direction:column;min-width:0}.nav-section-eyebrow{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#6358dc}.nav-section-name{font-size:1rem;font-weight:800;color:#0f172a}.nav-level-section>.nav-section-title{background:linear-gradient(135deg,#fffffffa,#f5f3ffd1);border-color:#e2dffff2;box-shadow:0 10px 24px #6358dc0f}.nav-level-section>.nav-section-title .nav-section-icon{width:36px;height:36px;color:#6358dc}.nav-level-section>.nav-section-title:hover .nav-section-icon,.nav-special-section>.nav-section-title:hover .nav-section-icon,.nav-personal-section>.nav-section-title:hover .nav-section-icon,.nav-changelog-section .nav-section-title:hover .nav-section-icon{transform:translateY(-1px) scale(1.04);background:linear-gradient(135deg,#6658e8,#7c6ff0);color:#fff;box-shadow:0 10px 20px #6358dc29}.nav-level-section>.nav-section-title.collapsible:hover{background:linear-gradient(135deg,#fff,#f3f1ff);border-color:#e2dfff;box-shadow:0 14px 28px #6358dc14;transform:translateY(-1px)}.nav-personal-section .nav-section-title,.nav-changelog-section .nav-section-title,.nav-support-section .nav-item{box-shadow:0 6px 16px #94a3b80f}.nav-section-side{display:flex;align-items:center;gap:10px;margin-left:12px;color:var(--text-muted);flex-shrink:0}.nav-section-count{min-width:30px;height:24px;padding:0 9px;border-radius:7px;background:#f3f1ff;color:#6358dc;font-size:.72rem;font-weight:700;line-height:1;display:inline-flex;align-items:center;justify-content:center;font-variant-numeric:tabular-nums}.chevron-icon{width:14px;height:14px;transition:transform .3s ease;flex-shrink:0}.chevron-icon.collapsed{transform:rotate(-90deg)}.nav-section-items{overflow:hidden;max-height:2000px;transition:max-height .35s ease-in-out,opacity .25s ease;opacity:1}.nav-section-items.collapsed{max-height:0;opacity:0}.nav-level-exams,.nav-year-set-list,.nav-special-list,.nav-personal-list,.nav-item-group-list{display:flex;flex-direction:column;gap:4px}.nav-year-group{position:relative;margin-bottom:2px}.nav-year-header{display:flex;align-items:center;gap:9px;width:100%;min-height:32px;padding:5px 9px;border:0;background:transparent;text-align:left;cursor:pointer;border-radius:7px;transition:background .16s ease,color .16s ease}.nav-year-header:hover{background:#f1f5f9e6}.nav-year-header .nav-year-chevron{width:14px;height:14px;color:#94a3b8;flex-shrink:0;transition:transform .18s ease,color .16s ease;transform:rotate(90deg)}.nav-year-chevron.collapsed{transform:rotate(0)}.nav-year-header .nav-year-title{font-size:.84rem;font-weight:700;color:#1e293b;letter-spacing:.01em}.nav-year-header .nav-year-count{font-size:.72rem;color:#94a3b8;font-weight:600;margin-left:auto;font-variant-numeric:tabular-nums}.nav-month-list{padding-left:16px;overflow:hidden;max-height:2000px;transition:max-height .3s ease,opacity .25s ease;opacity:1;margin-top:1px}.nav-month-list.collapsed{max-height:0;opacity:0}.nav-month-group{position:relative;margin-bottom:1px}.nav-month-header{display:flex;align-items:center;gap:9px;width:100%;min-height:30px;padding:4px 9px;border:0;background:transparent;text-align:left;cursor:pointer;border-radius:6px;transition:background .16s ease,color .16s ease}.nav-month-header:hover{background:#f1f5f9c2}.nav-month-header .nav-month-chevron{width:13px;height:13px;color:#94a3b8;flex-shrink:0;transition:transform .18s ease,color .16s ease;transform:rotate(90deg)}.nav-month-chevron.collapsed{transform:rotate(0)}.nav-month-header .nav-month-title{font-size:.8rem;font-weight:650;color:#334155;letter-spacing:.01em}.nav-month-header .nav-month-count{font-size:.7rem;color:#94a3b8;font-weight:550;margin-left:auto;font-variant-numeric:tabular-nums}.nav-set-list{padding-left:22px;margin-top:1px;margin-bottom:4px;overflow:hidden;max-height:2000px;transition:max-height .3s ease,opacity .25s ease;opacity:1}.nav-set-list.collapsed{max-height:0;opacity:0}.nav-set-item{display:flex;align-items:center;gap:12px;min-height:44px;padding:8px 10px 8px 12px;margin:0 0 3px;border-radius:9px;text-decoration:none;color:#475569;font-size:.8rem;transition:background-color .16s ease,color .16s ease,border-color .16s ease,box-shadow .16s ease,transform .16s ease;position:relative;border:1px solid transparent;background:transparent;box-shadow:none}.nav-set-item:hover{transform:translateY(-1px);background:#ffffffb8;border-color:#e2dfff;box-shadow:0 8px 18px #6358dc12;color:#1e293b}.nav-set-item.active{background:#f5f2ff;border-color:#e2dfff;color:#5f55d6;font-weight:700;box-shadow:0 8px 18px #6358dc12}.nav-set-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:28px;background:#6658e8;border-radius:999px}.nav-set-title{color:inherit;text-align:left;flex:1;min-width:0;display:flex;align-items:center;gap:7px;font-size:.78rem;font-weight:550}.nav-set-item.active .nav-set-title{font-weight:700}.nav-set-progress{width:92px;flex-shrink:0;display:inline-flex;flex-direction:column;gap:3px;align-items:center}.nav-set-progress-label{color:#94a3b8;font-size:.66rem;font-weight:600;line-height:1;text-align:center;white-space:nowrap;font-variant-numeric:tabular-nums}.nav-set-progress-track{display:block;width:82px;height:5px;margin-left:0;overflow:hidden;border-radius:999px;background:#cbd5e1}.nav-set-progress-fill{display:block;height:100%;min-width:0;border-radius:inherit;background:linear-gradient(90deg,#a39bf4,#6658e8);transition:width .25s ease}.nav-set-progress.status-completed .nav-set-progress-label{color:#5f55d6}.nav-set-progress.status-completed .nav-set-progress-fill{background:linear-gradient(90deg,#6658e8,#5f55d6)}.nav-set-progress.mastery-complete .nav-set-progress-label{color:#34d399}.nav-set-progress.mastery-complete .nav-set-progress-fill{background:linear-gradient(90deg,#6ee7b7,#34d399)}.nav-set-progress.status-pending .nav-set-progress-label{color:#94a3b8}.nav-set-progress.status-pending .nav-set-progress-fill{background:transparent}.nav-year-group.contains-active .nav-year-header{background:#eef2ffd1}.nav-year-group.contains-active .nav-year-title{color:#312e81}.nav-year-group.contains-active .nav-year-count{color:#94a3b8}.nav-year-group.contains-active .nav-year-chevron{color:#6d5df6}.nav-year-group.status-completed .nav-year-count,.nav-year-group.status-in-progress .nav-year-count{color:#94a3b8}.nav-month-group.contains-active .nav-month-header{background:#eef2ff99}.nav-month-group.contains-active .nav-month-title{color:#312e81}.nav-month-group.contains-active .nav-month-count{color:#94a3b8}.nav-month-group.contains-active .nav-month-chevron{color:#6d5df6}.nav-month-group.status-completed .nav-month-count{color:#a8b3c3}.nav-month-group.status-in-progress .nav-month-count{color:#94a3b8}.nav-item{display:flex;align-items:flex-start;gap:14px;padding:12px 12px 12px 14px;color:var(--text-secondary);text-decoration:none;border-radius:14px;transition:var(--transition);margin-bottom:0;position:relative;background:#ffffffe0;border:1px solid rgba(226,232,240,.9);box-shadow:0 6px 16px #94a3b814}.nav-item:hover{transform:translateY(-1px);background:#f3f1ff;border-color:#e2dfff;box-shadow:0 16px 30px #6358dc14;color:#6358dc}.nav-item.active{background:#f3f1ff;border-color:#e2dfff;color:#5f55d6;box-shadow:0 14px 28px #6358dc14}.nav-item-accent{position:absolute;left:-1px;top:12px;bottom:12px;width:4px;border-radius:999px;background:linear-gradient(180deg,#6658e8,#6658e8);opacity:0;transition:opacity .25s ease}.nav-item.active .nav-item-accent,.nav-item:hover .nav-item-accent{opacity:1}.nav-item-icon-wrap{width:38px;height:38px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f7f5ff,#ece9ff);color:#6358dc;flex-shrink:0;box-shadow:inset 0 0 0 1px #6358dc0f;transition:transform .18s ease,color .18s ease,background .18s ease,box-shadow .18s ease}.nav-item:hover .nav-item-icon-wrap,.nav-item.active .nav-item-icon-wrap{transform:translateY(-1px) scale(1.04);background:linear-gradient(135deg,#6658e8,#7c6ff0);color:#fff;box-shadow:0 10px 20px #6358dc29}.nav-item-content{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1}.nav-item-topline{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.nav-item-title-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.nav-pill{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;background:#f3f1ff;color:#6358dc;font-size:.7rem;font-weight:800;letter-spacing:.06em}.nav-item-meta{font-size:.72rem;color:#94a3b8;font-weight:700}.nav-item-title{font-size:.94rem;font-weight:800;color:#0f172a;line-height:1.35}.nav-item-description{font-size:.76rem;color:#94a3b8;line-height:1.5}.nav-item-status{display:inline-flex;align-items:center;gap:8px;font-size:.72rem;font-weight:700;color:#6358dc}.nav-item-eq{display:inline-flex;align-items:flex-end;gap:3px;height:12px}.nav-item-eq span{width:3px;border-radius:999px;background:linear-gradient(180deg,#6658e8,#6658e8);animation:nav-eq 1s ease-in-out infinite}.nav-item-eq span:nth-child(1){height:8px}.nav-item-eq span:nth-child(2){height:12px;animation-delay:.15s}.nav-item-eq span:nth-child(3){height:6px;animation-delay:.3s}@keyframes nav-eq{0%,to{transform:scaleY(.65);opacity:.65}50%{transform:scaleY(1);opacity:1}}.nav-icon{width:18px;height:18px;flex-shrink:0}.nav-listening-card.playing .nav-item-icon-wrap{background:linear-gradient(135deg,#3b82f629,#a594f933)}.nav-complete-check{width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:#f3f1ff;color:#6358dc;border:1px solid #DCD7FF;box-shadow:0 10px 18px #6d5df61f;flex-shrink:0}.nav-submenu-item{margin-left:14px;padding:14px}.nav-submenu-icon-wrap{width:22px;height:22px;border-radius:10px;background:transparent;color:#6b7280;box-shadow:none}.nav-submenu-icon{width:16px;height:16px}.nav-submenu-item:hover .nav-submenu-icon-wrap,.nav-submenu-item.active .nav-submenu-icon-wrap{color:#6358dc}.nav-check-icon{width:14px;height:14px}.nav-special-item .nav-item-title,.nav-personal-item .nav-item-title{font-size:.9rem}.support-card{margin-top:10px;background:linear-gradient(135deg,#fffffff0,#f5f3ffe6);border-color:#e2dfff;box-shadow:0 18px 32px #6358dc14}.support-card:hover{background:#f3f1ff;border-color:#e2dfff}.support-icon{width:18px;height:18px;flex-shrink:0}.support-icon-wrap{background:linear-gradient(135deg,#f7f5ff,#ece9ff);color:#6358dc}.menu-toggle{width:42px;height:42px;border-radius:14px;border:1px solid rgba(148,163,184,.18);background:#ffffffe6;color:#475569;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);box-shadow:0 10px 24px #94a3b81f}.menu-toggle:hover{transform:translateY(-1px);color:#6358dc;border-color:#e2dfff;background:#f3f1ff}.menu-toggle svg{width:18px;height:18px}body.sidebar-collapsed .sidebar{transform:translate(-100%)}body.sidebar-collapsed .main-content{margin-left:0;max-width:100vw}body.sidebar-collapsed .floating-action-bar,body.sidebar-collapsed .ai-summon-btn{opacity:.3;pointer-events:none}.main-content{margin-left:var(--sidebar-width);flex:1;padding:28px 40px;min-height:100vh;max-width:calc(100vw - var(--sidebar-width));overflow-y:auto}.main-content.player-page-content{height:100vh;overflow-y:hidden}.header-left{position:relative;display:flex;align-items:center;gap:26px}.page-title{display:flex;align-items:center;gap:8px}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#ffffffe6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;opacity:0;transition:opacity .3s ease}.loading-overlay.active{opacity:1}.loading-spinner{display:flex;flex-direction:column;align-items:center;gap:16px}.spinner-ring{width:48px;height:48px;border:4px solid var(--bg-hover);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--text-secondary);font-size:.875rem}.toast-container{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:12px}.toast{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--bg-card);border-radius:var(--radius);box-shadow:0 10px 40px #00000026;transform:translate(120%);opacity:0;transition:all .3s cubic-bezier(.4,0,.2,1);max-width:400px}.toast.show{transform:translate(0);opacity:1}.toast-success{border-left:4px solid var(--success)}.toast-error{border-left:4px solid var(--danger)}.toast-warning{border-left:4px solid var(--warning)}.toast-info{border-left:4px solid var(--primary)}.toast-icon{width:24px;height:24px;flex-shrink:0}.toast-success .toast-icon{color:var(--success)}.toast-error .toast-icon{color:var(--danger)}.toast-warning .toast-icon{color:var(--warning)}.toast-info .toast-icon{color:var(--primary)}.toast-message{flex:1;font-size:.9375rem;color:var(--text-primary)}.toast-close{width:24px;height:24px;border:none;background:none;color:var(--text-muted);cursor:pointer;font-size:1.25rem;line-height:1;opacity:.6;transition:opacity .2s}.toast-close:hover{opacity:1}.transcript-container.blurred .transcript-item .transcript-bubble p{filter:blur(5px);-webkit-user-select:none;user-select:none;will-change:filter;transform:translateZ(0);backface-visibility:hidden}.transcript-container.blurred .transcript-item:hover .transcript-bubble p{filter:blur(0);transition:filter .2s ease}.transcript-item{will-change:transform,background-color;transition:transform .2s ease,background-color .2s ease}@media (max-width: 1024px){.stats-overview{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.sidebar{width:min(300px,82vw);transform:translate(-100%);transition:transform .3s ease;z-index:1000;box-shadow:4px 0 20px #00000026}.sidebar:after{width:min(300px,82vw)}.sidebar-nav{padding:0 14px 24px}.nav-section-title{padding:14px 16px;border-radius:18px}.nav-year-card{padding:14px;border-radius:18px}.nav-item{padding:12px 12px 12px 14px}.sidebar.open{transform:translate(0)}.content-header{gap:12px}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;opacity:0;visibility:hidden;transition:all .3s ease;z-index:999}.sidebar-overlay.active{opacity:1;visibility:visible}.main-content{margin-left:0;padding:24px 20px;max-width:100vw}.stats-overview{grid-template-columns:1fr}.player-capsule{flex-wrap:wrap;gap:16px}.progress-section{order:3;width:100%}.player-controls{order:2}.detail-tabs{flex-direction:column}.audio-item{flex-direction:column;align-items:flex-start;gap:16px}.btn-listen{width:100%;justify-content:center}.floating-action-bar{width:calc(100% - 32px);justify-content:center;padding:8px 12px}.feedback-btn span{display:none}.feedback-btn{padding:14px;min-width:48px;justify-content:center}}@media (max-width: 480px){.main-content{padding:16px 12px}.stats-overview{grid-template-columns:1fr;gap:12px}.transcript-container{padding:20px}.transcript-item{gap:12px}.speaker-avatar{width:32px;height:32px;font-size:.8125rem}.floating-action-bar{bottom:20px;padding:8px 12px}}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0000004d;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;opacity:0;visibility:hidden;transition:all .3s ease}.modal-overlay.active{opacity:1;visibility:visible}.dialog-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0000004d;-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:3000;opacity:0;visibility:hidden;transition:all .3s ease;backdrop-filter:blur(4px)}.dialog-overlay.active{opacity:1;visibility:visible}.dialog-container{background:#fff;border-radius:16px;width:90%;max-width:420px;padding:28px;transform:scale(.9);transition:transform .3s ease;box-shadow:0 20px 60px #0003}.dialog-overlay.active .dialog-container{transform:scale(1)}.dialog-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.dialog-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:var(--primary)}.dialog-icon svg{width:100%;height:100%}.dialog-icon.warning{color:var(--warning, #f59e0b)}.dialog-icon.danger{color:var(--danger, #ef4444)}.dialog-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0}.dialog-body{font-size:.9375rem;color:var(--text-secondary);line-height:1.6;margin-bottom:24px}.dialog-footer{display:flex;gap:12px;justify-content:flex-end}.dialog-btn{padding:10px 24px;border-radius:var(--radius);font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.dialog-cancel{background:var(--bg-hover);color:var(--text-secondary)}.dialog-cancel:hover{background:var(--bg-active);color:var(--text-primary)}.dialog-confirm{background:var(--primary);color:#fff}.dialog-confirm:hover{background:var(--primary-dark);transform:translateY(-1px)}.dialog-confirm.danger{background:var(--danger)}.dialog-confirm.danger:hover{background:#dc2626}.modal-container{background:#fff;border-radius:24px;width:90%;max-width:420px;padding:32px;box-shadow:var(--shadow-hover);transform:scale(.9) translateY(20px);transition:all .3s ease;border:1px solid rgba(255,255,255,1)}.modal-overlay.active .modal-container{transform:scale(1) translateY(0)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.modal-header h2{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.modal-close{width:32px;height:32px;border-radius:50%;background:var(--bg-hover);border:none;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-card)}.modal-close:hover{background:#f3f1ff;color:var(--primary)}.modal-close svg{width:18px;height:18px}.support-intro{text-align:center;color:var(--text-secondary);font-size:.9375rem;margin-bottom:24px;line-height:1.6}.payment-methods{display:flex;gap:12px;margin-bottom:24px}.payment-card{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;background:#f9fafb;border:2px solid transparent;border-radius:12px;cursor:pointer;transition:all .2s ease}.payment-card:hover{background:#f3f4f6}.payment-card .payment-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.payment-card[data-method=wechat] .payment-icon{background:#07c160;color:#fff}.payment-card[data-method=share] .payment-icon{background:linear-gradient(135deg,#60a5fa,#6d5df6);color:#fff}.payment-card .payment-icon svg{width:24px;height:24px}.payment-card span{font-size:.875rem;font-weight:500;color:var(--text-primary)}.share-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;background:linear-gradient(135deg,#f3f1ff,#6d5df614);border:2px solid #6D5DF6;border-radius:12px;cursor:pointer;transition:var(--transition)}.share-btn:hover{background:linear-gradient(135deg,#f3f1ff,#6d5df626)}.share-btn svg{width:24px;height:24px;color:#6d5df6}.share-btn span{font-size:.875rem;font-weight:600;color:#6d5df6}.qrcode-section{margin-bottom:32px}.qrcode-container{display:none;padding:24px 20px 20px;background:#f3f1ff;border:1px solid #DCD7FF;border-radius:18px}.qrcode-container.active{display:block}.qrcode-box{width:180px;height:180px;margin:0 auto 12px;background:#f9fafb;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000000a}.qrcode-box img{width:100%;height:100%;object-fit:cover}.qrcode-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0f0f0,#e0e0e0)}.qrcode-placeholder svg{width:48px;height:48px;color:#ccc}.qrcode-tip{text-align:center;color:#6b7280;font-size:.8125rem}.support-note{text-align:left;color:#4b5563;font-size:.875rem;line-height:1.7}.contact-info{color:#6d5df6;font-weight:700}.qrcode-mobile-hint{margin:12px 0 0;text-align:center;color:#6d5df6;font-size:.8125rem;font-weight:500;letter-spacing:.2px}.copy-wxid-btn{display:inline-flex;align-items:center;gap:6px;margin:14px auto 0;padding:9px 18px;background:linear-gradient(135deg,#6d5df6,#6d5df6);color:#fff;border:none;border-radius:999px;font-size:.8125rem;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #6d5df64d;transition:transform .18s ease,box-shadow .18s ease}.copy-wxid-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px #6d5df666}.copy-wxid-btn:active{transform:translateY(0)}.copy-wxid-btn svg{width:14px;height:14px}.qrcode-container .copy-wxid-btn{display:flex;width:max-content}.support-contact-line{display:flex;align-items:center;justify-content:flex-start;flex-wrap:wrap;gap:8px;margin-top:12px;padding:10px 14px;background:#f3f1ff;border-radius:10px;font-size:.875rem;color:#4b5563}.support-contact-line .contact-label{color:#6d5df6;font-weight:600}.contact-email-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:transparent;padding:0;color:#6d5df6;font-weight:700;font-size:.9375rem;cursor:pointer;letter-spacing:.2px;text-decoration:underline;text-decoration-color:#a594f973;text-underline-offset:3px;transition:color .2s ease,text-decoration-color .2s ease}.contact-email-btn:hover{color:#6d5df6;text-decoration-color:#4f46e5}.contact-email-btn:active{transform:translateY(1px)}.share-btn-compact{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;border:1px solid rgba(148,163,184,.35);border-radius:999px;color:#64748b;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .2s ease;margin-bottom:20px}.share-btn-compact:hover{border-color:#a594f999;color:#6d5df6;background:#f3f1ff}.share-btn-compact svg{width:14px;height:14px}.qrcode-section-minimal{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:24px}.qrcode-section-minimal .qrcode-box{width:160px;height:160px;margin:0 auto;background:#f9fafb;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000000a}.qrcode-wxid{font-size:.8125rem;color:#94a3b8;cursor:pointer;transition:color .2s ease;-webkit-user-select:none;user-select:none}.qrcode-wxid:hover{color:#6d5df6}.support-footer{text-align:center;font-size:.8125rem;color:#94a3b8;line-height:1.8;margin:0}.contact-email-inline{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:transparent;padding:0;color:#6d5df6;font-weight:600;font-size:inherit;cursor:pointer;text-decoration:underline;text-decoration-color:#a594f966;text-underline-offset:2px;transition:color .2s ease}.contact-email-inline:hover{color:#6d5df6}@media (max-width: 480px){.modal-container{padding:24px;margin:16px}.payment-methods{flex-direction:column}.qrcode-box,.qrcode-section-minimal .qrcode-box{width:150px;height:150px}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background-color:#0000001f;border-radius:10px}::-webkit-scrollbar-thumb:hover{background-color:#00000040}::-webkit-scrollbar-button{display:none}::-webkit-scrollbar-corner{background:transparent}html{scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.15) transparent}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}@keyframes fadeOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(20px)}}.notification{position:fixed;top:20px;right:20px;background:#fff;padding:16px 20px;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;align-items:center;gap:12px;z-index:1000;animation:slideIn .3s ease;max-width:400px}.notification-success{border-left:4px solid #10B981}.notification-error{border-left:4px solid #EF4444}.notification-info{border-left:4px solid #6D5DF6}.notification-warning{border-left:4px solid #F59E0B}.notification span{flex:1}.notification button{background:none;border:none;font-size:20px;cursor:pointer;color:#999;padding:0;line-height:1;transition:color .2s}.notification button:hover{color:#333}.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#8b7dc8,#a594d0,#c4b5e0)}.login-container{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-hover);padding:48px;max-width:460px;width:92%;text-align:center}.login-header{margin-bottom:36px}.logo{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:24px}.logo-icon{width:42px;height:42px;background:linear-gradient(135deg,#6d5df6,#6d5df6);border-radius:14px;flex-shrink:0;position:relative;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 12px #6d5df659}.logo-icon svg{width:100%;height:100%}.logo-icon .cute-face{width:22px;height:22px}.logo-icon .cute-note{width:12px;height:12px}.logo-text-wrapper{display:flex;flex-direction:column;align-items:flex-start;line-height:1}.logo-text{font-size:1.3rem;font-weight:900;color:var(--text-primary);letter-spacing:.08em}.logo-subtitle{margin-top:3px;color:#6d5df6;font-size:.85rem;font-weight:800}.login-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:8px}.login-subtitle{font-size:.9375rem;color:var(--text-secondary)}.login-form,.register-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;align-items:flex-start;gap:8px}.form-label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.form-input{width:100%;padding:14px 18px;border:1px solid var(--border);border-radius:var(--radius);font-size:.9375rem;background-color:var(--bg-app);transition:var(--transition);font-family:inherit}.form-input:focus{outline:none;border-color:var(--primary);background-color:var(--bg-card);box-shadow:0 0 0 4px #8b7dc81a}.password-input{position:relative;width:100%}.toggle-password{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center}.toggle-password svg{width:20px;height:20px;color:var(--text-muted);transition:var(--transition)}.toggle-password:hover svg{color:var(--primary)}.form-options{display:flex;justify-content:space-between;align-items:center;margin-top:8px}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:.875rem;color:var(--text-secondary);cursor:pointer}.form-checkbox{width:18px;height:18px;accent-color:var(--primary)}.forgot-password{font-size:.875rem;color:var(--primary);text-decoration:none;transition:var(--transition)}.forgot-password:hover{text-decoration:underline}.login-btn{width:100%;padding:16px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);color:#fff;border:none;border-radius:var(--radius);font-size:1rem;font-weight:600;cursor:pointer;transition:var(--transition)}.login-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #8b7dc84d}.register-link{margin-top:20px;font-size:.875rem;color:var(--text-secondary)}.register-link a{color:var(--primary);text-decoration:none;font-weight:500;transition:var(--transition)}.register-link a:hover{text-decoration:underline}.onboarding-body{min-height:100vh;background:radial-gradient(circle at top left,rgba(96,165,250,.16),transparent 26%),linear-gradient(180deg,#f8fbff,#f3f1ff 48%,#fcfcff);color:#0f172a}.onboarding-shell{max-width:1120px;margin:0 auto;padding:64px 24px 80px}.onboarding-hero{text-align:center;max-width:760px;margin:0 auto 40px}.onboarding-illustration{width:min(240px,72%);margin:0 auto 18px}.onboarding-illustration svg{width:100%;height:auto}.empty-cloud{fill:#e0f2fe}.empty-head{fill:#fff7ed;stroke:#f59e0b;stroke-width:2}.empty-headband,.empty-smile{stroke:#6d5df6;stroke-width:6;stroke-linecap:round}.empty-earcup{fill:#6d5df6}.empty-face{fill:#334155}.empty-sparkle{fill:#fbbf24}.onboarding-eyebrow{font-size:.85rem;letter-spacing:.18em;text-transform:uppercase;color:#6d5df6;font-weight:700;margin-bottom:10px}.onboarding-title{font-size:clamp(2rem,4vw,3rem);line-height:1.08;color:#0f172a;margin-bottom:14px}.onboarding-subtitle{max-width:520px;margin:0 auto;color:#64748b;font-size:1rem}.onboarding-options{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px;align-items:stretch}.onboarding-option-card{position:relative;padding:32px;border-radius:28px;background:#ffffffeb;border:1px solid rgba(191,219,254,.7);box-shadow:0 24px 50px #94a3b81f}.onboarding-option-card.featured{background:radial-gradient(circle at top right,rgba(109,93,246,.1),transparent 28%),linear-gradient(145deg,#fffffffa,#f3f1ff)}.onboarding-option-top{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:14px}.onboarding-option-label{font-size:.8rem;font-weight:800;letter-spacing:.16em;color:#6366f1;text-transform:uppercase;margin-bottom:8px}.onboarding-option-top h2{font-size:1.75rem;line-height:1.15}.onboarding-option-badge{padding:8px 12px;border-radius:999px;background:#f3f1ff;color:#4f46e5;font-size:.78rem;font-weight:700}.onboarding-option-badge.subtle{background:#94a3b81f;color:#475569}.onboarding-option-desc{color:#64748b;line-height:1.8;margin-bottom:22px}.onboarding-time-hint{text-align:center;color:#94a3b8;font-size:.9rem;margin-top:20px}.onboarding-option-actions{display:flex;flex-wrap:wrap;gap:12px}.onboarding-primary-btn,.onboarding-secondary-btn{border:0;border-radius:999px;padding:12px 18px;font:inherit;font-weight:700;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.onboarding-primary-btn{background:linear-gradient(135deg,#6d5df6,#4f46e5);color:#fff;box-shadow:0 14px 28px #a594f947}.onboarding-secondary-btn{background:#ffffffe6;color:#334155;border:1px solid rgba(148,163,184,.28)}.onboarding-primary-btn:hover,.onboarding-secondary-btn:hover{transform:translateY(-1px)}.onboarding-highlight{z-index:1602;backdrop-filter:none;-webkit-backdrop-filter:none}.onboarding-highlight:not(.ai-summon-btn):not(.floating-action-bar):not(.menu-toggle){position:relative}.onboarding-highlight.menu-toggle,.player-page-content .onboarding-highlight.menu-toggle{position:absolute!important;z-index:1610!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;filter:none!important}.onboarding-highlight-box{position:fixed;z-index:1603;pointer-events:none;border:2px solid rgba(96,165,250,.72);border-radius:12px;box-shadow:0 0 0 2px #60a5fa24,0 10px 24px #3b82f638;transition:top .28s cubic-bezier(.34,1.56,.64,1),left .28s cubic-bezier(.34,1.56,.64,1),width .28s cubic-bezier(.34,1.56,.64,1),height .28s cubic-bezier(.34,1.56,.64,1),opacity .2s ease}.onboarding-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1601;pointer-events:none}.onboarding-mask-svg{width:100%;height:100%;display:block}.onboarding-mask-path{fill:#0f172a52}.onboarding-popover{position:fixed;z-index:2500;width:min(320px,calc(100vw - 32px));transition:top .38s cubic-bezier(.34,1.56,.64,1),left .38s cubic-bezier(.34,1.56,.64,1)}.onboarding-popover-instant{transition:none!important}@keyframes popIn{0%{opacity:0;transform:translateY(10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes popOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-10px) scale(.95)}}.onboarding-popover-active{animation:popIn .3s cubic-bezier(.175,.885,.32,1.275) forwards}.onboarding-popover-leaving{animation:popOut .2s cubic-bezier(.55,.085,.68,.53) forwards}.onboarding-popover-arrow{position:absolute;width:12px;height:12px;background:#f3f1ff;border:1px solid #DCD7FF;pointer-events:none;z-index:2;transition:left .36s cubic-bezier(.22,.61,.36,1)}.onboarding-popover[data-placement=bottom] .onboarding-popover-arrow{top:-7px;transform:translate(-50%) rotate(45deg)}.onboarding-popover[data-placement=top] .onboarding-popover-arrow{bottom:-7px;transform:translate(-50%) rotate(225deg)}.onboarding-popover-inner{padding:18px 18px 14px;border-radius:20px;background:#f3f1ff;color:#4f46e5;border:1px solid #DCD7FF;box-shadow:0 20px 45px #a594f929}.onboarding-popover-text{font-size:.95rem;line-height:1.7;margin:0 0 12px}.onboarding-popover-actions{display:flex;justify-content:flex-end;gap:10px}.onboarding-btn{border:0;border-radius:999px;padding:8px 14px;cursor:pointer;font-size:.82rem;font-weight:700;transition:transform .2s ease,opacity .2s ease}.onboarding-btn:hover{transform:translateY(-1px)}.onboarding-btn-secondary{background:#ffffffb8;color:#6d5df6;border:1px solid rgba(167,139,250,.28)}.onboarding-btn-primary{background:linear-gradient(135deg,#6d5df6,#4f46e5);color:#fff}.onboarding-btn-skip{display:block;margin:10px auto 0;background:transparent;color:#94a3b8;border:0;padding:6px 10px;font-size:.78rem;font-weight:500;cursor:pointer;transition:color .2s ease}.onboarding-btn-skip:hover{color:#64748b;text-decoration:underline}.onboarding-popover-progress{font-size:.75rem;font-weight:700;color:#6366f1;letter-spacing:.05em;margin-bottom:8px;text-transform:uppercase}@media (max-width: 480px){.onboarding-shell{padding:32px 16px 56px}.onboarding-option-card{padding:24px 20px}.onboarding-option-top{flex-direction:column}.onboarding-popover-actions{flex-direction:column;align-items:stretch}}@media (max-width: 900px){.onboarding-options{grid-template-columns:1fr}}.transcript-bubble p,.ai-original-sentence,.ai-response{font-size:18px}.dropdown-title{cursor:pointer;-webkit-user-select:none;user-select:none;padding:11px 24px 12px;margin:-8px 0 -8px 8px;border-radius:var(--radius);transition:all .2s ease;background:var(--bg-card);border:1px solid rgba(226,232,240,.72);display:inline-flex;align-items:center;gap:16px;min-width:250px}.dropdown-title:hover{border-color:var(--primary);transform:translateY(-1px)}.dropdown-title .title-copy{min-width:0;display:flex;flex-direction:column;gap:4px;line-height:1.1}.dropdown-title .title-meta{color:#64748b;font-size:.75rem;font-weight:700;letter-spacing:0}.dropdown-title .title-text{font-size:1.0625rem;font-weight:700;color:#0f172a;letter-spacing:0}.dropdown-title .dropdown-arrow{width:20px;height:20px;color:var(--primary);transition:transform .25s ease}.dropdown-title.active .dropdown-arrow{transform:rotate(180deg)}.dropdown-title.active{background:var(--bg-card);border-color:#e2dfff}.title-dropdown{position:absolute;top:100%;left:0;z-index:100;margin-top:8px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-hover);overflow:hidden;max-height:0;opacity:0;transition:max-height .3s ease,opacity .25s ease;min-width:300px}.title-dropdown.active{max-height:400px;opacity:1}.dropdown-content{max-height:400px;overflow-y:auto}.listening-item{display:flex;align-items:center;gap:12px;padding:12px 18px;cursor:pointer;transition:background .2s ease;border-left:3px solid transparent}.listening-item:hover{background:var(--bg-hover)}.listening-item.active{background:#f3f1ff;border-left-color:#6d5df6}.listening-item .item-index{font-size:.75rem;font-weight:600;color:var(--text-muted);min-width:24px}.listening-item.active .item-index{color:var(--primary)}.listening-item .item-name{flex:1;font-size:.875rem;font-weight:500;color:var(--text-secondary)}.listening-item.active .item-name{color:var(--primary);font-weight:600}.listening-item .item-status{font-size:.6875rem;font-weight:600;color:var(--text-muted)}.listening-item .item-status.completed{color:#10b981}.listening-item .item-status.playing{color:var(--primary)}.content-header{display:flex;align-items:center;gap:18px;margin-bottom:28px}.header-left{display:flex;align-items:center;gap:18px}.page-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);letter-spacing:-.02em}.set-progress-indicator{margin-left:12px;font-size:.875rem;font-weight:600;color:#4f46e5;background:#f3f1ff;border:1px solid #DCD7FF;padding:4px 12px;border-radius:var(--radius-full)}.listening-favorite-btn{display:flex;align-items:center;gap:10px;margin-left:8px;padding:10px 18px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:var(--transition)}.listening-favorite-btn:hover{background:#8b7dc81a;border-color:var(--primary);color:var(--primary)}.listening-favorite-btn.active{background:#f3f1ff;border-color:#6d5df6;color:#6d5df6}.listening-favorite-btn.active svg{fill:#6d5df6}.listening-favorite-btn svg{width:16px;height:16px}.player-mobile-favorite-btn{display:none}.player-capsule{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);height:72px;padding:0 24px;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:0;margin-bottom:32px;transition:var(--transition);border:1px solid rgba(0,0,0,.02);position:relative;z-index:2}.player-capsule:hover{box-shadow:0 18px 36px -20px #0f172a33,0 12px 22px -18px #0f172a1f;transform:translateY(-1px)}.player-topline,.player-mainrow{width:100%;display:flex;align-items:center}.player-topline{justify-content:space-between;gap:16px}.player-context{color:#1e293b;font-size:.88rem;font-weight:700;line-height:1.2}.player-mainrow{gap:20px;align-items:center}.player-inline-context{flex-shrink:0;padding:0 2px;color:#475569;font-size:.86rem;font-weight:700;line-height:1;white-space:nowrap}.play-btn{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,#6658e8,#5f55d6);border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;flex-shrink:0;align-self:center;padding:0;box-shadow:0 10px 22px #6358dc33}.play-btn:hover{transform:translateY(-2px);background:linear-gradient(135deg,#5f55d6,#5f55d6);box-shadow:0 12px 26px #5f55d63d}.play-icon{width:18px;height:18px}.progress-section{flex:1 1 500px;display:flex;align-items:center;gap:12px;min-width:160px;max-width:820px;align-self:center}.progress-bar-mini{flex:1;height:4px;background:var(--bg-app);border-radius:2px;position:relative;cursor:pointer}.progress-bar{position:relative;flex:1;height:5px;background:#eef1f7;border-radius:999px;cursor:pointer;overflow:visible;touch-action:none}.progress-fill{height:100%;background:#5f55d6;border-radius:999px;transform-origin:left center;transform:scaleX(0);will-change:transform}.progress-handle{position:absolute;top:50%;transform:translate(-50%,-50%);width:12px;height:12px;background:#5f55d6;border:2px solid #FFFFFF;border-radius:50%;pointer-events:none;box-shadow:0 1px 4px #5f55d647;transition:transform .14s ease;will-change:left}.progress-handle:hover{transform:translate(-50%,-50%) scale(1.2)}.time-info{display:flex;align-items:center;font-size:13px;color:#64748b;font-weight:600;letter-spacing:.5px;white-space:nowrap;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,Liberation Mono,monospace}.time-info .separator{color:var(--text-muted)}.player-controls{display:flex;align-items:center;justify-content:flex-end;gap:8px;margin-left:auto;flex-shrink:0}.control-btn{width:auto;min-width:42px;height:36px;padding:0 12px;border-radius:var(--radius);background:var(--bg-app);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);color:var(--text-secondary)}.speed-menu-wrapper{margin-right:4px}.dictation-btn{margin-left:4px}.control-btn:hover{background:#f3f1ff;color:#6d5df6;border-color:#dcd7ff}.control-btn svg{width:16px;height:16px;flex-shrink:0}.control-label{margin-left:6px;font-size:.78rem;font-weight:700;white-space:nowrap}.speed-btn{width:auto;padding:0 14px;font-size:.8125rem;font-weight:600}.speed-menu-wrapper{position:relative;z-index:100}.speed-menu{position:absolute;top:100%;left:-70px;margin-top:8px;background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-hover);padding:6px 8px;display:none;gap:4px;z-index:100}.speed-menu.active{display:flex}.speed-text{color:inherit}.reveal-btn{position:relative}.reveal-btn:after{content:"切换原文";position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:6px 12px;background:#0f172ae6;color:#fff;font-size:.75rem;border-radius:6px;white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s;margin-bottom:8px;pointer-events:none}.reveal-btn:hover:after{opacity:1;visibility:visible}.reveal-btn .eye-icon{transition:all .3s ease;stroke-width:1.5}.reveal-btn[data-mode=immersive]:after{content:"切换原文"}.reveal-btn[data-mode=immersive] .eye-icon{opacity:.6}.reveal-btn .eye-line{stroke:#475569;stroke-width:2}.dictation-btn{position:relative}.dictation-btn:after{content:"听写模式";position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:6px 12px;background:#0f172ae6;color:#fff;font-size:.75rem;border-radius:6px;white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s;margin-bottom:8px;pointer-events:none}.dictation-btn:hover:after{opacity:1;visibility:visible}.dictation-btn.active{background:#f3f1ff;color:#6d5df6;border:1px solid #DCD7FF}.dictation-btn svg{width:18px;height:18px}.transcript-container.immersive .transcript-item .transcript-bubble p{-webkit-user-select:text;user-select:text}.transcript-container.immersive .transcript-item.current .transcript-bubble p{filter:blur(0);font-weight:700;color:#1e1b4b}.loop-btn.active{background:#f3f1ff;color:#6d5df6;border:1px solid #DCD7FF}.speed-option{padding:8px 12px;border:none;background:none;border-radius:var(--radius-sm);font-size:.8125rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:var(--transition);white-space:nowrap}.speed-option:hover{background:var(--bg-hover);color:var(--primary)}.speed-option.active{background:#f3f1ff;color:#4f46e5;border:1px solid #DCD7FF}.transcript-section{margin-bottom:100px}.transcript-section:not(.immersive-active) .neighbor-card,.transcript-section:not(.immersive-active) .immersive-focus-stage{display:none!important}.transcript-section.immersive-active{display:grid;grid-template-columns:1fr 2.5fr 1fr;grid-template-rows:auto auto;gap:12px;align-items:stretch;margin-bottom:24px}.immersive-focus-stage{display:flex;flex-direction:column;position:relative;padding:18px 20px;border-radius:calc(var(--radius-lg) + 2px);border:1px solid #DCD7FF;background:linear-gradient(180deg,#fff,#f3f1ff);box-shadow:0 18px 32px -30px #1e293b6b;overflow:visible;grid-column:2;grid-row:1;min-height:540px;transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .25s ease;touch-action:pan-y}.immersive-focus-stage.swipe-dragging{transition:none}.immersive-focus-stage.swipe-reset{transform:translate(0)!important;opacity:1!important}.immersive-focus-stage.swipe-out-left{transform:translate(-40%) scale(.92);opacity:0}.immersive-focus-stage.swipe-out-right{transform:translate(40%) scale(.92);opacity:0}.immersive-focus-stage.swipe-in-left{animation:swipeInFromLeft .35s cubic-bezier(.4,0,.2,1) forwards}.immersive-focus-stage.swipe-in-right{animation:swipeInFromRight .35s cubic-bezier(.4,0,.2,1) forwards}@keyframes swipeInFromLeft{0%{transform:translate(-40%) scale(.92);opacity:0}to{transform:translate(0) scale(1);opacity:1}}@keyframes swipeInFromRight{0%{transform:translate(40%) scale(.92);opacity:0}to{transform:translate(0) scale(1);opacity:1}}.immersive-swipe-hint{position:absolute;top:50%;transform:translateY(-50%);padding:8px 14px;border-radius:999px;background:#0f172abf;color:#fff;font-size:.75rem;font-weight:600;opacity:0;transition:opacity .2s ease;pointer-events:none;z-index:10;white-space:nowrap}.immersive-swipe-hint.prev{left:12px}.immersive-swipe-hint.next{right:12px}.immersive-focus-stage.swipe-show-prev .immersive-swipe-hint.prev,.immersive-focus-stage.swipe-show-next .immersive-swipe-hint.next{opacity:1}.immersive-focus-stage:before{content:"";position:absolute;inset:0 0 auto;height:3px;background:linear-gradient(90deg,#6d5df6,#6d5df6,#6d5df6);opacity:.92}.immersive-focus-stage.empty{box-shadow:none}.immersive-focus-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.immersive-focus-label,.immersive-focus-line{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;font-size:.75rem;font-weight:700;letter-spacing:.03em}.immersive-focus-label{color:#4f46e5;background:#f3f1ff}.immersive-focus-line{color:#475569;background:#f1f5f9f5}.immersive-focus-head-left{display:flex;align-items:center;gap:12px}.immersive-play-btn{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#6d5df6,#4f46e5);border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #6d5df640;padding:0;flex-shrink:0}.immersive-play-btn:hover{transform:scale(1.1);box-shadow:0 6px 16px #4f46e559}.immersive-play-btn svg{width:14px;height:14px;margin-left:1px}.immersive-focus-body{display:flex;align-items:flex-start;gap:14px;min-height:98px;flex:1}.immersive-focus-speaker{margin-top:2px}.immersive-focus-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:10px;color:#0f172a;font-family:Iowan Old Style,Palatino Linotype,Book Antiqua,Baskerville,Georgia,Songti SC,STSong,"Noto Serif SC",serif;font-size:clamp(1.12rem,1.02rem + .34vw,1.3rem);font-weight:500;line-height:1.78;letter-spacing:.015em;caret-color:transparent}.immersive-focus-sentence{margin:0;padding:10px 0;color:inherit;font-family:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;letter-spacing:inherit;white-space:pre-wrap;border-bottom:1px solid rgba(226,232,240,.5)}.immersive-focus-sentence:last-child{border-bottom:none}.immersive-focus-sentence:first-child{padding-top:0}.transcript-section.immersive-active .floating-action-bar{position:relative;bottom:auto;left:auto;transform:none;grid-column:2;grid-row:2;z-index:auto;justify-self:center;opacity:1;pointer-events:auto}#immersiveBarTarget{display:flex;justify-content:center;margin-top:16px}.immersive-context-shell{display:grid;gap:10px;grid-column:1 / -1;grid-row:2}.transcript-section.immersive-active .immersive-context-shell{display:none}.neighbor-card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid rgba(226,232,240,.88);box-shadow:var(--shadow-soft);padding:14px 16px;display:flex;flex-direction:column;gap:10px;min-height:420px;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease,transform .15s ease;-webkit-user-select:none;user-select:none;caret-color:transparent}.neighbor-card:hover{border-color:#a78bfa73;box-shadow:0 8px 20px -8px #a594f92e;transform:translateY(-2px)}.neighbor-card:active{transform:translateY(0)}.neighbor-prev{grid-column:1;grid-row:1}.neighbor-next{grid-column:3;grid-row:1}.neighbor-head{display:flex;align-items:center}.neighbor-label{font-size:.75rem;font-weight:600;color:#94a3b8;background:#f1f5f9f5;padding:2px 10px;border-radius:999px}.neighbor-body{display:flex;align-items:flex-start;gap:10px;flex:1}.neighbor-speaker{width:28px;height:28px;border-radius:6px;font-size:.75rem;flex-shrink:0}.neighbor-text{flex:1;min-width:0;font-size:.875rem;color:#64748b;line-height:1.6;display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical;overflow:hidden}.neighbor-text.empty{display:flex;align-items:center;justify-content:center;color:#cbd5e1;font-size:1rem;letter-spacing:.15em;-webkit-line-clamp:unset;-webkit-user-select:none;user-select:none}.neighbor-card:not([data-index]){cursor:default}.neighbor-card:not([data-index]):hover{border-color:#e2e8f0e0;box-shadow:var(--shadow-soft);transform:none}.neighbor-card.review-hidden{cursor:default}.neighbor-card.review-hidden:hover{border-color:#e2e8f0e0;box-shadow:var(--shadow-soft);transform:none}.immersive-context-header{display:none;align-items:center;justify-content:space-between;gap:12px;padding:0 2px}.transcript-section.immersive-active .immersive-context-header{display:flex}.immersive-context-copy{display:grid;gap:2px}.immersive-context-title{color:#334155;font-size:.875rem;font-weight:700;line-height:1.2}.immersive-context-subtitle{color:#94a3b8;font-size:.75rem;line-height:1.3}.immersive-context-toggle{display:inline-flex;align-items:center;gap:8px;min-height:34px;padding:0 12px;border-radius:999px;border:1px solid rgba(203,213,225,.92);background:#ffffffeb;color:#475569;font-size:.8125rem;font-weight:600;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,color .2s ease}.immersive-context-toggle:hover{background:#f8fafc;border-color:#94a3b8d9;color:#1e293b}.immersive-context-chevron{width:14px;height:14px;transition:transform .22s ease}.transcript-section.immersive-context-collapsed .immersive-context-chevron{transform:rotate(180deg)}.transcript-container{background:#fff;border-radius:var(--radius-lg);box-shadow:0 12px 28px -18px #0f172a24;padding:18px;max-height:calc(100vh - 280px);overflow-y:auto;position:relative;z-index:1;border:1px solid rgba(226,232,240,.72)}.transcript-container.blurred .transcript-bubble p{filter:blur(5px);-webkit-user-select:text;user-select:text;transition:filter .3s ease}.transcript-container.blurred .speaker-avatar{filter:blur(5px);transition:filter .3s ease}.transcript-container.revealed .transcript-bubble p,.transcript-container.revealed .speaker-avatar{filter:blur(0)}.transcript-container.revealed:not(.immersive) .transcript-bubble p,.transcript-container.revealed:not(.immersive) .speaker-avatar{transition:none}.transcript-container.revealing .transcript-bubble p,.transcript-container.revealing .speaker-avatar{animation:revealText 1.5s ease-out forwards}.transcript-item.review-hidden .transcript-bubble p,.immersive-focus-stage.review-hidden .immersive-focus-text,.immersive-focus-text.review-hidden,.immersive-focus-stage.immersive-blurred .immersive-focus-text,.neighbor-card.review-hidden .neighbor-text,.neighbor-card.review-hidden .speaker-avatar{filter:blur(8px);user-select:none;-webkit-user-select:none}.immersive-focus-stage.immersive-blurred .immersive-focus-line{filter:blur(2px)}.feedback-tag{display:inline-flex;align-items:center;padding:0;border-radius:0;font-size:.72rem;font-weight:700;letter-spacing:0;margin-top:0;line-height:1.4;background:transparent;border:0;opacity:.72}.feedback-tag.understood{color:#4f9d7b}.feedback-tag.familiar{color:#a07722}.feedback-tag.unfamiliar{color:#be6963}.transcript-item.review-hidden .feedback-tag,.immersive-focus-stage.review-hidden .immersive-focus-line{filter:blur(2px)}.transcript-item.review-revealed .transcript-bubble p,.immersive-focus-stage.review-revealed .immersive-focus-text{filter:blur(0)}@keyframes revealText{0%{filter:blur(5px)}to{filter:blur(0)}}@keyframes fadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.floating-action-bar{position:fixed;bottom:32px;left:50%;transform:translate(-50%);background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-hover);padding:12px 24px;display:flex;gap:16px;z-index:1000;border:1px solid rgba(0,0,0,.03)}.feedback-btn-group{display:flex;align-items:center;gap:16px}.feedback-btn.reveal-answer{background:linear-gradient(135deg,#6658e8,#5f55d6);color:#fff;box-shadow:0 10px 22px #6358dc2e}.feedback-btn.reveal-answer:hover{background:linear-gradient(135deg,#5f55d6,#5f55d6);box-shadow:0 14px 26px #5f55d638}.feedback-btn.reveal-answer.revealed,.feedback-btn.reveal-answer:disabled{background:#f5f2ff;color:#5f55d6;cursor:default;box-shadow:none;border:1px solid #E2DFFF}.feedback-btn.share-roommate{background:#e0f2fe;color:#0369a1}.feedback-btn.share-roommate:hover{background:#bae6fd}.feedback-bar-copy{display:flex;align-items:center;padding:0 14px;border-radius:999px;background:#f5f2ff;border:1px solid #E2DFFF;color:#5f55d6;font-size:.8125rem;font-weight:600;white-space:nowrap}.transcript-item{display:block;margin-bottom:8px;padding:12px 14px;border-radius:14px;transition:background-color .28s ease,border-color .28s ease,opacity .24s ease;position:relative;background:#ffffffd6;border:1px solid #F6F7FB;box-shadow:none;will-change:opacity;z-index:0;overflow:visible}.transcript-item.sentence-short{padding-top:9px;padding-bottom:9px}.transcript-item.sentence-long{padding-top:15px;padding-bottom:15px}.transcript-inner{width:100%;max-width:1320px;margin:0 auto;display:flex;align-items:flex-start;gap:14px;min-height:30px}.transcript-item:after{content:"";position:absolute;top:4px;right:8px;bottom:4px;left:8px;border-radius:var(--radius-lg);border:0;background:transparent;opacity:0;pointer-events:none;transition:opacity .24s ease,border-color .24s ease,box-shadow .28s ease,background-color .24s ease;z-index:-1}.transcript-item:last-child{margin-bottom:0}.transcript-item:hover{background:#fafaff;border-color:#ded9ff}.transcript-container.blurred .transcript-item:hover .transcript-bubble p,.transcript-container.blurred .transcript-item:hover .speaker-avatar{filter:blur(0)}.transcript-item.current{background:#f5f2ff;border-color:#e2dfff;border-radius:var(--radius-lg);margin:6px 0 10px;padding-top:15px;padding-bottom:15px;padding-left:14px}.transcript-item.current .transcript-inner{display:grid;grid-template-columns:auto minmax(280px,1fr) auto;align-items:center;column-gap:14px}.transcript-item.current .transcript-bubble{max-width:none}.transcript-item.current .transcript-actions{margin-left:0}.transcript-item.current.sentence-short{padding-top:13px;padding-bottom:13px}.transcript-item.current.sentence-long{padding-top:17px;padding-bottom:17px}.transcript-item.current:after{opacity:1;background:#f5f2ff;box-shadow:0 14px 24px -24px #6358dc14}.transcript-container.blurred .transcript-item.current{background-color:#f5f2ff}.transcript-item.current:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:64%;background:linear-gradient(180deg,#6658e8,#6658e8);border-radius:999px;z-index:1}.speaker-avatar{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:700;font-size:.8125rem;color:#6b5cff;letter-spacing:0;background:#f1edff;border:1px solid #DDD6FE;opacity:.78;position:relative}.speaker-avatar.speaker-female,.speaker-avatar.female{color:#6b5cff;background:#f1edff;border-color:#ddd6fe}.speaker-avatar.speaker-male,.speaker-avatar.male{color:#5867e8;background:#eef2ff;border-color:#d7deff}.transcript-bubble{flex:1;min-width:0;max-width:min(1180px,calc(100% - 220px));position:relative;margin-right:0}.transcript-actions{display:flex;align-items:center;gap:10px;flex-shrink:0;margin-left:auto;margin-top:4px;min-width:184px;justify-content:flex-end}.transcript-actions .feedback-tag{position:static;flex-shrink:0;margin:0;white-space:nowrap;min-width:44px;justify-content:flex-end}.line-feedback-group{display:inline-flex;align-items:center;gap:6px;padding:4px;border-radius:999px;background:#f8fafcb8;border:1px solid rgba(226,232,240,.64);opacity:0;transform:translateY(2px);visibility:hidden;pointer-events:none;transition:opacity .18s ease,transform .18s ease,border-color .18s ease,visibility .18s ease}.transcript-item:hover .line-feedback-group,.transcript-item.current .line-feedback-group{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0)}.transcript-item.current .line-feedback-group{background:#ffffff73;border-color:#e2dfffb3}.transcript-item:not(.current):not(:hover) .line-feedback-group{visibility:hidden;pointer-events:none}.line-feedback-btn{width:26px;height:26px;border-radius:999px;border:none;background:transparent;color:#8a849e;font-size:.75rem;font-weight:700;cursor:pointer;transition:background-color .2s ease,color .2s ease,transform .18s ease}.line-feedback-btn:hover{transform:translateY(-1px)}.line-feedback-btn.understood.active{background:#82d6b12e;color:#2fae82}.line-feedback-btn.familiar.active{background:#eab30829;color:#b98317}.line-feedback-btn.unfamiliar.active{background:#f47c7429;color:#d56a61}.transcript-container,.transcript-bubble,.transcript-bubble p{-webkit-user-select:text;user-select:text;caret-color:transparent}.transcript-bubble p{font-size:1rem;font-weight:400;color:var(--text-secondary);line-height:1.52;letter-spacing:.01em;word-wrap:break-word;transition:opacity .22s ease,color .22s ease;will-change:opacity}.transcript-item.current .speaker-avatar{color:#fff;background:#6658e8;border-color:#6658e8;opacity:1;box-shadow:0 6px 14px #6358dc2e}.transcript-item.current .transcript-bubble p{font-weight:500;font-size:1.04rem;color:#5f55d6}.transcript-container.immersive .transcript-item{background:#f8fafc5c;border-color:#e2e8f073;box-shadow:none}.transcript-container.immersive .transcript-item:after{display:none}.transcript-container.immersive .transcript-item .transcript-bubble p{filter:none;opacity:1;color:var(--text-secondary);transition:opacity .12s linear,color .12s linear}.transcript-container.immersive .transcript-item.current{background:#f3f1ff;border-color:#dcd7ff;box-shadow:none}.transcript-container.immersive .transcript-item.current:after{opacity:0;border-color:transparent;background:transparent;box-shadow:none}.transcript-container.immersive .transcript-item.current .transcript-bubble p,.transcript-container.immersive .transcript-item.prev-context .transcript-bubble p,.transcript-container.immersive .transcript-item.next-context .transcript-bubble p{filter:none;opacity:1;color:var(--text-secondary);font-weight:400}.transcript-container.immersive .transcript-item.prev-context,.transcript-container.immersive .transcript-item.next-context{background:#ffffffc2;border-color:#e2e8f0bf}.transcript-section.immersive-active .transcript-container{max-height:min(38vh,340px);min-height:220px;box-shadow:none;background:#ffffffeb}.transcript-section.immersive-active .transcript-container.context-collapsed{min-height:0;max-height:0;padding-top:0;padding-bottom:0;border-color:transparent;opacity:0;overflow:hidden;pointer-events:none}.transcript-section.immersive-active .transcript-container{transition:max-height .26s ease,min-height .26s ease,padding .2s ease,opacity .18s ease,border-color .2s ease}.transcript-section.immersive-active .transcript-container .transcript-item.current{background:#fffffff5;border-color:#a78bfa38}.transcript-section.immersive-active .transcript-container .transcript-item.current:after,.transcript-section.immersive-active .transcript-container .transcript-item.current:before{display:none}.transcript-section.immersive-active .transcript-container .transcript-item.current .transcript-bubble p{color:var(--text-secondary);font-weight:400}.favorite-btn{width:32px;height:32px;border-radius:var(--radius);background:none;border:1px solid transparent;color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);flex-shrink:0;opacity:0;visibility:hidden;pointer-events:none}.transcript-item:hover .favorite-btn,.transcript-item.current .favorite-btn{opacity:1;visibility:visible;pointer-events:auto}.favorite-btn:hover{background:#f3f1ff;border-color:#dcd7ff;color:#6d5df6}.favorite-btn.active{opacity:1;visibility:visible;pointer-events:auto;color:#6d5df6}.favorite-btn.active svg{fill:#6d5df6}.favorite-btn svg{width:16px;height:16px;transform:translateY(2px)}.transcript-item.no-avatar{padding-left:16px}.dropdown-group-header{padding:8px 18px;font-size:.75rem;font-weight:700;color:var(--text-muted);letter-spacing:.08em;background:var(--bg-app);border-bottom:1px solid rgba(148,163,184,.12)}.dropdown-subgroup-header{padding:4px 18px 4px 24px;font-size:.7rem;font-weight:600;color:#94a3b8;letter-spacing:.05em}.swipe-cell{position:relative;overflow:hidden;touch-action:pan-y;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.swipe-cell-track{display:flex;transition:transform .3s cubic-bezier(.4,0,.2,1);will-change:transform}.swipe-cell-track.dragging{transition:none}.swipe-cell-left{flex:1;min-width:0}.swipe-cell-right{display:none;flex-shrink:0;align-items:stretch}.swipe-cell-right{display:none;flex-shrink:0;align-items:center;padding:0 8px;gap:8px;background:transparent}.swipe-actions{display:flex;align-items:center;gap:8px;height:100%;padding:0 4px}.swipe-action-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;border:none;background:#fffffff5;font-size:.75rem;font-weight:700;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent;box-shadow:0 1px 4px #00000014;flex-shrink:0}.swipe-action-btn:active{transform:scale(.92)}.swipe-action-btn.understood{color:#2fae82}.swipe-action-btn.understood.active{background:#eafbf3;color:#2fae82}.swipe-action-btn.familiar{color:#b98317}.swipe-action-btn.familiar.active{background:#fff6d8;color:#b98317}.swipe-action-btn.unfamiliar{color:#d56a61}.swipe-action-btn.unfamiliar.active{background:#ffedea;color:#d56a61}.swipe-action-btn.favorite{color:#8b5cf6;padding:0}.swipe-action-btn.favorite svg{width:16px;height:16px}.swipe-action-btn.favorite.active{background:#ede9fe;color:#7c3aed}.swipe-action-btn.favorite.active svg{fill:currentColor}.swipe-guide-hint{position:absolute;right:8px;top:50%;transform:translateY(-50%);display:none;align-items:center;gap:6px;padding:6px 12px;background:linear-gradient(135deg,#6d5df6,#4f46e5);color:#fff;border-radius:999px;font-size:.75rem;font-weight:600;pointer-events:auto;z-index:10;white-space:nowrap;box-shadow:0 4px 12px #6d5df64d;animation:swipeGuideFade 2.8s ease forwards}.swipe-guide-hand{width:18px;height:18px;flex-shrink:0;animation:swipeHandMove .7s ease-in-out .2s 3}.swipe-guide-hand svg{width:100%;height:100%}@keyframes swipeHandMove{0%,to{transform:translate(0)}50%{transform:translate(-10px)}}@keyframes swipeGuideFade{0%{opacity:0;transform:translateY(-50%) scale(.9)}12%{opacity:1;transform:translateY(-50%) scale(1)}82%{opacity:1;transform:translateY(-50%) scale(1)}to{opacity:0;transform:translateY(-50%) scale(.9);visibility:hidden}}.dictation-section{margin-bottom:24px}.dictation-panel{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:20px;min-height:380px;align-items:stretch}.dictation-focus-stage{display:flex;flex-direction:column;background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);border:1px solid rgba(226,232,240,.88);overflow:hidden;min-height:220px}.dictation-focus-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid rgba(226,232,240,.6);background:linear-gradient(180deg,#fff,#f8fafc)}.dictation-focus-label{font-size:.8125rem;font-weight:700;color:#4f46e5;letter-spacing:.04em}.dictation-play-btn{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#6d5df6,#4f46e5);border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #6d5df640;padding:0}.dictation-play-btn:hover{transform:scale(1.1);box-shadow:0 6px 16px #4f46e559}.dictation-play-btn svg{width:14px;height:14px;margin-left:1px}.dictation-focus-body{flex:1;position:relative;padding:24px;display:flex;align-items:center;justify-content:center;min-height:120px}.dictation-blur-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#ffffff14;backdrop-filter:blur(12px) saturate(1.1);-webkit-backdrop-filter:blur(12px) saturate(1.1);z-index:2;border-radius:0}.dictation-blurred-text{font-size:1.2rem;line-height:1.78;color:transparent;font-family:Iowan Old Style,Palatino Linotype,Book Antiqua,Baskerville,Georgia,Songti SC,STSong,"Noto Serif SC",serif;margin:0;text-shadow:0 0 10px rgba(15,23,42,.55);user-select:none;-webkit-user-select:none;text-align:center;word-break:break-word}.dictation-diff-result{font-size:1.15rem;line-height:1.82;color:#0f172a;font-family:Iowan Old Style,Palatino Linotype,Book Antiqua,Baskerville,Georgia,Songti SC,STSong,"Noto Serif SC",serif;white-space:pre-wrap;word-break:break-word;text-align:center}.dictation-diff-result .diff-correct,.dictation-diff-result .diff-missed,.dictation-diff-result .diff-wrong{white-space:pre-wrap}.dictation-diff-result .diff-correct{color:#0f172a}.dictation-diff-result .diff-missed{color:#dc2626;background:#fee2e299;border-bottom:2px solid #DC2626;border-radius:2px;padding:0 2px;font-weight:600}.dictation-diff-result .diff-wrong{color:#dc2626;text-decoration:line-through;text-decoration-color:#dc2626;text-decoration-thickness:2px;opacity:.75}.dictation-neighbor-nav{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-top:1px solid rgba(226,232,240,.4);gap:12px}.dictation-nav-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;cursor:pointer;transition:all .2s ease;border:none;background:#f1f5f9cc;color:#94a3b8;padding:0}.dictation-nav-btn:hover:not(:disabled){background:#e2e8f0e6;color:#64748b;transform:scale(1.1)}.dictation-nav-btn:disabled{opacity:.25;cursor:not-allowed}.dictation-nav-btn svg{width:16px;height:16px}.dictation-input-area{display:flex;flex-direction:column;background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);border:1px solid rgba(226,232,240,.88);overflow:hidden;min-height:220px}.dictation-input-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid rgba(226,232,240,.6);background:linear-gradient(180deg,#fff,#f8fafc)}.dictation-input-label{font-size:.8125rem;font-weight:700;color:#4f46e5;letter-spacing:.04em}.dictation-status{font-size:.75rem;font-weight:600;color:#94a3b8;padding:2px 10px;border-radius:999px;background:#f1f5f9f5}.dictation-status.reviewed{color:#10b981;background:#e6f9f0}.dictation-textarea{flex:1;width:100%;padding:20px;border:none;outline:none;font-size:1.05rem;line-height:1.72;color:#0f172a;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,PingFang SC,Microsoft YaHei,sans-serif;resize:none;background:transparent;min-height:180px}.dictation-textarea::placeholder{color:#94a3b8;font-style:italic}.dictation-textarea:read-only{background:#f8fafc;color:#64748b}.dictation-actions{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:14px 18px;border-top:1px solid rgba(226,232,240,.6);background:linear-gradient(180deg,#f8fafc,#fff)}.dictation-submit-btn,.dictation-next-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;border-radius:var(--radius);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.dictation-submit-btn{background:linear-gradient(135deg,#6d5df6,#4f46e5);color:#fff;box-shadow:0 8px 20px #6d5df640}.dictation-submit-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 24px #4f46e54d}.dictation-submit-btn:disabled{background:transparent;color:#cbd5e1;box-shadow:none;cursor:not-allowed;border:1px dashed #E2E8F0}.dictation-submit-btn svg,.dictation-next-btn svg{width:16px;height:16px}.dictation-next-btn{background:#f3f1ff;color:#4f46e5;border:1px solid #DCD7FF}.dictation-next-btn:hover{background:#ede9fe;border-color:#c4b5fd}.dictation-feedback-bar{grid-column:1 / -1;justify-self:center;width:fit-content;display:flex;align-items:center;justify-content:center;gap:16px;padding:10px 16px;background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-hover);border:1px solid rgba(0,0,0,.03)}.dictation-feedback-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border:none;border-radius:50px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-card)}.dictation-feedback-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}.dictation-feedback-btn:active{transform:scale(.96)}.dictation-feedback-btn.understood{background:#eafbf3;color:#2fae82}.dictation-feedback-btn.understood:hover{background:#ddf7ea}.dictation-feedback-btn.understood.active{background:#ddf7ea;color:#2fae82;box-shadow:0 2px 8px #2fae822e}.dictation-feedback-btn.familiar{background:#fff6d8;color:#b98317}.dictation-feedback-btn.familiar:hover{background:#ffefbe}.dictation-feedback-btn.familiar.active{background:#ffefbe;color:#b98317;box-shadow:0 2px 8px #b9831729}.dictation-feedback-btn.unfamiliar{background:#ffedea;color:#d56a61}.dictation-feedback-btn.unfamiliar:hover{background:#ffe1dc}.dictation-feedback-btn.unfamiliar.active{background:#ffe1dc;color:#d56a61;box-shadow:0 2px 8px #d56a6129}.dictation-feedback-btn svg{width:16px;height:16px}.dictation-stats-bar{display:flex;align-items:center;justify-content:space-around;padding:12px 18px;border-top:1px solid rgba(226,232,240,.6);background:linear-gradient(180deg,#fff,#f8fafc);gap:12px}.dictation-stat{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1}.dictation-stat-value{font-size:1.25rem;font-weight:700;line-height:1.2}.dictation-stat-value.correct{color:#10b981}.dictation-stat-value.missed{color:#dc2626}.dictation-stat-value.wrong{color:#f59e0b}.dictation-stat-value.accuracy{color:#4f46e5}.dictation-stat-label{font-size:.6875rem;font-weight:600;color:#94a3b8;letter-spacing:.04em}.dictation-panel.dictation-reviewed .dictation-blur-overlay{display:none}@media (max-width: 768px){.swipe-guide-hint{display:flex}}.ai-summon-btn{position:fixed;bottom:32px;right:32px;display:flex;align-items:center;gap:8px;padding:14px 24px;background:linear-gradient(135deg,#6658e8,#5f55d6);color:#fff;border:none;border-radius:50px;font-size:.9375rem;font-weight:600;cursor:pointer;box-shadow:0 10px 24px #6358dc33;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:1000}.ai-summon-btn:hover{transform:translateY(-2px) scale(1.01);box-shadow:0 12px 28px #6358dc3d}.ai-summon-btn:active{transform:scale(.96)}.ai-summon-btn svg{width:20px;height:20px}@media (max-width: 768px){.ai-summon-btn{bottom:24px;right:24px;padding:12px 20px;font-size:.875rem}.ai-summon-btn svg{width:18px;height:18px}}@media (max-width: 480px){.ai-summon-btn{bottom:16px;right:16px;padding:10px 16px;font-size:.8125rem}}.ai-modal{max-width:600px;width:min(600px,calc(100vw - 48px));max-height:min(760px,calc(100dvh - 56px));display:flex;flex-direction:column;overflow:hidden}.ai-modal .modal-header{align-items:flex-start;gap:16px;margin-bottom:18px}.ai-modal .modal-header h2{margin:0;font-size:1.45rem;line-height:1.25;font-weight:800;letter-spacing:0}.ai-body{display:flex;flex-direction:column;gap:14px;overflow-y:auto;padding-right:4px;min-height:0}.ai-original-card{display:flex;flex-direction:column;gap:9px;padding:12px 14px;border:1px solid #DCD7FF;border-radius:16px;background:#f8f7ff}.ai-original-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.ai-label{font-size:.75rem;font-weight:800;color:#6d5df6;text-transform:uppercase;letter-spacing:.05em}.ai-original-card p{margin:0;font-size:1rem;line-height:1.72;color:#312e81;white-space:normal;overflow-wrap:anywhere}.ai-slash-divider{display:inline-block;margin:0 .42em;color:#6d5df6;font-weight:900}.ai-sense-groups{display:grid;gap:8px}.ai-sense-group{display:grid;gap:5px;padding:9px 10px;border-radius:10px;background:#ffffffb8;color:#1f2937;border:1px solid rgba(124,58,237,.18)}.ai-sense-group-meta{display:flex;align-items:center;gap:6px}.ai-sense-group-index{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:#6d5df6;color:#fff;font-size:.72rem;font-weight:800;line-height:1}.ai-sense-group-role{display:inline-flex;align-items:center;min-height:20px;padding:2px 7px;border-radius:999px;background:#ece9ff;color:#5b4be8;font-size:.75rem;font-weight:800}.ai-sense-group-text,.ai-sense-group-meaning,.ai-sense-group-translation{margin:0}.ai-sense-group-text{color:#111827;font-size:.98rem;font-weight:750;line-height:1.48}.ai-breath-groups{padding:8px 9px;border-radius:8px;background:#f3f1ff;color:#312e81;font-size:.92rem;font-weight:800;line-height:1.65;overflow-wrap:anywhere}.ai-breath-chunk{display:inline}.ai-sense-group-meaning{color:#64748b;font-size:.88rem;line-height:1.5}.ai-sense-group-translation{color:#334155;font-size:.92rem;line-height:1.55}.ai-sense-group-translation:before{content:"译 ";color:#6d5df6;font-size:.78rem;font-weight:800}.ai-sense-group-analysis{display:grid;gap:4px;margin:1px 0 0;padding-left:18px;color:#475569;font-size:.86rem;line-height:1.55}.ai-sense-group-analysis li::marker{color:#6d5df6}.ai-play-btn{width:36px;height:36px;border:none;background:linear-gradient(135deg,#6d5df6,#6d5df6);color:#fff;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 2px 8px #6d5df64d}.ai-play-btn:hover{transform:scale(1.1);box-shadow:0 4px 12px #6d5df659}.ai-play-btn:active{transform:scale(.95)}.ai-play-btn.playing{background:linear-gradient(135deg,#f472b6,#ec4899);animation:pulse-playing 1s infinite}@keyframes pulse-playing{0%,to{box-shadow:0 0 #f472b666}50%{box-shadow:0 0 0 8px #f472b600}}.ai-play-btn svg{width:16px;height:16px}.ai-original-sentence{background:#f3f1ff;border:1px solid #DCD7FF;padding:16px 20px;border-radius:var(--radius);margin-bottom:24px;font-size:1.0625rem;line-height:1.8;color:#4f46e5;text-align:center}.ai-response{font-family:PingFang SC,Hiragino Sans GB,Microsoft YaHei,Segoe UI,sans-serif;font-size:1rem;font-weight:400;line-height:1.72;letter-spacing:.01em;color:var(--text-secondary);min-height:100px}.ai-response:empty:before{content:"正在分析中...";color:var(--text-muted);font-style:italic}.ai-response h3{display:inline-flex;align-items:center;margin:14px 0 8px;padding:5px 10px;border-radius:999px;background:#f3f1ff;font-size:.98rem;font-weight:800;color:#4f46e5;letter-spacing:0}.ai-response h3:first-child{margin-top:0}.ai-response p{margin:0 0 12px;line-height:1.72}.ai-response ol{margin:0 0 14px 22px;padding:0}.ai-response li{margin-bottom:9px;padding-left:4px;line-height:1.72}.ai-response strong{color:#1e293b;font-weight:800;background:linear-gradient(180deg,transparent 58%,#DCD7FF 58%)}.ai-response code{padding:2px 8px;border-radius:999px;background:#f3f1ff;color:#6d5df6;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.9em}@media (max-width: 768px){.ai-modal{width:auto;max-width:none;max-height:calc(100dvh - 32px - var(--safe-area-top) - var(--safe-area-bottom));padding:18px;border-radius:20px}.ai-modal .modal-header{margin-bottom:14px}.ai-modal .modal-header h2{font-size:1.35rem}.ai-original-card{padding:13px 14px;border-radius:14px}.ai-original-card p{font-size:16px;line-height:1.68}.ai-response{font-size:16px;line-height:1.72;min-height:80px}.ai-response h3{margin-top:16px;font-size:.95rem}.ai-response p{margin-bottom:14px}}@media (max-width: 480px){.ai-modal{margin:calc(10px + var(--safe-area-top)) calc(8px + var(--safe-area-right)) calc(10px + var(--safe-area-bottom)) calc(8px + var(--safe-area-left));padding:16px}.ai-play-btn{width:34px;height:34px}}.filter-tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:1px solid var(--border);padding-bottom:16px}.filter-tab{padding:10px 20px;background:none;border:none;font-size:.9375rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:var(--transition);position:relative}.filter-tab:hover{color:var(--primary)}.filter-tab.active{color:var(--primary);font-weight:600}.filter-tab.active:after{content:"";position:absolute;bottom:-17px;left:0;right:0;height:3px;background:var(--primary);border-radius:2px}.favorite-listen-panel{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:-6px 0 22px;padding:14px 16px;border:1px solid #E5E7EB;border-radius:var(--radius);background:var(--bg-card);box-shadow:var(--shadow-soft)}.favorite-listen-info{min-width:0;display:flex;flex-direction:column;gap:4px}.favorite-listen-label{font-size:.92rem;font-weight:700;color:var(--text-primary)}.favorite-listen-desc{font-size:.8125rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.favorite-listen-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.favorite-listen-action-stack{display:flex;flex-direction:column;align-items:flex-end;gap:10px}.favorite-listen-control-row{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.favorite-listen-row-label{font-size:.8125rem;font-weight:700;color:var(--text-secondary)}.favorite-listen-btn{min-height:36px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 14px;border-radius:var(--radius);border:1px solid #E5E7EB;background:var(--bg-card);color:var(--text-secondary);font-size:.875rem;font-weight:600;cursor:pointer;transition:var(--transition)}.favorite-listen-btn svg{width:15px;height:15px;flex-shrink:0}.favorite-listen-btn:hover{border-color:#dcd7ff;color:#6d5df6;background:#f3f1ff}.favorite-listen-pill{min-height:30px;padding:0 12px;border-radius:999px;background:#ffffffb8;color:var(--text-secondary);font-size:.8125rem;box-shadow:none}.favorite-listen-main-btn{min-width:186px;min-height:42px;padding:0 24px;border-radius:12px;font-size:.9375rem}.favorite-listen-stop-btn{min-height:42px;min-width:92px;border-radius:12px;background:#f9fafb}.favorite-listen-btn.primary{border-color:#6d5df6;background:#6d5df6;color:#fff;box-shadow:0 8px 20px #6d5df62e}.favorite-listen-btn.primary:hover{background:#4f46e5;color:#fff}.favorite-listen-btn.quiet{color:var(--text-muted)}.favorite-listen-btn:disabled{opacity:.56;cursor:default;transform:none}.speed-menu-wrapper{position:relative}.speed-menu-wrapper .speed-btn{min-width:84px;padding:0 12px}.speed-menu{position:absolute;top:calc(100% + 6px);left:50%;transform:translate(-50%) scale(.95);display:flex;flex-direction:column;gap:2px;padding:6px;background:var(--bg-card);border:1px solid #E5E7EB;border-radius:var(--radius);box-shadow:0 8px 24px #0000001a;opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:100}.speed-menu.active{opacity:1;pointer-events:auto;transform:translate(-50%) scale(1)}.speed-option{min-width:64px;padding:6px 12px;border:none;border-radius:6px;background:transparent;color:var(--text-secondary);font-size:.8125rem;font-weight:600;text-align:center;cursor:pointer;transition:background .15s ease,color .15s ease}.repeat-menu .speed-option{min-width:72px}.speed-option:hover{background:#f3f1ff;color:#6d5df6}.speed-option.active{background:#6d5df6;color:#fff}.favorites-list{display:flex;flex-direction:column;gap:16px}.favorites-section{display:flex;flex-direction:column;gap:14px}.favorites-section-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.favorites-section-title{margin:0;font-size:1.05rem;font-weight:700;color:var(--text-primary)}.favorites-section-count{font-size:.8125rem;color:var(--text-muted)}.sentence-favorites-list,.listening-favorites-list{display:flex;flex-direction:column;gap:16px}.favorite-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:20px;display:flex;align-items:center;gap:16px;transition:var(--transition)}.favorite-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.sentence-favorite-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:20px;display:flex;align-items:center;justify-content:space-between;gap:16px;transition:var(--transition)}.sentence-favorite-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.listening-favorite-card{align-items:stretch}.sentence-favorite-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:10px}.sentence-favorite-tags{display:flex;flex-wrap:wrap;gap:8px}.sentence-favorite-text{margin:0;font-size:1.15rem;font-weight:400;color:var(--text-secondary);line-height:2;letter-spacing:.03em;word-break:break-word}.listening-favorite-title{font-size:1.05rem;line-height:1.7}.listening-favorite-summary{margin:0;font-size:.875rem;color:var(--text-secondary);line-height:1.6}.sentence-favorite-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}.favorite-actions .play-btn,.sentence-favorite-actions .play-btn{width:34px;height:34px;border-radius:10px;box-shadow:0 3px 10px #a594f938;background:linear-gradient(135deg,#6d5df6,#6d5df6);border:none;color:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.favorite-actions .play-btn svg,.sentence-favorite-actions .play-btn svg{width:13px;height:13px}.favorite-actions .play-btn:hover,.sentence-favorite-actions .play-btn:hover{box-shadow:0 5px 12px #a594f947}.favorite-play{flex-shrink:0}.play-audio-btn{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition)}.play-audio-btn:hover{transform:scale(1.08);box-shadow:0 6px 20px #8b7dc866}.play-audio-btn svg{width:18px;height:18px}.favorite-content{flex:1;min-width:0}.favorite-english{font-size:1rem;font-weight:500;color:#333;line-height:1.6;margin-bottom:6px}.favorite-chinese{font-size:.875rem;color:#666;line-height:1.5}.favorite-meta{display:flex;align-items:center;gap:12px;flex-shrink:0}.source-tag{display:inline-block;padding:4px 10px;background:#f3f4f6;color:#4b5563;font-size:.75rem;font-weight:500;border-radius:var(--radius-sm)}.remove-favorite,.remove-btn{width:36px;height:36px;border-radius:var(--radius);background:var(--bg-card);border:1px solid #E5E7EB;color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-card)}.remove-favorite:hover,.remove-btn:hover{background:#fef2f2;border-color:#dc2626;color:#dc2626;box-shadow:var(--shadow-soft)}.remove-favorite svg,.remove-btn svg{width:18px;height:18px}@media (max-width: 640px){.favorite-listen-panel{align-items:stretch;flex-direction:column;gap:12px;margin-top:-4px;padding:14px}.favorite-listen-actions{width:100%}.favorite-listen-action-stack,.favorite-listen-control-row{width:100%;align-items:stretch}.favorite-listen-control-row{justify-content:flex-start}.favorite-listen-settings-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.favorite-listen-settings-row .speed-menu-wrapper,.favorite-listen-settings-row .favorite-listen-pill{width:100%;min-width:0}.favorite-listen-row-label{width:100%}.favorite-listen-settings-row .favorite-listen-row-label{grid-column:1 / -1}.favorite-listen-settings-row .favorite-listen-pill{padding:0 8px;gap:5px;font-size:.75rem;white-space:nowrap}.favorite-listen-settings-row .favorite-listen-pill svg{width:14px;height:14px}.favorite-listen-settings-row .speed-menu{left:0;right:0;width:100%;min-width:100%;transform:scale(.95);transform-origin:top center}.favorite-listen-settings-row .speed-menu.active{transform:scale(1)}.favorite-listen-settings-row .speed-option{min-width:0;width:100%;padding:7px 6px;white-space:nowrap}.favorite-listen-btn{flex:1;min-width:0}.favorite-listen-main-btn{flex:1 1 62%}.favorite-listen-stop-btn{flex:0 0 92px}.favorite-listen-desc{white-space:normal;line-height:1.5}}.stats-overview{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:16px;display:flex;align-items:center;gap:12px;transition:var(--transition)}.stat-card:hover{box-shadow:var(--shadow-hover)}.stat-card .stat-icon{width:40px;height:40px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-card .stat-icon svg{width:20px!important;height:20px!important}.stat-card.total .stat-icon{background:#f3f1ff;color:#6d5df6}.stat-card.unfamiliar .stat-icon{background:#fee2e2;color:#dc2626}.stat-card.familiar .stat-icon{background:#fef9c3;color:#d97706}.stat-card.understood .stat-icon{background:#d1fae5;color:#34d399}.stat-card .stat-info{display:flex;flex-direction:column;gap:4px}.stat-card .stat-label{font-size:.75rem;color:var(--text-secondary);white-space:nowrap}.stat-card .stat-value{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.learning-detail-section{margin-top:24px}.detail-tabs{display:flex;gap:12px;margin-bottom:24px}.tab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:10px;padding:16px 20px;background:var(--bg-card);border:none;border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition);font-size:.9375rem;font-weight:600;color:var(--text-secondary);box-shadow:var(--shadow-card)}.tab-btn svg{width:18px;height:18px}.tab-btn:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.tab-btn.active{background:var(--bg-card);color:#4f46e5;box-shadow:var(--shadow-hover)}.tab-btn[data-tab=unfamiliar].active{color:#dc2626}.tab-btn[data-tab=familiar].active{color:#d97706}.tab-btn[data-tab=understood].active{color:#34d399}.tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 10px;background:var(--bg-app);border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.detail-content{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);overflow:hidden}.tab-panel{display:none}.tab-panel.active{display:block}.audio-list{padding:20px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.empty-icon{width:80px;height:80px;color:var(--text-muted);opacity:.5;margin-bottom:20px}.empty-icon svg{width:100%;height:100%}.empty-text{font-size:16px;font-weight:500;color:var(--text-secondary);margin:0 0 8px}.empty-hint{font-size:14px;color:var(--text-muted);margin:0 0 24px}.empty-action{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;background:var(--primary);color:#fff;border-radius:var(--radius-md);text-decoration:none;font-weight:500;transition:all .2s}.empty-action:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #6d5df633}.audio-item{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;background:var(--bg-card);border-radius:var(--radius-lg);margin-bottom:12px;transition:var(--transition);box-shadow:var(--shadow-card)}.audio-item:last-child{margin-bottom:0}.audio-item:hover{box-shadow:var(--shadow-soft);transform:translateY(-2px)}.audio-info{display:flex;flex-direction:column;gap:8px}.audio-title{font-size:.9375rem;font-weight:600;color:var(--text-primary)}.audio-meta{font-size:.8125rem;color:var(--text-secondary)}.btn-listen{display:flex;align-items:center;gap:8px;padding:10px 18px;background:var(--bg-card);border:1px solid #E5E7EB;color:var(--text-secondary);border-radius:var(--radius);cursor:pointer;transition:var(--transition);font-size:.875rem;font-weight:600;box-shadow:var(--shadow-card)}.btn-listen:hover{background:#ecfdf5;border-color:#10b981;color:#10b981;transform:translateY(-2px);box-shadow:var(--shadow-hover)}.btn-listen svg{width:12px;height:12px}.familiar-item .btn-listen:hover{background:#fffbeb;border-color:#f59e0b;color:#f59e0b}.understood-item .btn-listen:hover{background:#e6f9f0;border-color:#6ee7b7;color:#34d399}.review-hero{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:32px 36px;margin-bottom:24px;border-radius:28px;border:1px solid rgba(109,93,246,.12);background:radial-gradient(circle at 10% 20%,rgba(109,93,246,.1),transparent 40%),radial-gradient(circle at 90% 80%,rgba(109,93,246,.14),transparent 45%),linear-gradient(135deg,#faf8ff,#f3efff,#f8f7ff);box-shadow:0 1px 2px #6d5df60a,0 8px 24px #6d5df60f;position:relative;overflow:hidden}.review-hero:after{content:"";position:absolute;right:-48px;top:-48px;width:220px;height:220px;border-radius:999px;background:radial-gradient(circle,#6d5df624,#6d5df600 70%);pointer-events:none}.review-hero:before{content:"";position:absolute;left:-30px;bottom:-40px;width:160px;height:160px;border-radius:999px;background:radial-gradient(circle,#6d5df61a,#6d5df600 70%);pointer-events:none}.review-hero-copy{display:flex;flex-direction:column;gap:10px;max-width:720px;position:relative;z-index:1}.review-hero-actions{display:flex;align-items:center;gap:12px;margin-top:10px;flex-wrap:wrap}.review-hero-eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.2em;color:#2e1065;text-transform:uppercase}.review-hero-title{margin:0;font-size:clamp(1.8rem,1.6rem + .42vw,2.1rem);line-height:1.15;color:#1e1b4b;letter-spacing:-.03em;font-weight:800}.review-hero-text{margin:0;color:#9e93bb;line-height:1.7;max-width:58ch;font-size:.96rem}.review-hero-action,.review-primary-btn,.review-launch-btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:0 28px;border-radius:999px;background:linear-gradient(180deg,#6d5df6,#6d5df6 40%,#4f46e5);box-shadow:0 1px #ffffff38 inset,0 4px 18px #5b3df561,0 1px 3px #0000001f;color:#fff;text-decoration:none;font-weight:600;font-size:.9375rem;letter-spacing:.01em;transition:transform .18s ease,box-shadow .18s ease}.review-hero-action:hover,.review-primary-btn:hover,.review-launch-btn:hover{transform:translateY(-2px);box-shadow:0 1px #ffffff47 inset,0 8px 28px #5b3df57a,0 2px 5px #00000024}.review-exam-countdown{display:inline-flex;align-items:center;gap:10px;min-height:44px;padding:0 16px;border:1px solid rgba(109,93,246,.18);border-radius:999px;background:#ffffffb8;box-shadow:0 1px #ffffffc2 inset,0 6px 18px #6d5df614;color:#4c1d95;white-space:nowrap}.review-exam-countdown-label{color:#7c6edb;font-size:.82rem;font-weight:700}.review-exam-countdown-value{color:#1e1b4b;font-size:.98rem;font-weight:900;font-variant-numeric:tabular-nums}.review-hero-focus-card{position:relative;z-index:1;min-width:220px;padding:28px 32px 26px;border-radius:24px;border:1px solid rgba(109,93,246,.18);background:linear-gradient(180deg,#fffffffa,#f7f5fffa);box-shadow:0 8px 32px #6d5df614,0 2px 8px #00000008;display:flex;flex-direction:column;gap:8px;align-items:flex-start;justify-content:center}.review-hero-focus-label{font-size:.75rem;font-weight:700;letter-spacing:.14em;color:#6d5df6;text-transform:uppercase}.review-hero-focus-value{font-size:clamp(3.2rem,2.8rem + 1.2vw,4.2rem);font-weight:900;line-height:1;letter-spacing:-.04em;color:#1e1b4b;font-family:DIN Alternate,DIN,Montserrat,Helvetica Neue,Arial,sans-serif}.review-hero-focus-meta{font-size:.875rem;color:#b8aed4;font-weight:500}.review-mobile-summary,.review-hero-mobile-actions{display:none}.review-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:24px}.review-stat-card{display:flex;flex-direction:column;gap:10px;padding:22px 24px;border-radius:24px;background:linear-gradient(180deg,#fff,#faf8ff);border:1px solid rgba(109,93,246,.08);box-shadow:0 1px 4px #6d5df608;position:relative;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.review-stat-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6d5df60f}.review-stat-card.unfamiliar{background:#6d5df614;border-color:#6d5df62e;box-shadow:0 1px 4px #6d5df60d;transform:translateY(-2px)}.review-stat-card.unfamiliar:hover{box-shadow:0 4px 16px #6d5df61a;border-color:#6d5df647}.review-stat-card.unfamiliar .review-stat-label{color:#6d5df6;font-weight:700}.review-stat-card.unfamiliar .review-stat-value{color:#4f46e5;font-weight:800}.review-stat-label{font-size:.8125rem;color:#a99ec8;position:relative;z-index:1;font-weight:500;letter-spacing:.01em}.review-stat-value{font-size:clamp(1.6rem,1.38rem + .5vw,1.95rem);font-weight:700;color:#1e1b4b;position:relative;z-index:1;letter-spacing:-.03em}.review-stat-number{display:flex;align-items:baseline;gap:6px}.review-section{padding:28px;border-radius:28px;background:linear-gradient(180deg,#fff,#faf8ff);box-shadow:0 1px 2px #6d5df608,0 4px 16px #6d5df608;border:1px solid rgba(109,93,246,.08)}.review-section-upcoming{margin-top:24px;background:linear-gradient(180deg,#fffffff5,#faf8fff5);opacity:.92}.review-section-head{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid rgba(109,93,246,.1)}.review-section-title{margin:0 0 6px;font-size:1.15rem;color:#1e1b4b;letter-spacing:-.02em;font-weight:700}.review-section-subtitle{margin:0;color:#a99ec8;font-size:.875rem;line-height:1.6}.review-group-list{display:grid;gap:18px}.review-group-card{padding:24px;border-radius:24px;border:1px solid rgba(109,93,246,.08);background:linear-gradient(90deg,rgba(109,93,246,.1) 0 4px,transparent 4px 100%),linear-gradient(180deg,#fff,#faf8ff);box-shadow:0 2px 10px #6d5df60a;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease}.review-group-card:hover{transform:translateY(-2px);border-color:#6d5df62e;box-shadow:0 8px 24px #6d5df61a,0 2px 6px #6d5df60f}.review-group-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}.review-group-title{margin:0 0 6px;font-size:1.05rem;color:#1e1b4b;letter-spacing:-.02em;font-weight:700}.review-group-meta{margin:0;color:#a99ec8;font-size:.875rem}.review-group-summary{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.review-pill{display:inline-flex;align-items:center;justify-content:center;min-height:32px;padding:0 14px;border-radius:999px;font-size:.8125rem;font-weight:600;border:1px solid transparent;letter-spacing:.01em}.review-pill.unfamiliar{background:linear-gradient(135deg,#6d5df6,#6d5df6);color:#fff;box-shadow:0 2px 8px #6d5df638}.review-pill.familiar{background:#f3f1ff;color:#6d5df6;border-color:#c4b5fd80}.review-group-actions{margin-bottom:16px}.review-line-list{display:flex;flex-wrap:wrap;gap:12px}.review-line-chip{display:inline-flex;align-items:center;gap:10px;padding:10px 16px;border-radius:16px;border:1px solid rgba(109,93,246,.1);background:#fff;color:inherit;text-decoration:none;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;min-height:44px}.review-line-chip:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6d5df61a;border-color:#6d5df638}.review-line-chip.unfamiliar{background:linear-gradient(135deg,#faf5ff,#f5efff);border-color:#6d5df62e}.review-line-chip.new{background:linear-gradient(135deg,#faf5ff,#f5efff);border-color:#6d5df633}.review-line-chip.fuzzy{background:#fff;border-color:#c4b5fd47}.review-line-chip.proficient{background:#f8fafc;border-color:#94a3b838}.review-line-chip.mastered{background:#f0fdf4;border-color:#34d39947}.review-line-chip.familiar{background:#fff;border-color:#c4b5fd40}.review-line-number{font-weight:600;color:#1e1b4b}.review-line-status{font-size:.8125rem;color:#a99ec8}.review-line-date{margin-left:auto;font-size:.75rem;font-weight:600;color:#6d5df6;letter-spacing:.01em}.review-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:72px 24px;text-align:center}.review-empty-icon{width:72px;height:72px;color:#6d5df6}.review-empty-title{margin:0;font-size:1.125rem;font-weight:700;color:#1e1b4b}.review-empty-text{max-width:520px;margin:0;color:#8b7db8;line-height:1.7}.review-launch-card{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:24px 28px;margin-bottom:24px;border-radius:24px;border:1px solid rgba(109,93,246,.1);background:radial-gradient(circle at top right,rgba(109,93,246,.08),transparent 40%),linear-gradient(135deg,#faf8ff,#fff);box-shadow:0 2px 10px #6d5df60a}.review-launch-card.empty{background:linear-gradient(135deg,#f9fafb,#fff)}.review-launch-copy{display:flex;flex-direction:column;gap:8px}.review-launch-eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.18em;color:#6d5df6;text-transform:uppercase}.review-launch-title{margin:0;font-size:1.2rem;color:#1e1b4b;font-weight:700;letter-spacing:-.02em}.review-launch-text{margin:0;color:#a99ec8;line-height:1.7;font-size:.9375rem}.settings-sections{display:flex;flex-direction:column;gap:24px}.settings-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:24px}.changelog-shell{display:flex;flex-direction:column;gap:24px}.changelog-intro{background:linear-gradient(135deg,#ede9fed1,#e0e7ffb8);border:1px solid rgba(167,139,250,.22);border-radius:var(--radius-lg);padding:24px 26px;box-shadow:var(--shadow-soft)}.changelog-kicker{display:inline-flex;align-items:center;gap:8px;margin-bottom:12px;padding:6px 12px;border-radius:var(--radius-full);background:#f3f1ff;color:#6d5df6;font-size:.75rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.changelog-intro h2{margin:0 0 10px;font-size:1.35rem;color:var(--text-primary)}.changelog-intro p{margin:0;color:var(--text-secondary);line-height:1.8}.changelog-version{position:relative;margin-top:-12px;padding:0;transition:transform .3s cubic-bezier(.34,1.56,.64,1),margin-top .35s ease,margin-bottom .35s ease,box-shadow .3s ease,border-color .3s ease;z-index:1;overflow:hidden;background:linear-gradient(180deg,#fff,#fafbfc);border:1px solid rgba(226,232,240,.8)}.changelog-version:first-child{margin-top:0}.changelog-version:after{content:"";position:absolute;top:0;right:0;width:32px;height:32px;background:linear-gradient(225deg,rgba(241,245,249,.95) 50%,transparent 50%);border-bottom-left-radius:8px;box-shadow:-2px 2px 4px #0000000a;z-index:3;pointer-events:none;transition:opacity .3s ease,transform .3s ease}.changelog-version:hover:after{transform:translateY(-2px)}.changelog-version.expanded:after{opacity:.5}.changelog-version:hover{transform:translateY(-6px);z-index:10;box-shadow:0 16px 40px #94a3b826;border-color:#dcd7ff}.changelog-version.expanded{margin-top:16px;margin-bottom:16px;transform:none;z-index:5;box-shadow:0 8px 24px #94a3b81a;border-color:#dcd7ff}.changelog-version.expanded:hover{transform:translateY(-2px);z-index:6}.changelog-version-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.changelog-version-title{margin:0;font-size:1.2rem;font-weight:700;color:var(--text-primary)}.changelog-date{display:inline-flex;align-items:center;justify-content:center;padding:6px 12px;border-radius:var(--radius-full);background:#94a3b81f;color:#475569;font-size:.8125rem;font-weight:600;white-space:nowrap}.changelog-section-list{display:flex;flex-direction:column;gap:16px;overflow:hidden;max-height:2000px;opacity:1;transition:max-height .4s cubic-bezier(.4,0,.2,1),opacity .3s ease,padding .3s ease;padding:0 24px 24px}.changelog-section-list.collapsed{max-height:0;opacity:0;padding-bottom:0}.changelog-version-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 24px;border:0;background:transparent;cursor:pointer;text-align:left;position:relative;z-index:2}.changelog-version-toggle:after{content:"";position:absolute;bottom:0;left:24px;right:24px;height:1px;background:linear-gradient(90deg,transparent,rgba(226,232,240,.6),transparent);opacity:0;transition:opacity .3s ease}.changelog-version:not(.expanded) .changelog-version-toggle:after{opacity:1}.changelog-version-toggle .changelog-version-header{flex:1}.changelog-toggle-icon{width:20px;height:20px;color:#94a3b8;transition:transform .25s ease;flex-shrink:0}.changelog-version-toggle:hover .changelog-version-header{opacity:.8}.changelog-version-toggle:hover .changelog-toggle-icon{color:#64748b}.changelog-version-toggle.expanded .changelog-toggle-icon{transform:rotate(0)}.changelog-version-toggle.collapsed .changelog-toggle-icon{transform:rotate(-90deg)}.changelog-group{border:1px solid #F1F5F9;border-radius:18px;padding:18px 20px;background:linear-gradient(180deg,#fffffff5,#f8fafce6)}.changelog-group-title{margin:0 0 12px;font-size:.98rem;font-weight:700;color:var(--text-primary)}.changelog-group ul{margin:0;padding-left:20px;color:var(--text-secondary);line-height:1.85}.changelog-group li+li{margin-top:8px}.settings-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid #F3F4F6}.setting-item{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid #F9FAFB}.setting-item:last-child{border-bottom:none;padding-bottom:0}.setting-info{display:flex;flex-direction:column;gap:4px}.setting-label{font-size:.9375rem;font-weight:500;color:var(--text-primary)}.setting-desc{font-size:.8125rem;color:var(--text-muted)}.setting-control{flex-shrink:0}.setting-select{padding:8px 16px;border:1px solid #E5E7EB;border-radius:var(--radius);font-size:.875rem;color:var(--text-primary);background:#fff;cursor:pointer;min-width:160px}.setting-select:focus{outline:none;border-color:var(--primary)}.setting-number-input{width:110px;padding:8px 12px;border:1px solid #E5E7EB;border-radius:var(--radius);font-size:.875rem;color:var(--text-primary);background:#fff}.setting-number-input:focus{outline:none;border-color:var(--primary)}.toggle-switch{position:relative;display:inline-block;width:52px;height:28px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#cbd5e1;transition:.3s;border-radius:28px}.toggle-slider:before{position:absolute;content:"";height:22px;width:22px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%;box-shadow:0 2px 4px #0003}.toggle-switch input:checked+.toggle-slider{background-color:var(--primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}.btn-danger{padding:8px 16px;background:#fee2e2;color:#dc2626;border:none;border-radius:var(--radius);font-size:.875rem;font-weight:500;cursor:pointer;transition:var(--transition)}.btn-danger:hover{background:#fecaca}.feedback-btn{display:flex;align-items:center;gap:6px;padding:10px 18px;border:none;border-radius:50px;cursor:pointer;transition:var(--transition);font-size:.875rem;font-weight:600;box-shadow:var(--shadow-card)}.feedback-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}.feedback-btn:active{transform:scale(.96)}.feedback-icon{width:16px;height:16px}.feedback-btn.understood{background:#d1fae5;color:#34d399}.feedback-btn.understood:hover{background:#a7f3d0}.feedback-btn.familiar{background:#fef3c7;color:#d97706}.feedback-btn.familiar:hover{background:#fde68a}.feedback-btn.unfamiliar{background:#fee2e2;color:#dc2626}.feedback-btn.unfamiliar:hover{background:#fee2e2}.exam-select-page{width:100%;max-width:calc(100vw - var(--sidebar-width))}.exam-hero{margin-bottom:9px}.exam-hero h1{margin:0;color:#0f172a;font-size:1.68rem;font-weight:800;letter-spacing:0}.exam-hero p{margin:4px 0 0;color:#64748b;font-size:.96rem}.exam-hero-mobile{display:none}.exam-focus-row{display:grid;grid-template-columns:minmax(0,2.1fr) minmax(230px,.9fr);gap:12px;margin-bottom:10px}.exam-continue-card{padding:12px 14px;border-radius:12px;border:1px solid #E2DFFF;background:linear-gradient(135deg,#f7f4ff,#fff);color:#312e81;text-decoration:none;display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:18px;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease;box-shadow:0 12px 24px -22px #6358dc4d}.exam-continue-card:hover{transform:translateY(-1px);border-color:#cfc7ff;box-shadow:0 16px 30px -24px #6358dc47}.exam-continue-label{color:#6358dc;font-size:.76rem;font-weight:800}.exam-continue-eyebrow{display:none}.exam-continue-main{display:flex;flex-direction:column;gap:3px}.exam-continue-rate{display:none}.exam-continue-card strong{font-size:1.08rem}.exam-continue-content{min-width:0;flex:1;display:flex;flex-direction:column;gap:6px}.exam-continue-main span:last-child{color:#64748b;font-size:.84rem}.exam-continue-modules{display:flex;flex-wrap:wrap;gap:5px;padding-top:0}.exam-continue-modules span{height:20px;padding:0 6px;border-radius:8px;display:inline-flex;align-items:center;background:#ffffff57;border:1px solid rgba(226,223,255,.42);color:#8b83e8;font-size:.68rem;font-weight:700}.exam-continue-progress{display:flex;flex-direction:column;gap:5px}.exam-continue-progress .exam-progress-track{height:8px}.exam-continue-action{align-self:center;min-width:124px;height:44px;padding:0 24px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;background:#6658e8;color:#fff;font-size:.92rem;font-weight:800;box-shadow:0 12px 22px -16px #5f55d6d9}.exam-continue-action svg{width:16px;height:16px;margin-left:8px;fill:none;stroke:currentColor;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}.exam-overview-card{padding:13px 14px;border:1px solid #EEF1F6;border-radius:12px;background:#fff;display:grid;gap:7px}.exam-overview-card p{margin:0 0 2px;color:#475569;font-size:.82rem;font-weight:700;line-height:1.35}.exam-overview-title{color:#64748b;font-size:.76rem;font-weight:800}.exam-overview-card div{display:flex;flex-direction:row;align-items:baseline;justify-content:flex-start;gap:4px}.exam-overview-card strong{color:#0f172a;font-size:.96rem;font-weight:800}.exam-overview-card span{color:#64748b;font-size:.82rem;font-weight:700}.exam-mobile-summary{display:none}.exam-filter-panel{display:flex;flex-direction:row;align-items:center;gap:12px;margin-bottom:12px;padding:7px 10px;border:1px solid #EEF1F6;border-radius:12px;background:#fff}.exam-filter-head{display:flex;align-items:center;justify-content:flex-start;gap:12px;color:#64748b;font-size:.82rem;font-weight:700}.exam-filter-head>span:first-child{color:#0f172a;font-size:.9rem;font-weight:800}.exam-filter-summary,.exam-filter-toggle{display:none}.exam-filter-row{display:flex;align-items:center;flex-wrap:wrap;gap:6px}.exam-filter-body{min-width:0;display:flex;align-items:center;flex-wrap:wrap;gap:7px 34px}.exam-filter-label{width:auto;color:#64748b;font-size:.82rem;font-weight:800}.exam-filter-chip{height:27px;padding:0 9px;border-radius:999px;border:1px solid #E7EAF2;background:#fff;color:#475569;font-weight:700;font-size:.82rem;cursor:pointer;transition:background-color .18s ease,color .18s ease,border-color .18s ease}.exam-filter-chip:hover,.exam-filter-chip.active{border-color:#dcd7ff;background:#f5f2ff;color:#5f55d6}.exam-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:15px}.exam-mobile-results{display:none}.exam-card{display:flex;flex-direction:column;gap:12px;padding:16px;min-height:214px;border-radius:12px;border:1px solid #EEF1F6;background:#fff;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.exam-card:hover{transform:translateY(-2px);border-color:#ded9ff;box-shadow:0 20px 36px -28px #0f172a38}.exam-card-head{display:flex;justify-content:space-between;gap:14px}.exam-card-meta{height:24px;padding:0 8px;border-radius:999px;display:inline-flex;align-items:center;background:#f8fafc;color:#64748b;font-size:.75rem;font-weight:800}.exam-card-meta.in-progress{background:#f5f2ff;color:#5f55d6}.exam-card-meta.completed{background:#f0fdf6;color:#4f9d7b}.exam-card-recent{height:24px;padding:0 9px;border-radius:999px;display:inline-flex;align-items:center;background:#f5f2ff;color:#5f55d6;font-size:.75rem;font-weight:800}.exam-card h2{margin:7px 0 0;color:#0f172a;font-size:1.06rem;font-weight:800}.exam-status{height:24px;padding:0 8px;border-radius:999px;display:inline-flex;align-items:center;flex-shrink:0;background:transparent;color:#94a3b8;font-size:.7rem;font-weight:800}.exam-status.in-progress{background:#f5f2ff;color:#5f55d6}.exam-status.completed{background:#f0fdf6;color:#4f9d7b}.exam-progress{display:flex;flex-direction:column;gap:7px}.exam-progress-top{display:flex;justify-content:space-between;gap:12px;color:#64748b;font-size:.82rem;font-weight:700}.exam-progress-track{height:6px;border-radius:999px;background:#eef1f7;overflow:hidden}.exam-progress-fill{display:block;height:100%;border-radius:inherit;background:#5f55d6}.exam-module-row{display:flex;flex-wrap:wrap;gap:8px;min-height:28px}.exam-module-chip{display:inline-flex;align-items:center;height:26px;padding:0 8px;border-radius:8px;background:#f8fafc;color:#64748b;font-size:.76rem;font-weight:700}.exam-primary-link{margin-top:auto;height:36px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;background:#6658e8;color:#fff;font-size:.88rem;font-weight:800;text-decoration:none}.exam-primary-link:hover{background:#5f55d6}.exam-primary-link.pending{background:#fff;color:#5f55d6;border:1px solid #DCD7FF}.exam-primary-link.pending:hover{background:#f5f2ff}.exam-primary-link.completed{background:#f8fafc;color:#475569;border:1px solid #E2E8F0}.exam-primary-link.completed:hover{background:#eef2f7}.exam-empty{padding:48px 20px;border:1px dashed #DDE3EE;border-radius:12px;color:#64748b;text-align:center;background:#fff}@media (max-width: 768px){.exam-select-page{width:100%;max-width:100vw;padding:18px 20px 28px;background:radial-gradient(circle at 80% 5%,rgba(98,84,230,.07),transparent 36%),#f7f8fc}.main-content.exam-select-page{min-height:100vh}.exam-hero{margin-bottom:14px}.exam-hero h1{color:#070b22;font-size:1.16rem;font-weight:700;line-height:1.2}.exam-hero p,.exam-hero-desktop{display:none}.exam-hero-mobile{display:inline}.exam-focus-row{grid-template-columns:1fr;gap:0;margin-bottom:14px}.exam-continue-card{position:relative;overflow:hidden;min-width:0;align-items:flex-start;flex-direction:column;gap:14px;padding:20px 18px 18px;border:1px solid #DED5FF;border-radius:18px;background:radial-gradient(circle at 92% 65%,rgba(102,88,232,.13) 0 18%,transparent 19%),linear-gradient(135deg,#fffffffa,#f7f3ff);box-shadow:0 22px 48px -32px #5f55d68c,inset 0 1px #ffffffc7}.exam-continue-card:after{content:"";position:absolute;right:-92px;bottom:-78px;width:240px;height:168px;background:radial-gradient(circle at 68% 68%,rgba(95,85,214,.13) 0 28%,transparent 29%),linear-gradient(135deg,transparent 0 34%,rgba(95,85,214,.06) 35% 100%);opacity:.24;pointer-events:none}.exam-continue-content{position:relative;z-index:1;width:100%;gap:16px}.exam-continue-main{position:relative;gap:8px;padding-right:104px}.exam-continue-label{color:#5f55d6;font-size:.8rem;opacity:.78;text-shadow:0 0 18px rgba(95,85,214,.18)}.exam-continue-eyebrow{display:block;color:#5f55d6;font-size:.68rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase}.exam-continue-card strong{color:#070b22;font-size:1.34rem;font-weight:800}.exam-continue-rate{position:absolute;top:36px;right:0;display:block;color:#5f55d6;font-size:2.08rem;font-weight:800;line-height:1}.exam-continue-main span:last-child{color:#4b5568;font-size:.88rem;font-weight:700}.exam-continue-progress{gap:0;margin-bottom:2px}.exam-continue-progress .exam-progress-track{height:7px;background:#e2dfffdb}.exam-continue-modules{display:none}.exam-continue-action{position:relative;z-index:1;align-self:flex-start;min-width:124px;height:42px;padding:0 18px;border-radius:999px;background:linear-gradient(135deg,#765cf3,#5f55d6);font-size:.95rem;box-shadow:0 14px 24px -16px #5f55d6bd}.exam-continue-action svg{width:15px;height:15px;margin-left:7px}.exam-overview-card{display:none}.exam-mobile-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));align-items:center;gap:14px;margin:0 0 18px;padding:0 4px;color:#4b5568;font-size:.8rem;font-weight:700}.exam-mobile-summary:not(.exam-mobile-summary-in-card){display:none}.exam-mobile-summary-in-card{position:relative;z-index:1;width:100%;margin:0 0 2px;padding:9px 0 0;border-top:1px solid rgba(226,223,255,.82)}.exam-mobile-summary>span{display:flex;align-items:center;justify-content:center;gap:6px;min-width:0;white-space:nowrap}.exam-mobile-summary>span+span{border-left:1px solid #E6EAF2}.exam-mobile-summary strong{display:block;color:#070b22;font-size:1rem;font-weight:800;line-height:1.05}.exam-mobile-summary em{display:block;margin-top:2px;color:#4b5568;font-size:.72rem;font-style:normal;font-weight:700}.exam-summary-icon{width:24px;height:24px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;background:#f6f3ff73;color:#6658e861;box-shadow:none}.exam-summary-icon svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.exam-filter-head{justify-content:space-between;width:100%;gap:8px}.exam-filter-head>span:first-child{display:none}.exam-filter-summary{min-width:0;display:flex;flex:1;gap:6px;overflow-x:auto;scrollbar-width:none}.exam-filter-summary::-webkit-scrollbar{display:none}.exam-filter-summary span{height:32px;padding:0 11px;border:1px solid #EEF1F6;border-radius:999px;display:inline-flex;align-items:center;flex-shrink:0;background:#ffffffb8;color:#475569;font-size:.8rem;font-weight:700;box-shadow:none}.exam-filter-toggle{height:32px;padding:0 12px;border:1px solid #EEF1F6;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;background:#ffffffb8;color:#475569;font-size:.8rem;font-weight:700;box-shadow:none}.exam-filter-panel{flex-direction:column;align-items:stretch;gap:0;margin-top:2px;margin-bottom:16px;padding:0;border:0;border-radius:0;background:transparent}.exam-filter-body{display:none;margin-top:8px;padding:10px;border:1px solid #EEF1F6;border-radius:12px;background:#fff;gap:8px}.exam-filter-panel.open .exam-filter-body{display:flex}.exam-filter-label{width:100%;font-size:.78rem}.exam-filter-chip{height:26px;padding:0 8px;font-size:.78rem}.exam-card-grid{display:none}.exam-mobile-results,.exam-mobile-block{display:flex;flex-direction:column;gap:12px}.exam-mobile-block h2{position:relative;margin:0 0 2px;color:#070b22;font-size:1rem;font-weight:800}.exam-mobile-block h2:after{content:"";position:absolute;left:0;bottom:-6px;width:24px;height:3px;border-radius:999px;background:#6658e8}.exam-mobile-list{display:flex;flex-direction:column;gap:5px;border-top:0}.exam-mobile-list-item{display:grid;grid-template-columns:34px minmax(0,1fr) auto 16px;align-items:center;gap:7px 10px;padding:11px 12px;border:1px solid #E8ECF4;border-radius:16px;background:#fff;color:#0f172a;text-decoration:none;box-shadow:0 14px 28px -28px #0f172a57}.exam-mobile-play{width:30px;height:30px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;grid-row:1 / 3;background:#f1edff;color:#6658e8d1}.exam-mobile-play.pending{background:#f8fafc;color:#94a3b8}.exam-mobile-play svg{width:17px;height:17px;transform:translate(1px);fill:currentColor}.exam-mobile-list-title{display:block;color:#0f172a;font-size:.94rem;font-weight:700}.exam-mobile-list-meta{display:block;margin-top:3px;color:#4b5568;font-size:.8rem;font-weight:700}.exam-mobile-list-item strong{color:#5f55d6;font-size:.94rem;font-weight:800}.exam-mobile-chevron{width:16px;height:16px;fill:none;stroke:#94a3b8;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}.exam-mobile-list-item .exam-progress-track{grid-column:2 / -1;height:5px;background:#eef1f7}}@media (min-width: 1440px){.exam-select-page{max-width:calc(100vw - var(--sidebar-width))}.exam-card-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}body.mobile-menu-open .floating-action-bar{opacity:0;pointer-events:none}@media (max-width: 768px){.player-capsule{display:flex;flex-direction:column;height:auto;min-height:112px;padding:14px 14px 12px;gap:12px}.player-topline,.player-mainrow{width:100%}.player-context{font-size:.8rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-mainrow{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.play-btn{width:48px;height:48px}.progress-section{flex:1 1 180px;max-width:none;min-width:140px;width:auto}.player-controls{width:100%;margin-left:0;justify-content:flex-end;gap:8px;flex-wrap:nowrap}.control-btn{min-width:38px;width:auto;height:34px;padding:0 10px}.control-label{display:none}.speed-btn{min-width:56px}}@media (max-width: 480px){.player-capsule{height:auto;min-height:108px;padding:12px 10px}.player-topline{gap:8px}.time-info{font-size:.68rem}.play-btn{width:44px;height:44px}.progress-section{flex-basis:150px}.control-btn{min-width:34px;height:32px;padding:0 8px}}@media (max-width: 768px){.player-capsule{height:auto;min-height:72px;padding:12px}.player-mainrow{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.player-inline-context{font-size:.78rem;order:2}.progress-section{order:4;flex:1 1 100%;max-width:none;min-width:0;width:100%;gap:10px}.player-controls{order:3;width:auto;margin-left:auto;gap:6px}}@media (max-width: 768px){.player-capsule{display:flex;flex-direction:column;min-height:112px;padding:14px 14px 12px;gap:12px}.player-topline{width:100%}.player-context{font-size:.8rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-mainrow{width:100%;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.play-btn{width:48px;height:48px}.progress-section{flex:1 1 180px;max-width:none;min-width:140px}.player-controls{width:100%;margin-left:0;justify-content:flex-end;gap:8px}.control-btn{min-width:38px;height:34px;padding:0 10px}.control-label{display:none}.speed-btn{min-width:56px}}@media (max-width: 768px){.player-capsule{height:auto;min-height:84px;padding:10px 12px;gap:8px}.player-mainrow{display:flex;align-items:center;gap:8px;flex-wrap:wrap;width:100%}.player-inline-context{display:none}.play-btn{order:1;width:42px;height:42px}.player-mobile-favorite-btn{order:2;display:flex;width:34px;height:34px;min-height:34px;padding:0;margin:0;border-radius:12px;flex-shrink:0}.player-mobile-favorite-btn span{display:none}.player-controls{order:3;display:flex;align-items:center;justify-content:flex-start;width:auto;margin-left:0;gap:6px;flex:1 1 auto;min-width:0;flex-wrap:nowrap}.control-btn{width:32px;min-width:32px;height:32px;min-height:32px;padding:0;border-radius:11px}.speed-btn{width:auto;min-width:50px;padding:0 8px}.control-label{display:none}.progress-section{order:4;flex:1 1 100%;width:100%;min-width:0;max-width:none;gap:8px}}@media (max-width: 768px){.player-page-content .player-mobile-favorite-btn,.player-page-content .player-controls .control-btn{height:34px;min-height:34px;max-height:34px;align-self:center}.player-page-content .player-mobile-favorite-btn{width:34px;min-width:34px;max-width:34px;padding:0}.player-page-content .player-controls .speed-btn{width:auto;min-width:52px;max-width:none;padding:0 8px}}@media (max-width: 380px){.player-capsule{padding-left:10px;padding-right:10px}.player-mainrow{gap:6px}.play-btn{width:40px;height:40px}.player-mobile-favorite-btn,.control-btn{width:30px;min-width:30px;height:30px;min-height:30px}.speed-btn{min-width:46px;padding:0 6px}}@media (max-width: 380px){.player-page-content .player-mobile-favorite-btn,.player-page-content .player-controls .control-btn{height:30px;min-height:30px;max-height:30px}.player-page-content .player-mobile-favorite-btn{width:30px;min-width:30px;max-width:30px}}@media (max-width: 768px){.player-page-content .player-capsule .player-mainrow{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.player-page-content .player-capsule .play-btn{order:1;flex:0 0 42px;width:42px;min-width:42px;height:42px;min-height:42px}.player-page-content .player-capsule .player-mobile-favorite-btn{order:2;flex:0 0 34px}.player-page-content .player-capsule .player-controls{order:3;flex:0 0 auto;width:auto;min-width:0;margin-left:auto;display:flex;align-items:center;justify-content:flex-end;gap:6px;flex-wrap:nowrap}.player-page-content .player-capsule .progress-section{order:4;flex:0 0 100%;width:100%;max-width:none;min-width:0}}@media (max-width: 380px){.player-page-content .player-capsule .player-mainrow{gap:6px}.player-page-content .player-capsule .play-btn{flex-basis:40px;width:40px;min-width:40px;height:40px;min-height:40px}}body.mobile-menu-open .ai-summon-btn{filter:blur(6px);opacity:.35;pointer-events:none}@media (max-width: 768px){.transcript-item{display:block;padding:14px 12px}.transcript-inner{max-width:none;align-items:flex-start;gap:10px}.transcript-item.current .transcript-inner{display:flex;grid-template-columns:none;align-items:flex-start;column-gap:0}.speaker-avatar{flex-shrink:0}.transcript-bubble{flex:1;min-width:0;max-width:none;margin-right:0}.transcript-actions{display:none!important;margin-left:0}.swipe-cell-right{display:flex!important}.transcript-bubble p{font-size:16px}.feedback-btn{width:auto;min-width:56px;height:28px;min-height:28px;padding:0 14px;border-radius:50px;gap:4px}.feedback-btn span{display:inline;font-size:.6875rem}.onboarding-option-actions{flex-direction:column}.onboarding-primary-btn,.onboarding-secondary-btn{width:100%;text-align:center}}@media (max-width: 480px){.transcript-bubble p,.ai-original-sentence,.ai-response{font-size:16px}.feedback-btn{min-width:64px;height:32px;min-height:32px;padding:0 10px;border-radius:50px}.feedback-btn span{font-size:.6875rem}}@media (max-width: 768px){.sidebar{width:min(320px,86vw);padding-top:var(--safe-area-top)}.sidebar:after{width:min(320px,86vw)}.main-content{padding:calc(18px + var(--safe-area-top)) calc(16px + var(--safe-area-right)) calc(18px + var(--safe-area-bottom)) calc(16px + var(--safe-area-left))}.main-content.player-page-content{min-height:100dvh;height:auto;overflow-y:visible;padding-bottom:calc(136px + var(--safe-area-bottom))}.content-header{margin-bottom:18px;align-items:flex-start}.header-left{width:100%;flex-wrap:wrap;gap:10px;align-items:stretch}.page-title.dropdown-title{width:100%;min-width:0;justify-content:space-between;padding:12px 14px;border-radius:16px;font-size:1.125rem;line-height:1.4}.title-text{min-width:0;flex:1;white-space:normal;word-break:break-word}.title-dropdown{width:100%;max-width:none}.dropdown-content{max-height:min(52vh,360px)}.listening-favorite-btn{width:100%;justify-content:center;min-height:44px}.player-capsule{padding:16px;gap:14px;border-radius:20px;margin-bottom:20px}.play-btn{width:48px;height:48px;flex-shrink:0}.progress-section{min-width:0}.player-controls{width:100%;justify-content:flex-end;flex-wrap:wrap;gap:10px}.control-btn{width:42px;height:42px}.speed-btn{min-width:72px;padding:0 16px}.speed-menu{right:0;left:auto}.transcript-section{margin-bottom:0}.transcript-section.immersive-active{gap:14px}.immersive-focus-stage{padding:16px 16px 64px}.immersive-focus-head{margin-bottom:14px}.immersive-focus-body{gap:12px;min-height:0}.immersive-focus-text{font-size:1.08rem;line-height:1.66}.immersive-context-header{gap:10px}.immersive-context-subtitle{max-width:220px}.transcript-container{max-height:none;min-height:calc(100dvh - 340px);padding:20px 16px;border-radius:20px}.transcript-item{gap:10px;align-items:flex-start}.transcript-inner{max-width:none}.transcript-bubble{min-width:0;flex:1;max-width:none;margin-right:0}.transcript-bubble p{word-break:break-word}.favorite-btn{width:36px;height:36px;flex-shrink:0}.floating-action-bar{left:calc(12px + var(--safe-area-left));right:calc(12px + var(--safe-area-right));width:auto;transform:none;bottom:calc(12px + var(--safe-area-bottom));padding:10px;gap:8px;border-radius:18px;justify-content:stretch;flex-wrap:wrap}.feedback-bar-copy{width:100%;justify-content:center;min-height:38px;font-size:.75rem}.feedback-btn{flex:1;min-width:0;padding:12px 10px;min-height:46px;border-radius:14px}.feedback-btn span{display:inline;font-size:.8125rem;white-space:nowrap}.ai-summon-btn{right:calc(12px + var(--safe-area-right));bottom:calc(86px + var(--safe-area-bottom));padding:11px 16px;border-radius:999px;max-width:calc(100vw - 24px - var(--safe-area-left) - var(--safe-area-right))}.modal-container,.dialog-container{width:min(100%,560px);margin:calc(16px + var(--safe-area-top)) calc(12px + var(--safe-area-right)) calc(16px + var(--safe-area-bottom)) calc(12px + var(--safe-area-left))}.notification{top:calc(12px + var(--safe-area-top));left:calc(12px + var(--safe-area-left));right:calc(12px + var(--safe-area-right));width:auto;max-width:none}.toast-container{top:calc(12px + var(--safe-area-top));right:calc(12px + var(--safe-area-right));left:calc(12px + var(--safe-area-left));align-items:flex-end;pointer-events:none}.toast{width:min(360px,100%);max-width:100%;padding:12px 14px;pointer-events:auto}}@media (max-width: 480px){.main-content{padding:calc(14px + var(--safe-area-top)) calc(12px + var(--safe-area-right)) calc(14px + var(--safe-area-bottom)) calc(12px + var(--safe-area-left))}.main-content.player-page-content{padding-bottom:calc(128px + var(--safe-area-bottom))}.main-content.player-page-content.player-mode-clear,.main-content.player-page-content.player-mode-dictation{padding-bottom:calc(20px + var(--safe-area-bottom))}.page-title.dropdown-title{font-size:1rem;padding:11px 12px}.listening-favorite-btn{min-height:42px;padding:0 12px}.listening-favorite-btn span{font-size:.875rem}.player-capsule{padding:14px 12px;gap:12px}.time-info{font-size:.8125rem}.player-controls{justify-content:space-between}.speed-menu{width:min(180px,calc(100vw - 48px))}.transcript-container{min-height:calc(100dvh - 320px);padding:16px 12px}.transcript-section.immersive-active .transcript-container{height:auto;min-height:180px;max-height:min(30vh,260px);padding:14px 12px}.transcript-section.immersive-active .transcript-container.context-collapsed{min-height:0;max-height:0;padding-top:0;padding-bottom:0}.speaker-avatar{width:30px;height:30px;font-size:.75rem}.transcript-bubble p{font-size:.9375rem;line-height:1.75}.floating-action-bar{left:calc(8px + var(--safe-area-left));right:calc(8px + var(--safe-area-right));bottom:calc(8px + var(--safe-area-bottom));padding:8px;gap:6px}.feedback-btn{padding:11px 8px}.feedback-btn span{display:none}.feedback-icon{width:18px;height:18px}.ai-summon-btn{right:calc(8px + var(--safe-area-right));bottom:calc(74px + var(--safe-area-bottom));width:auto;min-width:82px;height:44px;padding:0 14px;justify-content:center;border-radius:999px}.ai-summon-btn span{display:inline;font-size:.8125rem;font-weight:700;letter-spacing:0;white-space:nowrap}}@media (max-width: 768px){.sidebar:after{display:none}.main-content{padding:calc(14px + var(--safe-area-top)) calc(10px + var(--safe-area-right)) calc(14px + var(--safe-area-bottom)) calc(10px + var(--safe-area-left))}.main-content.player-page-content{padding-bottom:calc(96px + var(--safe-area-bottom))}.main-content.player-page-content.player-mode-clear,.main-content.player-page-content.player-mode-dictation{padding-bottom:calc(24px + var(--safe-area-bottom))}.content-header{display:flex;align-items:center;gap:12px;min-height:0;margin-bottom:12px}.player-page-content .content-header{position:relative;display:block;min-height:52px}.player-page-content .menu-toggle{position:absolute;top:0;left:0;width:40px;height:40px;border-radius:14px;z-index:20;pointer-events:auto}.player-page-content .header-left{width:100%;min-width:0;padding-left:52px;gap:0;padding-right:64px}.player-page-content .page-title.dropdown-title{width:100%;margin:0;padding:8px 34px 8px 10px;background:transparent;border:none;box-shadow:none;border-radius:0;min-height:40px}.player-page-content .set-progress-indicator{position:absolute;top:8px;right:28px;margin-left:0;padding:2px 8px;font-size:.6875rem;line-height:1.4}.dropdown-title:hover,.dropdown-title.active{transform:none;background:transparent;border:none}.dropdown-title .title-text{font-size:1rem;line-height:1.35}.dropdown-title .dropdown-arrow{width:16px;height:16px}.title-dropdown{left:0;right:0;width:auto;min-width:0;margin-top:6px}.player-page-content .listening-favorite-btn{position:static;width:34px;height:34px;min-height:34px;padding:0;margin:0;border-radius:12px;justify-content:center;grid-area:favorite;align-self:center}.listening-favorite-btn span{display:none}.listening-favorite-btn svg{width:18px;height:18px}.player-capsule{display:grid;grid-template-columns:48px 34px minmax(0,1fr);grid-template-areas:"play favorite controls" "progress progress progress";align-items:center;gap:8px 10px;padding:12px 12px 10px;margin-bottom:14px}.play-btn{grid-area:play;width:48px;height:48px}.player-controls{grid-area:controls;width:100%;justify-content:flex-start;gap:8px;flex-wrap:nowrap}.progress-section{grid-area:progress;width:100%;gap:10px}.time-info{font-size:.75rem;min-width:72px;justify-content:flex-end}.control-btn{width:34px;height:34px;border-radius:12px}.control-btn svg{width:16px;height:16px}.speed-btn{min-width:58px;padding:0 10px;font-size:.75rem}.speed-menu{left:0;right:auto}.transcript-container{height:auto;min-height:0;max-height:calc(100dvh - 248px);padding:14px 10px;border-radius:18px;overflow-y:auto;overscroll-behavior:contain}.transcript-item{gap:10px;padding:14px 12px;margin-bottom:10px}.transcript-section.immersive-active{grid-template-columns:1fr;gap:12px}.transcript-section.immersive-active .neighbor-card{display:none!important}.transcript-section.immersive-active .immersive-focus-stage{grid-column:1;padding:14px}.transcript-section.immersive-active .floating-action-bar{grid-column:1}.transcript-section.immersive-active .immersive-focus-head{align-items:flex-start;flex-direction:column;gap:8px}.transcript-section.immersive-active .immersive-focus-body{gap:10px}.transcript-section.immersive-active .immersive-focus-text{font-size:1.06rem;line-height:1.62}.transcript-section.immersive-active .immersive-context-header{align-items:flex-start;flex-direction:column}.transcript-section.immersive-active .immersive-context-subtitle{max-width:none}.transcript-section.immersive-active .immersive-context-toggle{min-height:32px;padding:0 11px;font-size:.75rem}.transcript-section.immersive-active .transcript-container{height:auto;min-height:164px;max-height:min(28vh,220px);padding:12px 8px}.transcript-section.immersive-active .transcript-container.context-collapsed{min-height:0;max-height:0;padding-top:0;padding-bottom:0}.speaker-avatar{width:28px;height:28px;font-size:.75rem}.transcript-bubble p{font-size:1rem;line-height:1.82}.floating-action-bar{background:transparent;box-shadow:none;border:none;padding:0;gap:10px;justify-content:center;bottom:calc(10px + var(--safe-area-bottom))}.feedback-bar-copy{width:100%;min-height:34px;font-size:.7rem;background:#fffffff0}.feedback-btn{width:44px;height:44px;min-width:44px;min-height:44px;padding:0;border-radius:50%;box-shadow:var(--shadow-soft);justify-content:center;flex:0 0 auto}.feedback-btn span{display:none}.feedback-icon{width:18px;height:18px}.ai-summon-btn{bottom:calc(64px + var(--safe-area-bottom));right:calc(10px + var(--safe-area-right))}}@media (max-width: 480px){.content-header{min-height:0}.player-page-content .content-header{min-height:48px}.player-page-content .menu-toggle,.player-page-content .listening-favorite-btn{width:36px;height:36px;min-height:36px;border-radius:12px}.player-page-content .header-left{padding-left:46px;padding-right:58px}.player-page-content .page-title.dropdown-title{padding:7px 28px 7px 6px}.player-page-content .set-progress-indicator{top:7px;right:24px;padding:2px 7px;font-size:.625rem}.dropdown-title .title-text{font-size:.9375rem}.player-capsule{grid-template-columns:44px 36px minmax(0,1fr);gap:8px;padding:10px 10px 8px;margin-bottom:12px}.play-btn{width:44px;height:44px}.player-controls{gap:6px}.control-btn{width:32px;height:32px;border-radius:11px}.speed-btn{min-width:54px;padding:0 8px}.progress-bar{height:5px}.progress-handle{width:14px;height:14px;border-width:2px}.time-info{font-size:.6875rem;min-width:64px}.transcript-container{height:auto;min-height:0;max-height:calc(100dvh - 224px);padding:12px 8px}.transcript-item{padding:12px 10px}.transcript-bubble p{font-size:.95rem;line-height:1.75}.floating-action-bar{gap:8px;bottom:calc(8px + var(--safe-area-bottom))}.feedback-bar-copy{min-height:32px;padding:0 12px}.feedback-btn{width:44px;height:44px;min-width:44px;min-height:44px}.feedback-icon{width:16px;height:16px}.ai-summon-btn{bottom:calc(56px + var(--safe-area-bottom))}}@media (max-width: 900px){.review-hero,.review-launch-card,.review-group-head{flex-direction:column;align-items:flex-start}.review-stats{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 768px){.review-hero,.review-launch-card{padding:20px;border-radius:22px}.review-hero-title{font-size:1.35rem}.review-section{padding:18px;border-radius:22px}.review-group-card{padding:18px;border-radius:20px}.review-line-list{gap:10px}.review-line-chip{width:100%;justify-content:space-between}}@media (max-width: 480px){.review-stats{grid-template-columns:1fr}.review-hero-action,.review-primary-btn,.review-launch-btn{width:100%}.review-exam-countdown{justify-content:center;width:100%}}@media (max-width: 640px){.review-hero{display:flex;flex-direction:column;align-items:stretch;gap:16px;margin-bottom:20px;padding:22px 18px 18px;border:1px solid rgba(109,93,246,.1);background:radial-gradient(circle at 10% 20%,rgba(109,93,246,.1),transparent 40%),radial-gradient(circle at 90% 80%,rgba(109,93,246,.14),transparent 45%),linear-gradient(135deg,#faf8ff,#f3efff,#f8f7ff);box-shadow:0 12px 28px #1e293b0f,0 1px 2px #6d5df60a}.review-hero:before,.review-hero:after{display:none}.review-hero-copy{width:100%;max-width:none;gap:8px}.review-hero-eyebrow,.review-hero-title,.review-hero-text,.review-exam-countdown-label,.review-exam-countdown-value{color:#1e1b4b}.review-hero-eyebrow{color:#6d5df6}.review-hero-text{color:#8b7cae}.review-hero-copy .review-hero-action{display:none}.review-hero-actions{margin-top:8px}.review-exam-countdown{width:auto;min-height:34px;padding:0 12px;border-color:#6d5df629;background:#f3f1ff;box-shadow:none}.review-exam-countdown-label{color:#7c6edb}.review-exam-countdown-value{color:#4f46e5}.review-hero-focus-card,.review-stats{display:none}.review-mobile-summary{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(108px,.92fr);gap:10px;margin:0;position:relative;z-index:1}.review-mobile-summary-main,.review-mobile-summary-mini{border:1px solid rgba(109,93,246,.12);box-shadow:0 8px 18px #6d5df614}.review-mobile-summary-main{min-height:186px;padding:18px;border-radius:22px;background:#fff;display:flex;flex-direction:column;justify-content:center;gap:8px;box-shadow:0 8px 18px #6d5df614}.review-mobile-summary-label,.review-mobile-summary-mini-label{font-size:.75rem;font-weight:800}.review-mobile-summary-label{color:#9e93bb}.review-mobile-summary-label{letter-spacing:.06em}.review-mobile-summary-value{color:#1e1b4b;font-size:3.45rem;line-height:.95;font-weight:900;letter-spacing:0;font-family:DIN Alternate,DIN,Montserrat,Helvetica Neue,Arial,sans-serif}.review-mobile-summary-unit{color:#9e93bb;font-size:.8125rem;font-weight:600}.review-mobile-summary-side{display:grid;grid-template-rows:repeat(3,minmax(0,1fr));gap:8px}.review-mobile-summary-mini{min-height:56px;padding:10px 12px;border-radius:16px;background:#fff;display:flex;flex-direction:column;justify-content:center;gap:3px}.review-mobile-summary-mini-label{color:#9e93bb;font-size:.7rem;white-space:nowrap}.review-mobile-summary-mini-value{display:flex;align-items:baseline;gap:3px;color:#1e1b4b;font-size:1.1rem;line-height:1.05;font-weight:850;letter-spacing:0}.review-mobile-summary-mini-value small{color:#9e93bb;font-size:.68rem;font-weight:700}.review-hero-mobile-actions{display:block;position:relative;z-index:1}.review-hero-mobile-actions .review-hero-action{width:100%;min-height:48px;background:linear-gradient(180deg,#6d5df6,#4f46e5);border:1px solid #6D5DF6;box-shadow:0 12px 24px #4f46e542,inset 0 1px #ffffff38;color:#fff}}@media (max-width: 768px){.main-content.player-page-content{min-height:100dvh;height:auto;overflow-y:visible;padding:calc(14px + var(--safe-area-top)) calc(10px + var(--safe-area-right)) calc(96px + var(--safe-area-bottom)) calc(10px + var(--safe-area-left))}.main-content.player-page-content.player-mode-clear,.main-content.player-page-content.player-mode-dictation{padding-bottom:calc(24px + var(--safe-area-bottom))}.player-page-content .content-header{position:relative;display:block;min-height:52px;margin-bottom:12px}.player-page-content .menu-toggle{position:absolute;top:0;left:0;width:40px;height:40px;border-radius:14px;z-index:20}.player-page-content .header-left{width:100%;min-width:0;padding-left:52px;padding-right:64px;gap:0}.player-page-content .page-title.dropdown-title{width:100%;min-height:40px;margin:0;padding:8px 34px 8px 10px;border:0;border-radius:0;background:transparent;box-shadow:none}.player-capsule{display:grid;grid-template-columns:48px 34px minmax(0,1fr);grid-template-areas:"play favorite controls" "progress progress progress";align-items:center;gap:8px 10px;padding:12px 12px 10px;margin-bottom:14px}.play-btn{grid-area:play;width:48px;height:48px}.player-page-content .listening-favorite-btn{grid-area:favorite;width:34px;height:34px;min-height:34px;padding:0;margin:0;border-radius:12px;justify-content:center;align-self:center}.player-page-content .header-left>.listening-favorite-btn{display:none}.player-mobile-favorite-btn{display:flex}.player-controls{grid-area:controls;width:100%;justify-content:flex-start;gap:8px;flex-wrap:nowrap}.progress-section{grid-area:progress;width:100%;gap:10px}.transcript-container{height:auto;min-height:0;max-height:calc(100dvh - 248px);padding:14px 10px;border-radius:18px;overflow-y:auto;overscroll-behavior:contain}.transcript-bubble p{font-size:1rem;line-height:1.82;word-break:break-word}.transcript-section.immersive-active{grid-template-columns:1fr;gap:12px}.transcript-section.immersive-active .neighbor-card{display:none!important}.transcript-section.immersive-active .immersive-focus-stage,.transcript-section.immersive-active .floating-action-bar{grid-column:1}.transcript-section.immersive-active .transcript-container{height:auto;min-height:164px;max-height:min(28vh,220px);padding:12px 8px}.transcript-section.immersive-active .immersive-focus-stage{min-height:min(46dvh,360px);max-height:none;overflow:visible}.transcript-section.immersive-active .immersive-focus-stage{padding-top:18px}.transcript-section.immersive-active .immersive-focus-head{padding-right:44px}.transcript-section.immersive-active .immersive-play-btn{position:absolute;top:12px;right:12px;z-index:4}.transcript-section.immersive-active .transcript-container.context-collapsed{min-height:0;max-height:0;padding-top:0;padding-bottom:0}.floating-action-bar{left:calc(8px + var(--safe-area-left));right:calc(8px + var(--safe-area-right));bottom:calc(10px + var(--safe-area-bottom));width:auto;padding:0;gap:10px;border:0;background:transparent;box-shadow:none;transform:none;justify-content:center}.feedback-btn{width:44px;height:44px;min-width:44px;min-height:44px;padding:0;border-radius:50%;flex:0 0 auto;justify-content:center}.feedback-btn span{display:none}.ai-summon-btn{right:calc(10px + var(--safe-area-right));bottom:calc(64px + var(--safe-area-bottom))}}@media (max-width: 480px){.main-content.player-page-content{padding-bottom:calc(88px + var(--safe-area-bottom))}.main-content.player-page-content.player-mode-clear,.main-content.player-page-content.player-mode-dictation{padding-bottom:calc(20px + var(--safe-area-bottom))}.player-page-content .content-header{min-height:48px}.player-page-content .menu-toggle,.player-page-content .listening-favorite-btn{width:36px;height:36px;min-height:36px;border-radius:12px}.player-page-content .header-left{padding-left:46px;padding-right:58px}.player-capsule{grid-template-columns:44px 36px minmax(0,1fr);gap:8px;padding:10px 10px 8px;margin-bottom:12px}.play-btn{width:44px;height:44px}.transcript-container{max-height:calc(100dvh - 224px);padding:12px 8px}.feedback-btn{width:44px;height:44px;min-width:44px;min-height:44px}.ai-summon-btn{bottom:calc(56px + var(--safe-area-bottom))}}@media (max-width: 768px){.dictation-panel{grid-template-columns:1fr;grid-template-rows:auto auto auto;gap:14px;min-height:auto}.dictation-focus-stage{min-height:180px}.dictation-focus-body{padding:16px}.dictation-blurred-text{font-size:1.05rem}.dictation-play-btn{width:28px;height:28px}.dictation-play-btn svg{width:12px;height:12px}.dictation-nav-btn{width:28px;height:28px}.dictation-nav-btn svg{width:14px;height:14px}.dictation-input-area{min-height:180px}.dictation-textarea{min-height:100px;font-size:1rem;padding:14px}.dictation-actions{justify-content:center}.dictation-submit-btn,.dictation-next-btn{width:100%;justify-content:center;padding:12px 20px}.dictation-feedback-bar{justify-self:stretch;width:100%;gap:8px;padding:10px 12px;flex-wrap:wrap}.dictation-feedback-btn{flex:1;min-width:70px;justify-content:center;padding:8px 12px;font-size:.8125rem}.dictation-feedback-btn svg{width:14px;height:14px}.dictation-stats-bar{padding:10px 12px;gap:8px}.dictation-stat-value{font-size:1.1rem}.dictation-diff-result{font-size:1rem;line-height:1.7}}@media (max-width: 768px){.player-capsule{display:flex;flex-direction:column;min-height:112px;padding:14px 14px 12px;gap:12px}.player-topline,.player-mainrow{width:100%}.player-context{font-size:.8rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-mainrow{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.play-btn{width:48px;height:48px}.progress-section{flex:1 1 180px;max-width:none;min-width:140px;width:auto}.player-controls{width:100%;margin-left:0;justify-content:flex-end;gap:8px;flex-wrap:nowrap}.control-btn{min-width:38px;width:auto;height:34px;padding:0 10px}.control-label{display:none}.speed-btn{min-width:56px}}@media (max-width: 480px){.player-capsule{min-height:108px;padding:12px 10px}.player-topline{gap:8px}.time-info{font-size:.68rem}.play-btn{width:44px;height:44px}.progress-section{flex-basis:150px}.control-btn{min-width:34px;height:32px;padding:0 8px}}.maintenance-overlay[data-v-b319973e]{position:fixed;top:0;right:0;bottom:0;left:0;z-index:12000;display:flex;align-items:center;justify-content:center;padding:24px;background:#0f172a94;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.maintenance-panel[data-v-b319973e]{width:min(92vw,430px);padding:30px;border:1px solid var(--border-light);border-radius:var(--radius-lg);background:var(--bg-card);box-shadow:var(--shadow-hover);text-align:center}.maintenance-icon[data-v-b319973e]{width:56px;height:56px;margin:0 auto 18px;border-radius:18px;display:flex;align-items:center;justify-content:center;color:#fff;background:linear-gradient(135deg,var(--primary) 0%,#0ea5e9 100%)}.maintenance-icon svg[data-v-b319973e]{width:30px;height:30px}.maintenance-panel h2[data-v-b319973e]{margin:0 0 10px;color:var(--text-primary);font-size:1.35rem;line-height:1.35}.maintenance-panel p[data-v-b319973e]{margin:0;color:var(--text-secondary);font-size:.95rem;line-height:1.7}.maintenance-meta[data-v-b319973e],.maintenance-contact[data-v-b319973e]{margin-top:12px;color:var(--text-muted);font-size:.9rem}.maintenance-refresh[data-v-b319973e]{width:100%;margin-top:22px;padding:12px 18px;border:0;border-radius:var(--radius);background:var(--primary);color:#fff;font:inherit;font-weight:600;cursor:pointer;transition:var(--transition)}.maintenance-refresh[data-v-b319973e]:hover{background:var(--primary-dark);transform:translateY(-1px)}@media (max-width: 480px){.maintenance-overlay[data-v-b319973e]{padding:18px}.maintenance-panel[data-v-b319973e]{padding:26px 22px}}.route-view-shell{min-height:100vh}.route-fade-enter-active,.route-fade-leave-active{transition:opacity .18s ease,transform .18s ease}.route-fade-enter-from{opacity:0;transform:translateY(6px)}.route-fade-leave-to{opacity:0;transform:translateY(-4px)}@media (prefers-reduced-motion: reduce){.route-fade-enter-active,.route-fade-leave-active{transition:none}.route-fade-enter-from,.route-fade-leave-to{opacity:1;transform:none}}
