*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f8fafc;color:#1e293b;min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;gap:10px;padding:16px 32px;background:#fff;border-bottom:1px solid #e2e8f0}.logo{font-size:18px;font-weight:700;color:#1e293b;letter-spacing:-.3px}.badge{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#6366f1;background:#eef2ff;padding:2px 8px;border-radius:99px}.app-main{flex:1;max-width:760px;width:100%;margin:0 auto;padding:48px 24px}.input-panel h1{font-size:28px;font-weight:700;margin-bottom:8px;letter-spacing:-.5px}.subtitle{color:#64748b;font-size:15px;margin-bottom:32px}.field{margin-bottom:20px}.field label{display:block;font-size:13px;font-weight:600;color:#374151;margin-bottom:6px}.optional{font-weight:400;color:#94a3b8}input[type=text],textarea{width:100%;padding:10px 14px;border:1.5px solid #e2e8f0;border-radius:8px;font-size:14px;font-family:inherit;color:#1e293b;background:#fff;transition:border-color .15s;outline:none}input[type=text]:focus,textarea:focus{border-color:#6366f1}textarea{resize:vertical;line-height:1.6}.char-count{font-size:12px;color:#94a3b8;text-align:right;margin-top:4px}.error-box{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;border-radius:8px;padding:10px 14px;font-size:13px;margin-bottom:16px}.btn-primary{background:#6366f1;color:#fff;border:none;border-radius:8px;padding:12px 28px;font-size:15px;font-weight:600;cursor:pointer;transition:background .15s}.btn-primary:hover:not(:disabled){background:#4f46e5}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-secondary{background:#fff;color:#374151;border:1.5px solid #e2e8f0;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:500;cursor:pointer;transition:border-color .15s}.btn-secondary:hover{border-color:#6366f1;color:#6366f1}.btn-ghost{background:transparent;color:#64748b;border:none;padding:8px 16px;font-size:13px;font-weight:500;cursor:pointer;border-radius:8px}.btn-ghost:hover{background:#f1f5f9;color:#1e293b}.loading-panel{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 0;gap:16px}.spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:16px;font-weight:500;color:#1e293b}.loading-sub{font-size:13px;color:#94a3b8}.result-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:24px}.result-header h2{font-size:22px;font-weight:700}.result-actions{display:flex;gap:8px;align-items:center}.mindmap-container{background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;padding:16px;overflow:hidden}#root{width:100%}
