:root{--sh-bg-primary: #2d1b4e;--sh-bg-secondary: #1a1a2e;--sh-bg-surface: #3d2a5e;--sh-border: #6b4aa3;--sh-accent: #ffd700;--sh-accent-hover: #ffb300;--sh-text-primary: #ffffff;--sh-text-secondary: #c9a0dc;--sh-text-muted: #8a6fb0;--sh-success-bg: #1a472a;--sh-success-border: #4ade80;--sh-success-text: #4ade80;--sh-error-bg: #4a1a1a;--sh-error-border: #ff6b6b;--sh-error-text: #ff6b6b;--sh-warning-bg: #4a3a1a;--sh-warning-border: #ffd700;--sh-warning-text: #ffd700;--sh-font-display: "Bungee", Impact, sans-serif;--sh-font-heading: "Space Grotesk", sans-serif;--sh-font-body: "DM Sans", "Segoe UI", Arial, sans-serif;--sh-weight-display: 700;--sh-weight-heading: 600;--sh-weight-body: 400;--sh-transform-display: none;--sh-transform-heading: none;--sh-transform-body: none;--sh-radius-sm: 8px;--sh-radius-md: 12px;--sh-radius-lg: 16px;--sh-radius-xl: 20px;--sh-shadow-card: 0 4px 20px rgba(0, 0, 0, .3);--sh-shadow-glow: 0 0 40px rgba(107, 74, 163, .4)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--sh-font-body);background:var(--sh-bg-secondary);color:var(--sh-text-primary);line-height:1.5;-webkit-font-smoothing:antialiased}.sh-card{background:linear-gradient(135deg,var(--sh-bg-primary) 0%,var(--sh-bg-secondary) 100%);border:2px solid var(--sh-border);border-radius:var(--sh-radius-lg);padding:24px;box-shadow:var(--sh-shadow-card)}.sh-title{font-family:var(--sh-font-display);font-weight:var(--sh-weight-display);text-transform:var(--sh-transform-display);color:var(--sh-accent);text-shadow:0 2px 4px rgba(0,0,0,.5)}.sh-subtitle{font-family:var(--sh-font-heading);font-weight:var(--sh-weight-heading);text-transform:var(--sh-transform-heading);color:var(--sh-text-secondary)}.sh-btn{padding:10px 24px;font-size:14px;font-weight:var(--sh-weight-heading);font-family:var(--sh-font-body);border:none;border-radius:var(--sh-radius-sm);cursor:pointer;transition:all .15s ease;text-decoration:none;display:inline-flex;align-items:center;gap:8px}.sh-btn-primary{background:linear-gradient(135deg,gold,#ffb300);color:#1a1a2e}.sh-btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #ffd70066}.sh-btn-secondary{background:#ffffff14;color:var(--sh-text-secondary);border:1px solid rgba(107,74,163,.4)}.sh-btn-secondary:hover{background:#ffffff1f}.sh-btn-danger{background:linear-gradient(135deg,#f44,#c00);color:#fff}.sh-btn-danger:hover{transform:translateY(-1px);box-shadow:0 4px 12px #f446}.sh-input{width:100%;padding:10px 14px;font-size:15px;font-family:var(--sh-font-body);border:2px solid var(--sh-border);border-radius:var(--sh-radius-sm);background:#ffffff0f;color:var(--sh-text-primary);outline:none;transition:border-color .15s}.sh-input:focus{border-color:var(--sh-accent);box-shadow:0 0 8px #ffd70033}.sh-label{display:block;font-size:13px;font-weight:var(--sh-weight-heading);color:var(--sh-text-secondary);margin-bottom:6px}.sh-badge{display:inline-block;padding:3px 10px;font-size:11px;font-weight:var(--sh-weight-display);border-radius:20px;text-transform:var(--sh-transform-display);letter-spacing:.5px}.sh-badge-gold{background:#ffd70026;color:var(--sh-accent)}.sh-badge-green{background:#4ade8026;color:var(--sh-success-text)}.sh-badge-red{background:#ff6b6b26;color:var(--sh-error-text)}.sh-icon{display:inline-block;vertical-align:middle;flex-shrink:0}.sh-icon.spin{animation:sh-spin 1s linear infinite}@keyframes sh-spin{to{transform:rotate(360deg)}}:root{--app-radius: 8px;--header-h: 56px;--sh-font-display: "Fraunces", "Iowan Old Style", Georgia, serif;--sh-font-heading: "Space Grotesk", system-ui, sans-serif;--sh-font-body: "DM Sans", system-ui, sans-serif;--app-bg: #1a1a2e;--app-surface: #232342;--app-surface-2: #2a2a4a;--app-text: #f3e8d6;--app-text-dim: #98a0b3;--app-accent: #d4af37;--app-border: #3a3a5a}html[data-app-theme=pocket]{--app-bg: #1a1a2e;--app-surface: #232342;--app-surface-2: #2a2a4a;--app-text: #f3e8d6;--app-text-dim: #98a0b3;--app-accent: #d4af37;--app-border: #3a3a5a}html[data-app-theme=midnight]{--app-bg: #050816;--app-surface: #0c1226;--app-surface-2: #161e3a;--app-text: #e8edff;--app-text-dim: #8a9bc7;--app-accent: #6ea8ff;--app-border: #1d2540}html[data-app-theme=forest]{--app-bg: #11201a;--app-surface: #1a2e25;--app-surface-2: #233b30;--app-text: #e8f0e2;--app-text-dim: #98b09a;--app-accent: #f0b450;--app-border: #2c4a3b}html[data-app-theme=coffee]{--app-bg: #1f1611;--app-surface: #2b1f17;--app-surface-2: #38291f;--app-text: #f1e4cd;--app-text-dim: #b39d80;--app-accent: #e0a96d;--app-border: #3e2e22}html[data-app-theme=mocha]{--app-bg: #1e1e2e;--app-surface: #313244;--app-surface-2: #45475a;--app-text: #cdd6f4;--app-text-dim: #a6adc8;--app-accent: #f5c2e7;--app-border: #45475a}html[data-app-theme=dracula]{--app-bg: #282a36;--app-surface: #343746;--app-surface-2: #44475a;--app-text: #f8f8f2;--app-text-dim: #bd93f9;--app-accent: #ff79c6;--app-border: #44475a}html[data-app-theme=nord]{--app-bg: #2e3440;--app-surface: #3b4252;--app-surface-2: #434c5e;--app-text: #eceff4;--app-text-dim: #d8dee9;--app-accent: #88c0d0;--app-border: #4c566a}html[data-app-theme=synthwave]{--app-bg: #1a0b2e;--app-surface: #2a1654;--app-surface-2: #3a1f6e;--app-text: #f8e8ff;--app-text-dim: #b48ce8;--app-accent: #ff71ce;--app-border: #4a2876}html[data-app-theme=monochrome]{--app-bg: #111111;--app-surface: #1c1c1c;--app-surface-2: #262626;--app-text: #f0f0f0;--app-text-dim: #999999;--app-accent: #f0f0f0;--app-border: #333333}html[data-app-theme=paper]{--app-bg: #faf6ee;--app-surface: #ffffff;--app-surface-2: #f1ead8;--app-text: #2a2419;--app-text-dim: #6a5d44;--app-accent: #b08442;--app-border: #e3dac1}html[data-app-theme=slate]{--app-bg: #eef2f7;--app-surface: #ffffff;--app-surface-2: #e0e7ee;--app-text: #1f2a3a;--app-text-dim: #5e6b7d;--app-accent: #2563eb;--app-border: #d4dae3}html[data-app-theme=mint]{--app-bg: #effaf3;--app-surface: #ffffff;--app-surface-2: #d8eede;--app-text: #163325;--app-text-dim: #527c66;--app-accent: #2f7d59;--app-border: #c7e6d4}html[data-app-theme=rose]{--app-bg: #fdf2f4;--app-surface: #ffffff;--app-surface-2: #f5dde3;--app-text: #3a1c25;--app-text-dim: #7d5260;--app-accent: #ad3d65;--app-border: #ecc7d2}html[data-app-theme=solar]{--app-bg: #fff7e0;--app-surface: #ffffff;--app-surface-2: #fbecc2;--app-text: #2d2410;--app-text-dim: #6e5d28;--app-accent: #d97706;--app-border: #ecd9a0}html[data-app-theme=paper] .login-button,html[data-app-theme=slate] .login-button,html[data-app-theme=mint] .login-button,html[data-app-theme=rose] .login-button,html[data-app-theme=solar] .login-button{color:#fff}*{box-sizing:border-box}html,body{margin:0;background:var(--app-bg);color:var(--app-text);font-family:var(--sh-font-body);min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--sh-font-heading);font-weight:600;letter-spacing:-.01em}.sh-title,.login-title{font-family:var(--sh-font-display);font-weight:500;letter-spacing:-.02em;font-variation-settings:"opsz" 144,"SOFT" 50,"WONK" 1}.loading,.empty{color:var(--app-text-dim);padding:12px}.error{color:#ff6b6b;padding:12px}.app-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--app-border);background:var(--app-surface);position:sticky;top:0;z-index:5}.app-header .sh-title{margin:0;font-size:20px;font-weight:600}.header-actions{display:flex;gap:8px}.header-link{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;background:transparent;border:1px solid var(--app-border);color:var(--app-text);font-size:16px;cursor:pointer;text-decoration:none}.header-link:hover{background:var(--app-surface-2)}.container{padding:20px;max-width:760px;margin:0 auto}.save-form{display:flex;gap:8px;margin-bottom:16px}.save-form input{flex:1;padding:10px 12px;border-radius:6px;border:1px solid var(--app-border);background:var(--app-surface);color:var(--app-text);font:inherit}.save-form button{padding:10px 18px;border:none;border-radius:6px;background:var(--app-accent);color:#1a0f2e;font-weight:600;cursor:pointer}.save-form button:disabled{opacity:.6;cursor:not-allowed}.search-row{position:relative;margin-bottom:12px}.search-input{width:100%;padding:10px 32px 10px 14px;border:1px solid var(--app-border);border-radius:8px;background:var(--app-surface);color:var(--app-text);font-size:14px}.search-input::placeholder{color:var(--app-text-dim)}.search-clear{position:absolute;top:50%;right:6px;transform:translateY(-50%);width:26px;height:26px;border:none;background:transparent;color:var(--app-text-dim);font-size:20px;line-height:1;cursor:pointer;border-radius:50%}.search-clear:hover{background:var(--app-border);color:var(--app-text)}.custom-themes-list{display:flex;flex-direction:column;gap:8px;margin:12px 0 16px}.custom-theme{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:10px 12px;border:1px solid var(--app-border);border-radius:8px;background:var(--app-surface)}.custom-theme-swatches{display:flex;gap:3px}.custom-theme-swatch{display:inline-block;width:14px;height:24px;border-radius:3px;border:1px solid var(--app-border)}.custom-theme-head strong{display:block;font-size:14px;color:var(--app-text)}.custom-theme-summary{font-size:11px;color:var(--app-text-dim);font-family:ui-monospace,Menlo,monospace}.custom-theme-buttons{display:flex;gap:6px}.custom-theme-buttons .settings-button{padding:6px 10px;font-size:12px}.custom-theme-add{margin-top:8px;border:1px solid var(--app-border);border-radius:8px;padding:8px 12px}.custom-theme-add>summary{list-style:none;font-weight:500}.custom-theme-add>summary::-webkit-details-marker{display:none}.custom-theme-form{display:flex;flex-direction:column;gap:12px;margin-top:12px}.custom-theme-field{display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--app-text-dim)}.custom-theme-field input[type=text]{padding:8px 10px;border-radius:6px;border:1px solid var(--app-border);background:var(--app-bg);color:var(--app-text);font:inherit}.custom-theme-colors{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px}.custom-theme-color{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:6px;font-size:12px;color:var(--app-text-dim)}.custom-theme-color input[type=color]{width:30px;height:30px;padding:0;border:1px solid var(--app-border);border-radius:4px;background:transparent;cursor:pointer}.custom-theme-color input[type=text]{width:78px;padding:5px 6px;border:1px solid var(--app-border);border-radius:4px;background:var(--app-bg);color:var(--app-text);font:11px ui-monospace,Menlo,monospace}.custom-theme-actions{display:flex;gap:8px}.filter-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;border-bottom:1px solid var(--app-border)}.filter-tabs{display:flex;gap:4px}.filter-tab{padding:8px 16px;background:transparent;border:none;color:var(--app-text-dim);cursor:pointer;font:inherit;border-bottom:2px solid transparent;margin-bottom:-1px}.filter-tab.active{color:var(--app-text);border-bottom-color:var(--app-accent)}.view-toggle{display:flex;gap:2px;padding:2px;background:var(--app-surface);border-radius:6px;margin-bottom:4px}.view-toggle button{width:30px;height:28px;padding:0;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--app-text-dim);cursor:pointer;border-radius:4px}.view-toggle button.active{background:var(--app-bg);color:var(--app-text)}.article-list[data-view=list]{display:flex;flex-direction:column}.article-item{display:flex;gap:8px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--app-border)}.article-link{flex:1;min-width:0;color:inherit;text-decoration:none;display:flex;gap:12px;align-items:flex-start}.article-text{flex:1;min-width:0}.article-thumb{width:80px;height:80px;flex-shrink:0;border-radius:6px;overflow:hidden;background:var(--app-surface-2)}.article-thumb img{width:100%;height:100%;object-fit:cover;display:block}.article-title{font-weight:600;font-size:16px;margin-bottom:4px;line-height:1.35}.article-meta{font-size:12px;color:var(--app-text-dim);margin-bottom:4px}.article-excerpt{font-size:13px;color:var(--app-text-dim);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.article-actions{display:flex;gap:4px;flex-shrink:0}.article-action{width:32px;height:32px;border:none;background:transparent;color:var(--app-text-dim);cursor:pointer;border-radius:6px;font-size:14px}.article-action:hover{background:var(--app-surface-2);color:var(--app-text)}.article-list[data-view=cards]{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.article-card{display:flex;flex-direction:column;background:var(--app-surface);border:1px solid var(--app-border);border-radius:10px;overflow:hidden;transition:border-color .15s,transform .15s}.article-card:hover{border-color:var(--app-accent);transform:translateY(-1px)}.article-card-link{color:inherit;text-decoration:none;display:flex;flex-direction:column;flex:1}.article-card-image{aspect-ratio:16 / 9;background:var(--app-surface-2);display:flex;align-items:center;justify-content:center;overflow:hidden}.article-card-image img{width:100%;height:100%;object-fit:cover;display:block}.article-card-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--sh-font-display, "Fraunces", serif);font-weight:600;font-size:56px;color:var(--app-accent);background:var(--app-surface-2);font-variation-settings:"opsz" 144,"SOFT" 50,"WONK" 1}.article-card-body{padding:12px 14px 4px;flex:1;display:flex;flex-direction:column;gap:4px}.article-card .article-actions{padding:4px 8px 8px}.article-card .article-title{font-size:15px}.article-card .article-excerpt{-webkit-line-clamp:3}.reader-page{--reader-bg: #f5efe6;--reader-surface: #fff;--reader-border: #ddd;--reader-text: #1a1a2e;--reader-text-dim: #555;--reader-link: #2a4365;--reader-rule: #d4af37;--reader-code-bg: #ece5d8;--reader-mark: #f4d03f;background:var(--reader-bg);color:var(--reader-text)}.reader-page[data-theme=sepia]{--reader-bg: #f4ecd8;--reader-surface: #fbf6e6;--reader-border: #d9ceb1;--reader-text: #3a2e1f;--reader-text-dim: #6b5a42;--reader-link: #6b3a1c;--reader-rule: #b08442;--reader-code-bg: #e8dfc4;--reader-mark: #f4c95d}.reader-page[data-theme=cream]{--reader-bg: #fbf3e3;--reader-surface: #fff9eb;--reader-border: #e7dcc4;--reader-text: #2c2616;--reader-text-dim: #6b5a3a;--reader-link: #8b5a1c;--reader-rule: #d4af37;--reader-code-bg: #efe5cb;--reader-mark: #ffe28a}.reader-page[data-theme=mint]{--reader-bg: #effaf3;--reader-surface: #f7fdf9;--reader-border: #c7e6d4;--reader-text: #1c3a2c;--reader-text-dim: #527c66;--reader-link: #2f7d59;--reader-rule: #5fa884;--reader-code-bg: #dff0e6;--reader-mark: #b5e6c5}.reader-page[data-theme=rose]{--reader-bg: #fdf2f4;--reader-surface: #fff7f9;--reader-border: #ecc7d2;--reader-text: #3a1c25;--reader-text-dim: #7d5260;--reader-link: #ad3d65;--reader-rule: #e07a99;--reader-code-bg: #f4dde4;--reader-mark: #f7b7c8}.reader-page[data-theme=high-contrast]{--reader-bg: #ffffff;--reader-surface: #ffffff;--reader-border: #000000;--reader-text: #000000;--reader-text-dim: #333333;--reader-link: #0000ee;--reader-rule: #000000;--reader-code-bg: #f0f0f0;--reader-mark: #ffe600}.reader-page[data-theme=nord-light]{--reader-bg: #eceff4;--reader-surface: #e5e9f0;--reader-border: #d8dee9;--reader-text: #2e3440;--reader-text-dim: #4c566a;--reader-link: #5e81ac;--reader-rule: #88c0d0;--reader-code-bg: #d8dee9;--reader-mark: #ebcb8b}.reader-page[data-theme=dark]{--reader-bg: #16161d;--reader-surface: #1e1e26;--reader-border: #2c2c36;--reader-text: #e6e1d3;--reader-text-dim: #9aa0ab;--reader-link: #ffd17a;--reader-rule: #d4af37;--reader-code-bg: #23232c;--reader-mark: #b88a1f}.reader-page[data-theme=solarized]{--reader-bg: #002b36;--reader-surface: #073642;--reader-border: #094553;--reader-text: #fdf6e3;--reader-text-dim: #93a1a1;--reader-link: #b58900;--reader-rule: #cb4b16;--reader-code-bg: #073642;--reader-mark: #b58900}.reader-page[data-theme=nord]{--reader-bg: #2e3440;--reader-surface: #3b4252;--reader-border: #434c5e;--reader-text: #eceff4;--reader-text-dim: #d8dee9;--reader-link: #88c0d0;--reader-rule: #5e81ac;--reader-code-bg: #3b4252;--reader-mark: #ebcb8b}.reader-page[data-theme=gruvbox]{--reader-bg: #282828;--reader-surface: #32302f;--reader-border: #3c3836;--reader-text: #ebdbb2;--reader-text-dim: #a89984;--reader-link: #fabd2f;--reader-rule: #d65d0e;--reader-code-bg: #3c3836;--reader-mark: #b57614}.reader-page[data-theme=dracula]{--reader-bg: #282a36;--reader-surface: #343746;--reader-border: #44475a;--reader-text: #f8f8f2;--reader-text-dim: #bd93f9;--reader-link: #8be9fd;--reader-rule: #ff79c6;--reader-code-bg: #44475a;--reader-mark: #f1fa8c}.reader-header{display:flex;align-items:center;gap:12px;padding:10px 16px;background:var(--reader-surface);border-bottom:1px solid var(--reader-border);position:sticky;top:0;z-index:5}.back-link{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;text-decoration:none;color:var(--reader-text);background:var(--reader-bg)}.reader-meta{flex:1;min-width:0}.reader-title{font-weight:700;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--reader-text)}.reader-byline{font-size:12px;color:var(--reader-text-dim)}.reader-byline a{color:var(--reader-text-dim)}.reader-actions{display:flex;gap:4px}.reader-action{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 8px;border:1px solid var(--reader-border);border-radius:8px;background:var(--reader-surface);color:var(--reader-text);cursor:pointer;font-size:14px;text-decoration:none;box-sizing:border-box}.reader-action:hover{background:var(--reader-bg)}.reader-page{--reader-width: 720px;--reader-size: 19px;--reader-leading: 1.7;--reader-align: left}.reader-page[data-width=narrow]{--reader-width: 580px}.reader-page[data-width=normal]{--reader-width: 720px}.reader-page[data-width=wide]{--reader-width: 880px}.reader-page[data-size=s]{--reader-size: 15px}.reader-page[data-size=m]{--reader-size: 17px}.reader-page[data-size=l]{--reader-size: 19px}.reader-page[data-size=xl]{--reader-size: 21px}.reader-page[data-size=xxl]{--reader-size: 24px}.reader-page[data-leading=tight]{--reader-leading: 1.45}.reader-page[data-leading=normal]{--reader-leading: 1.7}.reader-page[data-leading=loose]{--reader-leading: 1.9}.reader-page[data-align=justify]{--reader-align: justify}.reader-page[data-align=left]{--reader-align: left}.reader-page{--reader-para-gap: 1em}.reader-page[data-paragraphs=tight]{--reader-para-gap: .55em}.reader-page[data-paragraphs=normal]{--reader-para-gap: 1em}.reader-page[data-paragraphs=airy]{--reader-para-gap: 1.6em}.reader-page .article-body p{margin:0 0 var(--reader-para-gap)}.reader-page[data-hyphens=on] .article-body{hyphens:auto;-webkit-hyphens:auto}.reader-page[data-hyphens=off] .article-body{hyphens:manual;-webkit-hyphens:manual}.reader-page[data-dropcap=on] .article-body>p:first-of-type:first-letter,.reader-page[data-dropcap=on] .article-body>div:first-of-type p:first-of-type:first-letter{font-family:var(--sh-font-display, "Fraunces", serif);font-weight:600;float:left;font-size:3.4em;line-height:.85;padding:.08em .12em 0 0;color:var(--reader-rule)}.reader-container{max-width:var(--reader-width);margin:0 auto;padding:32px 24px 96px}.paywall-banner{display:flex;flex-wrap:wrap;align-items:center;gap:12px;padding:12px 16px;margin-bottom:24px;background:color-mix(in srgb,var(--reader-rule) 18%,var(--reader-bg));border:1px solid var(--reader-rule);border-radius:8px;color:var(--reader-text);font-size:14px}.paywall-banner-text{flex:1;min-width:200px}.paywall-banner-btn{padding:8px 14px;border-radius:6px;border:1px solid var(--reader-rule);background:var(--reader-rule);color:var(--reader-bg);font:inherit;font-weight:600;cursor:pointer}.paywall-banner-btn:hover{filter:brightness(1.05)}.paywall-banner-btn:disabled{opacity:.6;cursor:wait}.paywall-banner-progress{flex-basis:100%;height:6px;background:color-mix(in srgb,var(--reader-rule) 25%,transparent);border-radius:999px;overflow:hidden}.paywall-banner-progress-fill{height:100%;background:var(--reader-rule);border-radius:999px;transition:width .5s linear}.paywall-banner .sh-icon{color:var(--reader-rule);vertical-align:-3px;margin-right:6px}.reader-page[data-font=fraunces] .article-body{font-family:Fraunces,Iowan Old Style,Georgia,serif;font-variation-settings:"opsz" 14,"SOFT" 30,"WONK" 0}.reader-page[data-font=literata] .article-body{font-family:Literata,Iowan Old Style,Georgia,serif;font-variation-settings:"opsz" 14}.reader-page[data-font=newsreader] .article-body{font-family:Newsreader,Iowan Old Style,Georgia,serif;font-variation-settings:"opsz" 14}.reader-page[data-font=lora] .article-body{font-family:Lora,Georgia,serif}.reader-page[data-font=crimson-pro] .article-body{font-family:Crimson Pro,Georgia,serif}.reader-page[data-font=eb-garamond] .article-body{font-family:EB Garamond,Garamond,Georgia,serif}.reader-page[data-font=ibm-plex-serif] .article-body{font-family:"IBM Plex Serif",Georgia,serif}.reader-page[data-font=dm-sans] .article-body{font-family:DM Sans,system-ui,sans-serif}.reader-page[data-font=space-grotesk] .article-body{font-family:Space Grotesk,system-ui,sans-serif}.reader-page[data-font=inter] .article-body{font-family:Inter,system-ui,sans-serif}.reader-page[data-font=atkinson] .article-body{font-family:Atkinson Hyperlegible,system-ui,sans-serif}.reader-page[data-font=mono] .article-body{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Menlo,monospace;font-size:calc(var(--reader-size) * .92)}.article-body{font-size:var(--reader-size);line-height:var(--reader-leading);text-align:var(--reader-align);color:var(--reader-text);-webkit-touch-callout:none}.article-body .article-header{margin:0 0 1.4em;padding-bottom:.8em;border-bottom:1px solid var(--reader-border)}.article-body h1.article-headline{font-family:Space Grotesk,system-ui,sans-serif;font-size:1.85em;line-height:1.18;letter-spacing:-.02em;font-weight:700;color:var(--reader-text);margin:0;text-align:left}.article-body p.article-byline{margin:.5em 0 0;font-size:.85em;color:var(--reader-text-dim);text-align:left}.article-body .article-header+h2,.article-body .article-header+h3,.article-body h1.article-headline+h2,.article-body h1.article-headline+h3{font-family:var(--reader-font, inherit);font-size:1.1em;line-height:1.4;font-weight:400;font-style:italic;color:var(--reader-text-dim);letter-spacing:0;margin:-.2em 0 1.4em}.article-body h1,.article-body h2,.article-body h3,.article-body h4,.article-body h5,.article-body h6{font-family:Space Grotesk,system-ui,sans-serif;line-height:1.22;letter-spacing:-.015em;text-align:left;font-weight:700;color:var(--reader-text)}.article-body h1{font-size:1.85em;margin:1.4em 0 .55em}.article-body h2{font-size:1.45em;margin:1.6em 0 .5em}.article-body h3{font-size:1.2em;margin:1.4em 0 .45em;letter-spacing:-.005em}.article-body h4{font-size:1.05em;margin:1.2em 0 .4em;letter-spacing:0}.article-body h5,.article-body h6{font-size:.95em;margin:1em 0 .35em;letter-spacing:0;text-transform:uppercase;color:var(--reader-text-dim)}.article-body h1:first-child,.article-body h2:first-child{margin-top:0}.article-body img{max-width:100%;height:auto;border-radius:4px;display:block;margin:1.2em auto}.article-body picture{display:block;margin:1.2em auto}.article-body picture img{margin:0}.article-body figure{margin:1.6em 0}.article-body figure img,.article-body figure picture{margin:0}.article-body figcaption{margin-top:.6em;font-size:.85em;line-height:1.45;color:var(--reader-text-dim);text-align:center;font-style:italic}.article-body figcaption small,.article-body figcaption cite,.article-body figcaption .credit{display:block;font-size:.85em;margin-top:.25em;font-style:normal;opacity:.8;letter-spacing:.02em}.article-body svg{max-width:100%;height:auto}.article-body ul,.article-body ol{padding-left:1.4em;margin:1em 0}.article-body li{margin:.35em 0}.article-body blockquote.pullquote,.article-body blockquote.pull-quote{border-left:none;padding:0;margin:1.6em 0;text-align:center;font-style:italic;font-size:1.15em;color:var(--reader-text)}.article-body table{display:block;overflow-x:auto;max-width:100%;border-collapse:collapse;margin:1.2em 0}.article-body th,.article-body td{padding:6px 10px;border:1px solid var(--reader-rule);text-align:left}.article-body th{font-weight:700}.article-body img:not([src]),.article-body img[src=""]{display:none}.article-body a{color:var(--reader-link)}.article-body pre,.article-body code{background:var(--reader-code-bg);border-radius:4px;padding:2px 4px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.article-body pre{padding:12px;overflow-x:auto}.article-body blockquote{border-left:3px solid var(--reader-rule);padding-left:16px;color:var(--reader-text-dim);margin-left:0}mark.sh-highlight{background-color:var(--reader-mark);color:inherit;padding:0;cursor:pointer}.highlight-toolbar{position:absolute;z-index:50;display:flex;gap:8px;align-items:center;padding:6px 8px;background:#1a1a2e;border-radius:8px;box-shadow:0 4px 16px #00000059}.pr-color-picker{display:flex;gap:4px;align-items:center}.pr-color-btn{width:22px;height:22px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:border-color .15s,transform .1s}.pr-color-btn:hover{transform:scale(1.12);border-color:#ffffff59}.pr-color-btn--active{border-color:#fff}.highlight-note-add{padding:4px 10px;border:1px solid rgba(255,255,255,.2);border-radius:999px;background:transparent;color:#fff;cursor:pointer;font:inherit;font-size:12px}.highlight-note-add:hover{background:#ffffff1a}.reader-action.is-speaking{background:var(--reader-text);color:var(--reader-bg);border-color:var(--reader-text)}.pocket-read-from-flash{background:color-mix(in srgb,var(--reader-text) 18%,transparent);border-radius:3px;animation:pocket-read-from-fade .6s ease-out forwards}@keyframes pocket-read-from-fade{0%{background:color-mix(in srgb,var(--reader-text) 30%,transparent)}to{background:color-mix(in srgb,var(--reader-text) 0%,transparent)}}.reader-page .article-body{cursor:text}.prefs-select{width:100%;padding:6px 8px;border:1px solid var(--reader-border);border-radius:6px;background:var(--reader-bg);color:var(--reader-text);font:inherit;font-size:13px}.prefs-panel{position:fixed;right:16px;top:calc(var(--header-h, 56px) + 8px);width:min(320px,calc(100vw - 32px));background:var(--reader-surface);color:var(--reader-text);border:1px solid var(--reader-border);border-radius:10px;padding:14px 16px;box-shadow:0 8px 24px #0000002e;z-index:12}.prefs-panel h3{margin:0 0 10px;font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--reader-text-dim)}.prefs-row{display:grid;grid-template-columns:78px 1fr;align-items:center;gap:10px;margin-bottom:10px}.prefs-row--block{grid-template-columns:1fr}.prefs-row--block>label{margin-bottom:6px}.prefs-row>label{font-size:12px;color:var(--reader-text-dim)}.prefs-group{display:flex;flex-wrap:wrap;gap:4px}.prefs-group button{flex:1;min-width:36px;height:32px;padding:0 8px;border:1px solid var(--reader-border);border-radius:6px;background:var(--reader-bg);color:var(--reader-text);cursor:pointer;font:inherit;font-size:13px;line-height:1}.prefs-group button:hover{border-color:var(--reader-text-dim)}.prefs-group button.is-active{background:var(--reader-text);color:var(--reader-bg);border-color:var(--reader-text)}.prefs-swatches{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}.theme-swatch{aspect-ratio:1;height:auto;padding:0;border-radius:50%;border:2px solid transparent;cursor:pointer;position:relative;transition:border-color .15s,transform .1s}.theme-swatch:hover{transform:scale(1.08)}.theme-swatch.is-active{border-color:var(--reader-text)}.theme-swatch:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:1px solid var(--reader-border)}.theme-swatch--light{background:linear-gradient(135deg,#f5efe6 50%,#1a1a2e 50%)}.theme-swatch--sepia{background:linear-gradient(135deg,#f4ecd8 50%,#3a2e1f 50%)}.theme-swatch--cream{background:linear-gradient(135deg,#fbf3e3 50%,#2c2616 50%)}.theme-swatch--mint{background:linear-gradient(135deg,#effaf3 50%,#1c3a2c 50%)}.theme-swatch--rose{background:linear-gradient(135deg,#fdf2f4 50%,#3a1c25 50%)}.theme-swatch--hc{background:linear-gradient(135deg,#fff 50%,#000 50%)}.theme-swatch--nord-light{background:linear-gradient(135deg,#eceff4 50%,#2e3440 50%)}.theme-swatch--dark{background:linear-gradient(135deg,#16161d 50%,#e6e1d3 50%)}.theme-swatch--solarized{background:linear-gradient(135deg,#002b36 50%,#fdf6e3 50%)}.theme-swatch--nord{background:linear-gradient(135deg,#2e3440 50%,#eceff4 50%)}.theme-swatch--gruvbox{background:linear-gradient(135deg,#282828 50%,#ebdbb2 50%)}.theme-swatch--dracula{background:linear-gradient(135deg,#282a36 50%,#f8f8f2 50%)}.app-theme-swatches{grid-template-columns:repeat(7,1fr)}.app-swatch--pocket{background:linear-gradient(135deg,#1a1a2e 50%,#d4af37 50%)}.app-swatch--midnight{background:linear-gradient(135deg,#050816 50%,#6ea8ff 50%)}.app-swatch--forest{background:linear-gradient(135deg,#11201a 50%,#f0b450 50%)}.app-swatch--coffee{background:linear-gradient(135deg,#1f1611 50%,#e0a96d 50%)}.app-swatch--mocha{background:linear-gradient(135deg,#1e1e2e 50%,#f5c2e7 50%)}.app-swatch--dracula{background:linear-gradient(135deg,#282a36 50%,#ff79c6 50%)}.app-swatch--nord{background:linear-gradient(135deg,#2e3440 50%,#88c0d0 50%)}.app-swatch--synthwave{background:linear-gradient(135deg,#1a0b2e 50%,#ff71ce 50%)}.app-swatch--monochrome{background:linear-gradient(135deg,#111 50%,#f0f0f0 50%)}.app-swatch--paper{background:linear-gradient(135deg,#faf6ee 50%,#b08442 50%)}.app-swatch--slate{background:linear-gradient(135deg,#eef2f7 50%,#2563eb 50%)}.app-swatch--mint{background:linear-gradient(135deg,#effaf3 50%,#2f7d59 50%)}.app-swatch--rose{background:linear-gradient(135deg,#fdf2f4 50%,#ad3d65 50%)}.app-swatch--solar{background:linear-gradient(135deg,#fff7e0 50%,#d97706 50%)}@media (max-width: 600px){.app-theme-swatches{grid-template-columns:repeat(5,1fr)}}.prefs-reset{width:100%;margin-top:4px;padding:8px;border:1px solid var(--reader-border);border-radius:6px;background:transparent;color:var(--reader-text-dim);cursor:pointer;font:inherit;font-size:12px}.prefs-reset:hover{color:var(--reader-text)}@media (max-width: 600px){.prefs-panel{right:8px;left:8px;width:auto;top:64px}.prefs-row{grid-template-columns:64px 1fr}}.notes-panel{position:fixed;right:16px;bottom:16px;width:min(360px,calc(100vw - 32px));max-height:70vh;overflow-y:auto;background:var(--reader-surface, #fff);color:var(--reader-text, #1a1a2e);border:1px solid var(--reader-border, #ddd);border-radius:8px;padding:16px;box-shadow:0 8px 24px #0003;z-index:10}.notes-panel h3{margin:0 0 8px;color:var(--reader-text, #1a1a2e);font-size:14px}.notes-panel textarea{width:100%;min-height:120px;padding:8px;border:1px solid var(--reader-border, #ddd);border-radius:6px;background:var(--reader-bg, #fff);color:var(--reader-text, #1a1a2e);font:inherit;resize:vertical}.notes-panel ul{list-style:none;padding:0;margin:12px 0 0}.highlight-row{padding:8px 0;border-bottom:1px solid var(--reader-border, #eee);font-size:13px;color:var(--reader-text, #1a1a2e)}.highlight-row blockquote{margin:0 0 4px;padding-left:8px;border-left:3px solid var(--reader-mark, #f4d03f)}.highlight-note{margin:4px 0;color:var(--reader-text-dim, #555);font-style:italic}.highlight-delete{background:transparent;border:none;color:#c53030;cursor:pointer;padding:0;font-size:12px}.save-page{display:grid;place-items:center;min-height:100vh}.save-container{text-align:center;padding:32px}.save-message{color:var(--app-text-dim);word-break:break-all}.save-source-tag{display:inline-block;margin-top:6px;padding:2px 8px;border-radius:10px;font-size:11px;line-height:1.4;background:#78dc8c24;color:#6acb84}.save-source-tag--warn{background:#e6b45024;color:#d5a949}.reader-pending{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:48px 20px;gap:12px;color:var(--reader-text-dim)}.reader-pending h3{margin:0;color:var(--reader-text)}.reader-pending p{margin:0;max-width:420px;line-height:1.5}.reader-pending-elapsed{font-variant-numeric:tabular-nums;font-size:13px;opacity:.75}.reader-pending-spinner{width:36px;height:36px;border-radius:50%;border:3px solid var(--reader-rule);border-top-color:var(--reader-link);animation:reader-spin .9s linear infinite}@keyframes reader-spin{to{transform:rotate(360deg)}}.settings-page{background:var(--app-bg);color:var(--app-text);min-height:100vh}.settings-page .app-header{display:grid;grid-template-columns:36px 1fr 36px;align-items:center}.settings-page .app-header .sh-title{text-align:center;font-size:18px}.settings-main{padding-bottom:64px}.settings-section{padding:20px 0;border-bottom:1px solid var(--app-border)}.settings-section h2{margin:0 0 12px;font-size:16px;text-transform:uppercase;letter-spacing:.08em;color:var(--app-text-dim)}.settings-hint{color:var(--app-text-dim);font-size:13px}.settings-hint a{color:var(--app-accent)}.settings-button{display:inline-block;padding:10px 16px;border-radius:6px;background:var(--app-accent);color:#1a0f2e;font-weight:600;border:none;cursor:pointer;text-decoration:none;font:inherit}.settings-button:hover{filter:brightness(1.05)}.settings-button--ghost{background:transparent;color:var(--app-text);border:1px solid var(--app-border)}.settings-button--ghost:hover{background:var(--app-surface)}.settings-button--danger{background:transparent;color:#f88;border:1px solid #884444}.settings-button--danger:hover{background:#ff888814}.settings-dl{display:grid;grid-template-columns:130px 1fr;row-gap:8px;column-gap:16px;margin:0 0 16px;font-size:14px}.settings-dl dt{color:var(--app-text-dim);font-size:13px}.settings-dl dd{margin:0;color:var(--app-text);word-break:break-word}.settings-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.stat{display:flex;flex-direction:column;align-items:center;padding:16px 8px;background:var(--app-surface);border-radius:8px;border:1px solid var(--app-border)}.stat-num{font-family:var(--sh-font-display, "Fraunces", serif);font-size:28px;font-weight:600;color:var(--app-accent);font-variation-settings:"opsz" 144,"SOFT" 50,"WONK" 1}.stat-label{font-size:11px;color:var(--app-text-dim);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}.settings-preview{border-radius:10px;overflow:hidden;margin:12px 0 20px;border:1px solid var(--app-border)}.settings-preview .reader-container{padding:24px 24px 8px}.settings-preview-container{max-width:none}.settings-preview .article-body{font-size:var(--reader-size)}.prefs-list{display:flex;flex-direction:column;gap:4px}.prefs-list .prefs-row{background:var(--app-surface);padding:10px 12px;border-radius:6px}@media (max-width: 600px){.settings-dl{grid-template-columns:1fr;row-gap:0}.settings-dl dt{margin-top:8px}.settings-stats{grid-template-columns:repeat(2,1fr)}}.bookmarklet-link{display:inline-block;padding:10px 18px;border-radius:6px;background:var(--app-accent);color:#1a0f2e;font-weight:600;text-decoration:none;cursor:grab}.settings-section pre{background:var(--app-surface);padding:12px;border-radius:6px;overflow-x:auto;font-size:12px}.settings-tag{display:inline-block;margin-left:8px;padding:1px 8px;border-radius:999px;background:var(--app-surface);border:1px solid var(--app-border);font-family:var(--sh-font-body, system-ui, sans-serif);font-size:11px;font-weight:500;color:var(--app-text-dim);vertical-align:middle}.settings-list{margin:8px 0 12px 18px;padding:0;font-size:13px;line-height:1.5}.settings-list li{margin-bottom:4px}.settings-list code,.settings-section code{background:var(--app-surface);padding:1px 6px;border-radius:4px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}.settings-list kbd,.settings-section kbd{display:inline-block;padding:1px 6px;border:1px solid var(--app-border);border-bottom-width:2px;border-radius:4px;background:var(--app-surface);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px}.settings-section details{margin-top:8px}.settings-section summary{cursor:pointer;color:var(--app-accent);font-size:13px;padding:4px 0}.custom-sites-list{display:flex;flex-direction:column;gap:8px;margin:12px 0 16px}.custom-sites-empty{margin:0;padding:12px;border:1px dashed var(--app-border);border-radius:8px;text-align:center}.custom-site{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;border:1px solid var(--app-border);border-radius:8px;background:var(--app-surface)}.custom-site.is-disabled{opacity:.55}.custom-site-head{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.custom-site-head strong{font-size:14px;color:var(--app-text)}.custom-site-summary{font-size:12px;color:var(--app-text-dim)}.custom-site-buttons{display:flex;gap:6px;flex-shrink:0}.custom-site-buttons .settings-button{padding:6px 10px;font-size:12px}.custom-site-add{margin-top:8px;border:1px solid var(--app-border);border-radius:8px;padding:8px 12px}.custom-site-add>summary{list-style:none;font-weight:500}.custom-site-add>summary::-webkit-details-marker{display:none}.custom-site-add[open]>summary{color:var(--app-text-dim)}.custom-site-form{display:flex;flex-direction:column;gap:12px;margin-top:12px}.custom-site-field{display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--app-text-dim)}.custom-site-field--check{flex-direction:row;align-items:center;gap:8px}.custom-site-field input[type=text],.custom-site-field select,.custom-site-field textarea{padding:8px 10px;border-radius:6px;border:1px solid var(--app-border);background:var(--app-bg);color:var(--app-text);font:inherit;font-size:13px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.custom-site-field textarea{resize:vertical;min-height:44px}.custom-site-actions{display:flex;gap:8px}.login-page{display:grid;place-items:center;min-height:100vh}.login-container{width:100%;max-width:360px;padding:32px;background:var(--app-surface);border-radius:var(--app-radius)}.login-title{text-align:center;margin:0 0 24px}.login-form{display:flex;flex-direction:column;gap:12px}.login-label{display:flex;flex-direction:column;gap:4px;font-size:14px;color:var(--app-text-dim)}.login-label input{padding:10px;border-radius:6px;border:1px solid var(--app-border);background:var(--app-bg);color:var(--app-text);font:inherit}.login-error{color:#ff6b6b;min-height:1em;margin:0;font-size:13px}.login-button{padding:12px;border:none;border-radius:6px;background:var(--app-accent);color:#1a0f2e;font-weight:600;cursor:pointer}.toggle-link{display:block;text-align:center;margin-top:12px;color:var(--app-text-dim);cursor:pointer;font-size:13px}.google-signin-container{display:flex;justify-content:center;margin-bottom:8px;min-height:40px}.google-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:10px 16px;background:#fff;color:#333;border:none;border-radius:999px;font-family:var(--sh-font-heading);font-size:.95rem;font-weight:500;cursor:pointer;margin-bottom:8px}.google-btn:hover{background:#f5f5f5}.divider{display:flex;align-items:center;gap:12px;color:var(--app-text-dim);font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;margin:16px 0}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--app-border)}@media (max-width: 600px){.reader-container{padding:20px 16px 96px}.article-body{font-size:17px}}
