*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;color:#1f2937;background:#fff;min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column;background:#fff}.app-header{background:#fff;padding:2rem;text-align:center}.app-header h1{font-size:2.5rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.app-header p{font-size:1.1rem;color:#4b5563;margin:0 auto}.app-main{flex:1;padding:2rem;display:flex;flex-direction:column;align-items:center}.upload-section{display:flex;flex-direction:column;gap:3rem;align-items:center;width:100%;max-width:1200px}.file-upload-container{width:100%;max-width:500px}.file-upload-area{background:#fff;border:3px dashed #d1d5db;border-radius:16px;padding:3rem 2rem;text-align:center;transition:all .3s ease;cursor:pointer;position:relative;overflow:hidden}.file-upload-area:hover{border-color:#3b82f6;background:#f8fafc;transform:translateY(-2px);box-shadow:0 10px 25px #0000001a}.file-upload-area.drag-active{border-color:#10b981;background:#ecfdf5;transform:scale(1.02)}.file-upload-area.loading{border-color:#f59e0b;background:#fffbeb}.upload-icon{color:#6b7280;margin-bottom:1rem;transition:color .3s ease}.file-upload-area:hover .upload-icon{color:#3b82f6}.file-upload-area h3{font-size:1.5rem;font-weight:600;margin-bottom:.5rem;color:#1f2937}.file-upload-area p{color:#4b5563;margin-bottom:1.5rem}.file-input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.upload-button{background:#3b82f6;color:#fff;border:none;padding:.75rem 2rem;border-radius:8px;font-weight:500;cursor:pointer;transition:all .3s ease;margin-bottom:1rem}.upload-button:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.file-requirements{margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.file-requirements small{color:#4b5563;line-height:1.4}.help-link{background:none;border:none;color:#3b82f6;text-decoration:underline;cursor:pointer;font-size:inherit;padding:0;margin:0;font-family:inherit}.help-link:hover{color:#2563eb}.loading-state{display:flex;flex-direction:column;align-items:center;gap:1rem}.spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.demo-section{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;background:#f8fafc;border-radius:16px;border:2px solid #e2e8f0;width:100%;max-width:500px}.demo-button{background:#10b981;color:#fff;border:none;padding:1rem 2rem;border-radius:12px;font-weight:600;font-size:1.1rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #10b9814d}.demo-button:hover{background:#059669;transform:translateY(-2px);box-shadow:0 8px 20px #10b98166}.demo-description{color:#4b5563;text-align:center;font-size:.95rem;margin:0}.demo-notice{color:#059669;font-weight:500;font-style:italic;margin-top:.25rem}.how-it-works{background:#fff;padding:2rem;width:100%;max-width:600px}.how-it-works h3{font-size:1.5rem;font-weight:600;margin-bottom:1.5rem;text-align:center;color:#1f2937}.steps{display:flex;flex-direction:column;gap:1.5rem;align-items:center}.step{display:flex;align-items:flex-start;gap:1rem;max-width:400px;width:100%}.step-number{background:#3b82f6;color:#fff;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0}.step-content h4{font-weight:600;margin-bottom:.25rem;color:#1f2937}.step-content p{color:#4b5563;font-size:.9rem}.results-section{width:100%}.results-header{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem;padding:1.5rem;background:#fff;border-radius:16px;box-shadow:0 4px 20px #0000001a;max-width:1200px;margin-left:auto;margin-right:auto}.results-title h2{font-size:1.8rem;font-weight:700;color:#1f2937;margin-bottom:.25rem}.results-title p{color:#4b5563}.reset-button{background:#ef4444;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:500;cursor:pointer;transition:all .3s ease;align-self:flex-start}.reset-button:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 4px 12px #ef444466}.data-summary{background:#fff;padding:2rem;border-radius:16px;box-shadow:0 4px 20px #0000001a;margin-bottom:2rem;max-width:1200px;margin-left:auto;margin-right:auto}.summary-header{text-align:center;margin-bottom:2rem}.summary-header h3{font-size:1.5rem;font-weight:600;color:#1f2937;margin-bottom:.5rem}.summary-header p{color:#4b5563}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.summary-card{background:#f8fafc;padding:1.5rem;border-radius:12px;text-align:center;border:1px solid #e2e8f0}.summary-stat{display:flex;flex-direction:column;gap:.5rem}.stat-number{font-size:2rem;font-weight:700;color:#3b82f6}.stat-label{font-size:.9rem;color:#4b5563;font-weight:500}.summary-details{display:grid;grid-template-columns:1fr;gap:2rem}.stage-completion h4,.top-flows h4{font-size:1.2rem;font-weight:600;color:#1f2937;margin-bottom:1rem}.stage-list,.flow-list{display:flex;flex-direction:column;gap:1rem}.stage-item{display:flex;flex-direction:column;gap:.5rem}.stage-info{display:flex;justify-content:space-between;align-items:center}.stage-name{font-weight:500;color:#1f2937}.stage-count{font-size:.9rem;color:#4b5563}.stage-progress{display:flex;align-items:center;gap:1rem}.progress-bar{flex:1;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#10b981);border-radius:4px;transition:width .3s ease}.stage-percentage{font-size:.9rem;font-weight:500;color:#3b82f6;min-width:40px;text-align:right}.flow-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.flow-name{font-weight:500;color:#1f2937}.flow-count{font-size:.9rem;color:#4b5563;font-weight:500}.sankey-container{background:#fff;padding:2rem;border-radius:16px;box-shadow:0 4px 20px #0000001a;overflow:hidden;margin-bottom:2rem;width:calc(100vw - 4rem);margin-left:0}.sankey-header{text-align:center;margin-bottom:2rem}.sankey-header h2{font-size:1.6rem;font-weight:600;color:#1f2937;margin-bottom:.5rem}.sankey-header p{color:#4b5563}.chart-wrapper{height:500px;width:100%}.app-footer{background:#fff;padding:1.5rem 2rem;text-align:center;margin-top:auto}.app-footer p{color:#4b5563;font-size:.9rem}.app-footer a{color:#3b82f6;text-decoration:none}.app-footer a:hover{text-decoration:underline}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:16px;box-shadow:0 20px 40px #0003;max-width:700px;width:100%;max-height:90vh;overflow-y:auto;position:relative}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:2rem 2rem 1rem;border-bottom:1px solid #e5e7eb}.modal-header h2{font-size:1.5rem;font-weight:600;color:#1f2937;margin:0}.modal-close{background:none;border:none;color:#6b7280;cursor:pointer;padding:.5rem;border-radius:8px;transition:all .2s ease}.modal-close:hover{background:#f3f4f6;color:#1f2937}.modal-body{padding:2rem}.modal-footer{padding:1rem 2rem 2rem;border-top:1px solid #e5e7eb;text-align:right}.modal-button{background:#3b82f6;color:#fff;border:none;padding:.75rem 2rem;border-radius:8px;font-weight:500;cursor:pointer;transition:all .3s ease}.modal-button:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.help-section{margin-bottom:2rem}.help-section:last-child{margin-bottom:0}.help-section h3{font-size:1.2rem;font-weight:600;color:#1f2937;margin-bottom:1rem}.help-section p{color:#4b5563;margin-bottom:1rem;line-height:1.6}.format-requirements{display:flex;flex-direction:column;gap:1rem}.requirement{display:flex;gap:1rem;align-items:flex-start}.requirement-icon{background:#10b981;color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;flex-shrink:0;margin-top:.1rem}.requirement strong{color:#1f2937;display:block;margin-bottom:.25rem}.requirement p{color:#4b5563;font-size:.9rem;margin:0}.csv-example{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1rem;font-family:Monaco,Menlo,Ubuntu Mono,monospace}.csv-header{background:#e2e8f0;padding:.5rem;border-radius:4px;margin-bottom:.5rem}.csv-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem;border-bottom:1px solid #e5e7eb;gap:1rem}.csv-row:last-child{border-bottom:none}.csv-row code{flex:1;color:#1f2937}.row-description{color:#4b5563;font-size:.8rem;font-family:Inter,system-ui,sans-serif;font-style:italic;flex-shrink:0}.tips-list{color:#4b5563;padding-left:1.5rem}.tips-list li{margin-bottom:.5rem;line-height:1.5}.creation-steps{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1.5rem}.creation-steps .step{max-width:100%}.creation-steps strong{color:#1f2937;display:block;margin-bottom:.5rem}.creation-steps ol{color:#4b5563;padding-left:1.5rem}.creation-steps li{margin-bottom:.25rem}@media (min-width: 1024px){.results-title{text-align:left}.results-header{align-items:flex-start}.summary-details{grid-template-columns:1fr 1fr}}@media (max-width: 768px){.app-header{padding:1.5rem 1rem}.app-header h1{font-size:2rem}.app-main{padding:1rem}.file-upload-area{padding:2rem 1rem}.results-header{text-align:center}.steps{gap:1rem}.step{flex-direction:column;text-align:center}.chart-wrapper{height:400px}.summary-grid{grid-template-columns:1fr}.data-summary{padding:1.5rem}.app-footer{padding:1.5rem 1rem}.sankey-container{width:calc(100vw - 2rem)}.demo-section{padding:1.5rem}.demo-button{padding:.875rem 1.5rem;font-size:1rem}.modal-overlay{padding:.5rem}.modal-header{padding:1.5rem 1.5rem 1rem}.modal-body{padding:1.5rem}.modal-footer{padding:1rem 1.5rem 1.5rem}.csv-row{flex-direction:column;align-items:flex-start;gap:.5rem}.row-description{font-size:.75rem}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
