@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";*{box-sizing:border-box;margin:0;padding:0}body{color:#1f2937;-webkit-font-smoothing:antialiased;background:#f9fafb;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6}.app{flex-direction:column;min-height:100vh;display:flex}header{color:#fff;text-align:center;background:linear-gradient(135deg,#000 0%,#1f2937 100%);padding:2.5rem 1.5rem 2rem}.brand{flex-wrap:wrap;justify-content:center;align-items:center;gap:.75rem;display:flex}.logo{letter-spacing:-.5px;font-size:1.75rem;font-weight:700}.subtitle{text-transform:uppercase;letter-spacing:.1em;color:#9ca3af;font-size:.875rem;font-weight:500}.tagline{color:#d1d5db;max-width:560px;margin-top:1rem;margin-left:auto;margin-right:auto;font-size:1.05rem;font-weight:300;line-height:1.625}main{flex:1;width:100%;max-width:680px;margin:0 auto;padding:1.5rem}.stat-banner{text-align:center;color:#374151;background:#fff;border:1px solid #e5e7eb;border-left:4px solid #111827;border-radius:.5rem;margin-bottom:1.75rem;padding:.875rem 1.25rem;font-size:.95rem}.stat-banner strong{color:#111827;font-size:1.1rem;font-weight:700}.progress-bar{justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding:0 1rem;display:flex;position:relative}.progress-line{z-index:0;background:#e5e7eb;height:2px;position:absolute;top:16px;left:2.5rem;right:2.5rem}.progress-fill{background:#111827;height:100%;transition:width .3s}.progress-step{z-index:1;flex-direction:column;flex:1;align-items:center;display:flex}.step-circle{color:#6b7280;background:#e5e7eb;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.8rem;font-weight:600;transition:all .3s;display:flex}.progress-step.active .step-circle,.progress-step.completed .step-circle{color:#fff;background:#111827}.step-label{color:#9ca3af;text-align:center;margin-top:.35rem;font-size:.7rem;font-weight:500}.progress-step.active .step-label{color:#111827;font-weight:600}.step-card{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:2rem;transition:box-shadow .3s}.step-card h2{color:#111827;margin-bottom:.25rem;font-size:1.3rem;font-weight:700}.step-desc{color:#6b7280;margin-bottom:1.5rem;font-size:.9rem}.form-group{margin-bottom:1.25rem}.form-group label{color:#374151;margin-bottom:.4rem;font-size:.875rem;font-weight:600;display:block}.form-group input[type=text],.form-group input[type=email],.form-group select,.form-group textarea{color:#1f2937;background:#fff;border:1px solid #d1d5db;border-radius:.5rem;width:100%;padding:.65rem .85rem;font-family:inherit;font-size:.95rem;transition:all .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#111827;outline:none;box-shadow:0 0 0 3px #11182714}.error{color:#dc2626;margin-top:.25rem;font-size:.8rem;display:block}.checkbox-grid{grid-template-columns:1fr 1fr;gap:.5rem;display:grid}.checkbox-item,.radio-item{cursor:pointer;color:#4b5563;border:1px solid #e5e7eb;border-radius:.5rem;align-items:center;gap:.5rem;padding:.6rem .75rem;font-size:.875rem;transition:all .2s;display:flex}.checkbox-item:hover,.radio-item:hover{background:#f9fafb;border-color:#9ca3af}.checkbox-item input:checked+span,.radio-item input:checked+span{color:#111827;font-weight:600}.radio-group{gap:1rem;display:flex}.review-section{flex-direction:column;gap:1rem;display:flex}.review-block{background:#f9fafb;border:1px solid #f3f4f6;border-radius:.75rem;padding:1rem 1.25rem}.review-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.review-header h3{color:#111827;font-size:.95rem;font-weight:700}.edit-btn{color:#4b5563;cursor:pointer;text-underline-offset:2px;background:0 0;border:none;font-size:.8rem;font-weight:600;text-decoration:underline}.edit-btn:hover{color:#111827}.review-item{gap:.5rem;padding:.25rem 0;font-size:.875rem;display:flex}.review-item span{color:#6b7280;min-width:80px}.review-item strong{color:#1f2937}.nav-buttons{justify-content:space-between;gap:1rem;margin-top:1.5rem;display:flex}.btn-primary{color:#fff;cursor:pointer;background:#111827;border:none;border-radius:.5rem;margin-left:auto;padding:.75rem 2rem;font-size:1rem;font-weight:600;transition:background .2s}.btn-primary:hover{background:#1f2937}.btn-primary:disabled{cursor:not-allowed;background:#9ca3af}.btn-secondary{color:#111827;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:.5rem;padding:.75rem 2rem;font-size:1rem;font-weight:600;transition:all .2s}.btn-secondary:hover{background:#f3f4f6;border-color:#9ca3af}.btn-generate{width:100%;padding:1rem;font-size:1.05rem}.error-banner{text-align:center;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;margin-top:1rem;padding:1rem}.error-banner p{color:#991b1b;margin-bottom:.5rem;font-size:.9rem}.success-card{text-align:center;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;margin-top:2rem;padding:2.5rem}.success-icon{color:#fff;background:#111827;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 1.25rem;font-size:2rem;display:flex}.success-card h2{color:#111827;margin-bottom:1rem;font-weight:700}.success-card p{color:#4b5563;line-height:1.625}.success-card ul{text-align:left;max-width:320px;margin:1rem auto;list-style:none}.success-card ul li{color:#374151;padding:.35rem 0 .35rem 1.5rem;font-size:.9rem;position:relative}.success-card ul li:before{content:"✓";color:#111827;font-weight:700;position:absolute;left:0}.cta-section{border-top:1px solid #e5e7eb;margin-top:2rem;padding-top:1.5rem}.cta-section p{color:#374151}.cta-btn{color:#fff;background:#111827;border-radius:.5rem;margin-top:.75rem;padding:.875rem 2rem;font-weight:600;text-decoration:none;transition:background .2s;display:inline-block;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a}.cta-btn:hover{background:#1f2937}footer{text-align:center;color:#9ca3af;border-top:1px solid #e5e7eb;padding:1.5rem;font-size:.85rem}footer a{color:#4b5563;text-decoration:none}footer a:hover{color:#111827}@media (width<=600px){.brand{flex-direction:column;gap:.35rem}.checkbox-grid{grid-template-columns:1fr}.step-card{padding:1.25rem}main{padding:1rem}.step-label{display:none}header{padding:2rem 1rem 1.5rem}}
