body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.header{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 20px #0000001a;color:#fff;padding:2rem 0;text-align:center}.header-content{margin:0 auto;max-width:1200px;padding:0 2rem}.logo{align-items:center;display:flex;justify-content:center;margin-bottom:1rem}.heartbeat-icon{animation:heartbeat 2s ease-in-out infinite;font-size:2.5rem;margin-right:1rem}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.logo h1{font-size:3rem;font-weight:700;margin:0;text-shadow:2px 2px 4px #0000004d}.tagline{font-size:1.2rem;font-weight:300;margin:0;opacity:.9}.model-status{margin-top:1rem}.status-indicator{align-items:center;border-radius:25px;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:500;padding:.5rem 1rem;position:relative;transition:all .3s ease}.status-indicator i{font-size:1rem;margin-right:.5rem}.status-indicator.ready{background:#27ae6033;border:1px solid #27ae604d;color:#27ae60}.status-indicator.demo{background:#3498db33;border:1px solid #3498db4d;color:#3498db}.status-indicator.loading{background:#f1c40f33;border:1px solid #f1c40f4d;color:#f1c40f}.status-indicator.error{background:#e74c3c33;border:1px solid #e74c3c4d;color:#e74c3c}.status-indicator:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.status-tooltip{background:#2c3e50;border-radius:8px;box-shadow:0 4px 20px #0000004d;color:#fff;font-size:.8rem;margin-top:.5rem;opacity:0;padding:.75rem;top:100%;transition:all .3s ease;visibility:hidden;white-space:nowrap;z-index:1000}.status-tooltip,.status-tooltip:before{left:50%;position:absolute;transform:translateX(-50%)}.status-tooltip:before{border-bottom:5px solid #2c3e50;border-left:5px solid #0000;border-right:5px solid #0000;content:"";top:-5px}.status-indicator:hover .status-tooltip{opacity:1;visibility:visible}@media (max-width:768px){.header{padding:1.5rem 0}.logo h1{font-size:2.5rem}.heartbeat-icon{font-size:2rem}.tagline{font-size:1rem}.status-indicator{font-size:.8rem;padding:.4rem .8rem}.status-tooltip{max-width:250px;text-align:center;white-space:normal}}.single-image-prediction{width:100%}.prediction-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:20px;box-shadow:0 8px 32px #0000001a;display:flex;flex-direction:column;padding:40px;text-align:center}.prediction-card h2{color:#2c3e50;font-size:2rem;font-weight:600;margin-bottom:10px}.prediction-card p{color:#7f8c8d;font-size:1.1rem;margin-bottom:30px}.upload-area{margin-bottom:30px;padding:60px 20px;position:relative;transition:all .3s ease}.upload-area:hover{background:#e74c3c0d;border-color:#e74c3c}.upload-content{text-align:center}.upload-content i{margin-bottom:20px}.upload-area:hover .upload-content i{color:#e74c3c}.upload-content h3{color:#2c3e50;margin-bottom:10px}.preview-area{display:inline-block;margin-bottom:30px;position:relative}.preview-area img{border-radius:15px;box-shadow:0 4px 15px #0000001a;max-height:300px;max-width:300px}.remove-btn{align-items:center;background:#e74c3c;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:30px;justify-content:center;position:absolute;right:-10px;top:-10px;transition:all .3s ease;width:30px}.remove-btn:hover{background:#c0392b;transform:scale(1.1)}.predict-btn{background:linear-gradient(135deg,#e74c3c,#c0392b);border-radius:50px;box-shadow:0 4px 15px #e74c3c4d;display:flex;font-size:1.1rem;gap:10px;justify-content:center;margin:0 auto;max-width:fit-content;padding:15px 40px;transition:all .3s ease}.predict-btn:hover:not(:disabled){box-shadow:0 6px 20px #e74c3c66;transform:translateY(-2px)}.predict-btn:disabled{background:#bdc3c7;box-shadow:none}.predict-btn i{font-size:1.1rem}.result-area{margin-top:30px}.result-card{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:15px;box-shadow:0 4px 15px #0000001a;padding:30px}.result-card h3{color:#2c3e50;font-size:1.5rem;font-weight:600;margin-bottom:20px;text-align:center}.result-content{display:flex;flex-direction:column;gap:15px}.confidence,.prediction{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000000d;display:flex;justify-content:space-between;padding:15px}.label{color:#2c3e50;font-weight:600}.value{font-weight:500}.value,.value.positive{color:#e74c3c}.value.negative{color:#27ae60}@media (max-width:768px){.prediction-card{padding:20px}.prediction-card h2{font-size:1.5rem}.upload-area{padding:40px 20px}.upload-content i{font-size:2rem}.upload-content h3{font-size:1.2rem}}.batch-prediction{color:#333;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:0 auto;max-width:900px;padding:15px;width:100%}.batch-prediction h2{font-size:28px;margin-bottom:25px;text-align:center}.upload-area{background-color:#fafafa;border:3px dashed #bdc3c7;border-radius:15px;cursor:pointer;margin-bottom:20px;padding:40px 20px;text-align:center;transition:border-color .3s ease}.upload-area.dragover{background:#e74c3c1a;border-color:#e74c3c}.upload-content i{color:#bdc3c7;font-size:3rem;margin-bottom:15px;transition:color .3s ease}.upload-area.dragover .upload-content i,.upload-area:hover .upload-content i{color:#e74c3c}.upload-content h3{font-size:1.5rem;font-weight:600;margin-bottom:5px}.upload-content p{color:#7f8c8d;font-size:1rem}.selected-file{align-items:center;color:#27ae60;display:flex;font-size:16px;gap:8px;justify-content:center;margin-top:15px}.selected-file i{color:#27ae60}.predict-btn{background-color:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;display:block;font-size:16px;font-weight:600;margin:20px auto;max-width:300px;padding:12px 0;transition:background-color .3s ease;width:100%}.predict-btn:hover:not(:disabled){background-color:#2563eb}.predict-btn:disabled{background-color:#a5b4fc;cursor:not-allowed}.spinner{border:3px solid #fff6;border-top-color:#fff;display:inline-block;height:18px;vertical-align:middle;width:18px}.batch-result-area{margin-top:30px}.result-card{background:#f9fafb;border-radius:12px;box-shadow:0 2px 8px #0000000f;padding:25px}.batch-stats{display:flex;flex-wrap:wrap;gap:20px;justify-content:space-around;margin-bottom:25px}.stat{background-color:#fff;border-radius:10px;box-shadow:0 2px 8px #0000000d;flex:1 1;min-width:120px;padding:15px 25px;text-align:center}.stat-number{display:block;font-size:30px;font-weight:700;margin-bottom:5px}.stat-number.positive{color:#ef4444}.stat-number.negative{color:#10b981}.stat-label{color:#555;font-size:16px}.download-links{align-items:center;display:flex;flex-direction:column;gap:12px;margin-top:25px}.download-btn{align-items:center;background-color:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:15px;font-weight:600;gap:8px;justify-content:center;max-width:320px;padding:10px 18px;transition:background-color .3s ease;width:100%}.download-btn:hover:not(:disabled){background-color:#2563eb}.download-btn:disabled{background-color:#93c5fd;cursor:not-allowed}.roc-score{color:#374151;font-size:18px;font-weight:600;margin-top:20px;text-align:center}.classification-report{background-color:#fff;border-radius:8px;box-shadow:0 1px 6px #00000012;font-family:monospace;margin-top:30px;max-height:300px;overflow-y:auto;padding:20px;white-space:pre-wrap}.classification-report h4{border-bottom:2px solid #e5e7eb;font-size:20px;margin-bottom:15px;padding-bottom:5px}.results-section{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin-top:30px}.result-item{background:#fff;border-radius:10px;box-shadow:0 1px 6px #00000012;display:flex;flex:1 1 45%;flex-direction:column;gap:12px;max-width:400px;padding:15px;text-align:center}.result-item.full-width{flex-basis:100%;max-width:900px}.result-item h3{color:#111827;margin-bottom:12px}.result-item img{border-radius:8px;box-shadow:0 4px 12px #00000026;height:auto;max-width:100%}.result-item a{color:#3b82f6;font-weight:600;margin-top:auto;text-decoration:none;transition:color .3s ease}.result-item a:hover{color:#2563eb}@media (max-width:700px){.batch-stats{align-items:center;flex-direction:column}.stat{max-width:320px;width:80%}.results-section{flex-direction:column}.result-item{flex-basis:100%;max-width:100%}}.prediction-tabs{width:100%}.nav-tabs{justify-content:center;margin-bottom:30px}.nav-tabs,.tab-btn{display:flex;gap:10px}.tab-btn{align-items:center;background:#ffffffe6;border:none;border-radius:50px;box-shadow:0 4px 15px #0000001a;cursor:pointer;font-size:1rem;font-weight:500;padding:15px 30px;transition:all .3s ease}.tab-btn:hover{box-shadow:0 6px 20px #00000026;transform:translateY(-2px)}.tab-btn.active{background:#e74c3c;color:#fff}.tab-btn i{font-size:1.1rem}.tab-content{width:100%}@media (max-width:768px){.nav-tabs{align-items:center;flex-direction:column}.tab-btn{max-width:300px;width:100%}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);color:#333;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.App,body{min-height:100vh}.container{margin:0 auto;max-width:1200px;padding:20px}.spinner{animation:spin 1s linear infinite;border:2px solid #fff;border-radius:50%;border-top-color:#0000;height:20px;margin-right:8px;width:20px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){.container{padding:10px}}@media (max-width:480px){.container{padding:5px}}
/*# sourceMappingURL=main.dce6edcd.css.map*/