:root{--bg: #f0f4f1;--surface: #ffffff;--text: #2d3d2d;--text-muted: #6d8275;--accent: #527555;--accent-light: #82998a;--border: #dce5de;--shadow: rgba(45, 61, 45, .06)}@media(prefers-color-scheme:dark){:root{--bg: #1a2420;--surface: #243029;--text: #d4ddd6;--text-muted: #8a9e8e;--accent: #7da88a;--accent-light: #5a7d63;--border: #2d3d30;--shadow: rgba(0, 0, 0, .2)}}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;min-height:100dvh;padding-bottom:100px}.container{max-width:640px;margin:0 auto;padding:24px 20px}.app-header{padding:32px 0 24px}.app-header h1{font-size:1.5rem;font-weight:600;letter-spacing:-.02em}.url-form{display:flex;gap:8px;margin-bottom:32px}.url-form input{flex:1;padding:10px 14px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);font-size:.875rem;outline:none;transition:border-color .15s}.url-form input::placeholder{color:var(--text-muted)}.url-form input:focus{border-color:var(--accent)}.url-form button{padding:10px 20px;border:none;border-radius:8px;background:var(--accent);color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:opacity .15s}.url-form button:hover{opacity:.9}.url-form button:disabled{opacity:.5;cursor:not-allowed}.retreat-list{list-style:none}.retreat-item{padding:16px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:opacity .15s}.retreat-item:hover{opacity:.8}.retreat-item-title{font-weight:600;font-size:1rem}.retreat-item-meta{color:var(--text-muted);font-size:.8125rem;margin-top:2px}.retreat-header{padding-bottom:20px;margin-bottom:8px;border-bottom:1px solid var(--border)}.retreat-header h2{font-size:1.25rem;font-weight:600;letter-spacing:-.01em}.retreat-header-meta{color:var(--text-muted);font-size:.8125rem;margin-top:4px}.back-link{display:inline-block;margin-bottom:16px;color:var(--accent);font-size:.875rem;text-decoration:none;cursor:pointer}.back-link:hover{text-decoration:underline}.talk-list{list-style:none}.talk-item{padding:14px 0;border-bottom:1px solid var(--border)}.talk-item-top{display:flex;align-items:baseline;gap:10px}.talk-date{color:var(--text-muted);font-size:.75rem;font-variant-numeric:tabular-nums;flex-shrink:0}.talk-title{font-weight:500;font-size:.9375rem;flex:1;min-width:0}.talk-title.is-playing{color:var(--accent)}.talk-title.is-completed{opacity:.6}.talk-duration{color:var(--text-muted);font-size:.75rem;flex-shrink:0}.talk-item-bottom{display:flex;align-items:center;gap:12px;margin-top:4px;padding-left:0}.talk-teacher{color:var(--text-muted);font-size:.8125rem;text-decoration:none}.talk-teacher:hover{text-decoration:underline}.talk-actions{display:flex;align-items:center;gap:8px;margin-left:auto}.btn-icon{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;font-size:.8125rem;transition:color .15s;display:inline-flex;align-items:center;justify-content:center}.btn-icon svg,.download-status svg{width:16px;height:16px}.player-btn svg{width:20px;height:20px}.player-btn.play-pause svg{width:24px;height:24px}.btn-icon:hover,.btn-icon.active{color:var(--accent)}.talk-description{color:var(--text-muted);font-size:.8125rem;margin-top:4px;line-height:1.5}.download-status{font-size:.6875rem;color:var(--accent-light);display:inline-flex;align-items:center;justify-content:center;min-width:32px}.download-status.downloading{font-variant-numeric:tabular-nums}.player-bar{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);box-shadow:0 -2px 12px var(--shadow);padding:12px 20px;padding-bottom:max(12px,env(safe-area-inset-bottom));z-index:100;display:none}.player-bar.visible{display:block}.player-info{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.player-title{font-size:.8125rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.player-speed{font-size:.75rem;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:2px 4px;cursor:pointer;margin-left:8px;flex-shrink:0;-webkit-appearance:none;-moz-appearance:none;appearance:none}.player-controls{display:flex;align-items:center;gap:12px}.player-btn{background:none;border:none;color:var(--text);cursor:pointer;padding:4px;font-size:1.25rem;line-height:1}.player-btn.play-pause{font-size:1.5rem}.player-seek{flex:1;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--border);border-radius:2px;outline:none;cursor:pointer}.player-seek::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer}.player-time{font-size:.6875rem;color:var(--text-muted);font-variant-numeric:tabular-nums;flex-shrink:0}.loading{text-align:center;padding:40px 0;color:var(--text-muted)}.error{color:#b34040;padding:12px;font-size:.875rem}.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}.empty-state p{font-size:.875rem}.retreat-actions{margin-top:12px}.btn-text{background:none;border:1px solid var(--border);border-radius:6px;color:var(--accent);font-size:.8125rem;padding:6px 14px;cursor:pointer;transition:background .15s}.btn-text:hover{background:var(--surface)}.btn-text:disabled{opacity:.5;cursor:not-allowed}.cache-info{padding:16px 0;font-size:.75rem;color:var(--text-muted);text-align:center}
