*{box-sizing:border-box;margin:0;padding:0}body{color:#2c2c2c;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#faf7f2;font-family:DM Sans,system-ui,sans-serif}#root{min-height:100svh}.login-container{background:#faf7f2;justify-content:center;align-items:center;min-height:100vh;display:flex}.login-form{flex-direction:column;align-items:center;gap:1rem;width:100%;max-width:360px;padding:2rem;display:flex}.login-form h1{color:#8b1a1a;margin:0;font-family:Playfair Display,serif;font-size:2.5rem;font-weight:800}.login-subtitle{color:#6b6b6b;margin:0 0 1rem;font-family:DM Sans,sans-serif;font-size:.95rem}.login-form input{color:#2c2c2c;background:#fff;border:1px solid #d4d0cb;border-radius:8px;outline:none;width:100%;padding:.75rem 1rem;font-family:DM Sans,sans-serif;font-size:1rem;transition:border-color .2s}.login-form input:focus{border-color:#8b1a1a}.login-form button{color:#fff;cursor:pointer;background:#8b1a1a;border:none;border-radius:8px;width:100%;padding:.75rem;font-family:DM Sans,sans-serif;font-size:1rem;font-weight:500;transition:background .2s}.login-form button:hover:not(:disabled){background:#6e1515}.login-form button:disabled{opacity:.6;cursor:not-allowed}.login-error{color:#b91c1c;margin:0;font-family:DM Sans,sans-serif;font-size:.875rem}.add-form{background:#fff;border:1px solid #e8e4df;border-radius:12px;margin-bottom:1rem;padding:1rem 1.25rem}.add-fields{flex-direction:column;gap:.5rem;margin-bottom:.75rem;display:flex}.add-fields input{color:#2c2c2c;background:#faf7f2;border:1px solid #d4d0cb;border-radius:8px;outline:none;padding:.6rem .75rem;font-family:DM Sans,sans-serif;font-size:.9rem;transition:border-color .2s}.add-fields input:focus{border-color:#8b1a1a}.add-error{color:#b91c1c;margin:0 0 .5rem;font-family:DM Sans,sans-serif;font-size:.85rem}.add-actions{gap:.5rem;display:flex}.add-submit{color:#fff;cursor:pointer;background:#8b1a1a;border:none;border-radius:8px;padding:.5rem 1rem;font-family:DM Sans,sans-serif;font-size:.875rem;font-weight:500;transition:background .2s}.add-submit:hover:not(:disabled){background:#6e1515}.add-submit:disabled{opacity:.6;cursor:not-allowed}.add-cancel{color:#6b6b6b;cursor:pointer;background:0 0;border:1px solid #d4d0cb;border-radius:8px;padding:.5rem 1rem;font-family:DM Sans,sans-serif;font-size:.875rem;transition:border-color .2s}.add-cancel:hover{border-color:#8b1a1a}.install-hint{color:#2c2c2c;background:#fff;border:1px solid #e8e4df;border-radius:10px;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.75rem 1rem;font-family:DM Sans,sans-serif;font-size:.85rem;line-height:1.4;display:flex}.install-hint p{flex:1;margin:0}.install-icon{color:#8b1a1a;font-weight:600}.install-dismiss{color:#6b6b6b;cursor:pointer;background:0 0;border:1px solid #d4d0cb;border-radius:6px;flex-shrink:0;padding:.3rem .6rem;font-family:DM Sans,sans-serif;font-size:.8rem}.install-dismiss:hover{color:#8b1a1a;border-color:#8b1a1a}.article-list-page{background:#faf7f2;max-width:900px;min-height:100vh;margin:0 auto;padding:0 1rem 2rem}.list-header{justify-content:space-between;align-items:center;padding:1.5rem 0 1rem;display:flex}.list-header h1{color:#8b1a1a;margin:0;font-family:Playfair Display,serif;font-size:1.75rem;font-weight:800}.header-actions{align-items:center;gap:.5rem;display:flex}.icon-btn{color:#6b6b6b;cursor:pointer;background:0 0;border:1px solid #d4d0cb;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;font-family:DM Sans,sans-serif;font-size:.75rem;font-weight:600;transition:border-color .2s,color .2s;display:flex}.icon-btn:hover{color:#8b1a1a;border-color:#8b1a1a}.add-btn{color:#fff;cursor:pointer;background:#8b1a1a;border:none;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.25rem;font-weight:500;transition:background .2s;display:flex}.add-btn:hover{background:#6e1515}.logout-btn{color:#6b6b6b;cursor:pointer;background:0 0;border:1px solid #d4d0cb;border-radius:6px;padding:.4rem .75rem;font-family:DM Sans,sans-serif;font-size:.85rem;transition:border-color .2s,color .2s}.logout-btn:hover{color:#8b1a1a;border-color:#8b1a1a}.filter-bar{border-bottom:1px solid #e8e4df;gap:.5rem;margin-bottom:1.5rem;padding-bottom:.75rem;display:flex}.filter-btn{color:#6b6b6b;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.4rem .75rem;font-family:DM Sans,sans-serif;font-size:.9rem;transition:background .2s,color .2s}.filter-btn:hover{background:#f0ece6}.filter-btn.active{color:#fff;background:#8b1a1a}.list-status{text-align:center;color:#6b6b6b;padding:2rem 0;font-family:DM Sans,sans-serif}.list-error{color:#b91c1c}.empty-state{text-align:center;padding:4rem 1rem}.empty-state p{color:#6b6b6b;font-family:DM Sans,sans-serif;font-size:1.1rem}.empty-hint{margin-top:.5rem;font-size:.9rem!important}.article-grid{flex-direction:column;gap:1rem;display:flex}.article-card{cursor:pointer;background:#fff;border:1px solid #e8e4df;border-radius:12px;transition:box-shadow .2s,transform .15s;display:flex;overflow:hidden}.article-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.card-image{flex:0 0 180px;overflow:hidden}.card-image img{object-fit:cover;width:100%;height:100%;display:block}.card-body{flex-direction:column;flex:1;gap:.5rem;padding:1rem 1.25rem;display:flex}.card-title{color:#2c2c2c;margin:0;font-family:Playfair Display,serif;font-size:1.15rem;font-weight:700;line-height:1.3}.card-excerpt{color:#6b6b6b;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-family:DM Sans,sans-serif;font-size:.875rem;line-height:1.5;display:-webkit-box;overflow:hidden}.card-meta{color:#9b9b9b;gap:.75rem;margin-top:auto;font-family:DM Sans,sans-serif;font-size:.8rem;display:flex}.card-source{color:#8b1a1a;font-weight:500}@media (width<=600px){.article-card{flex-direction:column}.card-image{flex:none;height:160px}}.reader-page{background:#faf7f2;min-height:100vh;padding:0 1rem 3rem}.reader-nav{max-width:680px;margin:0 auto;padding:1.25rem 0}.back-btn{color:#8b1a1a;cursor:pointer;background:0 0;border:none;padding:.25rem 0;font-family:DM Sans,sans-serif;font-size:.9rem}.back-btn:hover{text-decoration:underline}.reader-status{text-align:center;color:#6b6b6b;padding:4rem 1rem;font-family:DM Sans,sans-serif}.reader-error{color:#b91c1c}.reader-content{max-width:680px;margin:0 auto}.reader-header{border-bottom:1px solid #e8e4df;margin-bottom:2rem;padding-bottom:1.5rem}.reader-header h1{color:#2c2c2c;margin:0 0 .75rem;font-family:Playfair Display,serif;font-size:2.25rem;font-weight:800;line-height:1.2}.reader-meta{color:#9b9b9b;flex-wrap:wrap;gap:.75rem;font-family:DM Sans,sans-serif;font-size:.85rem;display:flex}.reader-meta span:not(:last-child):after{content:"·";color:#d4d0cb;margin-left:.75rem}.reader-body{color:#2c2c2c;font-family:Lora,serif;font-size:1.125rem;line-height:1.7}.reader-body p{margin:0 0 1.25rem}.reader-body h1,.reader-body h2,.reader-body h3{color:#2c2c2c;margin:2rem 0 .75rem;font-family:Playfair Display,serif;line-height:1.3}.reader-body h2{font-size:1.5rem}.reader-body h3{font-size:1.25rem}.reader-body a{color:#8b1a1a;text-underline-offset:2px;-webkit-text-decoration:underline #8b1a1a4d;text-decoration:underline #8b1a1a4d}.reader-body a:hover{text-decoration-color:#8b1a1a}.reader-body img{border-radius:8px;max-width:100%;height:auto;margin:1rem 0}.reader-body blockquote{color:#555;border-left:3px solid #8b1a1a;margin:1.5rem 0;padding:.5rem 0 .5rem 1.25rem;font-style:italic}.reader-body pre,.reader-body code{font-family:ui-monospace,Cascadia Code,Source Code Pro,monospace;font-size:.9em}.reader-body pre{background:#f0ece6;border-radius:8px;margin:1.25rem 0;padding:1rem;overflow-x:auto}.reader-body ul,.reader-body ol{margin:0 0 1.25rem;padding-left:1.5rem}.reader-body li{margin-bottom:.4rem}.reader-actions{border-top:1px solid #e8e4df;flex-wrap:wrap;gap:.75rem;margin-top:3rem;padding-top:1.5rem;display:flex}.action-btn{color:#2c2c2c;cursor:pointer;background:#fff;border:1px solid #d4d0cb;border-radius:8px;padding:.5rem 1rem;font-family:DM Sans,sans-serif;font-size:.875rem;transition:border-color .2s,background .2s}.action-btn:hover{color:#8b1a1a;border-color:#8b1a1a}.action-btn.active{color:#8b1a1a;background:#f0ece6;border-color:#8b1a1a}.action-btn.danger:hover{color:#b91c1c;background:#fef2f2;border-color:#b91c1c}@media (width<=600px){.reader-header h1{font-size:1.75rem}.reader-body{font-size:1.05rem}}.bookmarklet-page{background:#faf7f2;max-width:640px;min-height:100vh;margin:0 auto;padding:2rem 1rem 3rem}.bookmarklet-page h1{color:#8b1a1a;margin:0 0 .5rem;font-family:Playfair Display,serif;font-size:2rem;font-weight:800}.bookmarklet-page h2{color:#2c2c2c;margin:0 0 .75rem;font-family:Playfair Display,serif;font-size:1.25rem;font-weight:700}.bm-intro{color:#6b6b6b;margin:0 0 2rem;font-family:DM Sans,sans-serif;line-height:1.6}.bm-drag-area{text-align:center;background:#fff;border:2px dashed #d4d0cb;border-radius:12px;margin-bottom:1.5rem;padding:2rem}.bm-button{color:#fff;cursor:grab;-webkit-user-select:none;user-select:none;background:#8b1a1a;border-radius:8px;padding:.75rem 1.5rem;font-family:DM Sans,sans-serif;font-size:1rem;font-weight:600;text-decoration:none;display:inline-block}.bm-button:active{cursor:grabbing}.bm-hint{color:#9b9b9b;margin:.75rem 0 0;font-family:DM Sans,sans-serif;font-size:.8rem}.bm-details{margin-bottom:2rem;font-family:DM Sans,sans-serif}.bm-details summary{color:#8b1a1a;cursor:pointer;margin-bottom:.5rem;font-size:.9rem}.bm-code{color:#2c2c2c;resize:vertical;background:#f0ece6;border:1px solid #d4d0cb;border-radius:8px;width:100%;min-height:100px;padding:.75rem;font-family:ui-monospace,monospace;font-size:.75rem}.bm-section{margin-bottom:2rem}.bm-section ol{color:#2c2c2c;padding-left:1.25rem;font-family:DM Sans,sans-serif;line-height:1.8}.bm-token{word-break:break-all;cursor:pointer;background:#f0ece6;border:1px solid #d4d0cb;border-radius:8px;padding:.75rem;font-family:ui-monospace,monospace;font-size:.7rem;transition:border-color .2s;display:block}.bm-token:hover{border-color:#8b1a1a}.bm-note{color:#6b6b6b;margin:0 0 .5rem;font-family:DM Sans,sans-serif;font-size:.85rem}.shortcut-page{background:#faf7f2;max-width:640px;min-height:100vh;margin:0 auto;padding:2rem 1rem 3rem}.shortcut-page h1{color:#8b1a1a;margin:0 0 .5rem;font-family:Playfair Display,serif;font-size:2rem;font-weight:800}.shortcut-page h2{color:#2c2c2c;margin:0 0 .75rem;font-family:Playfair Display,serif;font-size:1.25rem;font-weight:700}.shortcut-page h3{color:#2c2c2c;margin:0 0 .25rem;font-family:DM Sans,sans-serif;font-size:1rem;font-weight:600}.sc-intro{color:#6b6b6b;margin:0 0 2rem;font-family:DM Sans,sans-serif;line-height:1.6}.sc-section{margin-bottom:2rem}.sc-values{flex-direction:column;gap:.75rem;display:flex}.sc-value-row{flex-direction:column;gap:.25rem;display:flex}.sc-value-row label{color:#6b6b6b;text-transform:uppercase;letter-spacing:.05em;font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:500}.sc-value-row code{word-break:break-all;cursor:pointer;background:#f0ece6;border:1px solid #d4d0cb;border-radius:8px;padding:.6rem .75rem;font-family:ui-monospace,monospace;font-size:.75rem;transition:border-color .2s;display:block}.sc-value-row code:hover{border-color:#8b1a1a}.sc-hint{color:#9b9b9b;margin:.5rem 0 0;font-family:DM Sans,sans-serif;font-size:.8rem}.sc-steps{color:#2c2c2c;padding-left:1.25rem;font-family:DM Sans,sans-serif;line-height:1.8}.sc-steps li{margin-bottom:1rem}.sc-steps code{background:#f0ece6;border-radius:4px;padding:.15rem .4rem;font-size:.8rem}.sc-steps ul{margin:.25rem 0;padding-left:1.25rem}.sc-usage{flex-direction:column;gap:1rem;display:flex}.sc-usage-item{background:#fff;border:1px solid #e8e4df;border-radius:8px;padding:1rem}.sc-usage-item p{color:#6b6b6b;margin:0;font-family:DM Sans,sans-serif;font-size:.9rem}.sc-note{color:#6b6b6b;background:#fff;border:1px solid #e8e4df;border-radius:8px;padding:1rem;font-family:DM Sans,sans-serif;font-size:.9rem;line-height:1.6}
