*{margin:0;padding:0;box-sizing:border-box}:root{--color-primary: #2C3E50;--color-secondary: #00BFA5;--color-accent: #1A237E;--color-bg-primary: #F5F7FA;--color-bg-secondary: #FFFFFF;--color-text-primary: #2C3E50;--color-text-secondary: #666666}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-color:var(--color-bg-primary);background-image:url(/medical-bg-pattern.svg);background-size:200px 200px;background-repeat:repeat;color:var(--color-text-primary)}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background-color:#fff;color:var(--color-text-primary);padding:.75rem 1rem;text-align:center;box-shadow:0 2px 8px #0000001a;flex-shrink:0;border-bottom:3px solid var(--color-secondary)}.header-content{display:flex;align-items:center;justify-content:space-between;gap:1rem;max-width:1200px;margin:0 auto;width:100%;padding:0 1rem}.app-logo{height:50px;width:auto;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));max-width:200px;object-fit:contain}.header-text{display:flex;flex-direction:column;align-items:flex-start}.header-subtitle{font-size:1.2rem;font-weight:600;margin:0;color:var(--color-text-primary)}.app-main{flex:1;padding:1rem;max-width:1400px;margin:0 auto;width:100%;overflow:hidden;display:flex;flex-direction:column}.image-analyzer{flex:1;display:flex;flex-direction:column;gap:10px;overflow:hidden}.compact-controls{display:flex;flex-direction:column;gap:.5rem;background:var(--color-bg-secondary);padding:1rem;border-radius:12px;box-shadow:0 2px 8px #0000001a}.controls-row{display:flex;align-items:center;gap:1rem;justify-content:space-between}.content-section{display:flex;flex-direction:column}.file-input-wrapper{display:flex;flex-direction:column;align-items:center;gap:1rem}.file-input-label{display:inline-block;padding:.75rem 1.5rem;background-color:var(--color-secondary);color:#fff;border-radius:4px;cursor:pointer;transition:background-color .3s;font-size:1rem;font-weight:500}.file-input-label:hover{background-color:#00a693}.file-input{display:none}.selected-file{color:var(--color-text-secondary);font-size:.9rem}.analyze-button{padding:.75rem 1.5rem;background-color:var(--color-secondary);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background-color .3s;width:100%}.analyze-button:hover:not(:disabled){background-color:#283593}.analyze-button:disabled{background-color:var(--color-text-secondary);cursor:not-allowed}.analysis-container{display:grid;grid-template-columns:280px 1fr;gap:20px;background:var(--color-bg-secondary);padding:1rem;border-radius:12px;box-shadow:0 2px 8px #0000001a}.analysis-left{display:flex;flex-direction:column}.preview-section{display:flex;flex-direction:column;gap:.75rem}.analysis-right{display:flex;flex-direction:column;min-height:0;overflow:hidden}.results-inline{display:flex;flex-direction:column;height:100%;overflow:hidden}.results-inline h3{margin:0 0 .75rem;color:var(--color-text-primary);font-size:1.25rem}.preview-section{margin:.5rem 0}.preview-section h3{margin-bottom:.5rem;color:var(--color-text-primary);font-size:1rem}.image-preview{max-width:250px;max-height:150px;border-radius:4px;box-shadow:0 2px 4px #0000001a;object-fit:contain}.predictions-table{flex:1;overflow-y:auto;min-height:0;border:1px solid #e0e0e0;border-radius:8px;max-height:400px}.results-table{width:100%;border-collapse:collapse}.results-table thead{background:#f5f5f5;position:sticky;top:0;z-index:1}.results-table th,.results-table td{padding:.5rem;text-align:left;border-bottom:1px solid #e0e0e0}.results-table th{font-weight:600;color:var(--color-text-primary);font-size:.85rem}.results-table td{font-size:.85rem}.results-table tbody tr:hover{background:#f9f9f9}.results-table tbody tr:last-child td{border-bottom:none}.confidence-bar{width:100%;height:20px;background:#e0e0e0;border-radius:10px;overflow:hidden}.confidence-fill{height:100%;background:var(--color-secondary);display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem;font-weight:600;min-width:40px}.results-section{margin-top:1rem;flex:1;overflow:auto;display:flex;flex-direction:column}.results-section h3{margin-bottom:.5rem;color:var(--color-text-primary);font-size:1.2rem}.compression-results{background:var(--color-bg-secondary);border:1px solid var(--color-secondary);border-radius:8px;padding:1rem;margin-bottom:1rem;box-shadow:0 2px 4px #00bfa51a}.compression-results h4{margin:0 0 .5rem;color:var(--color-text-primary);font-size:1rem;display:flex;align-items:center;gap:.5rem}.compression-results h4:before{content:"🗜️"}.compression-results p{margin:0;font-size:.9rem;color:var(--color-text-secondary);line-height:1.4}.analyze-button.secondary{background-color:var(--color-text-secondary);color:#fff}.analyze-button.secondary:hover:not(:disabled){background-color:#555}.results-content{display:grid;grid-template-columns:1fr 1fr;gap:1rem;flex:1;overflow:hidden}.results-left{display:flex;flex-direction:column}.results-right{display:flex;flex-direction:column;overflow:auto}.detection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem;margin-top:1rem}.detection-card{background:var(--color-bg-secondary);border:1px solid #E8EAF6;border-radius:4px;padding:.5rem;transition:transform .2s,box-shadow .2s}.detection-card:hover{transform:translateY(-1px);box-shadow:0 2px 8px #1a237e33}.detection-label{font-weight:600;color:var(--color-text-primary);margin-bottom:.25rem;text-transform:capitalize;font-size:.9rem}.detection-score{color:var(--color-secondary);font-size:.8rem;margin-bottom:.25rem;font-weight:500}.detection-box{color:var(--color-text-secondary);font-size:.7rem}.loading{text-align:center;padding:1rem;color:var(--color-text-secondary);font-size:.9rem;background:var(--color-bg-secondary);border-radius:4px;border:1px solid var(--color-secondary)}.error{background-color:#ffebee;border:1px solid #FFCDD2;color:#c62828;padding:.75rem;border-radius:4px;margin:.5rem 0;font-size:.9rem}.summary{background-color:#e0f2f1;border:1px solid var(--color-secondary);padding:.5rem;border-radius:4px;margin-bottom:.5rem}.summary .summary-text{font-size:.85rem;margin:0}.summary-text{color:var(--color-secondary);font-weight:500}.image-with-detections{margin:.5rem 0;text-align:center}.image-with-detections h4,.results-left h4,.results-right h4{color:var(--color-text-primary);margin-bottom:.5rem;font-size:1rem}.canvas-container{position:relative;display:inline-block;margin:.5rem 0}.detection-canvas{max-width:100%;height:auto;border:2px solid var(--color-accent);border-radius:4px;box-shadow:0 2px 6px #1a237e26}.canvas-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fffffff2;padding:1rem;border-radius:4px;font-weight:500;color:var(--color-text-secondary);border:1px solid var(--color-secondary)}.no-detections{text-align:center;padding:2rem;background:var(--color-bg-secondary);border:1px solid #E8EAF6;border-radius:8px;color:var(--color-text-secondary);font-style:italic}@media (max-width: 768px){.header-content{flex-direction:column;gap:.5rem}.app-logo{height:40px}.header-subtitle{font-size:1rem;text-align:center}.header-text{align-items:center}.app-main{padding:.5rem}.image-analyzer{gap:8px}.compact-controls{padding:.75rem}.results-content{grid-template-columns:1fr;gap:.5rem}.detection-grid{grid-template-columns:1fr!important}.image-preview{max-width:250px;max-height:150px}.file-input-wrapper{gap:.5rem}.upload-section{margin-bottom:.5rem}}@media (max-height: 600px){.app-header{padding:.5rem}.app-logo{height:35px}.header-subtitle{font-size:.9rem}.app-main{padding:.5rem}}.source-selector{display:flex;gap:.5rem}.source-button{padding:.5rem 1rem;background-color:var(--color-bg-secondary);color:var(--color-text-primary);border:2px solid #E8EAF6;border-radius:4px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s ease}.source-button:hover:not(:disabled){border-color:var(--color-secondary);color:var(--color-secondary)}.source-button.active{background-color:var(--color-secondary);color:#fff;border-color:var(--color-secondary)}.source-button:disabled{opacity:.6;cursor:not-allowed}.image-gallery{margin:0}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:.5rem;padding:.25rem}.gallery-item{cursor:pointer;transition:transform .2s,box-shadow .2s;border-radius:6px;overflow:hidden;background:var(--color-bg-secondary);border:2px solid transparent;display:flex;flex-direction:column;aspect-ratio:1/1;position:relative}.gallery-item:hover:not(.disabled){transform:translateY(-2px);box-shadow:0 4px 12px #1a237e33;border-color:var(--color-accent)}.gallery-item.selected{border-color:var(--color-secondary);box-shadow:0 4px 12px #00bfa54d}.gallery-item.disabled{opacity:.6;cursor:not-allowed}.gallery-image{width:100%;height:100%;object-fit:cover;display:block}.selection-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#00bfa5cc;display:flex;align-items:center;justify-content:center;z-index:2}.checkmark{color:#fff;font-size:2rem;font-weight:700}.gallery-image-name{position:absolute;bottom:0;left:0;right:0;padding:.2rem .3rem;text-align:center;font-size:.55rem;color:#fff;font-weight:600;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:#000000b3;line-height:1.2;z-index:1}.gallery-loading,.gallery-error,.gallery-empty{text-align:center;padding:2rem;color:var(--color-text-secondary)}.gallery-error{color:#c62828}@media (max-width: 768px){.controls-row{flex-direction:column;gap:.5rem}.source-selector{width:100%;justify-content:stretch}.source-button{flex:1}.analysis-container{grid-template-columns:1fr;gap:1rem}.analysis-left{width:100%}.preview-section img{max-height:200px}.predictions-table{max-height:300px}.gallery-grid{gap:.3rem;padding:.2rem}.gallery-image-name{font-size:.5rem;padding:.15rem .2rem}}.analysis-counter{display:flex;align-items:center;gap:.75rem;background:var(--color-bg-primary);padding:.5rem 1rem;border-radius:8px;border:1px solid var(--color-secondary);position:relative;overflow:hidden}.counter-icon{font-size:1.5rem;animation:pulse 2s ease-in-out infinite;color:var(--color-secondary)}.counter-content{display:flex;flex-direction:column;align-items:flex-start}.counter-label{font-size:.75rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.counter-value{font-size:1.25rem;font-weight:700;color:var(--color-secondary);text-shadow:0 0 10px rgba(0,191,165,.5)}.counter-pulse{position:absolute;top:50%;right:-50px;width:100px;height:100px;background:radial-gradient(circle,rgba(0,191,165,.3) 0%,transparent 70%);transform:translateY(-50%);animation:slide 3s linear infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@keyframes slide{0%{right:-100px;opacity:0}20%{opacity:1}80%{opacity:1}to{right:100%;opacity:0}}.analysis-counter.loading .counter-value{color:var(--color-text-secondary)}@media (max-width: 768px){.header-content{justify-content:space-between;padding:0 .5rem}.analysis-counter{padding:.4rem .8rem}.counter-icon{font-size:1.2rem}.counter-label{font-size:.65rem}.counter-value{font-size:1rem}.app-logo{height:35px}}.info-button{background:#fff;border:2px solid var(--color-accent);border-radius:20px;padding:.4rem 1rem;display:flex;align-items:center;gap:.5rem;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px #0000001a;color:var(--color-accent);font-weight:500}.info-icon{width:20px;height:20px;border-radius:50%;background:var(--color-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;font-style:italic;font-family:Georgia,serif}.info-text{font-size:.9rem;display:none}.info-button:hover{background:var(--color-accent);color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #1a237e33}.info-button:hover .info-icon{background:#fff;color:var(--color-accent)}@media (min-width: 1024px){.info-text{display:inline}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:var(--color-bg-secondary);border-radius:12px;max-width:600px;width:100%;max-height:80vh;overflow:hidden;box-shadow:0 10px 30px #0000004d;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:2px solid var(--color-secondary);background:var(--color-bg-primary)}.modal-header h2{margin:0;color:var(--color-text-primary);font-size:1.5rem}.modal-close{background:none;border:none;font-size:2rem;cursor:pointer;color:var(--color-text-secondary);width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.modal-close:hover{background:var(--color-bg-primary);color:var(--color-text-primary)}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}.info-section{margin-bottom:1.5rem}.info-section:last-child{margin-bottom:0}.info-section h3{color:var(--color-secondary);margin-bottom:.75rem;font-size:1.2rem}.info-section ul{list-style:none;padding:0;margin:0}.info-section li{margin-bottom:.5rem;color:var(--color-text-primary);line-height:1.6}.info-section strong{color:var(--color-text-primary);font-weight:600}@media (max-width: 768px){.modal-content{max-height:90vh;margin:.5rem}.modal-header,.modal-body{padding:1rem}.modal-header h2{font-size:1.2rem}.info-button{padding:.3rem .6rem}.info-icon{width:18px;height:18px;font-size:.7rem}}@media (max-width: 480px){.counter-label{display:none}.analysis-counter{padding:.3rem .6rem}}
