:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:var(--color-text-primary);background-color:var(--color-bg-root);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--color-accent: #f97316;--color-accent-hover: #ea580c;--color-accent-muted: rgba(249,115,22,.1);--color-accent-muted-hover: rgba(249,115,22,.2);--color-bg-root: #242424;--color-bg-surface: #1a1a1a;--color-bg-elevated: #252525;--color-bg-active: #2a1a0a;--color-text-primary: #f0f0f0;--color-text-secondary: #d0d0d0;--color-text-muted: #888;--color-text-dimmed: #666;--color-border: #333;--color-border-input: #444;--color-success: #4ade80;--color-error: #f87171;--color-warning: #facc15}html{scroll-behavior:smooth}a{font-weight:500;color:var(--color-accent);text-decoration:inherit}a:hover{color:var(--color-accent-hover)}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--color-bg-surface);cursor:pointer;transition:border-color .25s}button:hover{border-color:var(--color-accent)}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 20px;gap:16px}.loading-spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-message{color:var(--color-text-muted);font-size:.875rem;margin:0}.issue-list{max-width:800px;margin:0 auto;padding:20px}.issue-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.issue-list-header h1{font-size:1.75rem;margin:0;color:var(--color-text-primary)}.issue-list-header .settings-link{font-size:1.5rem;text-decoration:none;opacity:.6;transition:opacity .2s}.issue-list-header .settings-link:hover{opacity:1}.issue-list h1{font-size:1.75rem;margin-bottom:24px;color:var(--color-text-primary)}.issue-list ul{list-style:none;padding:0;margin:0}.issue-item{margin-bottom:12px}.issue-item a{display:block;padding:16px 20px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:8px;text-decoration:none;color:inherit;transition:background .2s,border-color .2s}.issue-item a:hover{background:var(--color-bg-elevated);border-color:var(--color-border-input)}.issue-item h2{font-size:1.1rem;font-weight:500;margin:0 0 8px;color:var(--color-text-primary)}.issue-meta{display:flex;gap:16px;font-size:.875rem;color:var(--color-text-muted)}.status{padding:2px 8px;border-radius:4px;font-size:.75rem;font-weight:500}.status.processed{background:var(--color-accent-muted);color:var(--color-accent)}.status.pending{background:#facc151a;color:var(--color-warning)}.empty{text-align:center;padding:48px 20px;color:var(--color-text-muted)}.empty .hint{font-size:.875rem;margin-top:8px}.error-detail{color:var(--color-text-muted);font-size:.875rem;margin:0}.retry-btn{margin-top:8px;padding:8px 20px;border:1px solid var(--color-accent);border-radius:6px;background:transparent;color:var(--color-accent);font-size:.875rem;cursor:pointer}.process-section{margin-bottom:24px}.process-form{display:flex;gap:12px;margin-bottom:8px}.url-input{flex:1;padding:12px 16px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-primary);font-size:1rem;transition:border-color .2s}.url-input:focus{outline:none;border-color:var(--color-accent)}.process-btn{padding:12px 24px;background:var(--color-accent);border:none;border-radius:8px;color:#fff;font-weight:500;cursor:pointer;transition:background .2s,opacity .2s}.process-btn:hover:not(:disabled){background:var(--color-accent-hover)}.process-btn:disabled{opacity:.6;cursor:not-allowed}.process-error{color:var(--color-error);font-size:.875rem;padding:8px 12px;background:#f871711a;border-radius:6px;margin-top:8px}.process-success{color:var(--color-success);font-size:.875rem;padding:8px 12px;background:#4ade801a;border-radius:6px;margin-top:8px}@media(max-width:600px){.issue-list{padding:16px}.issue-list h1{font-size:1.5rem;margin-bottom:20px}.issue-item a{padding:14px 16px}.issue-item h2{font-size:1rem}.issue-meta{flex-direction:column;gap:8px}.status{align-self:flex-start}.process-form{flex-direction:column}.process-btn{width:100%}}.player{max-width:800px;margin:0 auto;padding:20px 20px 100px}.player-header{margin-bottom:20px}.header-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.settings-link{font-size:1.25rem;text-decoration:none;opacity:.6;transition:opacity .2s;color:var(--color-text-secondary)}.settings-link:hover{opacity:1;color:var(--color-text-primary)}.back-link{display:inline-block;color:var(--color-text-muted);text-decoration:none;font-size:.875rem;margin-bottom:12px}.back-link:hover{color:var(--color-text-secondary)}.player-header h1{font-size:1.5rem;font-weight:500;margin:0 0 8px;color:var(--color-text-primary)}.player-header .published-date{font-size:.875rem;color:var(--color-text-muted);margin:0}.bookmark-error-toast{position:fixed;top:20px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:12px 20px;background:#f87171f2;color:#fff;border-radius:8px;font-size:.875rem;box-shadow:0 4px 20px #0000004d;z-index:200;animation:slideDown .3s ease;max-width:calc(100% - 40px)}.voice-error-toast{position:fixed;top:72px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:12px 20px;background:#f97316f2;color:#fff;border-radius:8px;font-size:.875rem;box-shadow:0 4px 20px #0000004d;z-index:200;animation:slideDown .3s ease;max-width:calc(100% - 40px)}.toast-icon{font-size:1rem}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.player-error{max-width:800px;margin:0 auto;padding:20px}.player-error .back-link{display:inline-block;color:var(--color-text-muted);text-decoration:none;font-size:.875rem;margin-bottom:12px}.player-error .back-link:hover{color:var(--color-text-secondary)}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 20px;gap:12px}.error-icon{width:48px;height:48px;border-radius:50%;background:#f871711a;color:var(--color-error);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700}.error-message{color:var(--color-text-primary);font-size:1rem;font-weight:500;margin:0}.error-detail{color:var(--color-text-muted);font-size:.875rem;margin:0;text-align:center}.retry-btn{margin-top:8px;padding:8px 20px;border:1px solid var(--color-accent);border-radius:6px;background:transparent;color:var(--color-accent);font-size:.875rem;cursor:pointer;text-decoration:none}.retry-btn:hover{background:var(--color-accent-muted)}.no-chinese-content{display:flex;align-items:center;justify-content:center;padding:48px 20px;color:var(--color-text-muted);font-size:1rem}.no-chinese-content p{margin:0}@media(max-width:600px){.player{padding:16px 16px 90px}.player-header h1{font-size:1.25rem}}.audio-controls{position:fixed;bottom:0;left:0;right:0;display:flex;flex-direction:column;background:var(--color-bg-surface);border-top:1px solid var(--color-border);z-index:1100;padding-bottom:env(safe-area-inset-bottom)}.controls-row-main{display:flex;align-items:center;gap:12px;padding:12px 20px;width:100%;box-sizing:border-box}.controls-left,.controls-center,.controls-right{display:flex;align-items:center;gap:12px;min-width:0}.controls-left,.controls-right{flex:1}.controls-left{justify-content:flex-start}.controls-center{justify-content:center;flex:0 1 40%;min-width:0}.controls-right{justify-content:flex-end}.play-pause-btn{width:44px;height:44px;border:none;border-radius:50%;background:var(--color-accent);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px #f973164d;transition:transform .1s;padding:0}.play-pause-btn:active{transform:scale(.95)}.play-pause-btn:disabled{background:var(--color-text-muted);opacity:.5;cursor:not-allowed;box-shadow:none}.time-display{font-size:.8rem;color:var(--color-text-secondary);font-variant-numeric:tabular-nums;min-width:60px}.spacer{flex:1}.control-btn{background:transparent;border:none;color:var(--color-text-secondary);cursor:pointer;padding:8px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:color .2s,background .2s}.control-btn:hover{color:var(--color-text-primary);background:#ffffff0d}.speed-text{font-size:.85rem;font-weight:600;min-width:24px;text-align:center}.voice-toggle-btn{color:var(--color-text-primary);position:relative;gap:6px}.voice-toggle-btn.active{color:var(--color-accent);background:#f973161f}.voice-toggle-btn.speaking{animation:pulse-orange 1.4s infinite}.voice-status{display:flex;align-items:center;gap:6px;font-size:.7rem;color:var(--color-text-secondary);min-width:0}.controls-center .voice-status{max-width:100%}.voice-dot{width:6px;height:6px;border-radius:50%;background:var(--color-text-muted);box-shadow:0 0 #f9731666}.voice-dot.on{background:var(--color-accent);box-shadow:0 0 0 4px #f9731633}.voice-status-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.voice-last-command{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;overflow:hidden;max-width:120px}.mic-btn{color:var(--color-text-primary)}.mic-btn:hover{color:var(--color-accent)}.mic-btn.listening{color:var(--color-error);background:#f871711a;animation:pulse-red 1.5s infinite}.progress-container{width:100%;height:4px;background:var(--color-bg-elevated);cursor:pointer;position:relative}.progress-container:before{content:"";position:absolute;inset:-10px 0;z-index:10}.progress-bar{height:100%;background:var(--color-accent);transition:width .1s linear}@keyframes pulse-red{0%{box-shadow:0 0 #f8717166}70%{box-shadow:0 0 0 6px #f8717100}to{box-shadow:0 0 #f8717100}}@keyframes pulse-orange{0%{box-shadow:0 0 #f9731666}70%{box-shadow:0 0 0 6px #f9731600}to{box-shadow:0 0 #f9731600}}@media(max-width:600px){.controls-row-main{padding:8px 16px;gap:8px}.controls-left,.controls-center,.controls-right{gap:8px}.controls-center .voice-status{max-width:140px}.play-pause-btn{width:40px;height:40px}.time-display{font-size:.75rem}.control-btn{padding:6px}.voice-last-command{display:none}}.segments-list{display:flex;flex-direction:column;gap:8px}.no-segments{text-align:center;color:var(--color-text-muted);padding:48px 20px}.segment{position:relative;display:flex;align-items:flex-start;gap:12px;padding:8px 12px;background:transparent;border:none;border-radius:0;border-left:3px solid transparent;cursor:pointer;transition:background .2s,border-color .2s;scroll-margin-bottom:120px}.segment:hover{background:var(--color-bg-elevated)}.segment.active{border-left-color:var(--color-accent);background:var(--color-bg-active)}.segment-content{flex:1;min-width:0}.segment p{font-size:1rem;margin:0;color:var(--color-text-secondary);line-height:1.6;overflow-wrap:anywhere;word-break:break-word}.segment.active p{color:var(--color-text-primary)}.inline-link{color:inherit;text-decoration:underline;text-decoration-color:var(--color-accent);text-underline-offset:2px;overflow-wrap:anywhere;word-break:break-word}.inline-link:hover{color:var(--color-accent);text-decoration-color:var(--color-accent-hover)}.bookmark-btn{flex-shrink:0;width:32px;height:32px;padding:0;border:none;background:transparent;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;transition:all .2s}.bookmark-btn:hover:not(:disabled){color:var(--color-accent);background:var(--color-accent-muted);border-radius:4px}.bookmark-btn.bookmarked{color:var(--color-success)}.bookmark-btn:disabled{cursor:default;opacity:.8}.animate-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.section-header{display:block;margin:32px 0 16px;padding:16px 12px;border-top:1px solid var(--color-border);cursor:pointer;transition:background .2s}.section-header:first-child{margin-top:0;border-top:none}.section-header:hover{background:var(--color-bg-elevated)}.section-header.group-active{background:var(--color-bg-active)}.section-title{margin:0;font-size:1.4rem;font-weight:700;color:var(--color-accent);letter-spacing:.5px}.topic-group{display:block;margin-bottom:24px}.group-title{margin:24px 0 16px 12px;font-size:1.2rem;font-weight:700;color:var(--color-text-primary);padding-bottom:4px}.group-items{display:flex;flex-direction:column;gap:4px}@media(max-width:600px){.segment{padding:8px 12px}.segment p{font-size:.95rem}}.side-panel-scrim{position:fixed;inset:0;background:#00000080;z-index:1000;animation:fadeIn .2s ease-out}.side-panel{position:fixed;top:0;left:0;bottom:0;width:80vw;max-width:400px;background:var(--color-bg-elevated);z-index:1001;display:flex;flex-direction:column;box-shadow:4px 0 16px #0000004d;animation:slideIn .2s ease-out}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.side-panel-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--color-border);background:var(--color-bg-surface)}.side-panel-tabs{display:flex;gap:16px}.tab-btn{background:none;border:none;border-bottom:2px solid transparent;padding:8px 4px;font-size:1rem;color:var(--color-text-secondary);border-radius:0}.tab-btn:hover{color:var(--color-text-primary);border-color:transparent}.tab-btn.active{color:var(--color-text-primary);border-bottom-color:var(--color-accent)}.close-panel-btn{background:none;border:none;font-size:1.5rem;color:var(--color-text-muted);cursor:pointer;padding:4px}.close-panel-btn:hover{color:var(--color-text-primary)}.side-panel-content{flex:1;overflow-y:auto;padding:0}.toc-list{padding:12px 0}.toc-section-divider{padding:16px 20px 8px;cursor:pointer;border-top:1px solid var(--color-border);margin-top:8px;transition:all .2s}.toc-section-divider:first-child{border-top:none;margin-top:0}.toc-section-divider:hover{background:#ffffff08}.toc-section-divider.active{background:#f973161a}.toc-section-title{font-size:.85rem;font-weight:600;color:var(--color-accent);text-transform:uppercase;letter-spacing:.5px}.toc-section-divider.active .toc-section-title{color:var(--color-accent)}.toc-item{padding:12px 20px;cursor:pointer;border-left:3px solid transparent;transition:all .2s}.toc-item:hover{background:#ffffff08}.toc-item.active{border-left-color:var(--color-accent);background:#f973161a}.toc-title{font-size:1rem;color:var(--color-text-primary)}.toc-item.active .toc-title{color:var(--color-accent);font-weight:500}.qa-messages-container{padding:16px 16px 100px;display:flex;flex-direction:column;gap:12px}.qa-placeholder{text-align:center;color:var(--color-text-dimmed);font-style:italic;margin-top:40px}.voice-status-card{padding:12px 14px;border-radius:12px;border:1px solid var(--color-border);background:#f9731614;color:var(--color-text-primary);font-size:.85rem;display:flex;flex-direction:column;gap:6px}.voice-status-row{display:flex;align-items:center;gap:8px}.voice-status-dot{width:8px;height:8px;border-radius:50%;background:var(--color-text-muted);box-shadow:0 0 #f973164d}.voice-status-dot.on{background:var(--color-accent);box-shadow:0 0 0 4px #f9731633}.voice-status-command{color:var(--color-text-secondary);font-size:.75rem}.qa-message{padding:10px 14px;border-radius:12px;font-size:.9rem;line-height:1.4;max-width:90%}.qa-message.user{align-self:flex-end;background:var(--color-accent);color:#fff;border-bottom-right-radius:4px}.qa-message.assistant{align-self:flex-start;background:var(--color-bg-surface);color:var(--color-text-primary);border-bottom-left-radius:4px;border:1px solid var(--color-border)}.qa-message.error{align-self:center;background:#f871711a;color:var(--color-error);border:1px solid rgba(248,113,113,.3)}.qa-message.resuming{align-self:center;color:var(--color-accent);font-style:italic;opacity:.8}.qa-play-button{background:var(--color-warning);color:#000;margin-top:8px}.qa-message.listening,.qa-message.loading{font-style:italic;opacity:.8}.settings{max-width:700px;margin:0 auto;padding:20px}.settings-header{margin-bottom:32px}.settings-header .back-link{display:inline-block;color:var(--color-text-muted);text-decoration:none;font-size:.875rem;margin-bottom:12px;transition:color .2s}.settings-header .back-link:hover{color:var(--color-text-secondary)}.settings-header h1{font-size:1.75rem;font-weight:600;margin:0;color:var(--color-text-primary)}.settings-section{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:12px;padding:24px;margin-bottom:20px}.settings-section h2{font-size:1.125rem;font-weight:600;margin:0 0 8px;color:var(--color-text-primary);display:flex;align-items:center;gap:8px}.section-icon{font-size:1.25rem}.section-description{font-size:.875rem;color:var(--color-text-muted);margin:0 0 20px;line-height:1.5}.settings-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.875rem;font-weight:500;color:var(--color-text-secondary)}.form-group input{padding:12px 14px;background:var(--color-bg-root);border:1px solid var(--color-border-input);border-radius:8px;font-size:.9375rem;color:var(--color-text-primary);transition:border-color .2s,box-shadow .2s}.form-group input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #f9731626}.form-group input::placeholder{color:var(--color-text-dimmed)}.input-with-toggle{position:relative;display:flex}.input-with-toggle input{flex:1;padding-right:48px}.toggle-visibility{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:transparent;border:none;padding:6px;font-size:1rem;cursor:pointer;opacity:.6;transition:opacity .2s}.toggle-visibility:hover{opacity:1}.form-hint{font-size:.75rem;color:var(--color-text-dimmed);margin:0}.language-select{padding:12px 14px;background:var(--color-bg-root);border:1px solid var(--color-border-input);border-radius:8px;font-size:.9375rem;color:var(--color-text-primary);cursor:pointer;transition:border-color .2s,box-shadow .2s;min-width:200px}.language-select:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #f9731626}.language-select option{background:var(--color-bg-surface);color:var(--color-text-primary)}.form-actions{display:flex;gap:12px;margin-top:8px}.save-btn,.clear-btn{padding:10px 20px;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.save-btn{background:linear-gradient(135deg,var(--color-accent),var(--color-accent-hover));border:none;color:#fff}.save-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--color-accent-hover),#c2410c);transform:translateY(-1px)}.save-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.clear-btn{background:transparent;border:1px solid var(--color-text-dimmed);color:var(--color-text-muted)}.clear-btn:hover{border-color:var(--color-error);color:var(--color-error)}.save-status{padding:10px 14px;border-radius:8px;font-size:.875rem;text-align:center;animation:fadeIn .3s ease}.save-status.saved{background:#4ade801a;color:var(--color-success);border:1px solid rgba(74,222,128,.2)}.save-status.cleared{background:#f871711a;color:var(--color-error);border:1px solid rgba(248,113,113,.2)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.config-status{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:8px;font-size:.875rem;margin-top:20px}.config-status.configured{background:#4ade801a;color:var(--color-success);border:1px solid rgba(74,222,128,.2)}.config-status.not-configured{background:#facc151a;color:var(--color-warning);border:1px solid rgba(250,204,21,.2)}.status-icon{font-weight:700}.help-section{background:#000;background:#181818;border-color:var(--color-border)}.help-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px}.help-step h3{font-size:.9375rem;font-weight:600;color:var(--color-text-secondary);margin:0 0 12px}.help-step ol{margin:0;padding-left:20px;color:var(--color-text-muted);font-size:.875rem;line-height:1.8}.help-step li{margin-bottom:4px}.help-step a{color:var(--color-accent);text-decoration:none}.help-step a:hover{text-decoration:underline}.help-step code{background:var(--color-bg-root);padding:2px 6px;border-radius:4px;font-size:.75rem;color:var(--color-text-secondary);word-break:break-all}.help-step strong{color:var(--color-text-primary)}@media(max-width:600px){.settings{padding:16px}.settings-header h1{font-size:1.5rem}.settings-section{padding:20px 16px}.form-actions{flex-direction:column}.save-btn,.clear-btn{width:100%;justify-content:center}.help-steps{grid-template-columns:1fr}}.install-prompt{position:fixed;top:0;left:0;right:0;background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-accent-hover) 100%);padding:12px 16px;z-index:200;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.install-prompt-content{max-width:800px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.install-prompt-text{color:#fff;font-size:.875rem;font-weight:500}.install-prompt-buttons{display:flex;gap:8px}.install-btn{padding:6px 16px;border:none;border-radius:4px;background:#fff;color:var(--color-accent);font-size:.875rem;font-weight:600;cursor:pointer}.install-btn:hover{background:var(--color-text-primary)}.dismiss-btn{padding:6px 12px;border:1px solid rgba(255,255,255,.5);border-radius:4px;background:transparent;color:#fff;font-size:.875rem;cursor:pointer}.dismiss-btn:hover{border-color:#fff;background:#ffffff1a}.app{min-height:100vh}
