@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@500;700&display=swap";:root{--primary:#f43f5e;--primary-hover:#e11d48;--bg-color:#0f172a;--card-bg:#1e293bb3;--text-main:#f8fafc;--text-muted:#94a3b8;--border-color:#ffffff1a;--success:#10b981}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-main);min-height:100vh;font-family:Inter,sans-serif;overflow-x:hidden}.app-container{justify-content:center;min-height:100vh;padding:3rem 1rem;display:flex;position:relative}.background-shapes{z-index:-1;width:100%;height:100%;position:fixed;top:0;left:0;overflow:hidden}.shape{filter:blur(80px);opacity:.5;border-radius:50%;animation:20s ease-in-out infinite alternate float;position:absolute}.shape-1{background:radial-gradient(circle,#f43f5e66 0%,#0000 70%);width:50vw;height:50vw;top:-10%;left:-10%}.shape-2{background:radial-gradient(circle,#6366f14d 0%,#0000 70%);width:60vw;height:60vw;animation-delay:-5s;bottom:-20%;right:-10%}.shape-3{background:radial-gradient(circle,#10b98133 0%,#0000 70%);width:40vw;height:40vw;animation-delay:-10s;top:40%;left:60%}@keyframes float{0%{transform:translate(0)scale(1)}50%{transform:translate(5%,10%)scale(1.1)}to{transform:translate(-5%,5%)scale(.9)}}.main-content{z-index:1;width:100%;max-width:800px}.header{text-align:center;margin-bottom:3rem}.header h1{letter-spacing:-.02em;margin-bottom:.5rem;font-family:Outfit,sans-serif;font-size:3rem;font-weight:700}.header h1 span{color:var(--primary);background:-webkit-linear-gradient(45deg,#f43f5e,#fb923c);-webkit-text-fill-color:transparent;-webkit-background-clip:text}.header p{color:var(--text-muted);font-size:1.1rem}.card{background:var(--card-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-color);border-radius:24px;margin-bottom:2rem;padding:2rem;box-shadow:0 25px 50px -12px #00000080}.form-group{margin-bottom:1.5rem}.form-group label{color:var(--text-muted);margin-bottom:.5rem;font-size:.9rem;font-weight:500;display:block}.radio-group{gap:1rem;display:flex}.radio-btn{border:1px solid var(--border-color);cursor:pointer;background:#ffffff0d;border-radius:12px;flex:1;justify-content:center;align-items:center;padding:.75rem;font-weight:500;transition:all .2s;display:flex}.radio-btn input{display:none}.radio-btn.active{border-color:var(--primary);color:var(--primary);background:#f43f5e1a}.file-upload-group{cursor:pointer;margin-top:2rem}.upload-area{border:2px dashed var(--border-color);text-align:center;background:#0003;border-radius:16px;padding:3rem 2rem;transition:all .3s}.upload-area:hover{border-color:var(--primary);background:#f43f5e0d}.upload-icon{opacity:.8;margin-bottom:1rem;font-size:3rem}.file-size{color:var(--primary);margin-top:.5rem;font-size:.85rem;display:block}.patient-info{grid-template-columns:1fr 1fr;gap:1rem;transition:opacity .3s;display:grid}.patient-info.disabled{opacity:.3;pointer-events:none}input[type=text]{border:1px solid var(--border-color);color:#fff;background:#0000004d;border-radius:12px;outline:none;width:100%;padding:.75rem 1rem;font-family:inherit;font-size:1rem;transition:border-color .2s}input[type=text]:focus{border-color:var(--primary)}.submit-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;width:100%;margin-top:1rem;padding:1rem;font-size:1.1rem;font-weight:600;transition:all .2s;display:flex}.submit-btn:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 10px 20px -10px #f43f5e80}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.spinner{border:3px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:24px;height:24px;animation:1s ease-in-out infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.error-message{color:#fca5a5;background:#ef44441a;border-left:4px solid #ef4444;border-radius:8px;margin-top:1rem;padding:1rem}.result-card{animation:.5s cubic-bezier(.16,1,.3,1) forwards slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.result-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.result-header h2{font-family:Outfit,sans-serif;font-size:1.5rem}.badge{border-radius:99px;padding:.25rem .75rem;font-size:.85rem;font-weight:600}.badge.success{color:#34d399;background:#10b98133}.result-grid{grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:2rem;display:grid}@media (width>=640px){.result-grid{grid-template-columns:repeat(4,1fr)}}.stat-box{border:1px solid var(--border-color);text-align:center;background:#0003;border-radius:16px;padding:1.5rem 1rem}.stat-box.accent{background:linear-gradient(135deg,#f43f5e1a,#f43f5e0d);border-color:#f43f5e4d}.stat-box.accent .stat-value{color:var(--primary)}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-size:.85rem;display:block}.stat-value{font-family:Outfit,sans-serif;font-size:2rem;font-weight:700}.stat-value small{color:var(--text-muted);font-size:1rem}.info-list{background:#0003;border-radius:12px;margin-bottom:2rem;padding:1.5rem}.info-item{border-bottom:1px solid #ffffff0d;padding:.75rem 0;font-size:.95rem}.info-item:last-child{border-bottom:none}.info-item strong{color:var(--text-muted);margin-right:.5rem;font-weight:500}.action-buttons{gap:1rem;display:flex}.action-btn{text-align:center;border:1px solid var(--border-color);color:#fff;background:#ffffff0d;border-radius:12px;flex:1;padding:1rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-block}.action-btn:hover{background:#ffffff1a;transform:translateY(-2px)}.action-btn.primary{border-color:var(--primary);color:#fda4af;background:#f43f5e1a}.action-btn.primary:hover{background:#f43f5e33}.localization-box{background:#f43f5e0d;border:1px solid #f43f5e33;border-radius:16px;margin-bottom:2rem;padding:1.5rem}.localization-header{border-bottom:1px solid #f43f5e1a;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.localization-header h3{color:var(--primary);font-family:Outfit,sans-serif;font-size:1.25rem}.localization-badge{color:#fda4af;background:#f43f5e1a;border:1px solid #f43f5e33;border-radius:99px;padding:.25rem .75rem;font-size:.8rem;font-weight:600}.dominant-origin{flex-direction:column;margin-bottom:1.5rem;display:flex}.origin-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-size:.9rem}.origin-value{color:#fff;text-shadow:0 0 20px #f43f5e4d;font-family:Outfit,sans-serif;font-size:2rem;font-weight:700}.origin-breakdown{background:#0003;border-radius:12px;padding:1rem}.origin-breakdown h4{color:var(--text-muted);margin-bottom:1rem;font-size:.9rem}.origin-breakdown ul{gap:.75rem;list-style:none;display:grid}.origin-breakdown li{border:1px solid var(--border-color);background:#ffffff08;border-radius:8px;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.origin-name{color:#e2e8f0;font-weight:500}.origin-count{background:var(--primary);color:#fff;border-radius:99px;padding:.15rem .6rem;font-size:.85rem;font-weight:600}.ml-badge{color:#a5b4fc!important;background:#6366f11a!important;border:1px solid #6366f14d!important}.text-glow{color:#f8fafc;text-shadow:0 0 15px #f43f5e66,0 0 30px #6366f133}.ml-score-indicator{color:#a5b4fc;margin-top:.4rem;font-size:.9rem;font-weight:500;display:block}.confidence-section{border:1px solid var(--border-color);background:#0003;border-radius:12px;margin-bottom:1.5rem;padding:1rem}.confidence-row{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.section-subtitle{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem;font-weight:500}.confidence-badge{border:1px solid #0000;border-radius:99px;padding:.25rem .75rem;font-size:.85rem;font-weight:600}.confidence-badge.confidence-high{color:#34d399;background:#10b9811a;border-color:#10b9814d}.confidence-badge.confidence-medium{color:#fbbf24;background:#f59e0b1a;border-color:#f59e0b4d}.confidence-badge.confidence-low{color:#f87171;background:#ef44441a;border-color:#ef44444d}.reason-flags{flex-wrap:wrap;gap:.5rem;display:flex}.reason-flag-tag{border:1px solid var(--border-color);color:var(--text-muted);background:#ffffff08;border-radius:6px;padding:.2rem .5rem;font-size:.75rem;font-weight:500}.ml-breakdown-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1.5rem;display:grid}.breakdown-card{background:#6366f108;border:1px solid #6366f126;border-radius:12px;padding:1rem;transition:all .2s}.breakdown-card:hover{background:#6366f10f;border-color:#6366f14d}.breakdown-card.full-width{background:#f43f5e08;border-color:#f43f5e26;grid-column:span 2}.breakdown-card.full-width:hover{background:#f43f5e0f;border-color:#f43f5e4d}.breakdown-card h5{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-size:.8rem}.breakdown-card p{color:#e2e8f0;font-size:.95rem;font-weight:500}.breakdown-card p.highlight-text{color:#fda4af;font-weight:600}.candidate-origins-section{margin-bottom:1.5rem}.candidate-origins-section .section-subtitle{margin-bottom:.5rem;display:block}.candidate-tags{flex-wrap:wrap;gap:.5rem;display:flex}.candidate-tag{border:1px solid var(--border-color);color:#cbd5e1;background:#ffffff0d;border-radius:8px;padding:.25rem .75rem;font-size:.8rem;font-weight:500}.footer-disclaimer{-webkit-backdrop-filter:blur(8px);text-align:center;background:#0f172a66;border:1px solid #ffffff0d;border-radius:16px;width:100%;margin-top:4rem;padding:1.5rem}.footer-disclaimer p{color:var(--text-muted);margin-bottom:.75rem;font-size:.8rem;line-height:1.6}.footer-disclaimer p strong{color:var(--primary);font-weight:600}.footer-disclaimer .footer-contact{color:var(--text-main);margin-bottom:0;font-size:.85rem;font-weight:500}.footer-disclaimer .footer-contact a{color:var(--primary);font-weight:600;text-decoration:none;transition:all .2s}.footer-disclaimer .footer-contact a:hover{color:#fda4af;text-decoration:underline}
