*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#1a1a1a;background:#f0f2f5;flex-direction:column;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex}.nav-header{z-index:100;background:#2c3e50;border-bottom:3px solid #4a6b8a;position:sticky;top:0}.nav-inner{justify-content:center;align-items:center;gap:14px;max-width:960px;margin:0 auto;padding:12px 20px;display:flex}.nav-logo{width:auto;height:40px}.nav-title{color:#fff;letter-spacing:.3px;font-size:20px;font-weight:700}.page-content{flex:1}.app-footer{text-align:center;background:#2c3e50;border-top:3px solid #4a6b8a;padding:16px 20px}.app-footer p{color:#a0aec0;font-size:13px}.app-footer a{color:#68d391;font-weight:600;text-decoration:none}.app-footer a:hover{color:#9ae6b4;text-decoration:underline}.login-overlay{z-index:9999;background:#2c3e50;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.login-card{text-align:center;background:#fff;border-radius:12px;width:100%;max-width:380px;padding:40px 36px;box-shadow:0 8px 30px #0000004d}.login-logo{height:60px;margin-bottom:16px}.login-card h2{color:#2c3e50;margin-bottom:4px;font-size:22px;font-weight:700}.login-subtitle{color:#888;margin-bottom:24px;font-size:14px}.login-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;margin-bottom:16px;padding:8px 12px;font-size:13px}.login-input{color:#1a1a1a;border:1px solid #d0d5dd;border-radius:6px;width:100%;margin-bottom:12px;padding:11px 14px;font-family:inherit;font-size:14px;display:block}.login-input:focus{border-color:#4a6b8a;outline:none;box-shadow:0 0 0 3px #4a6b8a1f}.login-btn{color:#fff;cursor:pointer;background:#2c3e50;border:none;border-radius:6px;justify-content:center;align-items:center;width:100%;margin-top:4px;padding:12px;font-size:15px;font-weight:600;transition:background .2s;display:inline-flex}.login-btn:hover{background:#1a2a3a}.login-btn:disabled{cursor:not-allowed;background:#5a7a8a}.container{max-width:900px;margin:0 auto;padding:28px 20px}.section{margin-bottom:28px}.section-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.section-header h2{color:#2c3e50;font-size:17px;font-weight:600}.section-footer{justify-content:center;margin-top:16px;display:flex}.section-footer .generate-btn{padding:14px 48px;font-size:16px}.input-area{color:#1a1a1a;resize:vertical;background:#fff;border:1px solid #d0d5dd;border-radius:8px;width:100%;min-height:180px;padding:16px 20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.6;box-shadow:0 1px 3px #00000014}.input-area:focus{border-color:#4a6b8a;outline:none;box-shadow:0 0 0 3px #4a6b8a1f}.input-area::placeholder{color:#999}.spinner{vertical-align:middle;border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;margin-right:8px;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.ai-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#2d6a4f;border:none;border-radius:6px;align-items:center;padding:9px 20px;font-size:14px;font-weight:600;transition:background .2s;display:inline-flex}.ai-btn:hover{background:#1b4332}.ai-btn:disabled{cursor:not-allowed;background:#6a9f7e}.generate-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#4a6b8a;border:none;border-radius:6px;align-items:center;padding:9px 20px;font-size:14px;font-weight:600;transition:background .2s;display:inline-flex}.generate-btn:hover{background:#3a5a7a}.generate-btn:disabled{cursor:not-allowed;background:#7a9bb5}.editor-wrapper{background:#fff;border:1px solid #d0d5dd;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #00000014}.toolbar{background:#f8f9fa;border-bottom:1px solid #e0e0e0;flex-wrap:wrap;align-items:center;gap:4px;padding:8px 12px;display:flex}.toolbar-group{gap:2px;display:flex}.toolbar-separator{background:#d0d5dd;width:1px;height:24px;margin:0 6px}.toolbar-btn{cursor:pointer;color:#444;background:0 0;border:1px solid #0000;border-radius:4px;padding:5px 10px;font-size:14px;line-height:1.2;transition:all .15s}.toolbar-btn:hover{background:#e8ecf0;border-color:#ccd}.toolbar-btn.active{color:#1a3a5a;background:#d6e4f0;border-color:#a0b8d0}.toolbar-select{color:#444;cursor:pointer;background:#fff;border:1px solid #d0d5dd;border-radius:4px;padding:5px 8px;font-size:13px}.editor-content{min-height:350px;max-height:60vh;padding:20px 24px;overflow-y:auto}.editor-content .tiptap{color:#1a1a1a;outline:none;min-height:310px;font-size:15px;line-height:1.6}.editor-content .tiptap p{margin-bottom:8px}.editor-content .tiptap h1{margin-top:16px;margin-bottom:12px;font-size:24px;font-weight:700}.editor-content .tiptap h2{margin-top:14px;margin-bottom:10px;font-size:20px;font-weight:600}.editor-content .tiptap h3{margin-top:12px;margin-bottom:8px;font-size:17px;font-weight:600}.editor-content .tiptap ul,.editor-content .tiptap ol{margin-bottom:8px;padding-left:24px}.editor-content .tiptap li{margin-bottom:4px}.editor-content .tiptap u{text-decoration:underline}.editor-content .tiptap p.is-editor-empty:first-child:before{content:"AI-generated letter will appear here. You can also type directly...";color:#999;pointer-events:none;float:left;height:0}
