:root{font-family: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}}.header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem 2rem}.header-content h1{margin:0;font-size:2rem;font-weight:600}.header-content p{margin:.5rem 0 0;opacity:.9;font-size:1rem}.footer{background:#f5f5f5;padding:1rem 2rem;text-align:center;color:#666;font-size:.875rem;border-top:1px solid #e0e0e0}.layout{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:2rem;max-width:1200px;margin:0 auto;width:100%;box-sizing:border-box}.file-upload{margin-bottom:1.5rem;position:relative}.file-upload-label{display:block;margin-bottom:.5rem;font-weight:600;font-size:.9rem;letter-spacing:.02em;color:#1a1a2e}.drop-zone{border:2px dashed #c4c4d4;border-radius:12px;padding:2.5rem 2rem;text-align:center;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);background:linear-gradient(135deg,#fafafa,#f0f0f5);position:relative;overflow:hidden}.drop-zone:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#6366f10d,#a855f70d);opacity:0;transition:opacity .3s ease}.drop-zone:hover{border-color:#6366f1;transform:translateY(-2px);box-shadow:0 8px 24px -8px #6366f140}.drop-zone:hover:before{opacity:1}.drop-zone.dragging{border-color:#6366f1;background:linear-gradient(135deg,#eef2ff,#ede9fe);transform:scale(1.02);box-shadow:0 12px 32px -8px #6366f159}.drop-zone.uploaded{border-style:solid;border-color:#10b981;background:linear-gradient(135deg,#ecfdf5,#d1fae5)}.drop-hint{display:flex;flex-direction:column;gap:.5rem;color:#4b5563;position:relative;z-index:1}.drop-icon{font-size:2rem;margin-bottom:.25rem;opacity:.8;transition:transform .3s ease}.drop-zone:hover .drop-icon{transform:scale(1.1)}.file-type{font-size:.8rem;color:#9ca3af;font-weight:500}.upload-progress{position:relative;width:100%;height:28px;background:#e5e7eb;border-radius:8px;overflow:hidden;box-shadow:inset 0 2px 4px #0000000f}.progress-bar{height:100%;background:linear-gradient(90deg,#6366f1,#a855f7,#ec4899);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;transition:width .3s cubic-bezier(.4,0,.2,1);position:relative}.progress-bar:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:pulse 1s ease-in-out infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes pulse{0%,to{opacity:0}50%{opacity:1}}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.8rem;font-weight:600;color:#1f2937;text-shadow:0 1px 2px rgba(255,255,255,.8);z-index:1}.uploaded-file{display:flex;align-items:center;justify-content:center;gap:.75rem;position:relative;z-index:1;animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.file-icon{font-size:1.75rem}.file-name{color:#065f46;font-weight:600;font-size:.95rem}.error-message{margin-top:.625rem;padding:.5rem .75rem;color:#dc2626;font-size:.85rem;font-weight:500;background:linear-gradient(135deg,#fef2f2,#fee2e2);border-radius:6px;border-left:3px solid #dc2626;animation:shake .4s ease-out}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-4px)}40%,80%{transform:translate(4px)}}.pipeline-control{margin:2rem 0}.pipeline-steps{display:flex;gap:1rem;margin-bottom:1.5rem}.pipeline-step{flex:1;display:flex;align-items:center;gap:1rem;padding:1rem;background:#f5f5f5;border-radius:8px;transition:all .3s ease}.pipeline-step.active{background:#edeaff;border:2px solid #667eea}.pipeline-step.completed{background:#f0fff0;border:2px solid #4caf50}.step-number{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ccc;border-radius:50%;font-weight:600;color:#fff}.pipeline-step.active .step-number{background:#667eea}.pipeline-step.completed .step-number{background:#4caf50}.step-content{flex:1}.step-label{font-weight:500;color:#333}.step-description{font-size:.875rem;color:#666}.step-progress{font-weight:600;color:#667eea}.start-button{width:100%;padding:1rem;font-size:1rem;font-weight:500;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;cursor:pointer;transition:opacity .2s ease}.start-button:disabled{opacity:.5;cursor:not-allowed}.start-button:not(:disabled):hover{opacity:.9}.error-box{padding:1rem;background:#ffebee;border:1px solid #f44336;border-radius:8px;margin-bottom:1rem;color:#c62828}.success-box{padding:1rem;background:#e8f5e9;border:1px solid #4caf50;border-radius:8px;margin-bottom:1rem;color:#2e7d32}.hint{text-align:center;color:#999;margin-top:1rem}.result-display{margin:2rem 0;padding:1.5rem;background:#fafafa;border-radius:12px}.result-display h3{margin-bottom:1rem;color:#333}.result-status{padding:1rem;border-radius:8px;text-align:center;font-weight:600;font-size:1.25rem;margin-bottom:1.5rem}.result-status.passed{background:#e8f5e9;color:#2e7d32;border:1px solid #4caf50}.result-status.failed{background:#ffebee;color:#c62828;border:1px solid #f44336}.metrics{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:1.5rem}.metric{display:flex;flex-direction:column;gap:.5rem}.metric-header{display:flex;justify-content:space-between;color:#333}.metric-value{font-weight:600}.progress-bar-container{height:12px;background:#e0e0e0;border-radius:6px;overflow:hidden}.progress-bar{height:100%;border-radius:6px;transition:width .5s ease}.progress-bar.text-match{background:linear-gradient(135deg,#667eea,#764ba2)}.progress-bar.style-score.good{background:#4caf50}.progress-bar.style-score.medium{background:#ff9800}.progress-bar.style-score.low{background:#f44336}.download-buttons{display:flex;gap:1rem}.download-button{flex:1;padding:1rem;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.download-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.download-button.secondary{background:#fff;border:2px solid #667eea;color:#667eea}.download-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.app-content{max-width:800px;margin:0 auto;padding:1rem}.upload-section{margin-bottom:2rem}.upload-section h2{color:#333;margin-bottom:1.5rem;font-size:1.5rem}.upload-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media (max-width: 640px){.upload-grid{grid-template-columns:1fr}}.reset-button{width:100%;padding:1rem;margin-top:1.5rem;font-size:1rem;font-weight:500;color:#667eea;background:#fff;border:2px solid #667eea;border-radius:8px;cursor:pointer;transition:all .2s ease}.reset-button:hover{background:#edeaff}
