*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--ink:#1a1612;--ink-soft:#4a4540;--ink-faint:#9a9590;--paper:#faf8f5;--paper-warm:#f2ede6;--paper-rule:#e8e2d9;--accent:#8b3a2a;--accent-light:#c4614e;--accent-pale:#f5ede9;--success:#2d6a4f;--success-pale:#e8f5ef;--font-display:"DM Serif Display", Georgia, serif;--font-body:"EB Garamond", Georgia, serif;--font-ui:"DM Sans", system-ui, sans-serif;--radius:4px;--shadow:0 1px 3px #1a161214, 0 4px 16px #1a16120f;--shadow-lg:0 4px 8px #1a16121a, 0 12px 40px #1a16121a;--transition:.2s ease}html{font-size:16px}body{font-family:var(--font-ui);background:var(--paper);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.6}h1,h2,h3{font-family:var(--font-display);font-weight:400;line-height:1.2}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.layout{min-height:100vh;display:flex}.sidebar{background:var(--ink);width:240px;color:var(--paper);flex-direction:column;flex-shrink:0;padding:0;display:flex}.sidebar-brand{border-bottom:1px solid #ffffff14;padding:28px 24px 24px}.sidebar-brand h1{font-family:var(--font-display);color:var(--paper);letter-spacing:.02em;font-size:1.5rem}.sidebar-brand p{opacity:.4;letter-spacing:.12em;text-transform:uppercase;margin-top:2px;font-size:.7rem}.sidebar-nav{flex:1;padding:16px 0}.nav-item{color:#faf8f5a6;cursor:pointer;transition:all var(--transition);text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:10px 24px;font-size:.875rem;text-decoration:none;display:flex}.nav-item:hover{color:var(--paper);background:#ffffff0d;text-decoration:none}.nav-item.active{color:var(--paper);background:#ffffff1a}.nav-item svg{opacity:.6;flex-shrink:0}.nav-item.active svg{opacity:1}.sidebar-footer{opacity:.5;border-top:1px solid #ffffff14;padding:16px 24px;font-size:.8rem}.main{flex-direction:column;flex:1;display:flex;overflow-y:auto}.page-header{border-bottom:1px solid var(--paper-rule);background:var(--paper);padding:32px 40px 24px}.page-header h2{color:var(--ink);font-size:2rem}.page-header p{color:var(--ink-soft);margin-top:4px;font-size:.9rem}.page-content{flex:1;padding:32px 40px}.auth-page{background:var(--ink);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{background:var(--paper);width:100%;max-width:440px;box-shadow:var(--shadow-lg);border-radius:8px;padding:48px}.auth-logo{text-align:center;margin-bottom:32px}.auth-logo h1{font-family:var(--font-display);color:var(--ink);font-size:2.2rem}.auth-logo p{letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);margin-top:4px;font-size:.8rem}.auth-divider{text-align:center;color:var(--ink-faint);margin:20px 0;font-size:.8rem;position:relative}.auth-divider:before,.auth-divider:after{content:"";background:var(--paper-rule);width:40%;height:1px;position:absolute;top:50%}.auth-divider:before{left:0}.auth-divider:after{right:0}.form-group{margin-bottom:16px}.form-group label{letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:6px;font-size:.8rem;font-weight:500;display:block}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--paper-rule);border-radius:var(--radius);width:100%;font-family:var(--font-ui);color:var(--ink);transition:border-color var(--transition);background:#fff;outline:none;padding:10px 14px;font-size:.95rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-pale)}.form-group textarea{resize:vertical;line-height:1.6;font-family:var(--font-body);font-size:1rem}.btn{border-radius:var(--radius);font-family:var(--font-ui);cursor:pointer;transition:all var(--transition);border:none;align-items:center;gap:8px;padding:10px 20px;font-size:.875rem;font-weight:500;text-decoration:none;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-light);color:#fff;text-decoration:none}.btn-secondary{color:var(--ink);border:1px solid var(--paper-rule);background:#fff}.btn-secondary:hover{background:var(--paper-warm);border-color:var(--ink-faint)}.btn-ghost{color:var(--ink-soft);background:0 0}.btn-ghost:hover{background:var(--paper-warm);color:var(--ink)}.btn-danger{color:#c0392b;background:0 0;border:1px solid #e8b4ae}.btn-danger:hover{background:#fdf0ee}.btn-lg{padding:13px 28px;font-size:1rem}.btn-sm{padding:6px 14px;font-size:.8rem}.btn-full{justify-content:center;width:100%}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-google{color:var(--ink);border:1px solid var(--paper-rule);background:#fff;justify-content:center;width:100%;padding:11px 20px;font-size:.9rem}.btn-google:hover{background:var(--paper-warm)}.card{border:1px solid var(--paper-rule);transition:box-shadow var(--transition);background:#fff;border-radius:6px;padding:24px}.card:hover{box-shadow:var(--shadow)}.book-grid{grid-template-columns:repeat(auto-fill,minmax(440px,1fr));gap:20px;display:grid}.book-card{border:1px solid var(--paper-rule);cursor:pointer;transition:all var(--transition);background:#fff;border-radius:6px;flex-direction:column;gap:8px;padding:24px;display:flex}.book-card:hover{box-shadow:var(--shadow);border-color:var(--ink-faint);transform:translateY(-1px)}.book-card-title{font-family:var(--font-display);color:var(--ink);font-size:1.2rem;line-height:1.3}.book-card-author{font-family:var(--font-body);color:var(--ink-soft);font-size:.95rem;font-style:italic}.book-card-meta{color:var(--ink-faint);margin-top:8px;font-size:.75rem}.book-card-actions{border-top:1px solid var(--paper-rule);align-items:center;gap:8px;margin-top:12px;padding-top:12px;display:flex}.editor-layout{flex:1;min-height:0;display:flex}.editor-main{flex-direction:column;flex:1;min-height:0;display:flex}.editor-toolbar{border-bottom:1px solid var(--paper-rule);background:#fff;flex-shrink:0;align-items:center;gap:12px;padding:12px 24px;display:flex}.editor-toolbar-title{font-family:var(--font-display);color:var(--ink);flex:1;font-size:1.1rem}.editor-textarea{resize:none;width:100%;color:var(--ink);background:var(--paper);border:none;outline:none;flex:1;padding:48px 60px;font-family:EB Garamond,Georgia,serif;font-size:1.1rem;line-height:1.8;overflow-y:auto}.settings-panel{border-left:1px solid var(--paper-rule);background:#fff;flex-shrink:0;width:280px;padding:24px;overflow-y:auto}.settings-panel h3{font-family:var(--font-display);border-bottom:1px solid var(--paper-rule);margin-bottom:20px;padding-bottom:12px;font-size:1.1rem}.settings-section{margin-bottom:24px}.settings-section-label{letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:10px;font-size:.7rem;font-weight:500}.toggle-row{color:var(--ink-soft);justify-content:space-between;align-items:center;margin-bottom:10px;font-size:.875rem;display:flex}.toggle{width:36px;height:20px;position:relative}.toggle input{opacity:0;width:0;height:0}.toggle-track{background:var(--paper-rule);cursor:pointer;transition:background var(--transition);border-radius:20px;position:absolute;inset:0}.toggle input:checked+.toggle-track{background:var(--accent)}.toggle-track:after{content:"";width:14px;height:14px;transition:transform var(--transition);background:#fff;border-radius:50%;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0003}.toggle input:checked+.toggle-track:after{transform:translate(16px)}.alert{border-radius:var(--radius);margin-bottom:16px;padding:12px 16px;font-size:.875rem}.alert-error{color:#c0392b;background:#fdf0ee;border:1px solid #e8b4ae}.alert-success{background:var(--success-pale);color:var(--success);border:1px solid #a8d5bb}.alert-info{color:#2471a3;background:#eef4fb;border:1px solid #aecde8}.empty-state{text-align:center;color:var(--ink-faint);padding:80px 40px}.empty-state h3{font-family:var(--font-display);color:var(--ink-soft);margin-bottom:12px;font-size:1.8rem}.empty-state p{margin-bottom:24px;font-size:.95rem}.word-count{color:var(--ink-faint);border-top:1px solid var(--paper-rule);background:#fff;flex-shrink:0;padding:6px 24px;font-size:.75rem}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}.spinner-dark{border-color:#1a161226;border-top-color:var(--accent)}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=768px){.sidebar{display:none}.page-content{padding:20px}.editor-textarea{padding:24px}.settings-panel{display:none}}
