:root{color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;--app-min-width: 320px;--bg: #f5f7fb;--surface: #ffffff;--surface-soft: #eef2f6;--surface-strong: #e6edf3;--text: #111827;--text-soft: #4b5563;--text-muted: #6b7280;--border: #d9e1ea;--shadow: 0 10px 30px rgb(15 23 42 / 10%);--accent: #2563eb;--accent-strong: #1d4ed8;--accent-soft: #dbeafe;--accent-text: #ffffff;--green: #0f8a5f;--green-soft: #dff6ec;--danger: #c2410c;--danger-soft: #ffedd5;--radius: 8px;--topbar-height: 64px}@media(prefers-color-scheme:dark){:root{color-scheme:dark;--bg: #101010;--surface: #181818;--surface-soft: #232323;--surface-strong: #303030;--text: #f5f5f5;--text-soft: #d4d4d4;--text-muted: #a3a3a3;--border: #3d3d3d;--shadow: 0 16px 40px rgb(0 0 0 / 34%);--accent: #f5f5f5;--accent-strong: #ffffff;--accent-soft: #2b2b2b;--accent-text: #101010;--green: #34d399;--green-soft: #12352a;--danger: #fb923c;--danger-soft: #3b2417}}*{box-sizing:border-box}html{min-width:var(--app-min-width);background:var(--bg)}body{margin:0;min-width:var(--app-min-width);min-height:100vh;background:var(--bg);color:var(--text)}button,input{font:inherit}button{border:0}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}#root{min-height:100vh;min-width:var(--app-min-width)}.app-shell{min-height:100vh;min-width:var(--app-min-width);--topbar-offset: var(--topbar-height)}.topbar{position:fixed;z-index:90;top:0;right:0;left:0;min-width:var(--app-min-width);border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--surface) 92%,transparent);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.topbar.search-mode{bottom:0;display:flex;flex-direction:column}.search-mode-surface{flex:1 1 auto;min-height:0;overflow-y:auto;padding:28px 16px 44px}.search-hint{display:grid;width:min(100%,560px);justify-items:center;gap:14px;margin:74px auto 0;color:var(--text-soft);text-align:center}.search-hint-icon{display:inline-flex;color:var(--accent)}.search-hint p{margin:0;line-height:1.6}.search-hint-muted{color:var(--text-muted);font-weight:700}.search-inline-icon{display:inline-flex;vertical-align:-2px;align-items:center;justify-content:center;color:var(--accent)}.search-results{display:grid;width:min(100%,1040px);gap:12px;margin:0 auto}.app-shell.search-open .app-main{visibility:hidden;pointer-events:none}.topbar-main{display:grid;grid-template-columns:44px minmax(0,1fr) 44px;align-items:center;gap:8px;height:var(--topbar-height);padding:0 14px}.app-shell.search-open .topbar-main{grid-template-columns:minmax(0,1fr) 44px}.topbar-title{min-width:0;color:var(--text);font-size:17px;font-weight:700}.topbar-title>span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-main{width:min(100%,1040px);margin:0 auto;padding:calc(var(--topbar-offset) + 15px) 16px 40px}.topbar.with-feed-tools~.app-main{padding-top:calc(var(--topbar-offset) + 10px)}.feed-switch-zone{width:min(100%,1040px);height:calc(178px * var(--feed-switch-progress));min-height:0;margin:0 auto;overflow:hidden;padding:0 16px;transition:height .12s ease}.feed-switch-indicator{display:grid;justify-items:center;gap:8px;padding-top:4px;opacity:0;pointer-events:none;transform:translateY(18px) scale(.97);transition:opacity .16s ease,transform .16s ease}.feed-switch-indicator.visible{opacity:1;transform:translateY(0) scale(1)}.feed-switch-indicator strong{max-width:min(78vw,360px);overflow:hidden;color:var(--text);font-size:14px;line-height:1.2;text-overflow:ellipsis;white-space:nowrap}.feed-switch-circle{position:relative;display:grid;width:54px;height:54px;place-items:center;overflow:hidden;border:1px solid color-mix(in srgb,var(--feed-switch-color) 58%,var(--border));border-radius:999px;background:color-mix(in srgb,var(--surface) 90%,transparent);box-shadow:var(--shadow);color:color-mix(in srgb,var(--feed-switch-color) 56%,var(--text))}.feed-switch-circle:before{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:color-mix(in srgb,var(--feed-switch-color) 72%,transparent);content:"";transform:scale(var(--feed-switch-progress));transition:transform .06s linear}.feed-switch-circle svg{position:relative;z-index:1;filter:drop-shadow(0 1px 1px var(--surface))}.icon-button,.primary-button,.secondary-button,.text-button,.chip-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-width:0;cursor:pointer;transition:background-color .18s ease,border-color .18s ease,color .18s ease,transform .18s ease}.icon-button{width:40px;height:40px;border:1px solid transparent;border-radius:999px;background:transparent;color:var(--text-soft)}.icon-button:hover:not(:disabled),.icon-button:focus-visible{border-color:var(--border);background:var(--surface-soft);color:var(--text)}.icon-button.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-strong)}.icon-button.muted{border-color:var(--border);background:var(--surface-soft);color:var(--text-muted)}.danger-button{color:var(--danger)}.danger-button:hover:not(:disabled),.danger-button:focus-visible{border-color:color-mix(in srgb,var(--danger) 36%,var(--border));background:var(--danger-soft);color:var(--danger)}.icon-button:disabled,.primary-button:disabled,.secondary-button:disabled,.text-button:disabled{cursor:not-allowed;opacity:.58}.primary-button,.secondary-button,.text-button{min-height:42px;border-radius:999px;padding:0 16px;font-weight:700;white-space:nowrap}.primary-button{background:var(--accent);color:var(--accent-text);box-shadow:0 8px 18px color-mix(in srgb,var(--accent) 22%,transparent)}.primary-button:hover:not(:disabled),.primary-button:focus-visible{background:var(--accent-strong)}.secondary-button{border:1px solid var(--border);background:var(--surface);color:var(--text)}.secondary-button:hover:not(:disabled),.secondary-button:focus-visible{background:var(--surface-soft)}.danger-action{border-color:color-mix(in srgb,var(--danger) 34%,var(--border));color:var(--danger)}.danger-action:hover:not(:disabled),.danger-action:focus-visible{background:var(--danger-soft);color:var(--danger)}.secondary-button.compact{min-height:38px;padding:0 12px}.primary-button.compact{min-height:36px;padding:0 13px}.text-button{min-height:38px;background:transparent;color:var(--text-soft)}.text-button:hover,.text-button:focus-visible{background:var(--surface-soft);color:var(--text)}.text-button.danger{color:var(--danger)}.full-width{width:100%}.search-field{display:flex;align-items:center;gap:8px;width:100%;height:42px;padding:0 12px;border:1px solid var(--border);border-radius:999px;background:var(--surface-soft);color:var(--text-muted)}.search-field input{min-width:0;width:100%;border:0;outline:0;background:transparent;color:var(--text);font-weight:600}.search-field input::placeholder{color:var(--text-muted)}.feed-toolbar{position:relative;display:grid;gap:10px;padding:11px 14px 8px}.feed-scroll-track{position:absolute;z-index:3;top:0;right:0;left:0;height:8px;cursor:default;touch-action:none}.feed-scroll-track:before{position:absolute;top:0;right:0;left:0;height:1px;background:var(--border);content:""}.feed-scroll-track.active{cursor:pointer}.feed-scroll-thumb{position:absolute;top:0;height:8px;border:0;background:transparent;cursor:grab;opacity:0;padding:0;pointer-events:none;transition:opacity .18s ease}.feed-scroll-track.active .feed-scroll-thumb{opacity:1;pointer-events:auto}.feed-scroll-track.dragging .feed-scroll-thumb{cursor:grabbing}.feed-scroll-thumb:before{position:absolute;top:0;right:0;left:0;height:3px;border-radius:999px;background:var(--accent);content:""}.feed-toolbar-row{display:grid;grid-template-columns:44px minmax(0,1fr);align-items:center;gap:8px}.filter-toggle.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-strong)}.feed-strip-frame{position:relative;min-width:0;--feed-arrow-size: 30px;--feed-arrow-zone: 40px;--feed-fade-width: 34px}.feed-strip-frame:before,.feed-strip-frame:after{position:absolute;z-index:3;top:0;bottom:0;width:calc(var(--feed-arrow-zone) + var(--feed-fade-width));opacity:0;pointer-events:none;transition:opacity .18s ease;content:""}.feed-strip-frame:before{left:0;background:linear-gradient(to right,var(--surface) 0,var(--surface) var(--feed-arrow-zone),transparent 100%)}.feed-strip-frame:after{right:0;background:linear-gradient(to left,var(--surface) 0,var(--surface) var(--feed-arrow-zone),transparent 100%)}.feed-strip-frame.can-scroll-left:before,.feed-strip-frame.can-scroll-right:after{opacity:1}.feed-strip{display:flex;gap:8px;min-width:0;overflow-x:auto;padding:2px 0;scroll-behavior:smooth;scrollbar-width:none}.feed-strip::-webkit-scrollbar{display:none}.feed-strip-arrow{position:absolute;z-index:4;top:50%;display:grid;width:var(--feed-arrow-zone);height:34px;place-items:center;border:0;border-radius:0;background:var(--surface);color:var(--text-soft);cursor:pointer;opacity:0;pointer-events:none;transform:translateY(-50%);transition:opacity .18s ease,background-color .18s ease,color .18s ease}.feed-strip-arrow:hover:not(:disabled),.feed-strip-arrow:focus-visible{background:var(--surface);color:var(--accent-strong)}.feed-strip-arrow:disabled{cursor:default}.feed-strip-arrow-left{left:0}.feed-strip-arrow-right{right:0}.feed-strip-frame.can-scroll-left .feed-strip-arrow-left,.feed-strip-frame.can-scroll-right .feed-strip-arrow-right{opacity:1;pointer-events:auto}.feed-pill{--feed-pill-color: var(--accent);display:inline-flex;align-items:center;flex:0 0 auto;justify-content:center;min-width:0;max-width:clamp(116px,18vw,168px);min-height:38px;border:1px solid color-mix(in srgb,var(--feed-pill-color) 24%,var(--border));border-radius:999px;background:color-mix(in srgb,var(--feed-pill-color) 8%,var(--surface));color:color-mix(in srgb,var(--feed-pill-color) 46%,var(--text-soft));font-size:14px;font-weight:800;padding:0 14px;cursor:pointer}.feed-pill-label{display:block;max-width:100%;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.feed-pill:hover,.feed-pill:focus-visible,.feed-pill.active{border-color:color-mix(in srgb,var(--feed-pill-color) 72%,var(--border));background:color-mix(in srgb,var(--feed-pill-color) 22%,var(--surface));color:color-mix(in srgb,var(--feed-pill-color) 78%,var(--text))}.filter-panel{position:absolute;z-index:92;top:calc(100% + 8px);left:14px;width:min(720px,calc(100vw - 28px));display:grid;gap:8px;padding:10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow)}.filter-row{display:grid;grid-template-columns:128px minmax(0,1fr);align-items:center;gap:10px;min-height:40px}.filter-row-label{color:var(--text-muted);font-size:12px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.filter-control{position:relative;min-width:0}.filter-select{display:inline-flex;align-items:center;justify-content:space-between;gap:8px;width:100%;min-height:38px;border:1px solid var(--border);border-radius:999px;background:var(--surface-soft);color:var(--text);cursor:pointer;font-weight:800;padding:0 12px;text-align:left}.filter-select:hover,.filter-select:focus-visible{border-color:var(--accent)}.filter-select svg:last-child{margin-left:auto;flex:0 0 auto}.filter-popover{position:absolute;z-index:94;top:calc(100% + 8px);left:0;display:grid;gap:8px;width:min(360px,calc(100vw - 28px));padding:10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow)}.filter-popover-backdrop{position:fixed;z-index:89;top:0;right:0;bottom:0;left:0;width:100%;height:100%;border:0;background:transparent;cursor:default}.filter-popover>button:not(.primary-button){min-height:36px;border-radius:var(--radius);background:transparent;color:var(--text);cursor:pointer;font-weight:700;text-align:left;padding:0 10px}.filter-popover>button:hover,.filter-popover>button:focus-visible{background:var(--surface-soft)}.filter-popover .primary-button{justify-content:center;border-radius:999px;background:var(--accent);color:var(--accent-text);text-align:center}.filter-popover .text-button{justify-content:center;background:transparent;color:var(--text-soft);text-align:center}.date-input-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding-top:4px}.date-input-grid label{display:grid;gap:5px;color:var(--text-muted);font-size:12px;font-weight:800}.date-native-holder{position:absolute;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}.date-native-holder input{width:1px;height:1px}.date-input-button{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;min-height:38px;min-width:0;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);cursor:pointer;padding:0 9px;font-weight:800;text-align:left}.date-input-button:hover,.date-input-button:focus-visible{border-color:var(--accent)}.category-popover{width:min(420px,calc(100vw - 28px))}.category-options{display:grid;max-height:280px;overflow-y:auto}.category-empty{margin:0;color:var(--text-muted);font-size:13px;font-weight:700;line-height:1.45;padding:8px}.checkbox-row{display:grid;grid-template-columns:24px minmax(0,1fr);align-items:center;gap:9px;min-height:36px;border-radius:var(--radius);color:var(--text);cursor:pointer;font-size:14px;font-weight:700;padding:0 8px}.checkbox-row:hover,.checkbox-row:focus-within{background:var(--surface-soft)}.checkbox-row input{position:absolute;opacity:0;pointer-events:none}.custom-checkbox{display:grid;width:20px;height:20px;place-items:center;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--accent)}.checkbox-row input:checked+.custom-checkbox{border-color:var(--accent);background:var(--accent-soft)}.popover-actions{display:flex;justify-content:flex-end;gap:8px;padding-top:6px;border-top:1px solid var(--border)}.drawer-backdrop{position:fixed;z-index:91;top:var(--topbar-height);right:0;bottom:0;left:0;display:none;width:100%;height:100%;background:#00000057;cursor:default}.drawer-backdrop.visible{display:block}.drawer{position:fixed;z-index:92;top:var(--topbar-height);bottom:0;left:0;display:flex;width:min(320px,calc(100vw - 36px));flex-direction:column;padding:18px;border-right:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow);transform:translate(-104%);transition:transform .22s ease}.drawer.open{transform:translate(0)}.drawer-brand,.user-summary{display:flex;align-items:center;gap:12px;min-width:0}.drawer-brand{padding:4px 4px 18px}.drawer-brand strong,.user-summary strong{display:block;overflow:hidden;color:var(--text);font-size:15px;line-height:1.3;text-overflow:ellipsis;white-space:nowrap}.drawer-brand span,.user-summary span{display:block;overflow:hidden;color:var(--text-muted);font-size:12px;line-height:1.4;text-overflow:ellipsis;white-space:nowrap}.brand-mark{display:grid;width:42px;height:42px;flex:0 0 auto;place-items:center;border-radius:var(--radius);background:var(--accent-soft);color:var(--accent)}.drawer-nav{display:flex;min-height:0;flex:1;flex-direction:column;gap:4px;overflow-y:auto;padding-right:2px}.drawer-link{display:flex;align-items:center;gap:11px;min-height:42px;min-width:0;border-radius:var(--radius);color:var(--text-soft);font-weight:700;padding:0 12px}.drawer-link:hover,.drawer-link:focus-visible,.drawer-link.active{background:var(--surface-soft);color:var(--text)}.drawer-link.active{box-shadow:inset 3px 0 0 var(--accent)}.feed-link span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.feed-dot{width:10px;height:10px;flex:0 0 auto;border-radius:999px}.drawer-section-title{margin:16px 10px 8px;color:var(--text-muted);font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.drawer-hint{display:block;padding:8px 12px;color:var(--text-muted);font-size:14px}.drawer-user{display:grid;gap:12px;padding-top:16px;border-top:1px solid var(--border)}.page-section{display:grid;gap:18px}.section-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.feed-heading{display:block;min-width:0;max-width:100%}.feed-heading-content{position:relative;min-width:0;max-width:100%}.feed-heading-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:44px;margin-bottom:4px}.feed-heading-meta .eyebrow{min-width:0;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.feed-heading-actions{position:relative;z-index:2;display:flex;align-items:center;flex-direction:row;gap:2px;flex:0 0 auto;justify-content:center;padding:3px;border:1px solid var(--border);border-radius:999px;background:var(--surface)}.feed-heading-actions .icon-button{width:36px;height:36px}.feed-sources-panel{display:grid;gap:12px;padding:14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.feed-sources-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.feed-sources-heading h2{margin:0;color:var(--text);font-size:18px;line-height:1.2}.feed-sources-heading p,.feed-sources-status{margin:4px 0 0;color:var(--text-soft);line-height:1.45}.feed-sources-status{margin:0;font-weight:700}.feed-sources-status.error{color:var(--danger)}.local-source-form{display:grid;grid-template-columns:minmax(120px,.8fr) minmax(180px,1fr) auto;align-items:end;gap:8px;padding:10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-soft)}.local-source-form label{display:grid;min-width:0;gap:6px;color:var(--text-soft);font-size:12px;font-weight:800}.local-source-form input{width:100%;min-height:38px;border:1px solid var(--border);border-radius:var(--radius);outline:0;background:var(--surface);color:var(--text);padding:0 10px}.local-source-form input:focus{border-color:var(--accent)}.local-source-submit{width:40px;min-width:40px;height:40px;padding:0;border-radius:999px}.feed-source-list{display:grid;gap:8px}.feed-source-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-soft)}.feed-source-main{display:grid;min-width:0;gap:4px}.feed-source-main strong,.feed-source-main span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.feed-source-main strong{color:var(--text);font-size:14px}.feed-source-main>span{color:var(--text-muted);font-size:12px}.feed-source-meta{display:flex;flex-wrap:wrap;gap:6px}.feed-source-meta span{display:inline-flex;width:fit-content;max-width:100%;min-height:24px;align-items:center;border-radius:999px;background:var(--surface);color:var(--text-soft);font-size:11px;font-weight:800;padding:0 8px;text-transform:uppercase}.feed-source-actions{display:flex;flex:0 0 auto;gap:2px;padding:2px;border:1px solid var(--border);border-radius:999px;background:var(--surface)}.feed-source-actions .icon-button{width:34px;height:34px}.section-heading h1,.topic-heading h2,.feed-card h2{margin:0;color:var(--text);line-height:1.15}.section-heading h1{position:relative;z-index:1;font-size:clamp(26px,4vw,36px);max-width:100%;overflow-wrap:anywhere}.section-heading p,.topic-heading p,.feed-card p,.empty-state p,.auth-card p{margin:0;color:var(--text-soft);line-height:1.55}.eyebrow{margin:0 0 4px;color:var(--green);font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.state,.empty-state,.notice{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.state{display:flex;align-items:center;justify-content:center;gap:10px;min-height:180px;color:var(--text-soft);font-weight:700}.empty-state{display:grid;justify-items:center;gap:12px;padding:42px 22px;text-align:center}.empty-state h2{margin:0;color:var(--text);font-size:22px}.empty-state p{max-width:520px}.empty-icon{display:grid;width:64px;height:64px;place-items:center;border-radius:999px;background:var(--surface-soft);color:var(--accent)}.empty-action{margin-top:4px}.notice{display:flex;gap:10px;padding:12px 14px;color:var(--text-soft)}.notice strong,.notice span{display:block;line-height:1.4}.notice strong{color:var(--text)}.notice-error{border-color:color-mix(in srgb,var(--danger) 34%,var(--border));background:var(--danger-soft);color:var(--danger)}.spinner{width:18px;height:18px;border:2px solid var(--surface-strong);border-top-color:var(--accent);border-radius:999px;animation:spin .9s linear infinite}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-page{display:grid;min-height:100vh;place-items:center;padding:22px;background:var(--bg)}.auth-card{width:min(100%,430px);padding:30px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow)}.auth-logo{display:grid;width:48px;height:48px;place-items:center;margin-bottom:18px;border-radius:var(--radius);background:var(--accent-soft);color:var(--accent)}.auth-card h1{margin:0 0 8px;font-size:30px;line-height:1.1}.auth-form{display:grid;gap:14px;margin-top:24px}.auth-form label,.catalog-builder label,.edit-feed-form label{display:grid;gap:7px;color:var(--text-soft);font-size:13px;font-weight:800}.auth-form input,.catalog-builder input,.edit-feed-form input,.edit-feed-form textarea{width:100%;min-height:44px;border:1px solid var(--border);border-radius:var(--radius);outline:0;background:var(--surface);color:var(--text);padding:0 12px}.edit-feed-form textarea{min-height:104px;padding:12px;resize:vertical}.auth-form input:focus,.catalog-builder input:focus,.edit-feed-form input:focus,.edit-feed-form textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 18%,transparent)}.form-error{border-radius:var(--radius);background:var(--danger-soft);color:var(--danger);font-size:14px;font-weight:700;padding:10px 12px}.modal-layer{position:fixed;z-index:90;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:18px;background:#0000006b}.modal-panel{width:min(100%,520px);max-height:calc(100vh - 36px);overflow:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow)}.feed-edit-dialog{padding:22px}.reader-layer{position:fixed;z-index:130;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-end;justify-items:center;justify-content:center;padding:10px;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:background .2s ease,backdrop-filter .2s ease}.reader-layer.collapsed{pointer-events:none;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none}.reader-panel{position:relative;display:block;width:min(100%,840px);height:calc(100dvh - 10px);overflow:hidden;border:1px solid var(--border);border-radius:18px 18px 0 0;background:var(--surface);box-shadow:var(--shadow);pointer-events:auto;transform:translateY(0);transition:height .22s ease,transform .22s ease,border-radius .22s ease}.reader-panel.collapsed{height:58px;border-radius:18px 18px 0 0}.reader-panel.collapsed:before{position:absolute;z-index:3;top:8px;left:50%;width:48px;height:4px;border-radius:999px;background:var(--border);content:"";opacity:.9;pointer-events:none;transform:translate(-50%)}.reader-sheet-handle{position:absolute;z-index:4;top:0;right:0;left:0;display:flex;align-items:center;justify-content:center;height:42px;padding:8px 12px 4px;touch-action:none}.reader-sheet-handle>span{display:block;width:48px;height:4px;border-radius:999px;background:var(--border);opacity:.9}.reader-sheet-handle .reader-close{position:absolute;top:6px;right:12px}.reader-panel.collapsed .reader-sheet-handle,.reader-panel.collapsed .reader-scroll,.reader-panel.collapsed .reader-source-fab,.reader-collapsed-bar{display:none}.reader-panel.collapsed .reader-collapsed-bar{display:grid;grid-template-columns:minmax(0,1fr) 30px;align-items:start;gap:14px;height:100%;padding:24px 12px 7px 14px;cursor:pointer;touch-action:none}.reader-panel.collapsed .reader-close{width:30px;height:30px;align-self:start;margin-top:-5px}.reader-collapsed-text{min-width:0}.reader-collapsed-text h2{height:1.15em;margin:0;overflow:hidden;color:var(--text);font-size:17px;line-height:1.15;mask-image:linear-gradient(90deg,#000 calc(100% - 34px),transparent);-webkit-mask-image:linear-gradient(90deg,#000 calc(100% - 34px),transparent);white-space:nowrap}.reader-collapsed-text p{display:none}.reader-scroll{height:100%;overflow:auto;padding:42px 22px 112px;scrollbar-gutter:stable}.reader-header{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:14px;padding:8px 0 16px}.reader-heading{min-width:0}.reader-source-line{display:flex;align-items:center;flex-wrap:wrap;gap:7px;justify-content:flex-end;color:var(--text-muted);font-size:12px;font-weight:800;line-height:1.25;text-align:right}.reader-heading h2{margin:0;color:var(--text);font-size:27px;line-height:1.18}.reader-heading p{margin:9px 0 0;color:var(--text-soft);font-size:14px;line-height:1.35}.reader-close{align-self:start}.reader-image-frame{display:block;margin:0 0 18px}.reader-image{display:block;width:auto;max-width:100%;max-height:min(420px,48dvh);height:auto;border-radius:var(--radius);object-fit:contain;background:var(--surface-soft)}.reader-content{min-height:0;padding:0}.reader-loading{display:inline-flex;align-items:center;gap:8px;margin-bottom:14px;color:var(--text-muted);font-size:14px;font-weight:800}.reader-note{margin:0 0 14px;color:var(--text-muted);font-size:13px;font-weight:700;line-height:1.4}.reader-body{color:var(--text-soft);font-size:17px;line-height:1.65}.reader-body :where(p,ul,ol,blockquote,pre){margin:0 0 16px}.reader-body :where(h2,h3){margin:22px 0 10px;color:var(--text);line-height:1.25}.reader-body a{color:var(--accent-strong);font-weight:700}.reader-body img{display:block;width:auto!important;max-width:100%;height:auto!important;max-height:min(560px,70dvh);margin:16px 0;border-radius:var(--radius);background:var(--surface-soft);object-fit:contain}.reader-body blockquote{padding-left:14px;border-left:3px solid var(--accent);color:var(--text)}.reader-body pre{overflow:auto;padding:12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-soft);font-size:14px;line-height:1.45}.reader-body code{font-family:JetBrains Mono,Fira Code,Consolas,monospace}.reader-source-fab{position:absolute;right:22px;bottom:22px;z-index:5;display:grid;width:62px;height:62px;place-items:center;border:1px solid var(--border);border-radius:999px;background:color-mix(in srgb,var(--surface) 88%,transparent);box-shadow:var(--shadow);color:var(--text);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:border-color .18s ease,color .18s ease,transform .18s ease}.reader-source-fab:hover,.reader-source-fab:focus-visible{border-color:var(--accent);color:var(--accent-strong);transform:translateY(-1px)}.modal-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:18px}.modal-heading h2{margin:0;color:var(--text);font-size:24px;line-height:1.15}.edit-feed-form{display:grid;gap:14px}.color-field{display:grid;grid-template-columns:54px minmax(0,1fr);align-items:center;gap:10px}.color-field input[type=color]{width:54px;height:44px;padding:4px}.color-field span{color:var(--text);font-size:14px;font-weight:800}.color-swatch-list{display:flex;gap:8px;flex-wrap:wrap}.color-swatch{display:grid;width:34px;height:34px;place-items:center;border:2px solid transparent;border-radius:999px;color:#fff;cursor:pointer}.color-swatch.active,.color-swatch:focus-visible{border-color:var(--text);outline:3px solid color-mix(in srgb,var(--accent) 20%,transparent)}.form-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;padding-top:4px}.auth-switch{margin-top:20px;color:var(--text-muted);font-size:14px;text-align:center}.auth-switch a{color:var(--accent);font-weight:800}.feed-grid{display:grid;gap:12px}.feed-card{display:flex;align-items:center;justify-content:space-between;gap:14px;min-width:0;padding:16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.feed-card-main{display:flex;align-items:center;gap:13px;min-width:0}.feed-card-main>div{min-width:0}.feed-card h2{overflow:hidden;font-size:18px;text-overflow:ellipsis;white-space:nowrap}.feed-card p{display:-webkit-box;overflow:hidden;margin-top:3px;-webkit-box-orient:vertical;-webkit-line-clamp:2}.feed-card-icon{display:grid;width:42px;height:42px;flex:0 0 auto;place-items:center;border-radius:var(--radius);color:#fff}.feed-card-actions{display:flex;align-items:center;gap:8px;flex:0 0 auto;flex-wrap:wrap;justify-content:flex-end}.catalog-page{gap:16px}.catalog-builder{position:sticky;z-index:20;top:calc(var(--topbar-height) + 8px);display:grid;grid-template-columns:minmax(180px,1fr) auto;grid-template-areas:"name actions" "selected .";align-items:end;gap:8px 14px;padding:14px;border:1px solid var(--border);border-radius:var(--radius);background:color-mix(in srgb,var(--surface) 94%,transparent);box-shadow:0 8px 22px #00000014;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.catalog-builder.existing-feed{grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"selected actions";align-items:center}.catalog-builder>label:not(.catalog-color-button){grid-area:name}.builder-actions{display:flex;grid-area:actions;align-items:center;justify-content:flex-end;gap:8px}.builder-selected-count{grid-area:selected;color:var(--text-muted);font-weight:800}.catalog-color-button{position:relative;display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--text-soft);cursor:pointer;overflow:hidden}.catalog-color-button input[type=color]{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;padding:0;border:0;opacity:0;cursor:pointer}.catalog-color-button:hover,.catalog-color-button:focus-within{border-color:var(--accent);background:var(--surface-soft);color:var(--text)}.catalog-color-swatch{width:22px;height:22px;border:2px solid color-mix(in srgb,#ffffff 80%,transparent);border-radius:999px;box-shadow:0 0 0 1px var(--border)}.catalog-color-button svg{position:absolute;right:6px;bottom:6px;padding:2px;border-radius:999px;background:var(--surface)}.catalog-create-button{width:44px;min-width:44px;height:44px;padding:0}.catalog-folder-list{display:grid;gap:12px}.catalog-folder{overflow:hidden;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.catalog-folder-button{display:grid;width:100%;min-height:70px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;border:0;background:transparent;color:var(--text);cursor:pointer;font:inherit;padding:14px;text-align:left}.catalog-folder-button:hover,.catalog-folder-button:focus-visible{background:var(--surface-soft)}.catalog-folder-title{display:flex;min-width:0;align-items:center;gap:10px}.catalog-folder-title>svg{flex:0 0 auto;color:var(--accent)}.catalog-folder-title>span{display:grid;min-width:0;gap:3px}.catalog-folder-title strong,.catalog-folder-title small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.catalog-folder-title strong{color:var(--text);font-size:18px;line-height:1.2}.catalog-folder-title small{color:var(--text-muted);font-size:13px;font-weight:700;line-height:1.35}.catalog-folder-count{flex:0 0 auto;color:var(--text-muted);font-size:13px;font-weight:850;white-space:nowrap}.catalog-folder-body{display:grid;gap:18px;padding:0 14px 14px}.catalog-folder-empty{margin:0;color:var(--text-muted);font-weight:750;line-height:1.45}.topic-list{display:grid;gap:22px}.topic-section{display:grid;gap:12px}.topic-heading{display:grid;gap:5px}.topic-heading h2{font-size:22px}.source-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));align-items:start;gap:12px}.source-card{position:relative;display:grid;grid-template-columns:34px minmax(0,1fr);gap:11px;padding:14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer}.source-card:hover,.source-card:focus-within{border-color:color-mix(in srgb,var(--accent) 42%,var(--border))}.source-card.selected{border-color:var(--accent);background:color-mix(in srgb,var(--accent-soft) 56%,var(--surface))}.source-card input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.source-check{display:grid;width:34px;height:34px;place-items:center;border-radius:999px;background:var(--surface-soft);color:var(--accent)}.source-card-body{display:grid;min-width:0;align-content:start;gap:7px}.source-card-body strong{overflow-wrap:anywhere}.source-card-body>span:not(.chip-row){display:-webkit-box;overflow:hidden;color:var(--text-soft);font-size:14px;line-height:1.45;-webkit-box-orient:vertical;-webkit-line-clamp:2}.sources-page{gap:16px}.source-folder-list{display:grid;gap:12px}.source-folder{overflow:hidden;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.source-folder.disabled .source-folder-title span{color:var(--text-muted)}.source-folder-header{display:grid;grid-template-columns:minmax(190px,1fr) minmax(220px,320px) auto;align-items:center;gap:12px;padding:14px}.source-folder-title{display:flex;align-items:center;gap:10px;min-width:0;border:0;background:transparent;color:var(--text);cursor:pointer;font-size:18px;font-weight:850;text-align:left}.source-folder-title span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.source-name-field,.custom-source-builder label{display:grid;gap:7px;color:var(--text-soft);font-size:12px;font-weight:800}.source-name-field input,.custom-source-builder input{width:100%;min-height:40px;border:1px solid var(--border);border-radius:var(--radius);outline:0;background:var(--surface-soft);color:var(--text);padding:0 11px}.source-name-field input:focus,.custom-source-builder input:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 18%,transparent)}.source-folder-body{display:grid;gap:10px;padding:0 14px 14px}.managed-source-row{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"name toggle" "link link";align-items:end;gap:8px 12px;padding:12px;border:1px solid var(--border);border-radius:var(--radius);background:color-mix(in srgb,var(--surface-soft) 66%,transparent)}.managed-source-row.custom{grid-template-columns:minmax(0,1fr) auto}.managed-source-row.disabled .managed-source-name,.managed-source-row.disabled .managed-source-link{opacity:.64}.managed-source-name{grid-area:name}.managed-source-row>.icon-button{grid-area:toggle}.managed-source-name input{min-height:44px;font-size:16px;font-weight:850}.managed-source-link{grid-area:link;display:inline-flex;align-items:center;gap:7px;min-width:0;overflow:hidden;color:var(--text-muted);font-size:14px;text-overflow:ellipsis;white-space:nowrap}.managed-source-link>svg:first-child{flex:0 0 auto;color:var(--accent)}.managed-source-link span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.custom-source-builder{display:grid;grid-template-columns:minmax(150px,.8fr) minmax(220px,1.2fr) auto;align-items:end;gap:10px;padding:12px;border:1px dashed color-mix(in srgb,var(--accent) 38%,var(--border));border-radius:var(--radius);background:color-mix(in srgb,var(--accent-soft) 35%,transparent)}.custom-source-submit{width:42px;min-width:42px;height:42px;padding:0}.filter-rail{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}.filter-rail::-webkit-scrollbar{display:none}.chip-button{min-height:36px;flex:0 0 auto;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--text-soft);font-size:14px;font-weight:800;padding:0 13px}.chip-button:hover,.chip-button:focus-visible,.chip-button.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-strong)}.article-list{display:grid;gap:12px}.article-card{--article-card-padding: 0;--article-card-height: 168px;--article-media-size: 168px;--article-copy-height: 130px;--article-copy-line-budget: 6;display:grid;position:relative;grid-template-columns:var(--article-media-size) minmax(0,1fr);align-items:stretch;gap:12px;height:var(--article-card-height);padding:0 10px 0 0;border:0;border-radius:var(--radius);background:var(--surface)}.article-card:before{content:"";position:absolute;z-index:1;top:0;right:0;bottom:0;left:0;border:1px solid var(--border);border-radius:inherit;pointer-events:none}.article-media{display:block;width:var(--article-media-size);height:var(--article-media-size);overflow:hidden;border-radius:calc(var(--radius) - 1px);background:var(--surface-soft)}.article-media img,.article-placeholder{width:100%;height:100%}.article-media img{object-fit:cover}.article-placeholder{display:grid;place-items:center;color:var(--text-muted)}.article-content{display:flex;height:100%;min-width:0;flex-direction:column;justify-content:space-between;gap:4px;padding:6px 0 2px}.article-copy{display:flex;height:var(--article-copy-height);flex:0 0 var(--article-copy-height);min-width:0;overflow:hidden;flex-direction:column;gap:6px}.article-title{display:-webkit-box;overflow:hidden;color:var(--text);font-size:17px;font-weight:800;line-height:1.3;flex:0 0 auto;overflow-wrap:anywhere;-webkit-box-orient:vertical;-webkit-line-clamp:3}.article-title:hover,.article-title:focus-visible{color:var(--accent-strong)}.article-excerpt{display:-webkit-box;overflow:hidden;margin:0;color:var(--text-soft);font-size:14px;line-height:1.35;flex:0 1 auto;overflow-wrap:anywhere;-webkit-box-orient:vertical;-webkit-line-clamp:var(--article-excerpt-lines, 1)}.article-footer{display:grid;flex:0 0 auto;gap:0;margin-top:auto;min-width:0}.article-meta,.chip-row{display:flex;align-items:center;min-width:0}.article-meta{min-height:26px;overflow:visible;flex-wrap:nowrap;justify-content:space-between;gap:12px;color:var(--text-muted);font-size:12px;font-weight:700;line-height:1.2}.article-meta-actions,.article-published-at{display:inline-flex;align-items:center;flex:0 0 auto}.article-meta-actions{justify-content:flex-end;gap:4px;min-width:0}.article-published-at{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.article-source{position:relative;flex:1 1 auto;min-width:0}.article-source-button{display:inline-flex;align-items:center;gap:4px;width:100%;max-width:100%;min-width:0;border:0;background:transparent;color:var(--text-muted);cursor:pointer;font-size:12px;font-weight:700;line-height:1.2;padding:0;white-space:nowrap;transition:color .18s ease}.article-source-button span{min-width:0;overflow:hidden;text-overflow:ellipsis}.article-source-button:hover,.article-source-button:focus-visible,.article-source-button[aria-expanded=true]{color:var(--accent-strong)}.article-source-popover{position:absolute;z-index:8;bottom:calc(100% + 8px);left:0;display:none;width:min(300px,calc(100vw - 150px));gap:8px;padding:10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow);opacity:0;pointer-events:none;transform:translateY(4px);transition:opacity .16s ease,transform .16s ease,visibility .16s ease;visibility:hidden}.article-source-popover.visible{display:grid;opacity:1;transform:translateY(0);visibility:visible}.article-source-author,.article-source-empty{color:var(--text-soft);line-height:1.35}.article-source-tags{display:flex;align-items:center;flex-wrap:wrap;gap:6px;min-width:0}.article-source-tags-label{color:var(--text-muted);font-weight:800}.chip-row{flex-wrap:wrap;gap:6px;flex:1 1 auto;min-width:0}.chip{display:inline-flex;align-items:center;max-width:100%;min-width:0;min-height:24px;border-radius:999px;font-size:12px;font-weight:800;line-height:1;padding:0 9px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chip-muted{background:var(--surface-soft);color:var(--text-muted)}.save-button{width:26px;height:26px;flex:0 0 auto;color:var(--accent)}.save-button svg{width:19px;height:19px}.save-button[aria-pressed=true]{background:var(--green-soft);color:var(--green)}@media(min-width:900px){.app-main{padding-right:24px;padding-left:24px}}@media(max-width:720px){.topbar-main{grid-template-columns:42px minmax(0,1fr) 42px;padding:0 10px}.app-shell.search-open .topbar-main{grid-template-columns:minmax(0,1fr) 42px}.feed-toolbar{padding-right:8px;padding-left:8px}.drawer{width:min(320px,calc(100vw - 20px));padding:10px}.drawer-brand{padding:4px 2px 14px}.drawer-link{padding:0 10px}.drawer-section-title{margin:14px 8px 7px}.drawer-hint{padding:8px 10px}.feed-toolbar-row{grid-template-columns:36px minmax(0,1fr);gap:4px}.filter-toggle{width:36px;height:36px}.feed-strip-frame{--feed-arrow-size: 22px;--feed-arrow-zone: 36px;--feed-fade-width: 26px}.feed-strip-arrow{height:34px;color:var(--accent-strong)}.feed-strip-arrow-left{left:-3px}.feed-strip-arrow-right{right:-2px}.feed-strip{gap:6px}.feed-pill{max-width:clamp(96px,28vw,126px);min-height:36px;padding:0 12px;font-size:13px}.filter-panel{left:10px;width:calc(100vw - 20px)}.app-main{padding:calc(var(--topbar-offset) + 12px) 10px 28px}.topbar.with-feed-tools~.app-main{padding-top:calc(var(--topbar-offset) + 6px)}.search-mode-surface{padding:20px 10px 32px}.search-hint{margin-top:52px}.section-heading{align-items:stretch;flex-direction:column}.page-section{gap:12px}.section-heading>.secondary-button,.section-heading>.primary-button{align-self:flex-start}.feed-heading{display:block}.feed-heading-actions{align-items:center;justify-content:center}.feed-card{align-items:stretch;flex-direction:column}.feed-card-actions{justify-content:flex-start}.local-source-form{grid-template-columns:minmax(0,1fr) auto}.local-source-form label{grid-column:1 / -1}.local-source-submit{grid-column:2}.catalog-builder{grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"name name" "selected actions";align-items:center}.catalog-builder.existing-feed{grid-template-areas:"selected actions"}.builder-actions{justify-content:flex-end}.catalog-folder-button{grid-template-columns:minmax(0,1fr);align-items:start;min-height:0;padding:12px}.catalog-folder-title{align-items:flex-start}.catalog-folder-title strong{font-size:16px}.catalog-folder-title small{display:-webkit-box;white-space:normal;-webkit-box-orient:vertical;-webkit-line-clamp:2}.catalog-folder-count{justify-self:start}.catalog-folder-body{gap:14px;padding:0 12px 12px}.source-folder-header{grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"title toggle" "name name";gap:10px;padding:12px}.source-folder-title{grid-area:title}.source-folder-header>.icon-button{grid-area:toggle}.source-folder-header>.source-name-field{grid-area:name}.source-folder-body{padding:0 12px 12px}.managed-source-row,.managed-source-row.custom{grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"name toggle" "link link";gap:10px;padding:10px}.managed-source-name{grid-area:name}.managed-source-row>.icon-button:last-child{grid-area:toggle}.custom-source-builder{grid-template-columns:minmax(0,1fr) auto}.custom-source-builder label{grid-column:1 / -1}.custom-source-submit{grid-column:2}.filter-row{grid-template-columns:1fr;gap:6px}.filter-select{width:100%}.article-card{--article-card-height: 130px;--article-media-size: 130px;--article-copy-height: 92px;--article-copy-line-budget: 5;grid-template-columns:var(--article-media-size) minmax(0,1fr);align-items:stretch;gap:10px;padding:0 8px 0 0}.article-content{justify-content:flex-start;padding:6px 0 2px;gap:4px}.article-title{font-size:13px;-webkit-line-clamp:4}.article-excerpt{font-size:11px;-webkit-line-clamp:var(--article-excerpt-lines, 1)}.article-footer{gap:6px}.article-meta{gap:8px;font-size:11px}.article-published-at{max-width:150px}.article-source-button{font-size:11px}.article-source-popover{width:min(260px,calc(100vw - 150px));padding:8px}.article-list{gap:8px}.reader-layer{padding:0}.reader-panel{width:100%;height:100dvh;border-right:0;border-left:0;border-radius:16px 16px 0 0}.reader-panel.collapsed{height:58px}.reader-header{grid-template-columns:minmax(0,1fr);gap:10px;padding:8px 0 14px}.reader-scroll{padding:42px 14px 104px}.reader-heading h2{font-size:21px}.reader-source-line{justify-content:flex-start;text-align:left}.reader-image{max-height:220px}.reader-body{font-size:15px;line-height:1.58}.reader-collapsed-text h2{font-size:16px}.reader-source-fab{right:14px;bottom:14px;width:56px;height:56px}.chip{max-width:100%}}@media(max-width:460px){.topbar-main{grid-template-columns:38px minmax(0,1fr) 38px;gap:6px;padding:0 8px}.topbar-main>.icon-button{width:38px;height:38px}.app-shell.search-open .topbar-main{grid-template-columns:minmax(0,1fr) 38px}.auth-card{padding:24px 18px}.primary-button,.secondary-button,.text-button{padding-right:13px;padding-left:13px}.article-card{--article-card-height: 130px;--article-copy-height: 92px;grid-template-columns:var(--article-media-size) minmax(0,1fr)}.article-content{gap:2px}.article-meta{gap:5px 8px}.article-published-at{max-width:110px}.article-source-button{max-width:100%}.article-source-popover{width:min(220px,calc(100vw - 130px))}}
