*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #f8f9fc;--bg-secondary: #ffffff;--bg-card: #ffffff;--bg-card-hover: #fff5f5;--bg-input: #f9fafb;--border-color: rgba(220, 38, 38, .15);--border-hover: rgba(220, 38, 38, .35);--text-primary: #1a1a2e;--text-secondary: #4a5568;--text-muted: #94a3b8;--accent-red: #dc2626;--accent-red-light: #f87171;--accent-rose: #f43f5e;--accent-rose-light: #fb7185;--accent-green: #16a34a;--accent-error: #b91c1c;--accent-orange: #ea580c;--gradient-primary: linear-gradient(135deg, #dc2626 0%, #f43f5e 100%);--gradient-bg: linear-gradient(180deg, #f8f9fc 0%, #ffffff 100%);--glass-bg: rgba(255, 255, 255, .85);--glass-border: rgba(220, 38, 38, .1);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .07);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .1);--shadow-glow: 0 0 20px rgba(220, 38, 38, .15);--font-family: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--radius-sm: 10px;--radius-md: 14px;--radius-lg: 18px;--radius-xl: 24px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1)}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;overflow-x:hidden}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:#dc262633;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--accent-red)}.header{position:sticky;top:0;z-index:100;background:#ffffffe6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border);padding:.75rem 2rem;box-shadow:0 1px 4px #0000000a}.header-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.logo{display:flex;align-items:center;gap:.75rem}.logo-icon{display:flex;filter:drop-shadow(0 2px 6px rgba(220,38,38,.25))}.logo-text h1{font-size:1.25rem;font-weight:800;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.2}.logo-subtitle{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;font-weight:500}.header-status{display:flex;align-items:center;gap:.5rem;padding:.4rem 1rem;background:#16a34a14;border:1px solid rgba(22,163,74,.25);border-radius:20px;font-size:.8rem;color:var(--accent-green)}.header-status.processing{background:#dc26260f;border-color:#dc262640;color:var(--accent-red)}.header-status.processing .status-dot{background:var(--accent-red);animation:pulse-dot 1.5s infinite}.status-dot{width:8px;height:8px;background:var(--accent-green);border-radius:50%;animation:pulse-dot 2s infinite}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.steps-indicator{max-width:800px;margin:2rem auto;display:flex;align-items:center;justify-content:center;gap:0;padding:0 1rem}.step{display:flex;align-items:center;gap:.5rem;opacity:.35;transition:var(--transition-base)}.step.active{opacity:1}.step.completed{opacity:.7}.step-number{width:36px;height:36px;border-radius:50%;background:var(--bg-input);border:2px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;transition:var(--transition-base);flex-shrink:0;color:var(--text-muted)}.step.active .step-number{background:var(--gradient-primary);border-color:transparent;box-shadow:var(--shadow-glow);color:#fff}.step.completed .step-number{background:var(--accent-green);border-color:var(--accent-green);color:#fff}.step-label{font-size:.8rem;font-weight:500;white-space:nowrap;color:var(--text-muted)}.step.active .step-label{color:var(--text-primary);font-weight:600}.step-line{flex:1;height:2px;background:var(--border-color);margin:0 .5rem;min-width:20px;max-width:60px}.main-content{max-width:1000px;margin:0 auto;padding:0 1.5rem 3rem}.panel{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:2rem;margin-bottom:1.5rem;animation:fadeIn .4s ease;box-shadow:var(--shadow-sm)}.panel.hidden{display:none}@keyframes fadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.panel-header{margin-bottom:1.5rem}.panel-header h2{font-size:1.35rem;font-weight:700;margin-bottom:.4rem;color:var(--text-primary)}.panel-desc{color:var(--text-secondary);font-size:.9rem}.upload-zone{border:2px dashed rgba(220,38,38,.25);border-radius:var(--radius-lg);padding:3rem 2rem;text-align:center;cursor:pointer;transition:var(--transition-base);position:relative;background:linear-gradient(135deg,#dc262605,#f43f5e05)}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--accent-red);background:#dc26260a;transform:translateY(-2px);box-shadow:var(--shadow-md)}.upload-zone.drag-over{border-color:var(--accent-rose);background:#f43f5e0f;box-shadow:var(--shadow-glow)}.upload-icon{color:var(--text-muted);margin-bottom:1rem;transition:var(--transition-base)}.upload-zone:hover .upload-icon{color:var(--accent-red);transform:translateY(-4px)}.upload-text{font-size:1rem;color:var(--text-secondary);margin-bottom:1rem}.upload-hint{font-size:.8rem;color:var(--text-muted);margin-top:1rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;border:none;border-radius:var(--radius-sm);font-family:var(--font-family);font-size:.9rem;font-weight:600;cursor:pointer;transition:var(--transition-fast);outline:none}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 14px #dc26264d}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:#fff;color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{border-color:var(--accent-red);background:var(--bg-card-hover)}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid transparent}.btn-ghost:hover{color:var(--accent-red);background:#dc26260d}.btn-lg{padding:.85rem 2rem;font-size:1rem;border-radius:var(--radius-md)}.btn-generate{width:100%;justify-content:center;font-size:1.1rem;padding:1rem;margin-top:1.5rem;position:relative;overflow:hidden}.btn-generate:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:.5s}.btn-generate:hover:before{left:100%}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.file-info-card{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:1rem}.file-icon{font-size:2rem}.file-details{flex:1}.file-details h3{font-size:.95rem;font-weight:600;margin-bottom:.2rem}.file-stats{font-size:.8rem;color:var(--text-muted);display:flex;gap:.5rem;align-items:center}.dot{opacity:.5}.file-preview,.headings-list{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1rem 1.25rem;margin-bottom:1rem;max-height:200px;overflow-y:auto}.file-preview h4,.headings-list h4{font-size:.85rem;color:var(--text-muted);margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.5px}.preview-content{font-size:.85rem;color:var(--text-secondary);line-height:1.7;white-space:pre-wrap}.headings-content .heading-item{padding:.25rem 0;font-size:.85rem;color:var(--text-secondary)}.analysis-loading{text-align:center;padding:3rem 1rem}.analysis-loading h3{margin-top:1.5rem;font-size:1.1rem;color:var(--text-primary)}.analysis-loading p{color:var(--text-muted);margin-top:.5rem}.loader{position:relative;width:80px;height:80px;margin:0 auto}.loader-ring{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:3px solid transparent;animation:spin 1.5s linear infinite}.loader-ring:nth-child(1){border-top-color:var(--accent-red);animation-duration:1.5s}.loader-ring:nth-child(2){border-right-color:var(--accent-rose);animation-duration:2s;animation-direction:reverse}.loader-ring:nth-child(3){top:8px;right:8px;bottom:8px;left:8px;border-bottom-color:var(--accent-red-light);animation-duration:1s}@keyframes spin{to{transform:rotate(360deg)}}.style-profile{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1.5rem;margin-bottom:1.5rem;max-height:500px;overflow-y:auto;font-size:.9rem;line-height:1.8;color:var(--text-secondary);white-space:pre-wrap}.style-profile h3,.style-profile strong{color:var(--accent-red)}.outline-editor-container{margin-bottom:1.5rem}.outline-editor{width:100%;min-height:250px;padding:1.25rem;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-family);font-size:.95rem;line-height:1.8;resize:vertical;outline:none;transition:var(--transition-base)}.outline-editor:focus{border-color:var(--accent-red);box-shadow:0 0 0 3px #dc26261a}.outline-editor::placeholder{color:var(--text-muted);opacity:.6}.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.setting-item{display:flex;flex-direction:column;gap:.5rem}.setting-item label{font-size:.85rem;font-weight:600;color:var(--text-secondary)}.setting-item select,.setting-item input[type=number]{padding:.6rem 1rem;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-family);font-size:.9rem;outline:none;transition:var(--transition-fast)}.setting-item select:focus,.setting-item input:focus{border-color:var(--accent-red)}.setting-item select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%2394a3b8' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:2rem;background-color:#fff}.number-input{display:flex;align-items:center;gap:0}.number-input input{width:60px;text-align:center;border-radius:0;border-left:none;border-right:none;background:#fff}.num-btn{padding:.6rem .8rem;background:#fff;border:1px solid var(--border-color);color:var(--text-primary);font-size:1rem;cursor:pointer;transition:var(--transition-fast)}.num-btn:first-child{border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.num-btn:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0}.num-btn:hover{background:var(--accent-red);color:#fff;border-color:var(--accent-red)}.word-estimate{text-align:center;padding:.75rem;background:#dc26260a;border:1px solid rgba(220,38,38,.15);border-radius:var(--radius-sm);font-size:.9rem;color:var(--accent-red)}.word-estimate strong{color:var(--accent-error)}.result-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding:.75rem 1rem;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:1rem}.result-stats{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-muted)}.result-actions{display:flex;gap:.5rem;flex-wrap:wrap}.result-content{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-md);padding:2rem;min-height:400px;max-height:70vh;overflow-y:auto;position:relative;box-shadow:var(--shadow-sm)}.result-text{font-size:.95rem;line-height:1.9;color:var(--text-primary);white-space:pre-wrap}.result-text h1,.result-text h2,.result-text h3{color:var(--accent-red);margin:1.5rem 0 .75rem}.result-text h1{font-size:1.3rem}.result-text h2{font-size:1.15rem}.result-text h3{font-size:1.05rem}.typing-cursor{display:inline;color:var(--accent-red);animation:blink .7s infinite;font-weight:300}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.toast-container{position:fixed;bottom:2rem;right:2rem;z-index:1000;display:flex;flex-direction:column;gap:.75rem}.toast{padding:.85rem 1.25rem;border-radius:var(--radius-md);font-size:.85rem;font-weight:500;box-shadow:var(--shadow-lg);animation:slideInToast .3s ease;display:flex;align-items:center;gap:.5rem;max-width:360px;background:#fff}.toast.success{background:#16a34a14;border:1px solid rgba(22,163,74,.3);color:var(--accent-green)}.toast.error{background:#b91c1c14;border:1px solid rgba(185,28,28,.3);color:var(--accent-error)}.toast.info{background:#dc26260f;border:1px solid rgba(220,38,38,.25);color:var(--accent-red)}@keyframes slideInToast{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.hidden{display:none!important}@media(max-width:768px){.header{padding:.75rem 1rem}.steps-indicator{margin:1rem auto;gap:0}.step-label{display:none}.panel{padding:1.25rem}.settings-grid{grid-template-columns:1fr}.result-toolbar{flex-direction:column;align-items:stretch}.result-actions{justify-content:stretch}.result-actions .btn{flex:1;justify-content:center}.upload-zone{padding:2rem 1rem}}.login-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fef2f2,#fff1f2 30%,#f8f9fc)}.login-screen.hidden{display:none!important}.login-card{background:#fff;border-radius:var(--radius-xl);padding:3rem 2.5rem;width:100%;max-width:420px;text-align:center;box-shadow:0 20px 60px #dc26261a,0 4px 16px #0000000f;animation:loginFadeIn .6s ease}@keyframes loginFadeIn{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.login-logo{margin-bottom:1rem;filter:drop-shadow(0 4px 12px rgba(220,38,38,.2))}.login-logo svg{width:72px;height:72px}.login-title{font-size:2rem;font-weight:800;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.3rem}.login-subtitle{font-size:.95rem;color:var(--text-secondary);margin-bottom:.5rem}.login-divider{width:50px;height:3px;background:var(--gradient-primary);border-radius:2px;margin:1.5rem auto}.google-btn-container{margin:1.5rem 0}.btn-google{display:inline-flex;align-items:center;gap:.75rem;padding:.85rem 2rem;background:#fff;border:2px solid #e5e7eb;border-radius:50px;font-family:var(--font-family);font-size:.95rem;font-weight:600;color:var(--text-primary);cursor:pointer;transition:var(--transition-base);width:100%;justify-content:center}.btn-google:hover{border-color:#4285f4;box-shadow:0 4px 16px #4285f433;transform:translateY(-1px)}.btn-google:active{transform:translateY(0)}.login-error{color:var(--accent-error);font-size:.85rem;margin-top:.75rem;padding:.5rem 1rem;background:#b91c1c0f;border-radius:var(--radius-sm)}.login-footer{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #f1f5f9}.login-author{font-size:.85rem;color:var(--text-secondary);margin-bottom:.25rem}.login-author strong{color:var(--accent-red);font-weight:700}.login-version{font-size:.75rem;color:var(--text-muted)}.header-right{display:flex;align-items:center;gap:1rem}.user-info{display:flex;align-items:center;gap:.5rem}.user-avatar{width:30px;height:30px;border-radius:50%;border:2px solid var(--border-color);object-fit:cover}.user-name{font-size:.8rem;font-weight:600;color:var(--text-secondary);max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-sm{padding:.3rem .75rem;font-size:.75rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;animation:modalFadeIn .3s ease}.modal-overlay.hidden{display:none}.modal-card{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:2.5rem 2rem;text-align:center;max-width:420px;width:90%;box-shadow:0 20px 60px #0003;animation:modalBounce .4s cubic-bezier(.34,1.56,.64,1)}.modal-icon{font-size:3.5rem;margin-bottom:1rem;animation:modalPop .5s ease .2s both}.modal-title{font-size:1.35rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.modal-desc{font-size:.9rem;color:var(--text-muted);margin-bottom:1.75rem}.modal-actions{display:flex;flex-direction:column;gap:.75rem}.modal-actions .btn{width:100%;justify-content:center;padding:.85rem 1.5rem}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalBounce{0%{opacity:0;transform:scale(.85) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes modalPop{0%{transform:scale(0)}to{transform:scale(1)}}.credit-badge{display:flex;align-items:center;gap:.4rem;padding:.35rem .6rem .35rem .8rem;background:linear-gradient(135deg,#dc26260f,#f43f5e14);border:1px solid rgba(220,38,38,.2);border-radius:20px;font-size:.85rem;font-weight:600}.credit-icon{font-size:1rem}.credit-count{color:var(--accent-red);font-weight:800;min-width:18px;text-align:center}.btn-accent{background:var(--gradient-primary);color:#fff;font-size:.7rem;padding:.25rem .6rem;border-radius:12px;border:none;cursor:pointer;font-weight:600;transition:var(--transition-fast)}.btn-accent:hover{transform:translateY(-1px);box-shadow:0 2px 8px #dc26264d}.user-plan-badge{font-size:.65rem;font-weight:700;padding:.15rem .5rem;border-radius:10px;text-transform:uppercase;letter-spacing:.5px;background:#16a34a1a;color:var(--accent-green);border:1px solid rgba(22,163,74,.25)}.user-plan-badge[data-plan=starter]{background:#3b82f61a;color:#3b82f6;border-color:#3b82f640}.user-plan-badge[data-plan=pro]{background:#a855f71a;color:#a855f7;border-color:#a855f740}.user-plan-badge[data-plan=vip]{background:linear-gradient(135deg,#eab30826,#f59e0b26);color:#d97706;border-color:#eab30859}.modal-pricing{max-width:720px;width:95%;position:relative}.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:1px solid var(--border-color);border-radius:50%;width:32px;height:32px;cursor:pointer;font-size:1rem;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:var(--transition-fast)}.modal-close:hover{background:var(--accent-red);color:#fff;border-color:var(--accent-red)}.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.75rem;margin:1.5rem 0}.pricing-card{background:var(--bg-input);border:2px solid var(--border-color);border-radius:var(--radius-md);padding:1.25rem 1rem;text-align:center;transition:var(--transition-base);cursor:pointer;position:relative}.pricing-card:hover{border-color:var(--accent-red);transform:translateY(-2px);box-shadow:var(--shadow-md)}.pricing-card.recommended{border-color:var(--accent-rose);background:linear-gradient(135deg,#f43f5e0a,#dc26260a)}.pricing-card.recommended:before{content:"⭐ Phổ biến";position:absolute;top:-10px;left:50%;transform:translate(-50%);background:var(--gradient-primary);color:#fff;font-size:.65rem;font-weight:700;padding:.15rem .6rem;border-radius:8px;white-space:nowrap}.pricing-card.current{border-color:var(--accent-green);background:#16a34a0a}.pricing-card.current:after{content:"✓ Gói hiện tại";display:block;margin-top:.5rem;font-size:.7rem;color:var(--accent-green);font-weight:600}.pricing-name{font-size:1rem;font-weight:700;margin-bottom:.25rem;color:var(--text-primary)}.pricing-price{font-size:1.3rem;font-weight:800;color:var(--accent-red);margin-bottom:.25rem}.pricing-credits{font-size:.8rem;color:var(--text-muted);margin-bottom:.75rem}.pricing-btn{width:100%;padding:.5rem;font-size:.8rem}.pricing-footer{text-align:center;padding-top:1rem;border-top:1px solid var(--border-color);font-size:.85rem;color:var(--text-secondary)}.referral-input-group{display:flex;gap:.5rem;margin-top:.5rem;justify-content:center}.referral-input-group input{padding:.4rem .8rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.85rem;outline:none;width:200px}.referral-input-group input:focus{border-color:var(--accent-red)}.modal-payment{max-width:480px;width:95%;position:relative}.payment-content{text-align:center}.qr-container{margin:1rem 0}.qr-image{width:260px;height:auto;border-radius:var(--radius-md);border:2px solid var(--border-color)}.payment-info{text-align:left;background:var(--bg-input);border-radius:var(--radius-md);padding:1rem;margin:1rem 0}.payment-detail{display:flex;justify-content:space-between;padding:.35rem 0;font-size:.85rem;border-bottom:1px solid rgba(0,0,0,.04)}.payment-detail:last-child{border-bottom:none}.payment-label{color:var(--text-muted)}.payment-value{font-weight:600;color:var(--text-primary)}.payment-amount{color:var(--accent-red);font-size:1rem;font-weight:800}.payment-content-ck{color:var(--accent-red);font-weight:700;font-family:monospace}.payment-status{margin:1rem 0}.payment-waiting{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.75rem;background:#eab30814;border:1px solid rgba(234,179,8,.25);border-radius:var(--radius-sm);color:#b45309;font-size:.85rem;font-weight:500}.payment-success{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.75rem;background:#16a34a14;border:1px solid rgba(22,163,74,.25);border-radius:var(--radius-sm);color:var(--accent-green);font-size:.9rem;font-weight:600}.loader-sm{width:18px;height:18px;border:2px solid rgba(180,83,9,.3);border-top-color:#b45309;border-radius:50%;animation:spin .8s linear infinite}.payment-note{font-size:.75rem;color:var(--text-muted);margin-top:.5rem}
