@import "https://fonts.googleapis.com/css2?family=EB+Garamond:ital,wght@0,400;0,500;1,400&family=Inter:wght@400;500&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg-primary:#0d0d0f;--bg-secondary:#141418;--bg-tertiary:#1a1a22;--bg-hover:#212130;--text-primary:#e8e0d0;--text-secondary:#a89f8f;--text-muted:#6b6358;--accent:#a78bfa;--accent-warm:#f59e0b;--accent-dim:#7c3aed;--border:#a89f8f1a;--border-hover:#a78bfa4d;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--font-serif:"EB Garamond", Georgia, serif;--font-sans:"Inter", system-ui, sans-serif}body{background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);min-height:100vh}.auth-container{flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.auth-container h1{font-family:var(--font-serif);color:var(--accent);letter-spacing:.05em;margin-bottom:.5rem;font-size:3rem;font-weight:400}.auth-subtitle{color:var(--text-secondary);font-size:1rem;font-style:italic;font-family:var(--font-serif);margin-bottom:2rem}.auth-form{flex-direction:column;gap:1rem;width:100%;max-width:380px;display:flex}.auth-form input{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);outline:none;padding:.75rem 1rem;font-size:1rem;transition:border-color .2s}.auth-form input:focus{border-color:var(--border-hover)}.auth-form input::placeholder{color:var(--text-muted)}.auth-form button{background:var(--accent);border-radius:var(--radius-md);color:#0d0d0f;cursor:pointer;font-family:var(--font-sans);border:none;padding:.75rem;font-size:.95rem;font-weight:500;transition:opacity .2s}.auth-form button:hover{opacity:.9}.auth-error{color:#f87171;text-align:center;font-size:.875rem}.auth-link{color:var(--text-secondary);text-align:center;font-size:.875rem}.auth-link a{color:var(--accent);text-decoration:none}.auth-link a:hover{text-decoration:underline}.page{flex-direction:column;min-height:100vh;display:flex}.navbar{padding:1rem 2rem;padding-top:max(1.5rem, calc(env(safe-area-inset-top) + .75rem));padding-left:max(1.25rem, env(safe-area-inset-left));padding-right:max(1.25rem, env(safe-area-inset-right));border-bottom:1px solid var(--border);background:var(--bg-secondary);justify-content:space-between;align-items:center;display:flex}.navbar-brand{font-family:var(--font-serif);color:var(--accent);letter-spacing:.05em;font-size:1.5rem;text-decoration:none}.navbar-right{align-items:center;gap:1rem;display:flex}.navbar-user{color:var(--text-secondary);font-size:.875rem}.navbar-logout{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;background:0 0;padding:.375rem .75rem;font-size:.875rem;transition:border-color .2s,color .2s}.navbar-logout:hover{border-color:var(--border-hover);color:var(--text-primary)}.dashboard{width:100%;max-width:1100px;margin:0 auto;padding:2rem}@media (width<=768px){.dashboard{padding:1.25rem}.dashboard-header{flex-direction:column;align-items:flex-start;gap:.75rem}.dashboard-title{font-size:1.5rem}}.dashboard-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem;display:flex}.dashboard-title{font-family:var(--font-serif);color:var(--text-primary);font-size:2rem;font-weight:400}.btn-primary{background:var(--accent);border-radius:var(--radius-md);color:#0d0d0f;cursor:pointer;font-family:var(--font-sans);border:none;padding:.5rem 1.25rem;font-size:.875rem;font-weight:500;transition:opacity .2s}.btn-primary:hover{opacity:.9}.btn-secondary{border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-family:var(--font-sans);background:0 0;padding:.5rem 1.25rem;font-size:.875rem;transition:border-color .2s}.btn-secondary:hover{border-color:var(--border-hover)}.btn-back{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:0;font-size:.875rem;transition:color .2s}.btn-back:hover{color:var(--text-primary)}.chapter-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));align-items:start;gap:1.25rem;display:grid}.chapter-card{background:var(--bg-secondary);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius-lg);cursor:pointer;padding:1.25rem;transition:border-color .2s,background .2s}.chapter-card:hover{background:var(--bg-hover);border-color:var(--border-hover)}.chapter-card-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.chapter-icon{font-size:1.5rem}.chapter-type-badge{background:var(--bg-tertiary);border-radius:var(--radius-sm);color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;padding:.2rem .5rem;font-size:.7rem}.chapter-name{font-family:var(--font-serif);color:var(--text-primary);font-size:1.2rem;font-weight:400}.chapter-view{width:100%;max-width:800px;margin:0 auto;padding:2rem}.chapter-view-header{margin-bottom:2rem}.chapter-view-title{align-items:center;gap:.75rem;margin-top:1rem;display:flex}.chapter-view-title h2{font-family:var(--font-serif);font-size:2rem;font-weight:400}.entry-list{flex-direction:column;gap:1rem;display:flex}.entry-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:1rem 1.25rem;transition:border-color .2s}.entry-card:hover{border-color:var(--border-hover)}.entry-title{font-family:var(--font-serif);color:var(--text-primary);margin-bottom:.5rem;font-size:1.1rem;font-weight:400}.entry-tags{flex-wrap:wrap;gap:.5rem;display:flex}.tag{background:var(--bg-tertiary);border-radius:var(--radius-sm);color:var(--text-secondary);padding:.2rem .6rem;font-size:.75rem}.modal-overlay{z-index:100;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:420px;padding:2rem}.modal-title{font-family:var(--font-serif);margin-bottom:1.5rem;font-size:1.5rem;font-weight:400}.modal-form{flex-direction:column;gap:1rem;display:flex}.modal-form input,.modal-form select{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);outline:none;padding:.75rem 1rem;font-size:1rem;transition:border-color .2s}.modal-form input:focus,.modal-form select:focus{border-color:var(--border-hover)}.modal-form select option{background:var(--bg-tertiary)}.modal-actions{justify-content:flex-end;gap:.75rem;margin-top:.5rem;display:flex}.color-picker{gap:.5rem;display:flex}.color-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;width:28px;height:28px;transition:transform .2s}.color-swatch:hover{transform:scale(1.1)}.color-swatch.selected{border-color:var(--text-primary);transform:scale(1.15)}.empty-state{text-align:center;color:var(--text-muted);font-family:var(--font-serif);padding:4rem 2rem;font-size:1.1rem;line-height:2}.loading-text{text-align:center;color:var(--text-muted);font-family:var(--font-serif);padding:4rem;font-style:italic}.entry-form-container{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:1.5rem;padding:1.5rem}.entry-form-title{font-family:var(--font-serif);color:var(--text-primary);margin-bottom:1.25rem;font-size:1.25rem;font-weight:400}.entry-form{flex-direction:column;gap:.875rem;display:flex}.entry-input{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);outline:none;width:100%;padding:.75rem 1rem;font-size:1rem;transition:border-color .2s}.entry-input:focus{border-color:var(--border-hover)}.entry-input::placeholder{color:var(--text-muted)}.entry-select{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);cursor:pointer;outline:none;width:100%;padding:.75rem 1rem;font-size:1rem;transition:border-color .2s}.entry-select:focus{border-color:var(--border-hover)}.entry-select option{background:var(--bg-tertiary)}.entry-textarea{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-serif);resize:vertical;outline:none;width:100%;padding:.75rem 1rem;font-size:1rem;line-height:1.7;transition:border-color .2s}.entry-textarea:focus{border-color:var(--border-hover)}.entry-textarea::placeholder{color:var(--text-muted)}.entry-form-actions{justify-content:flex-end;gap:.75rem;margin-top:.5rem;display:flex}.entry-card-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.5rem;display:flex}.entry-meta{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.entry-status-badge{text-transform:capitalize;font-size:.75rem;font-weight:500}.entry-priority-badge{background:var(--bg-tertiary);border-radius:var(--radius-sm);color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;padding:.2rem .5rem;font-size:.7rem}.entry-mood{color:var(--text-secondary);text-transform:capitalize;font-size:.8rem}.entry-rating{color:var(--accent-warm);letter-spacing:.05em;font-size:.875rem}.entry-body{color:var(--text-secondary);font-family:var(--font-serif);white-space:pre-wrap;margin-bottom:.75rem;font-size:1rem;line-height:1.7}.entry-notes{color:var(--text-muted);margin-bottom:.75rem;font-size:.875rem;line-height:1.6}.entry-due{color:var(--text-muted);margin-top:.5rem;font-size:.8rem}.btn-delete{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;padding:.25rem;font-size:.75rem;line-height:1;transition:color .2s}.btn-delete:hover{color:#f87171}.chapter-card-actions{align-items:center;gap:.5rem;display:flex}.emoji-label{color:var(--text-muted);margin-bottom:-.25rem;font-size:.8rem}.emoji-picker{flex-wrap:wrap;gap:.375rem;display:flex}.emoji-option{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;padding:.375rem;font-size:1.25rem;line-height:1;transition:border-color .2s,background .2s}.emoji-option:hover{background:var(--bg-hover);border-color:var(--border-hover)}.emoji-option.selected{border-color:var(--accent);background:var(--bg-hover)}.entry-links{flex-direction:column;gap:.25rem;margin-top:.5rem;display:flex}.entry-link{color:var(--accent);text-overflow:ellipsis;white-space:nowrap;font-size:.8rem;text-decoration:none;overflow:hidden}.entry-link:hover{text-decoration:underline}.btn-edit{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;padding:.25rem;font-size:.875rem;line-height:1;transition:color .2s}.btn-edit:hover{color:var(--accent)}.chapter-edit-form{flex-direction:column;gap:.75rem;display:flex}.landing{flex-direction:column;justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.landing-glow{pointer-events:none;background:radial-gradient(#a78bfa0f 0%,#0000 70%);width:600px;height:400px;position:absolute;top:20%;left:50%;transform:translate(-50%)}.landing-content{text-align:center;z-index:1;flex-direction:column;align-items:center;max-width:580px;padding:2rem;display:flex}.landing-ornament{color:var(--accent);letter-spacing:.5em;opacity:.6;margin-bottom:2rem;font-size:.6rem}.landing-title{font-family:var(--font-serif);color:var(--text-primary);letter-spacing:.08em;margin-bottom:1rem;font-size:clamp(4rem,12vw,7rem);font-weight:400;line-height:1}.landing-tagline{font-family:var(--font-serif);color:var(--accent-warm);letter-spacing:.05em;margin-bottom:2rem;font-size:1.25rem;font-style:italic}.landing-divider{align-items:center;gap:1rem;width:100%;max-width:300px;margin-bottom:2rem;display:flex}.landing-divider-line{background:var(--border);flex:1;height:1px}.landing-divider-icon{color:var(--accent);opacity:.6;font-size:.5rem}.landing-description{font-family:var(--font-serif);color:var(--text-secondary);margin-bottom:2.5rem;font-size:1.1rem;line-height:1.9}.landing-actions{flex-direction:column;gap:.875rem;width:100%;max-width:280px;margin-bottom:3rem;display:flex}.landing-btn-primary{background:var(--accent);border-radius:var(--radius-md);color:#0d0d0f;cursor:pointer;font-family:var(--font-serif);letter-spacing:.03em;border:none;padding:.875rem 1.5rem;font-size:1.1rem;font-weight:400;transition:opacity .2s}.landing-btn-primary:hover{opacity:.9}.landing-btn-secondary{border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-family:var(--font-serif);background:0 0;padding:.75rem 1.5rem;font-size:1rem;font-style:italic;transition:border-color .2s,color .2s}.landing-btn-secondary:hover{border-color:var(--border-hover);color:var(--text-primary)}.landing-types{color:var(--text-muted);letter-spacing:.12em;text-transform:uppercase;align-items:center;gap:.75rem;font-size:.75rem;display:flex}.landing-footer{color:var(--text-muted);font-family:var(--font-serif);letter-spacing:.05em;font-size:.8rem;font-style:italic;position:absolute;bottom:2rem}.spinner{border:2px solid #0d0d0f4d;border-top-color:#0d0d0f;border-radius:50%;width:16px;height:16px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.auth-form button:disabled{opacity:.7;cursor:not-allowed}.sort-controls{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:1.25rem;display:flex}.sort-label{color:var(--text-muted);margin-right:.25rem;font-size:.8rem}.sort-btn{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-family:var(--font-sans);background:0 0;padding:.3rem .75rem;font-size:.75rem;transition:border-color .2s,color .2s}.sort-btn:hover{border-color:var(--border-hover);color:var(--text-primary)}.sort-btn.active{border-color:var(--accent);color:var(--accent)}.tag-search{max-width:400px;margin-bottom:2rem;position:relative}.tag-search-input-wrapper{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);align-items:center;padding:0 1rem;transition:border-color .2s;display:flex}.tag-search-input-wrapper:focus-within{border-color:var(--border-hover)}.tag-search-icon{color:var(--accent);margin-right:.5rem;font-size:1rem;font-weight:500}.tag-search-input{color:var(--text-primary);font-family:var(--font-sans);background:0 0;border:none;outline:none;width:100%;padding:.75rem 0;font-size:.9rem}.tag-search-input::placeholder{color:var(--text-muted)}.tag-search-spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.7s linear infinite spin;display:inline-block}.tag-search-results{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);z-index:50;max-height:360px;position:absolute;top:calc(100% + .5rem);left:0;right:0;overflow-y:auto}.tag-search-empty{color:var(--text-muted);font-family:var(--font-serif);text-align:center;padding:1rem;font-size:.9rem;font-style:italic}.tag-search-result{border-bottom:1px solid var(--border);cursor:pointer;padding:.875rem 1rem;transition:background .15s}.tag-search-result:last-child{border-bottom:none}.tag-search-result:hover{background:var(--bg-hover)}.tag-search-result-header{align-items:center;gap:.4rem;margin-bottom:.25rem;display:flex}.tag-search-chapter-icon{font-size:.875rem}.tag-search-chapter-name{text-transform:uppercase;letter-spacing:.06em;font-size:.75rem;font-weight:500}.tag-search-entry-title{color:var(--text-primary);font-family:var(--font-serif);margin-bottom:.375rem;font-size:1rem}.tag-search-tags{flex-wrap:wrap;gap:.375rem;display:flex}.tag-highlight{background:var(--accent-dim);color:var(--text-primary);border-color:var(--accent)}
