*{margin:0;padding:0;box-sizing:border-box}body{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;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);min-height:100vh;padding:20px}.app{max-width:1200px;margin:0 auto}.app-header{text-align:center;color:#fff;margin-bottom:30px}.app-header h1{font-size:2.5rem;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.progress-bar{display:flex;justify-content:space-between;margin-bottom:40px;background:white;padding:20px;border-radius:15px;box-shadow:0 10px 30px #0003;overflow-x:auto}.progress-step{flex:1;display:flex;flex-direction:column;align-items:center;position:relative;min-width:100px}.progress-step:not(:last-child):after{content:"";position:absolute;top:20px;left:50%;width:100%;height:3px;background:#e0e0e0;z-index:0}.progress-step.active:not(:last-child):after{background:#667eea}.step-number{width:40px;height:40px;border-radius:50%;background:#e0e0e0;color:#666;display:flex;align-items:center;justify-content:center;font-weight:700;margin-bottom:8px;position:relative;z-index:1;transition:all .3s ease}.progress-step.active .step-number{background:#667eea;color:#fff}.progress-step.current .step-number{background:#764ba2;color:#fff;transform:scale(1.2);box-shadow:0 4px 10px #764ba266}.step-title{font-size:.85rem;color:#666;text-align:center;font-weight:500}.progress-step.active .step-title{color:#667eea;font-weight:600}.form-container{background:white;border-radius:15px;padding:40px;box-shadow:0 10px 30px #0003;animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.form-step h2{color:#333;margin-bottom:30px;font-size:2rem;border-bottom:3px solid #667eea;padding-bottom:10px}.form-section{margin-bottom:30px}.form-section h3{color:#667eea;margin-bottom:20px;font-size:1.3rem}.form-section h4{color:#764ba2;margin:20px 0 15px;font-size:1.1rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:20px}.form-group{display:flex;flex-direction:column}.form-group label{font-weight:600;color:#555;margin-bottom:8px;font-size:.95rem}.form-group input,.form-group select,.form-group textarea{padding:12px 15px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:all .3s ease;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled,.form-group select:disabled{background-color:#f5f5f5;cursor:not-allowed}.form-group textarea{resize:vertical;min-height:80px}.checkbox-group{flex-direction:row;align-items:center}.checkbox-group label{display:flex;align-items:center;margin:0;cursor:pointer}.checkbox-group input[type=checkbox]{width:auto;margin-right:10px;cursor:pointer}.form-buttons{display:flex;gap:15px;justify-content:flex-end;margin-top:30px;padding-top:20px;border-top:2px solid #e0e0e0}.form-buttons-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:15px;margin-top:30px;padding-top:20px;border-top:2px solid #e0e0e0}.btn{padding:12px 30px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}.btn:hover{transform:translateY(-2px);box-shadow:0 5px 15px #0003}.btn:active{transform:translateY(0)}.btn-primary{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff}.btn-secondary{background:#6c757d;color:#fff}.btn-add{background:#28a745;color:#fff;margin-top:15px}.btn-add:disabled{background:#ccc;cursor:not-allowed;transform:none}.btn-remove{background:#dc3545;color:#fff;padding:8px 15px;font-size:.9rem}.btn-info{background:#17a2b8;color:#fff}.btn-success{background:#28a745;color:#fff}.list-items{display:flex;flex-direction:column;gap:15px}.list-item{display:flex;justify-content:space-between;align-items:center;padding:15px;background:#f8f9fa;border-radius:8px;border-left:4px solid #667eea}.item-info{flex:1}.item-info strong{color:#333;font-size:1.1rem}.item-info small{color:#666;font-size:.9rem}.percent-indicator{font-size:1.2rem;font-weight:700;text-align:center;padding:10px;background:#f8f9fa;border-radius:8px;margin-bottom:15px}.summary-section{background:#f8f9fa;padding:20px;border-radius:8px;margin-bottom:20px;border-left:4px solid #667eea}.summary-section h3{color:#764ba2;margin-bottom:15px;font-size:1.3rem}.summary-section p{margin-bottom:10px;color:#555;line-height:1.6}.summary-section strong{color:#333;font-weight:600}.success-message{background:#d4edda;color:#155724;border:1px solid #c3e6cb;border-radius:8px;padding:15px;margin-top:20px;text-align:center;font-weight:600;animation:fadeIn .3s ease-in}.records-container{margin-top:30px;padding:20px;background:#f8f9fa;border-radius:8px}.records-table{width:100%;border-collapse:collapse;margin-top:15px}.records-table th,.records-table td{padding:12px;text-align:left;border-bottom:1px solid #dee2e6}.records-table th{background:#667eea;color:#fff;font-weight:600}.records-table tr:hover{background:#f1f3f5}.records-table button{padding:6px 12px;font-size:.85rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.modal-content{background:white;border-radius:15px;max-width:1200px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;border-bottom:2px solid #e0e0e0}.modal-header h2{margin:0;color:#667eea}.btn-close{background:none;border:none;font-size:2rem;color:#999;cursor:pointer;transition:color .3s ease}.btn-close:hover{color:#333}.modal-body{padding:30px}.records-info{background:#f8f9fa;padding:15px;border-radius:8px;margin-bottom:20px}.records-info p{margin:0;font-size:1.1rem}.records-actions{display:flex;gap:15px;margin-bottom:20px}.records-table-container{overflow-x:auto}.manage-records-btn{position:fixed;bottom:30px;right:30px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;padding:15px 25px;border-radius:50px;font-size:1rem;font-weight:600;cursor:pointer;box-shadow:0 5px 20px #667eea66;transition:all .3s ease;z-index:999}.manage-records-btn:hover{transform:translateY(-3px);box-shadow:0 8px 25px #667eea99}@media (max-width: 768px){body{padding:10px}.app-header h1{font-size:1.8rem}.form-container{padding:20px}.form-step h2{font-size:1.5rem}.form-row{grid-template-columns:1fr}.progress-bar{padding:15px;flex-wrap:nowrap}.progress-step{min-width:80px}.step-number{width:35px;height:35px;font-size:.9rem}.step-title{font-size:.7rem}.form-buttons{flex-direction:column}.btn{width:100%}}
