:root{--accent: #0a0a0a;--on-accent: #ffffff;--bg: oklch(.97 .008 80);--surface: #ffffff;--ink: oklch(.16 .01 60);--muted: oklch(.45 .01 60);--line: oklch(.9 .008 60)}[data-theme=dark]{--accent: oklch(.95 .006 80);--on-accent: #0a0a0a;--bg: oklch(.18 .006 80);--surface: oklch(.24 .008 80);--ink: oklch(.94 .006 80);--muted: oklch(.62 .008 80);--line: oklch(.3 .008 80)}[data-theme=dark] .read-badge{color:#4ade80;background:#4ade8014;border-color:#4ade8033}[data-theme=dark] .compact-row__check,[data-theme=dark] .save-status--ok{color:#4ade80}[data-theme=dark] .login-form input{background:var(--surface);border-color:var(--line)}[data-theme=dark] .login-form input:focus{border-color:var(--ink)}[data-theme=dark] .login-card{background:var(--surface);border-color:var(--line)}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);color:var(--ink);font-family:Inter Tight,system-ui,sans-serif;font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}.shell{background:var(--bg)}button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}a{color:inherit;text-decoration:none}input,select{font:inherit;color:inherit;outline:none;border:none;background:none}.shell{min-height:100vh;display:flex;flex-direction:column}.nav{display:flex;align-items:center;gap:32px;padding:18px 40px;border-bottom:1px solid var(--line);background:var(--surface);position:sticky;top:0;z-index:20}.nav__brand{display:flex;align-items:center;gap:10px}.nav__logo{width:32px;height:32px;border-radius:8px;background:var(--ink);color:var(--surface);display:grid;place-items:center;font-family:"Instrument Serif",serif;font-size:20px;font-style:italic}.nav__name{font-family:"Instrument Serif",serif;font-size:22px;font-weight:500;letter-spacing:-.01em}.nav__links{display:flex;gap:22px;margin-left:8px}.nav__links a{font-size:13.5px;color:var(--muted);transition:color .15s}.nav__links a:hover{color:var(--ink)}.nav__right{margin-left:auto;display:flex;align-items:center;gap:12px}.nav__search{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--bg);border:1px solid var(--line);border-radius:999px;width:220px;color:var(--muted)}.nav__search input{flex:1;font-size:13px;color:var(--ink)}.nav__search input::placeholder{color:var(--muted)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:999px;font-size:13px;font-weight:500;border:1px solid var(--line);background:var(--surface);transition:all .18s ease}.btn:hover{border-color:var(--ink)}.btn--ghost{background:transparent}.btn--primary{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}.btn--primary:hover{filter:brightness(1.1)}.icon-btn{padding:8px;border-radius:8px;color:var(--muted)}.icon-btn:hover{background:var(--bg);color:var(--ink)}.icon-btn--quiet{opacity:.5}.icon-btn--quiet:hover{opacity:1;color:#b94642}.anon-banner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 20px;background:var(--surface);border:1px solid var(--line);border-radius:12px;margin-bottom:24px;font-size:13.5px}.anon-banner__text{color:var(--muted);line-height:1.5}.anon-banner__text strong{color:var(--ink);font-weight:600}@media (max-width: 720px){.anon-banner{flex-direction:column;align-items:stretch;text-align:center;gap:12px}}.brand-header{padding:44px 40px 22px;max-width:1240px;width:100%;margin:0 auto;display:flex}.brand-header__link{display:flex;align-items:center;gap:18px;cursor:pointer;transition:opacity .15s}.brand-header__link:hover{opacity:.8}.brand-header__logo{width:64px;height:64px;border-radius:16px;background:var(--ink);color:var(--surface);display:grid;place-items:center;font-family:"Instrument Serif",serif;font-size:40px;font-style:italic;font-weight:500;letter-spacing:-.02em;line-height:1;box-shadow:0 8px 24px -10px color-mix(in oklch,var(--ink) 50%,transparent);flex-shrink:0}.brand-header__name{font-family:"Instrument Serif",serif;font-size:44px;font-weight:500;letter-spacing:-.025em;line-height:1;color:var(--ink)}.brand-header__sep{color:var(--line);font-size:24px;line-height:1;margin:0 2px}.brand-header__tagline{font-size:16px;color:var(--muted);letter-spacing:.01em;font-style:italic;font-family:"Instrument Serif",serif;line-height:1.2}@media (max-width: 720px){.brand-header{padding:28px 20px 14px;justify-content:center}.brand-header__link{flex-wrap:wrap;justify-content:center;gap:12px}.brand-header__logo{width:50px;height:50px;font-size:32px;border-radius:13px}.brand-header__name{font-size:32px}.brand-header__sep{display:none}.brand-header__tagline{width:100%;text-align:center;font-size:14px}}.quick-add-cats{padding-bottom:20px;margin-bottom:20px;border-bottom:1px solid var(--line)}.quick-add-cats h4{font-size:13.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:6px}.quick-add-cats__hint{font-size:13px;color:var(--muted);line-height:1.45;margin-bottom:12px}.quick-add-cats__btns{display:flex;gap:8px;flex-wrap:wrap}.btn--outline{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:13.5px;font-weight:500;color:var(--ink);background:transparent;border:1px solid var(--line);cursor:pointer;transition:all .15s}.btn--outline:hover{background:var(--ink);color:var(--surface);border-color:var(--ink)}.filter-bar{position:sticky;top:65px;z-index:10;background:color-mix(in oklch,var(--bg) 80%,transparent);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:14px 40px}.filter-bar__inner{max-width:1240px;margin:0 auto;display:flex;gap:8px;flex-wrap:wrap}.pill{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;font-size:13.5px;font-weight:500;color:var(--muted);border:1px solid var(--line);background:var(--surface);transition:all .18s ease}.pill:hover{color:var(--ink);border-color:color-mix(in oklch,var(--ink) 30%,var(--line))}.pill__count{font-family:JetBrains Mono,monospace;font-size:11px;padding:1px 7px;border-radius:999px;background:color-mix(in oklch,var(--ink) 6%,transparent);color:var(--muted)}.pill.is-active{background:var(--ink);color:var(--surface);border-color:var(--ink)}.pill.is-active .pill__count{background:color-mix(in oklch,var(--surface) 22%,transparent);color:var(--surface)}.content{max-width:1240px;width:100%;margin:0 auto;padding:40px}.hero-card{display:grid;grid-template-columns:1.1fr 1fr;gap:0;margin-bottom:48px;background:var(--surface);border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:transform .25s ease,box-shadow .25s ease}.hero-card:hover{transform:translateY(-2px);box-shadow:0 20px 40px -20px color-mix(in oklch,var(--ink) 30%,transparent)}.hero-card__media{position:relative;aspect-ratio:4 / 3;display:grid;place-items:center;overflow:hidden}.media-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.hero-card__body{padding:44px 44px 40px;display:flex;flex-direction:column;justify-content:center}.hero-card__meta{display:flex;align-items:center;gap:8px;font-family:JetBrains Mono,monospace;font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin-bottom:18px}.hero-card__title{font-family:"Instrument Serif",serif;font-weight:500;font-size:clamp(28px,3vw,40px);line-height:1.1;letter-spacing:-.02em;text-wrap:pretty;color:var(--ink);margin-bottom:16px}.hero-card__summary{font-size:16px;color:var(--muted);line-height:1.55;text-wrap:pretty;margin-bottom:26px;max-width:50ch}.grid{display:grid;gap:32px;grid-template-columns:repeat(auto-fill,minmax(310px,1fr))}.news-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;transition:transform .22s ease,box-shadow .22s ease}.news-card:hover{transform:translateY(-3px);box-shadow:0 18px 36px -18px color-mix(in oklch,var(--ink) 30%,transparent)}.news-card__media{position:relative;aspect-ratio:16 / 10;display:grid;place-items:center;overflow:hidden}.news-card__body{padding:22px 22px 24px;display:flex;flex-direction:column;gap:10px;flex:1}.news-card__meta{display:flex;align-items:center;gap:8px;font-family:JetBrains Mono,monospace;font-size:10.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}.news-card__title{font-family:"Instrument Serif",serif;font-weight:500;font-size:22px;line-height:1.18;letter-spacing:-.018em;text-wrap:pretty;color:var(--ink)}.news-card__summary{font-size:14px;color:var(--muted);line-height:1.5;text-wrap:pretty;flex:1}.media-stripe{position:absolute;top:0;right:0;bottom:0;left:0;background-image:repeating-linear-gradient(135deg,transparent 0,transparent 18px,rgba(255,255,255,.07) 18px,rgba(255,255,255,.07) 19px)}.media-label{position:relative;font-family:JetBrains Mono,monospace;font-size:11px;color:#ffffffd9;text-transform:uppercase;letter-spacing:.14em;background:#0000002e;padding:4px 10px;border-radius:4px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.cat-tag{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;background:color-mix(in oklch,var(--accent) 8%,var(--bg));color:var(--accent);border:1px solid color-mix(in oklch,var(--accent) 18%,var(--line))}.cat-tag--overlay{position:absolute;top:14px;left:14px;background:#fffffff2;color:#111;border-color:transparent;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.dot-sep{opacity:.5}.card__footer{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:14px}.bookmark-btn{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:6px;color:var(--muted);transition:color .15s,background .15s}.bookmark-btn:hover{color:var(--ink);background:var(--bg)}.bookmark-btn.is-saved{color:var(--ink)}.bookmark-btn.is-saved svg{fill:currentColor}.archive-header{padding:24px 0 8px}.archive-header h2{font-family:"Instrument Serif",serif;font-size:28px;font-weight:500}.archive-header p{font-size:13.5px;color:var(--muted);margin-top:4px}.nav__links a.is-active{color:var(--ink)}.read-more{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:500;color:var(--ink);padding:4px 0;align-self:flex-start;border-bottom:1px solid color-mix(in oklch,var(--ink) 30%,transparent);transition:gap .18s ease,border-color .18s}.read-more:hover{gap:10px;border-color:var(--ink)}.read-more--small{font-size:12.5px}.empty{text-align:center;padding:80px 24px;color:var(--muted)}.empty h3{font-family:"Instrument Serif",serif;font-size:28px;color:var(--ink);margin-bottom:6px;font-weight:500}.foot{max-width:1240px;margin:40px auto 0;padding:0 40px 40px;width:100%}.foot__rule{height:1px;background:var(--line);margin-bottom:18px}.foot__row{display:flex;justify-content:space-between;font-family:JetBrains Mono,monospace;font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted)}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;opacity:0;pointer-events:none;transition:opacity .22s ease;z-index:100}.drawer-overlay.is-open{opacity:1;pointer-events:auto}.drawer{position:fixed;top:0;right:0;bottom:0;width:min(540px,100vw);background:var(--surface);transform:translate(100%);transition:transform .28s cubic-bezier(.32,.72,0,1);z-index:101;display:flex;flex-direction:column;box-shadow:-20px 0 60px -20px #00000040}.drawer.is-open{transform:translate(0)}.drawer__head{padding:28px 32px 22px;border-bottom:1px solid var(--line);display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.drawer__eyebrow{font-family:JetBrains Mono,monospace;font-size:10.5px;text-transform:uppercase;letter-spacing:.16em;color:var(--muted);margin-bottom:6px}.drawer__head h2{font-family:"Instrument Serif",serif;font-size:28px;font-weight:500;letter-spacing:-.02em}.drawer__head p{font-size:13.5px;color:var(--muted);margin-top:6px;max-width:38ch}.save-status{font-size:12.5px;font-weight:500;margin-top:8px}.save-status--saving{color:var(--muted)}.save-status--ok{color:#16a34a}.save-status--error{color:#dc2626;max-width:38ch;word-break:break-word}.drawer__body{flex:1;overflow-y:auto;padding:24px 32px 40px;display:flex;flex-direction:column;gap:28px}.add-feed{background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:18px}.add-feed h4{font-family:JetBrains Mono,monospace;font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin-bottom:12px}.add-feed__row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.add-feed__row input,.add-feed__row select{padding:9px 12px;background:var(--surface);border:1px solid var(--line);border-radius:8px;font-size:13px}.add-feed__row input:focus,.add-feed__row select:focus{border-color:var(--ink)}@media (max-width: 720px){.add-feed__row{grid-template-columns:1fr}}.feed-group__head{display:flex;align-items:baseline;justify-content:space-between;padding:0 4px 10px;border-bottom:1px dashed var(--line);margin-bottom:8px}.feed-group__head h4{font-family:"Instrument Serif",serif;font-size:20px;font-weight:500;letter-spacing:-.01em}.feed-group__count{font-family:JetBrains Mono,monospace;font-size:10.5px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.feed-list{list-style:none;display:flex;flex-direction:column;gap:4px}.feed-row{display:flex;align-items:center;gap:12px;padding:10px 8px;border-radius:8px;transition:background .15s}.feed-row:hover{background:var(--bg)}.feed-row--empty{color:var(--muted);font-style:italic;font-size:13px}.feed-row__text{flex:1;min-width:0}.feed-row__name{font-size:14px;font-weight:500;color:var(--ink)}.feed-row__url{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.feed-row__edit{display:flex;align-items:center;gap:6px;flex:1;min-width:0}.feed-row__edit input{padding:5px 8px;border:1px solid var(--line);border-radius:6px;font-size:13px;background:var(--surface);color:var(--ink);flex:0 0 120px}.feed-row__edit input.feed-row__edit-url{flex:1;min-width:0;font-family:JetBrains Mono,monospace;font-size:11px}.tgl{width:34px;height:20px;border-radius:999px;background:color-mix(in oklch,var(--ink) 18%,transparent);position:relative;flex-shrink:0;transition:background .18s}.tgl__knob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:var(--surface);transition:transform .18s;box-shadow:0 1px 2px #0003}.tgl.is-on{background:var(--accent)}.tgl.is-on .tgl__knob{transform:translate(14px)}.card__actions{display:flex;align-items:center;gap:4px}.reader-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0000008c;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:flex-start;justify-content:center;padding:40px 24px;overflow-y:auto}.reader-modal{position:relative;width:100%;max-width:680px;background:var(--surface);border-radius:16px;padding:52px 56px 56px;box-shadow:0 24px 64px -16px #00000059;display:flex;flex-direction:column}.reader-close{position:absolute;top:16px;right:16px;color:var(--muted)}.reader-loading,.reader-error{display:flex;flex-direction:column;align-items:center;gap:16px;padding:60px 0;text-align:center;color:var(--muted)}.reader-error h3{font-family:"Instrument Serif",serif;font-size:24px;font-weight:500;color:var(--ink)}.reader-error p{font-size:14px;max-width:36ch}.reader-spinner{animation:spin .9s linear infinite;color:var(--muted)}.reader-head{margin-bottom:32px}.reader-source{font-family:JetBrains Mono,monospace;font-size:10.5px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin-bottom:12px}.reader-title{font-family:"Instrument Serif",serif;font-weight:500;font-size:clamp(26px,3.5vw,38px);line-height:1.1;letter-spacing:-.02em;text-wrap:pretty;color:var(--ink);margin-bottom:12px}.reader-byline{font-size:14px;color:var(--muted)}.reader-body{font-size:18px;line-height:1.75;color:var(--ink);flex:1}.reader-body p{margin-bottom:1.2em;text-wrap:pretty}.reader-body h1,.reader-body h2,.reader-body h3{font-family:"Instrument Serif",serif;font-weight:500;letter-spacing:-.018em;margin:1.6em 0 .5em;color:var(--ink)}.reader-body h2{font-size:1.35em}.reader-body h3{font-size:1.15em}.reader-body img{display:none}.reader-body a{border-bottom:1px solid var(--line)}.reader-body ul,.reader-body ol{padding-left:1.4em;margin-bottom:1.2em}.reader-body blockquote{border-left:3px solid var(--line);padding-left:1em;color:var(--muted);font-style:italic;margin:1.2em 0}.reader-foot{margin-top:40px;padding-top:24px;border-top:1px solid var(--line)}@media (max-width: 720px){.reader-overlay{padding:0;align-items:flex-end}.reader-modal{border-radius:20px 20px 0 0;padding:44px 28px 40px;max-height:92vh;overflow-y:auto}}.filter-toggle{display:none;align-items:center;gap:6px;padding:8px 14px;border-radius:999px;font-size:13.5px;font-weight:500;color:var(--muted);border:1px solid var(--line);background:var(--surface);transition:all .18s ease}.filter-toggle svg{transition:transform .2s}.filter-toggle.is-open svg{transform:rotate(180deg)}.filter-toggle.has-filter{background:var(--ink);color:var(--surface);border-color:var(--ink)}.filter-pills{display:flex;gap:8px;flex-wrap:wrap}@media (max-width: 880px){.hero-card{grid-template-columns:1fr}.hero-card__body{padding:28px}.nav__links{display:none}.nav__search{width:140px}.masthead-band{padding:36px 24px 24px}.content{padding:24px}.filter-bar{position:static;padding:12px 24px}.filter-toggle{display:inline-flex}.filter-pills{display:none;width:100%;max-height:15vh;overflow-y:auto;padding-top:8px;flex-wrap:wrap;gap:8px}.filter-pills.is-open{display:flex}}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg, oklch(.97 .008 80))}.login-card{background:#fff;border:1px solid oklch(.9 .008 60);border-radius:16px;padding:2.5rem 2rem;width:100%;max-width:360px;display:flex;flex-direction:column;align-items:center;gap:.75rem}.login-card__logo{width:48px;height:48px;background:#0a0a0a;color:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:700;font-family:"Instrument Serif",serif}.login-card__title{font-family:"Instrument Serif",serif;font-size:1.5rem;font-weight:400;margin-bottom:.5rem}.login-form{width:100%;display:flex;flex-direction:column;gap:.6rem}.login-form input{width:100%;padding:.55rem .75rem;border:1px solid oklch(.88 .008 60);border-radius:8px;font:inherit;font-size:.9rem;background:#faf8f5;outline:none;transition:border-color .15s}.login-form input:focus{border-color:#0a0a0a}.login-error{font-size:.82rem;color:#c0392b;text-align:center}.filter-bar__inner{align-items:center}.filter-bar__tools{margin-left:auto;display:flex;align-items:center;gap:10px;flex-shrink:0}.btn--sm{padding:6px 11px;font-size:12px}.view-toggle{display:flex;gap:2px;background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:2px}.view-btn{display:flex;align-items:center;justify-content:center;width:30px;height:28px;border-radius:6px;color:var(--muted);transition:all .15s}.view-btn:hover{color:var(--ink)}.view-btn.is-active{background:var(--surface);color:var(--ink);box-shadow:0 1px 3px #00000014}.read-badge{display:inline-flex;align-items:center;gap:3px;font-size:10px;color:#16a34a;font-weight:500;background:#f0fdf4;padding:1px 6px;border-radius:4px;border:1px solid #bbf7d0}.news-card.is-read .news-card__title,.hero-card.is-read .hero-card__title{color:var(--muted)}.news-card.is-read{opacity:.75}.hero-card.is-read{opacity:.8}.compact-list{display:flex;flex-direction:column;gap:3px}.compact-row{display:grid;grid-template-columns:72px 1fr auto;align-items:center;gap:14px;padding:10px 14px;border-radius:10px;background:var(--surface);border:1px solid var(--line);transition:background .15s}.compact-row:hover{background:color-mix(in oklch,var(--bg) 60%,var(--surface))}.compact-row.is-read{opacity:.65}.compact-row__img{width:72px;height:50px;border-radius:7px;overflow:hidden;position:relative;flex-shrink:0}.compact-row__img .media-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.compact-row__text{min-width:0;display:flex;flex-direction:column;gap:3px}.compact-row__title{font-size:14px;font-weight:500;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .15s}.compact-row__title:hover{color:#3f3935}.compact-row.is-read .compact-row__title{color:var(--muted)}.compact-row__meta{font-family:JetBrains Mono,monospace;font-size:10.5px;color:var(--muted);white-space:nowrap}.compact-row__actions{display:flex;align-items:center;gap:4px}.compact-row__check{color:#16a34a;display:flex;align-items:center}@media (max-width: 880px){.compact-row{grid-template-columns:60px 1fr auto;gap:10px}.compact-row__img{width:60px;height:42px}.compact-row__meta{display:none}.filter-bar__tools{gap:6px}.btn--sm span{display:none}}.card__actions{display:flex;align-items:center;gap:2px}.reader-btn{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:6px;color:var(--muted);transition:color .15s,background .15s}.reader-btn:hover{color:var(--ink);background:var(--bg)}.reader-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0009;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;justify-content:center;align-items:flex-start;padding:48px 20px;overflow-y:auto}.reader-modal{position:relative;background:var(--surface);border-radius:18px;width:100%;max-width:720px;min-height:320px;padding:56px 60px 60px;box-shadow:0 32px 80px -20px #0006;animation:reader-in .22s cubic-bezier(.32,.72,0,1)}@keyframes reader-in{0%{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}.reader-close{position:absolute;top:18px;right:18px;width:36px;height:36px;border-radius:50%;background:var(--bg);color:var(--muted);display:grid;place-items:center;transition:background .15s,color .15s}.reader-close:hover{background:var(--line);color:var(--ink)}.reader-loading{min-height:280px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;color:var(--muted);font-size:14px}.reader-spinner{width:34px;height:34px;border:2.5px solid var(--line);border-top-color:var(--ink);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.reader-error{min-height:280px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center;padding:24px}.reader-error h2{font-family:"Instrument Serif",serif;font-size:26px;font-weight:500;margin-bottom:4px}.reader-error p{color:var(--muted);max-width:42ch;line-height:1.55}.reader-error__detail{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--muted);background:var(--bg);padding:8px 14px;border-radius:6px;max-width:100%;word-break:break-all}.reader-content{max-width:100%}.reader-title{font-family:"Instrument Serif",serif;font-size:clamp(26px,3.5vw,38px);font-weight:500;line-height:1.18;letter-spacing:-.022em;text-wrap:pretty;margin-bottom:14px}.reader-byline{font-size:13.5px;color:var(--muted);margin-bottom:32px;padding-bottom:28px;border-bottom:1px solid var(--line)}.reader-body{font-size:17px;line-height:1.82;color:var(--ink)}.reader-body p{margin-bottom:1.4em;text-wrap:pretty}.reader-body h1,.reader-body h2,.reader-body h3,.reader-body h4{font-family:"Instrument Serif",serif;font-weight:500;line-height:1.22;letter-spacing:-.018em;margin:2em 0 .65em}.reader-body h1{font-size:30px}.reader-body h2{font-size:26px}.reader-body h3{font-size:22px}.reader-body a{text-decoration:underline;text-underline-offset:3px;opacity:.85}.reader-body a:hover{opacity:1}.reader-body ul,.reader-body ol{padding-left:1.6em;margin-bottom:1.4em}.reader-body li{margin-bottom:.4em}.reader-body blockquote{border-left:3px solid var(--line);margin:0 0 1.4em;padding:.4em 0 .4em 1.2em;color:var(--muted);font-style:italic}.reader-body img,.reader-body figure,.reader-body figcaption,.reader-body aside,.reader-body .ad,.reader-body iframe,.reader-body video{display:none!important}.reader-footer{margin-top:52px;padding-top:24px;border-top:1px solid var(--line)}.login-modal{background:var(--surface);border-radius:18px;width:100%;max-width:400px;padding:52px 44px 48px;position:relative;box-shadow:0 32px 80px -20px #0006;animation:reader-in .22s cubic-bezier(.32,.72,0,1);display:flex;flex-direction:column;align-items:center}.login-modal__logo{width:48px;height:48px;border-radius:12px;background:var(--ink);color:var(--surface);display:grid;place-items:center;font-family:"Instrument Serif",serif;font-size:28px;font-style:italic;margin-bottom:24px;flex-shrink:0}.login-modal__tabs{display:flex;gap:0;background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:3px;width:100%;margin-bottom:8px}.login-modal__tabs button{flex:1;padding:8px 6px;border-radius:8px;font-size:13.5px;font-weight:500;color:var(--muted);transition:all .15s}.login-modal__tabs button.is-active{background:var(--surface);color:var(--ink);box-shadow:0 1px 3px #0000001a}.login-modal__hint{font-size:13px;color:var(--muted);text-align:center;margin-bottom:4px;line-height:1.5;max-width:32ch}.login-modal__done{text-align:center;padding:12px 0}.login-modal__done h2{font-family:"Instrument Serif",serif;font-size:26px;font-weight:500;margin-bottom:12px}.login-modal__done p{color:var(--muted);line-height:1.55}.signup-benefits{width:100%;margin-top:12px}.signup-benefits__lead{font-size:13.5px;color:var(--muted);line-height:1.55;margin-bottom:10px;text-align:center}.signup-benefits__list{list-style:none;display:flex;flex-direction:column;gap:6px;padding:12px 14px;background:color-mix(in oklch,var(--bg) 60%,var(--surface));border:1px solid var(--line);border-radius:10px}.signup-benefits__list li{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink)}.signup-benefits__list svg{color:#16a34a;flex-shrink:0}[data-theme=dark] .signup-benefits__list svg{color:#4ade80}.drawer__eyebrow--admin{display:inline-flex;align-items:center;gap:5px;color:#c53829;font-weight:700}[data-theme=dark] .drawer__eyebrow--admin{color:#eb881f}.anon-upgrade{font-size:13.5px;color:var(--muted);margin-top:18px;line-height:1.5}.anon-upgrade__btn{color:var(--ink);font-weight:500;text-decoration:underline;text-underline-offset:2px;transition:opacity .15s}.anon-upgrade__btn:hover{opacity:.65}.reader-hero-img{display:block;width:calc(100% + 120px);margin:-56px -60px 36px;height:260px;object-fit:cover;border-radius:18px 18px 0 0}.list{display:flex;flex-direction:column;gap:4px}.list-card{display:grid;grid-template-columns:80px 1fr auto;align-items:center;gap:16px;padding:12px 16px;border-radius:12px;background:var(--surface);border:1px solid var(--line);transition:background .15s,transform .15s}.list-card:hover{background:color-mix(in oklch,var(--bg) 50%,var(--surface));transform:translate(2px)}.list-card__media{width:80px;height:56px;border-radius:8px;overflow:hidden;position:relative;flex-shrink:0}.list-card__media .media-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.list-card__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.list-card__meta{display:flex;align-items:center;gap:6px;font-family:JetBrains Mono,monospace;font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}.list-card__title{font-size:15px;font-weight:500;color:var(--ink);line-height:1.3;text-wrap:pretty;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.list-card__title:hover{color:#3f3935}.list-card__actions{display:flex;align-items:center;gap:2px;flex-shrink:0}.cat-tag--small{padding:2px 6px;font-size:9.5px}.hello__brand{cursor:pointer}@media (max-width: 760px){.reader-modal{padding:48px 28px 40px;border-radius:14px}.reader-title{font-size:24px}.reader-body{font-size:16px}.reader-overlay{padding:20px 12px 32px}.reader-hero-img{width:calc(100% + 56px);margin:-48px -28px 28px;height:180px;border-radius:14px 14px 0 0}.list-card{grid-template-columns:64px 1fr auto;gap:10px}.list-card__media{width:64px;height:44px}}.load-more{display:flex;justify-content:center;padding:32px 0 8px}.load-more .btn--ghost{padding:10px 28px;border-radius:100px;font-size:13.5px;font-weight:500;border:1.5px solid var(--line);transition:border-color .15s,background .15s}.load-more .btn--ghost:hover:not(:disabled){border-color:#857f7a;background:color-mix(in oklch,var(--bg) 60%,var(--surface))}.load-more .btn--ghost:disabled{opacity:.5;cursor:default}@media (max-width: 640px){.filter-bar{padding:10px 0}.filter-bar__inner{flex-wrap:nowrap;overflow-x:auto;padding:0 16px;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:6px}.filter-bar__inner::-webkit-scrollbar{display:none}.pill{white-space:nowrap;flex-shrink:0}.filter-bar__tools{flex-shrink:0}}@media (max-width: 480px){.nav{padding:12px 16px;gap:12px}.nav__search{display:none}.content{padding:16px}.foot{padding:0 16px 28px}.foot__row{flex-direction:column;gap:6px;align-items:flex-start}.hero-card__body{padding:20px}.hero-card__title{font-size:24px}.hero-card__summary{font-size:14px;margin-bottom:18px}.grid{gap:20px}.brand-header{padding:20px 16px 12px}}@media (max-width: 640px){.compact-row__title{white-space:normal;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}}.about-modal{position:relative;background:var(--surface);border-radius:20px;padding:52px 52px 44px;max-width:560px;width:100%;max-height:88vh;overflow-y:auto;box-shadow:0 24px 80px -12px #00000038;animation:reader-in .22s cubic-bezier(.32,.72,0,1)}.about-modal__logo{width:52px;height:52px;border-radius:14px;background:var(--ink);color:var(--surface);display:grid;place-items:center;font-family:"Instrument Serif",serif;font-size:32px;font-style:italic;font-weight:500;margin-bottom:20px}.about-modal h2{font-family:"Instrument Serif",serif;font-size:32px;font-weight:500;letter-spacing:-.025em;margin-bottom:12px}.about-modal h3{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin:24px 0 10px}.about-modal__lead{font-size:15.5px;color:var(--muted);line-height:1.65;max-width:44ch}.about-modal p{font-size:14.5px;line-height:1.65}.about-modal a{color:var(--ink);text-decoration:underline}.about-sources{display:flex;flex-direction:column;gap:8px}.about-sources__group{display:flex;align-items:baseline;gap:10px;padding:8px 12px;border-radius:8px;background:color-mix(in oklch,var(--bg) 60%,var(--surface));border:1px solid var(--line)}.about-sources__cat{font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);white-space:nowrap;flex-shrink:0;min-width:80px}.about-sources__names{font-size:13.5px;color:var(--ink);line-height:1.4}.about-modal__footer{margin-top:28px;padding-top:20px;border-top:1px solid var(--line)}@media (max-width: 600px){.about-modal{padding:44px 24px 36px;border-radius:16px}.about-sources__group{flex-direction:column;gap:4px}.about-sources__cat{min-width:unset}}.gdpr-banner{position:fixed;bottom:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 32px;background:var(--ink);color:var(--surface);font-size:13.5px}.gdpr-banner__text{flex:1;line-height:1.5;opacity:.85}.gdpr-link{color:inherit;opacity:.7;text-decoration:underline;font:inherit;background:none;border:none;cursor:pointer;padding:0}.gdpr-link:hover{opacity:1}.gdpr-banner .btn--primary{background:var(--surface);color:var(--ink);flex-shrink:0}.gdpr-banner .btn--primary:hover{opacity:.9}@media (max-width: 600px){.gdpr-banner{flex-direction:column;align-items:flex-start;padding:16px 20px}.gdpr-banner .btn--primary{width:100%;text-align:center}}.privacy-modal{position:relative;background:var(--surface);border-radius:20px;padding:48px 48px 40px;max-width:600px;width:100%;max-height:85vh;overflow-y:auto;box-shadow:0 24px 80px -12px #00000038}.privacy-modal h2{font-family:"Instrument Serif",serif;font-size:28px;font-weight:500;letter-spacing:-.02em;margin-bottom:4px}.privacy-updated{font-size:12.5px;color:var(--muted);margin-bottom:24px}.privacy-modal h3{font-size:14px;font-weight:600;letter-spacing:.02em;text-transform:uppercase;color:var(--muted);margin:20px 0 8px}.privacy-modal p,.privacy-modal li{font-size:14.5px;line-height:1.65;color:var(--ink)}.privacy-modal ul{padding-left:18px;display:flex;flex-direction:column;gap:4px}.privacy-modal a{color:var(--ink);text-decoration:underline}.privacy-modal__footer{margin-top:28px}@media (max-width: 640px){.privacy-modal{padding:40px 24px 32px;border-radius:14px}}.foot__privacy-link{font:inherit;font-size:inherit;color:var(--muted);background:none;border:none;cursor:pointer;padding:0;text-decoration:underline;text-decoration-color:transparent;transition:color .15s,text-decoration-color .15s}.foot__privacy-link:hover{color:var(--ink);text-decoration-color:var(--muted)}.placeholder-logo-wrap{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;pointer-events:none}.placeholder-logo{background:var(--ink);color:var(--surface);display:grid;place-items:center;font-family:"Instrument Serif",serif;font-style:italic;font-weight:500;line-height:1;box-shadow:0 6px 16px -8px color-mix(in oklch,var(--ink) 50%,transparent);-webkit-user-select:none;user-select:none}.hero-card .placeholder-logo,.news-card .placeholder-logo{width:64px;height:64px;border-radius:16px;font-size:40px}.compact-row .placeholder-logo{width:32px;height:32px;border-radius:8px;font-size:20px}
