*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#111;--surface:#1a1a1a;--card:#1f1f1f;--border:#2a2a2a;--text:#f0f0f0;--sub:#888;--accent:#6c63ff;--radius:10px;--font:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--settings-btn:#1e1e24;--settings-btn-hover:#282830;--settings-btn-border:#3a3a44;--settings-btn-text:#ececf1;--settings-input-bg:#141418;--settings-input-border:#383842;--settings-muted-surface:#18181c}@media (prefers-color-scheme:light){:root{--bg:#f5f5f5;--surface:#fff;--card:#fff;--border:#e0e0e0;--text:#111;--sub:#666;--settings-btn:#e4e4ea;--settings-btn-hover:#d8d8e0;--settings-btn-border:#b4b4c0;--settings-btn-text:#121218;--settings-input-bg:#fafafa;--settings-input-border:#c8c8d0;--settings-muted-surface:#f0f0f4}}html,body{background:var(--bg);height:100%;color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;overscroll-behavior:none;font-size:16px;line-height:1.5}#root{flex-direction:column;max-width:680px;min-height:100dvh;margin:0 auto;display:flex}.app-header{z-index:10;background:var(--bg);border-bottom:1px solid var(--border);padding:12px 16px;padding-top:max(12px, env(safe-area-inset-top));justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.header-left{align-items:baseline;gap:8px;display:flex}.header-right{gap:4px;display:flex}.app-title{letter-spacing:-.02em;font-size:1.25rem;font-weight:700}.last-refresh{color:var(--sub);font-size:.75rem}.icon-btn{color:var(--sub);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:8px;font-size:1.1rem;line-height:1;transition:color .15s,background .15s;display:flex}.icon-btn:hover{color:var(--text);background:var(--border)}.icon-btn:disabled{opacity:.4;cursor:default}@keyframes spin{to{transform:rotate(360deg)}}.view-tabs{border-bottom:1px solid var(--border);background:var(--bg);display:flex}.tab{color:var(--sub);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px 0;font-size:.875rem;font-weight:500;transition:color .15s,border-color .15s;display:flex}.tab.active{color:var(--text);border-bottom-color:var(--accent)}.tab-count{background:var(--accent);color:#fff;border-radius:9px;padding:1px 5px;font-size:.7rem;font-weight:600}.topic-filter{scrollbar-width:none;background:var(--bg);border-bottom:1px solid var(--border);gap:6px;padding:10px 12px;display:flex;overflow-x:auto}.topic-filter::-webkit-scrollbar{display:none}.topic-pill{background:var(--surface);border:1px solid var(--border);color:var(--sub);cursor:pointer;border-radius:20px;flex-shrink:0;align-items:center;gap:5px;padding:5px 12px;font-size:.8rem;font-weight:500;transition:all .15s;display:flex}.topic-pill:hover{color:var(--text);border-color:var(--sub)}.topic-pill.active{background:var(--pill-color,var(--accent));border-color:var(--pill-color,var(--accent));color:#fff}.pill-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.feed{flex-direction:column;flex:1;gap:8px;padding:8px 12px 80px;display:flex}.feed-error,.feed-empty{text-align:center;color:var(--sub);padding:40px 16px;font-size:.9rem}.feed-end{text-align:center;color:var(--sub);flex-direction:column;align-items:center;gap:8px;padding:32px 16px 16px;font-size:.85rem;display:flex}.feed-end-icon{color:var(--accent);font-size:1.4rem}.sentinel{height:1px}.btn-retry{background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:8px;margin-top:12px;padding:8px 16px;font-size:.875rem}.feed-loading{flex-direction:column;gap:8px;display:flex}.skeleton-card{background:var(--card);border-radius:var(--radius);height:130px;animation:1.5s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:.7}50%{opacity:.3}}@keyframes cardIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes cardEnterAppend{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);transition:border-color .15s;animation:.2s both cardIn;overflow:hidden}.card.card-enter{animation:.45s both cardEnterAppend}.card:hover{border-color:var(--sub)}.card-image-link{display:block;position:relative;overflow:hidden}.card-image{object-fit:cover;width:100%;height:180px;animation:.3s fadeIn;display:block}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.card-play-btn{color:#fff;pointer-events:none;background:#00000059;justify-content:center;align-items:center;font-size:2rem;transition:background .15s;display:flex;position:absolute;inset:0}.card-image-link:hover .card-play-btn{background:#0000008c}.card-body{padding:12px 14px}.card-meta{color:var(--sub);flex-wrap:wrap;align-items:center;gap:5px;margin-bottom:6px;font-size:.75rem;display:flex}.card-dot{opacity:.4}.card-source{font-weight:600}.card-topic{font-weight:500}.card-title-link{color:inherit;text-decoration:none}.card-title{letter-spacing:-.01em;-webkit-line-clamp:3;-webkit-box-orient:vertical;margin-bottom:6px;font-size:1rem;font-weight:600;line-height:1.35;display:-webkit-box;overflow:hidden}.card-title-link:hover .card-title{color:var(--accent)}.card-desc{color:var(--sub);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:10px;font-size:.85rem;line-height:1.45;display:-webkit-box;overflow:hidden}.card-downvoted{opacity:.45;transition:opacity .15s}.card-downvoted:hover{opacity:.75}.card-body-collapsed{padding:8px 14px}.card-collapsed-row{align-items:center;gap:8px;min-width:0;display:flex}.card-source-muted{color:var(--sub);flex-shrink:0;font-size:.72rem;font-weight:600}.card-collapsed-title{min-width:0;color:var(--sub);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.875rem;text-decoration:none;overflow:hidden}.card-collapsed-title:hover{color:var(--text)}.card-actions{justify-content:space-between;align-items:center;display:flex}.card-read-group{flex-shrink:0;align-items:center;gap:10px;display:flex}.btn-discuss{color:var(--sub);align-items:center;min-height:40px;padding:8px 0;font-size:.8rem;font-weight:500;text-decoration:none;transition:color .15s;display:inline-flex}.btn-discuss:hover{color:var(--text)}.card-vote-group{align-items:center;gap:2px;display:flex}.btn-vote{color:var(--sub);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;min-width:40px;min-height:40px;padding:8px 12px;font-size:1rem;line-height:1;transition:color .15s,background .15s;display:inline-flex}.btn-vote:hover{background:var(--border);color:var(--text)}.btn-upvote.active{color:#4caf50}.btn-downvote.active{color:#e05050}.btn-read{color:var(--accent);letter-spacing:.02em;align-items:center;min-height:40px;padding:8px 0;font-size:.875rem;font-weight:600;text-decoration:none;display:inline-flex}.btn-read:hover{opacity:.8}.btn-save{color:var(--sub);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;min-width:40px;min-height:40px;padding:8px 10px;font-size:1.25rem;line-height:1;transition:color .15s,background .15s;display:inline-flex}.btn-save:hover{background:var(--border);color:var(--text)}.btn-save.saved{color:#e8a020}.settings-overlay{z-index:100;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000000b8;align-items:flex-end;display:flex;position:fixed;inset:0}.settings-panel{background:var(--surface);width:100%;max-width:680px;max-height:88dvh;padding:0 0 env(safe-area-inset-bottom);border:1px solid var(--border);border-bottom:none;border-radius:16px 16px 0 0;margin:0 auto;overflow-y:auto;box-shadow:0 -8px 40px #00000059}.settings-header{border-bottom:1px solid var(--border);background:var(--surface);z-index:1;justify-content:space-between;align-items:center;padding:20px 20px 14px;display:flex;position:sticky;top:0}.settings-header h2{letter-spacing:-.02em;color:var(--text);font-size:1.15rem;font-weight:700}.btn-close{background:var(--settings-btn);border:1px solid var(--settings-btn-border);color:var(--settings-btn-text);cursor:pointer;border-radius:8px;padding:8px 12px;font-size:1rem;transition:background .15s,border-color .15s,color .15s}.btn-close:hover{background:var(--settings-btn-hover);color:var(--text)}.btn-close:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.settings-section{border-bottom:1px solid var(--border);padding:18px 20px}.settings-section:last-child{border-bottom:none}.settings-section h3{color:var(--text);opacity:.92;text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px;font-size:.82rem;font-weight:700}.settings-hint{color:var(--sub);max-width:52ch;margin-bottom:14px;font-size:.85rem;line-height:1.55}.settings-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;display:grid}.setting-toggle{background:var(--settings-muted-surface);border:1px solid var(--settings-btn-border);cursor:pointer;color:var(--text);border-radius:8px;align-items:center;gap:6px;padding:10px 12px;font-size:.875rem;transition:border-color .15s,background .15s,opacity .15s;display:flex}.setting-toggle.on{border-color:var(--toggle-color,var(--accent));background:var(--settings-btn)}.setting-toggle.off{opacity:.55}.setting-toggle:hover{opacity:1}.setting-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.toggle-label{text-align:left;flex:1;font-weight:500}.toggle-boost{color:var(--sub);font-size:.7rem}.toggle-indicator{background:var(--border);border-radius:50%;flex-shrink:0;width:8px;height:8px;transition:background .15s}.toggle-indicator.on{background:var(--toggle-color,var(--accent))}.source-list{flex-direction:column;gap:4px;display:flex}.source-item{background:var(--settings-muted-surface);border:1px solid var(--settings-btn-border);cursor:pointer;color:var(--text);border-radius:8px;align-items:center;gap:10px;padding:10px 12px;font-size:.875rem;transition:border-color .15s,background .15s,opacity .15s;display:flex}.source-item.off{opacity:.5}.source-item:hover{opacity:1;background:var(--settings-btn)}.source-item.on{border-color:var(--border);background:var(--settings-btn)}.source-item:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.source-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.source-name{text-align:left;flex:1;font-weight:500}.source-cat{color:var(--sub);font-size:.75rem}.settings-about{color:var(--sub);max-width:54ch;margin-bottom:10px;font-size:.875rem;line-height:1.65}.settings-about strong{color:var(--text)}.btn-reset-prefs{background:var(--settings-btn);color:#f07178;cursor:pointer;border:1px solid #e050508c;border-radius:8px;padding:10px 18px;font-size:.875rem;font-weight:600;transition:background .15s,color .15s,border-color .15s}.btn-reset-prefs:hover{color:#ff8a90;background:#e050502e;border-color:#e05050}.btn-reset-prefs:focus-visible{outline-offset:2px;outline:2px solid #e05050}@media (prefers-color-scheme:light){.btn-reset-prefs{color:#b00020;border-color:#b0002073}.btn-reset-prefs:hover{color:#8a0018;background:#b000201a;border-color:#b00020}}.source-row-custom{align-items:stretch;gap:4px;display:flex}.source-item-flex{flex:1;min-width:0}.custom-source-list{flex-direction:column;gap:6px;margin:0 0 12px;padding:0;list-style:none;display:flex}.custom-source-item{background:var(--settings-muted-surface);border:1px solid var(--settings-btn-border);border-radius:8px;align-items:center;gap:10px;padding:10px 12px;display:flex}.custom-source-info{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.custom-source-name{color:var(--text);font-size:.875rem;font-weight:600}.custom-source-url{color:var(--sub);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;overflow:hidden}.btn-remove-source{background:var(--settings-btn);border:1px solid var(--settings-btn-border);color:var(--sub);cursor:pointer;border-radius:6px;flex-shrink:0;padding:6px 10px;font-size:.85rem;transition:color .15s,background .15s,border-color .15s}.btn-remove-source:hover{color:#f07178;background:#e050501f;border-color:#e0505059}.btn-remove-source:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.custom-source-form{flex-direction:column;gap:10px;display:flex}.custom-source-input{background:var(--settings-input-bg);border:1px solid var(--settings-input-border);color:var(--text);box-sizing:border-box;border-radius:8px;outline:none;width:100%;padding:10px 14px;font-size:.875rem;transition:border-color .15s,box-shadow .15s}.custom-source-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6c63ff33}.custom-source-input::placeholder{color:var(--sub);opacity:.85}.btn-add-source{background:var(--settings-btn);border:1px solid var(--settings-btn-border);color:var(--settings-btn-text);cursor:pointer;border-radius:8px;align-self:flex-start;padding:10px 18px;font-size:.875rem;font-weight:600;transition:background .15s,border-color .15s,color .15s}.btn-add-source:hover:not(:disabled){background:var(--settings-btn-hover);border-color:var(--accent)}.btn-add-source:disabled{opacity:.38;cursor:not-allowed}.btn-add-source:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.opml-actions{flex-direction:column;gap:12px;display:flex}.opml-import-row{align-items:center;gap:10px;display:flex}.opml-divider{border:none;border-top:1px solid var(--border);margin:16px 0}.opml-file-input{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute}.settings-field{flex-direction:column;gap:8px;display:flex}.settings-field-import{border-top:1px solid var(--border);margin-top:4px;padding-top:16px}.settings-label{letter-spacing:.06em;text-transform:uppercase;color:var(--text);opacity:.8;font-size:.72rem;font-weight:700}.settings-hint-tight{margin-top:0;margin-bottom:0}.settings-code{background:var(--settings-muted-surface);border:1px solid var(--settings-btn-border);color:var(--accent);white-space:nowrap;border-radius:4px;padding:2px 6px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.78em}.settings-textarea{background:var(--settings-input-bg);border:1px solid var(--settings-input-border);color:var(--text);box-sizing:border-box;resize:vertical;border-radius:8px;outline:none;width:100%;max-width:100%;min-height:96px;padding:10px 14px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.8125rem;line-height:1.45;transition:border-color .15s,box-shadow .15s}.settings-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6c63ff33}.settings-textarea::placeholder{color:var(--sub);opacity:.85;font-family:var(--font)}.btn-import-apply{margin-top:2px}.btn-bookmark{appearance:none;cursor:pointer;letter-spacing:.01em;text-align:center;color:#fff;background:var(--accent);border:1px solid #5248cc;border-radius:10px;justify-content:center;align-items:center;width:100%;max-width:22rem;min-height:48px;padding:12px 20px;font-family:inherit;font-size:.9375rem;font-weight:700;line-height:1.2;transition:filter .15s,box-shadow .15s,transform .1s;display:inline-flex;box-shadow:inset 0 1px #ffffff1f,0 2px 8px #00000059,0 4px 16px #6c63ff59}.btn-bookmark:hover{filter:brightness(1.08);box-shadow:inset 0 1px #ffffff26,0 3px 12px #0006,0 6px 20px #6c63ff73}.btn-bookmark:active{filter:brightness(.97);transform:scale(.985)}.btn-bookmark:focus-visible{outline-offset:3px;outline:2px solid #fff}@media (prefers-color-scheme:light){.btn-bookmark{border-color:#5c54d6;box-shadow:inset 0 1px #ffffff40,0 2px 6px #5248b459}.btn-bookmark:focus-visible{outline-color:var(--accent)}}.bookmark-import-row{flex-wrap:wrap;align-items:stretch;gap:10px;display:flex}.bookmark-import-row .custom-source-input{flex:1;min-width:160px}.bookmark-import-row .btn-add-source{align-self:stretch}.import-status{border:1px solid #0000;border-radius:8px;margin-top:10px;padding:10px 12px;font-size:.85rem;font-weight:500;line-height:1.45}.import-status.ok{color:#81c784;background:#2e7d322e;border-color:#81c78459}.import-status.error{color:#ef9a9a;background:#b71c1c26;border-color:#ef9a9a59}@media (prefers-color-scheme:light){.import-status.ok{color:#1b5e20;background:#2e7d321a;border-color:#2e7d3240}.import-status.error{color:#b71c1c;background:#b71c1c14;border-color:#b71c1c33}}.pull-indicator{justify-content:center;padding:10px 0 4px;display:flex}.pull-indicator-inner{background:var(--surface);border:1px solid var(--border);width:38px;height:38px;color:var(--accent);border-radius:50%;justify-content:center;align-items:center;transition:opacity .1s,transform .1s;display:flex;box-shadow:0 2px 10px #00000040}@media (width<=640px){.btn-vote{min-width:44px;min-height:44px;padding:10px 14px;font-size:1.1rem}.btn-save{min-width:44px;min-height:44px;padding:10px 12px;font-size:1.4rem}.btn-read{min-height:44px;font-size:.95rem}.icon-btn{min-width:44px;min-height:44px;padding:12px}.card-body{padding:14px 16px}.card-actions{gap:4px}.card-vote-group{gap:2px}}
