:root{--bg: #f7f7f9;--surface: #ffffff;--surface-alt: #f0f0f4;--text: #1a1a1f;--text-muted: #5a5a66;--border: #e3e3eb;--accent: #2868ff;--accent-hover: #1d52d6;--danger: #d8403c;--success: #22a06b;--warn: #d49a00;--radius: 10px;--shadow: 0 2px 8px rgba(0, 0, 0, .04), 0 1px 2px rgba(0, 0, 0, .06);--max-width: 640px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Hiragino Sans,PingFang SC,Microsoft YaHei,sans-serif}@media(prefers-color-scheme:dark){:root{--bg: #0f0f12;--surface: #1a1a1f;--surface-alt: #232329;--text: #ececf1;--text-muted: #9b9ba8;--border: #2c2c33;--accent: #5e8bff;--accent-hover: #7da1ff;--shadow: 0 2px 8px rgba(0, 0, 0, .4), 0 1px 2px rgba(0, 0, 0, .3)}}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--text);min-height:100vh}body{display:flex;flex-direction:column}.top-bar{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);background:var(--surface)}.app-title{margin:0;font-size:1.1rem;font-weight:600;letter-spacing:-.01em}.language-switcher{display:flex;gap:.25rem;font-size:.85rem}.lang-link{color:var(--text-muted);text-decoration:none;padding:.25rem .5rem;border-radius:6px}.lang-link:hover{background:var(--surface-alt);color:var(--text)}.lang-link.is-current{color:var(--text);background:var(--surface-alt);font-weight:500}.app{flex:1;width:100%;max-width:var(--max-width);margin:0 auto;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.tagline{margin:0;font-size:1rem;color:var(--text-muted)}.intro{margin:0;font-size:.95rem;line-height:1.6;color:var(--text-muted)}.app-title a{color:inherit;text-decoration:none}.app-title a:hover{opacity:.8}.prose-page{max-width:720px}.prose{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.75rem 2rem;box-shadow:var(--shadow);line-height:1.65;font-size:.95rem}.prose h1{margin:0 0 .5rem;font-size:1.5rem}.prose h2{margin:1.75rem 0 .5rem;font-size:1.1rem}.prose h3{margin:1.25rem 0 .4rem;font-size:1rem}.prose p{margin:0 0 .85rem}.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.prose a:hover{text-decoration-color:var(--accent-hover)}.prose code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.85em;background:var(--surface-alt);padding:.1em .35em;border-radius:3px}.prose table{width:100%;border-collapse:collapse;margin:.5rem 0 1rem;font-size:.85rem}.prose th,.prose td{text-align:left;padding:.55rem .75rem;border-bottom:1px solid var(--border);vertical-align:top}.prose th{font-weight:600;background:var(--surface-alt)}.prose ul,.prose ol{margin:0 0 .85rem;padding-left:1.4rem}.prose li{margin:.25rem 0}.page-meta{color:var(--text-muted);font-size:.85rem;margin:0 0 1.5rem}.page-meta time{font-variant-numeric:tabular-nums}.back-link{margin-top:2rem;font-size:.9rem}.back-link a{color:var(--accent)}.post-description{font-size:1rem;color:var(--text-muted);font-style:italic;margin:0 0 1.5rem;padding-left:.75rem;border-left:3px solid var(--border)}.post-list{list-style:none;margin:1.5rem 0 0;padding:0}.post-list-item{padding:1.25rem 0;border-top:1px solid var(--border)}.post-list-item:first-of-type{border-top:0;padding-top:0}.post-list-item h2{margin:0 0 .35rem;font-size:1.15rem}.post-list-item h2 a{color:var(--text);text-decoration:none}.post-list-item h2 a:hover{color:var(--accent)}.post-list-meta{font-size:.8rem;color:var(--text-muted);margin:0 0 .5rem}.read-more{margin:.5rem 0 0;font-size:.9rem}.prose pre{background:var(--surface-alt);padding:.85rem 1rem;border-radius:6px;overflow-x:auto;font-size:.8rem;line-height:1.5;margin:0 0 1rem}.prose pre code{background:transparent;padding:0;font-size:inherit}.prose blockquote{border-left:3px solid var(--border);padding-left:1rem;margin:0 0 1rem;color:var(--text-muted)}.faq{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow)}.faq h2{margin:0 0 1rem;font-size:1.1rem}.faq-item{padding:.875rem 0;border-top:1px solid var(--border)}.faq-item:first-of-type{border-top:0;padding-top:0}.faq-item:last-of-type{padding-bottom:0}.faq-item h3{margin:0 0 .5rem;font-size:.95rem;font-weight:600}.faq-item p{margin:0;font-size:.9rem;line-height:1.6;color:var(--text-muted)}.github-buttons{margin:.75rem 0 0;display:flex;justify-content:center;gap:.5rem;flex-wrap:wrap;min-height:28px}.github-buttons .github-button{text-decoration:none}.footer-meta{margin:.75rem 0 0;display:flex;justify-content:center;flex-wrap:wrap;gap:.4rem;font-size:.75rem;color:var(--text-muted)}.footer-meta a{color:inherit;text-decoration:underline;text-decoration-color:var(--border);text-underline-offset:2px}.footer-meta a:hover{text-decoration-color:var(--text-muted)}.status-card,.settings-card,.instructions{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow)}.status-row{display:flex;align-items:center;gap:.625rem;font-size:1rem;font-weight:500}.status-dot{width:10px;height:10px;border-radius:50%;background:var(--text-muted);flex-shrink:0}.status-dot[data-state=listening]{background:var(--success);box-shadow:0 0 0 4px color-mix(in srgb,var(--success) 25%,transparent);animation:pulse 1.6s ease-in-out infinite}.status-dot[data-state=alerted]{background:var(--danger);animation:pulse .6s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.volume-row{margin-top:1rem;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.75rem}.volume-caption{font-size:.85rem;color:var(--text-muted)}.volume-bar{position:relative;height:8px;background:var(--surface-alt);border-radius:4px;overflow:hidden}.volume-bar-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--success),var(--warn) 70%,var(--danger));transition:width .1s linear}.volume-bar-threshold{position:absolute;top:-3px;bottom:-3px;width:2px;background:var(--accent);transform:translate(-1px);pointer-events:none}.volume-readout{font-variant-numeric:tabular-nums;font-size:.85rem;color:var(--text-muted);min-width:4.5em;text-align:right}.settings-card{display:flex;flex-direction:column;gap:1.25rem}.field{display:flex;flex-direction:column;gap:.5rem}.field-label{display:flex;justify-content:space-between;font-size:.9rem;font-weight:500}.field-value{color:var(--text-muted);font-weight:400;font-variant-numeric:tabular-nums}.field-control{display:flex;align-items:center;gap:.5rem}.field-control input[type=number]{width:6rem;padding:.5rem .625rem;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:var(--text);font:inherit}.field-unit{color:var(--text-muted);font-size:.9rem}.field-hint{font-size:.8rem;color:var(--text-muted);line-height:1.4}.range-input{width:100%;accent-color:var(--accent)}.checkbox{display:flex;align-items:center;gap:.5rem;font-size:.95rem;cursor:pointer}.checkbox input[type=checkbox]{width:1rem;height:1rem;accent-color:var(--accent)}.action-row{display:flex;gap:.75rem}button.primary,button.secondary{flex:1;padding:.875rem 1rem;border-radius:8px;font:inherit;font-weight:600;cursor:pointer;border:1px solid transparent;transition:background-color .15s ease,border-color .15s ease}button.primary{background:var(--accent);color:#fff}button.primary:hover:not(:disabled){background:var(--accent-hover)}button.primary:disabled{opacity:.5;cursor:not-allowed}button.secondary{background:var(--surface);color:var(--text);border-color:var(--border)}button.secondary:hover{background:var(--surface-alt)}.error-message{margin:0;padding:.75rem 1rem;background:color-mix(in srgb,var(--danger) 12%,transparent);border:1px solid color-mix(in srgb,var(--danger) 40%,transparent);border-radius:8px;color:var(--danger);font-size:.9rem}.instructions{font-size:.95rem;line-height:1.6}.instructions h2{margin:0 0 .75rem;font-size:1rem}.instructions ol{margin:0;padding-left:1.25rem}.browser-hint{margin:.75rem 0 0;padding:.625rem .75rem;background:var(--surface-alt);border-radius:6px;font-size:.85rem;color:var(--text-muted)}.footer{padding:1rem 1.5rem 1.5rem;text-align:center;font-size:.8rem;color:var(--text-muted)}.footer p{margin:0}.consent-banner{position:fixed;left:0;right:0;bottom:0;z-index:900;background:var(--surface);border-top:1px solid var(--border);box-shadow:0 -4px 16px #00000014;padding:.875rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.consent-banner[hidden]{display:none}.consent-message{margin:0;font-size:.85rem;color:var(--text-muted);flex:1 1 18rem;line-height:1.5}.consent-actions{display:flex;gap:.5rem;flex-shrink:0}.consent-actions button{flex:0 0 auto;padding:.5rem 1rem;font-size:.85rem}@media(max-width:480px){.consent-banner{padding:.75rem 1rem}.consent-actions{width:100%}.consent-actions button{flex:1}}.modal{position:fixed;inset:0;background:color-mix(in srgb,black 50%,transparent);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1.5rem}.modal[hidden]{display:none}.modal-content{background:var(--surface);border-radius:var(--radius);padding:1.75rem;max-width:28rem;width:100%;text-align:center;box-shadow:0 20px 60px #0000004d}.modal-content h2{margin:0 0 .75rem;font-size:1.25rem;color:var(--danger)}.modal-content p{margin:0 0 1.25rem;color:var(--text-muted);line-height:1.5}.modal-content button{width:100%}@media(max-width:480px){.top-bar{padding:1rem}.app{padding:1rem;gap:1rem}.status-card,.settings-card,.instructions{padding:1rem}}
