*{margin:0;padding:0;box-sizing:border-box}html{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:linear-gradient(135deg,#f5f5f5 0%,#ffffff 100%);color:#2d3748;line-height:1.6;min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}.container{max-width:900px;margin:0 auto;padding:2rem;width:100%}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mt-4{margin-top:1rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.rounded{border-radius:.5rem}.rounded-lg{border-radius:.75rem}.shadow{box-shadow:0 1px 3px #0000001a}.shadow-md{box-shadow:0 4px 6px #0000001a}h1{font-size:2rem;font-weight:700;margin-bottom:.5rem}h2{font-size:1.5rem;font-weight:600;margin-bottom:1rem}h3{font-size:1.25rem;font-weight:600;margin-bottom:.75rem}p{margin-bottom:1rem;color:#4a5568}input,textarea{width:100%;padding:.75rem;border:2px solid #e2e8f0;border-radius:.5rem;font-size:1rem;font-family:inherit;transition:border-color .2s}input:focus,textarea:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 3px #4299e11a}textarea{resize:vertical;min-height:100px}label{display:block;margin-bottom:.5rem;font-weight:500;color:#2d3748}button{padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.btn-primary{background:#4299e1;color:#fff}.btn-primary:hover{background:#3182ce;transform:translateY(-2px);box-shadow:0 4px 6px #4299e14d}.btn-secondary{background:#edf2f7;color:#2d3748;border:2px solid #cbd5e0}.btn-secondary:hover{background:#e2e8f0}.btn-success{background:#48bb78;color:#fff}.btn-success:hover{background:#38a169}.btn-small{padding:.5rem 1rem;font-size:.875rem}.card{background:white;border:2px solid #e2e8f0;border-radius:.75rem;padding:1.5rem;transition:all .2s}.card:hover{border-color:#cbd5e0;box-shadow:0 4px 12px #0000001a}.card-header{font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.card-description{font-size:.875rem;color:#718096}.grid{display:grid;gap:1.5rem}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.stage-container{background:white;border-radius:1rem;padding:3rem;max-width:700px;margin:0 auto;box-shadow:0 10px 30px #00000014}.stage-header{text-align:center;margin-bottom:2rem}.stage-number{display:inline-block;background:#edf2f7;padding:.5rem 1rem;border-radius:2rem;font-size:.875rem;font-weight:600;color:#4299e1;margin-bottom:1rem}.button-group{display:flex;gap:1rem;margin-top:2rem}.button-group button{flex:1}.button-group.full button{width:100%}.alert{padding:1rem;border-radius:.5rem;margin-bottom:1rem}.alert-info{background:#ebf8ff;border-left:4px solid #4299e1;color:#2c5282}.alert-success{background:#f0fff4;border-left:4px solid #48bb78;color:#22543d}.nav-tabs{display:flex;gap:1rem;border-bottom:2px solid #e2e8f0;margin-bottom:1.5rem}.nav-tab{padding:1rem;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-weight:600;color:#718096;transition:all .2s}.nav-tab.active{color:#4299e1;border-bottom-color:#4299e1}.nav-tab:hover{color:#4299e1}@media (max-width: 640px){.container{padding:1rem}.stage-container{padding:1.5rem}h1{font-size:1.5rem}h2{font-size:1.25rem}.button-group{flex-direction:column}.grid-2{grid-template-columns:1fr}}
