.App{width:100%;max-width:1200px;margin:0 auto;padding:2rem;text-align:center;min-height:100vh;display:flex;flex-direction:column}.App-header{margin-bottom:2rem}.App-header h1{color:#8b5cf6;margin-bottom:.5rem}.App-header p{color:#888;font-size:1.1rem}.App-nav{display:flex;gap:1rem;justify-content:center;margin-bottom:2rem;flex-wrap:wrap}.App-nav button{padding:.8rem 1.5rem;border:2px solid #8B5CF6;background:transparent;color:#8b5cf6;border-radius:8px;cursor:pointer;transition:all .3s ease;font-weight:500}.App-nav button:hover,.App-nav button.active{background:#8B5CF6;color:#fff}.App-main{flex:1;min-height:400px;width:80%;margin:0 auto;padding:2rem;border:1px solid #333;border-radius:12px;background:#1a1a1a;text-align:left}@media (prefers-color-scheme: light){.App-main{background:#f9f9f9;border-color:#ddd;color:#213547}.App-header p{color:#666}}.repository-input{max-width:600px;margin:0 auto;text-align:left}.repository-input h2{color:#8b5cf6;margin-bottom:1rem;text-align:center}.description{color:#888;text-align:center;margin-bottom:2rem;line-height:1.6}.input-form{margin-bottom:2rem}.input-group{margin-bottom:1.5rem}.input-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.input-group input{width:100%;padding:1rem;border:2px solid #ddd;border-radius:8px;font-size:1rem;transition:border-color .3s ease}.input-group input:focus{outline:none;border-color:#8b5cf6}.input-group input.error{border-color:#ff6b6b}.input-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.analyze-button{width:100%;padding:1rem 2rem;background:#8B5CF6;color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:500;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.analyze-button:hover:not(:disabled){background:#7C3AED;transform:translateY(-2px)}.analyze-button:disabled{background:#ccc;cursor:not-allowed;transform:none}.spinner{width:20px;height:20px;border:2px solid #ffffff3d;border-top-color:#fff;border-radius:50%;animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}.message{padding:1rem;border-radius:8px;margin:1rem 0;display:flex;align-items:flex-start;gap:.5rem}.message .icon{font-size:1.2rem;margin-right:.5rem}.error-message{background:#ffebee;color:#c62828;border:1px solid #ffcdd2;border-radius:8px;padding:1rem;margin:1rem 0;display:flex;align-items:flex-start;gap:.5rem}.error-content{flex:1}.error-text{margin-bottom:.5rem;font-weight:500}.cors-help{background:#fff3e0;border:1px solid #ffcc02;border-radius:6px;padding:1rem;margin-top:1rem}.cors-help strong{color:#e65100;display:block;margin-bottom:.5rem}.cors-help p{margin:.5rem 0;color:#bf360c}.cors-help details{margin-top:.75rem}.cors-help summary{cursor:pointer;font-weight:500;color:#e65100;margin-bottom:.5rem}.cors-help ol{margin:.5rem 0;padding-left:1.5rem}.cors-help li{margin-bottom:.5rem;color:#bf360c}.cors-help code{background:#f5f5f5;padding:.25rem .5rem;border-radius:3px;font-family:Courier New,monospace}.success-message{background:#e8f5e8;color:#2e7d32;border:1px solid #c8e6c9}.info-box{margin-top:3rem;padding:1.5rem;background:#f8f9fa;border:1px solid #e9ecef;border-radius:12px}.info-box h3{margin-top:0;margin-bottom:1rem;color:#495057}.info-box ul{margin-bottom:1rem;padding-left:1.5rem}.info-box li{margin-bottom:.5rem;color:#6c757d}.info-box p{margin-bottom:0;font-size:.9rem;color:#6c757d}.server-status{margin-bottom:2rem;padding:1rem;border-radius:8px;border:2px solid}.server-status.checking{background:#fff3cd;border-color:#ffeaa7;color:#856404}.server-status.connected{background:#d4edda;border-color:#c3e6cb;color:#155724}.server-status.disconnected{background:#f8d7da;border-color:#f5c6cb;color:#721c24}.status-item{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.status-icon{font-size:1.2rem}.status-actions{margin-left:auto;display:flex;gap:.5rem;flex-wrap:wrap}.retry-btn,.test-btn{padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .3s ease;white-space:nowrap}.retry-btn{background:#dc3545;color:#fff}.retry-btn:hover{background:#c82333}.test-btn{background:#007bff;color:#fff}.test-btn:hover{background:#0056b3}.server-help{margin-top:1.5rem;padding:1rem;background:#fff3cd;border:1px solid #ffeaa7;border-radius:8px}.server-help h4{margin:0 0 1rem;color:#856404}.server-help p{margin-bottom:.5rem;color:#856404}.server-help pre{background:#f8f9fa;padding:.5rem;border-radius:4px;border:1px solid #e9ecef;margin:.5rem 0}.server-help code{font-family:Courier New,monospace;color:#495057}.example-repos-carousel{margin:0 0 2rem;padding:0;background:transparent;border:none;border-radius:0}.example-toggle-btn{width:100%;padding:1rem 1.5rem;background:linear-gradient(135deg,#f8f9fa 0%,#ffffff 100%);border:1px solid #e9ecef;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:.75rem;font-size:1rem;color:#495057;transition:all .3s ease;margin-bottom:1rem}.example-toggle-btn:hover{background:linear-gradient(135deg,#e9ecef 0%,#f8f9fa 100%);border-color:#8b5cf6;transform:translateY(-2px);box-shadow:0 4px 8px #8b5cf61a}.toggle-icon{font-size:.8rem;transition:transform .3s ease}.toggle-text{font-weight:500}.carousel-content-box{padding:1.5rem;background:linear-gradient(135deg,#f8f9fa 0%,#ffffff 100%);border:1px solid #e9ecef;border-radius:12px;margin-bottom:1rem;box-shadow:0 2px 8px #0000000d;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.carousel-container{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;padding:0}.carousel-btn{background:#8B5CF6;color:#fff;border:none;border-radius:8px;width:48px;height:48px;font-size:1.8rem;font-weight:700;line-height:1;cursor:pointer;transition:all .3s ease;flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:0;box-shadow:0 2px 6px #8b5cf64d}.carousel-btn:hover{background:#7C3AED;transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf666}.carousel-btn:active{transform:translateY(0);box-shadow:0 2px 6px #8b5cf64d}.repo-card-carousel{flex:1;background:#ffffff;border:2px solid #e9ecef;border-radius:10px;padding:1.5rem;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px #0000000d;min-height:140px}.repo-card-carousel:hover{border-color:#8b5cf6;transform:translateY(-4px);box-shadow:0 8px 16px #8b5cf626}.carousel-indicators{display:flex;justify-content:center;gap:.5rem;margin-bottom:.75rem;padding:0}.indicator{width:8px;height:8px;border-radius:50%;border:none;background:#d0d0d0;cursor:pointer;transition:all .3s ease;padding:0}.indicator:hover{background:#a0a0a0}.indicator.active{background:#8B5CF6;width:24px;border-radius:4px}.carousel-hint{text-align:center;color:#6c757d;font-size:.9rem;margin:0;padding:0}.repo-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.repo-icon{font-size:1.5rem;line-height:1}.repo-header h4{margin:0;color:#333;font-size:1rem;flex:1}.repo-desc{color:#6c757d;font-size:.9rem;line-height:1.5;margin-bottom:.75rem}.repo-url{font-family:Courier New,monospace;font-size:.85rem;color:#8b5cf6;word-break:break-all;display:block}@media (prefers-color-scheme: dark){.input-group label{color:#e0e0e0}.input-group input{background:#2a2a2a;border-color:#444;color:#e0e0e0}.input-group input:focus{border-color:#8b5cf6}.input-group input:disabled{background-color:#1a1a1a}.info-box{background:#2a2a2a;border-color:#444}.info-box h3,.info-box li,.info-box p{color:#e0e0e0}.error-message{background:#3a1f1f;color:#faa;border-color:#5a2a2a}.success-message{background:#1f3a1f;color:#afa;border-color:#2a5a2a}.server-status.checking{background:#3a3a2a;border-color:#5a5a4a;color:#ffdb4a}.server-status.connected{background:#1f3a1f;border-color:#2a5a2a;color:#afa}.server-status.disconnected{background:#3a1f1f;border-color:#5a2a2a;color:#faa}.server-help{background:#3a3a2a;border-color:#5a5a4a}.server-help h4,.server-help p{color:#ffdb4a}.server-help pre{background:#1a1a1a;border-color:#444}.server-help code{color:#e0e0e0}.example-toggle-btn{background:linear-gradient(135deg,#2a2a2a 0%,#333333 100%);border-color:#444;color:#e0e0e0}.example-toggle-btn:hover{background:linear-gradient(135deg,#333333 0%,#3a3a3a 100%);border-color:#8b5cf6;box-shadow:0 4px 8px #8b5cf633}.carousel-content-box{background:linear-gradient(135deg,#2a2a2a 0%,#333333 100%);border-color:#444;box-shadow:0 2px 8px #0000004d}.carousel-btn{background:#7C3AED}.carousel-btn:hover{background:#6D28D9}.repo-card-carousel{background:#2a2a2a;border-color:#444}.repo-card-carousel:hover{border-color:#8b5cf6;box-shadow:0 8px 16px #8b5cf640}.indicator{background:#555}.indicator:hover{background:#777}.indicator.active{background:#a78bfa}.carousel-hint{color:#aaa}.repo-header h4{color:#e0e0e0}.repo-desc{color:#aaa}.repo-url{color:#a78bfa}}.progress-tracker{max-width:800px;margin:0 auto}.progress-tracker h2{color:#8b5cf6;margin-bottom:2rem;text-align:center}.analysis-item{padding:1rem;border:2px solid #ddd;border-radius:8px;cursor:pointer;transition:all .3s ease;background:white}.analysis-item:hover{border-color:#8b5cf6;background:#f8f9ff}.analysis-item.selected{border-color:#8b5cf6;background:#f0f2ff}.progress-details-dropdown{margin-top:.5rem;margin-bottom:1rem;border:1px solid #8B5CF6;border-radius:0 0 8px 8px;background:#f8f9ff;animation:slideDown .2s ease-out;overflow:visible}.progress-details-content{padding:1rem}.analysis-url{font-weight:500;color:#333;word-break:break-all}.analysis-meta{display:flex;gap:1rem;font-size:.9rem;color:#666}.status-badge{padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.status-queued{background:#fff3cd;color:#856404}.status-running{background:#cce5ff;color:#004085}.status-completed{background:#d4edda;color:#155724}.status-failed{background:#f8d7da;color:#721c24}.progress-details{border:1px solid #ddd;border-radius:12px;padding:1.5rem;background:white}.details-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.details-header h3{margin:0;color:#333}.refresh-button{background:#8B5CF6;color:#fff;border:none;border-radius:6px;padding:.5rem;cursor:pointer;font-size:1rem;transition:background .3s ease}.refresh-button:hover{background:#7C3AED}.error-state,.completed-state,.loading-state{text-align:center;padding:2rem}.error-state h4{color:#dc3545;margin-bottom:1rem}.completed-state h4{color:#28a745;margin-bottom:1rem}.progress-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-bottom:2rem}.progress-item{display:flex;flex-direction:column;gap:.5rem}.progress-item label{font-weight:600;color:#555;font-size:.9rem}.progress-stats h4{margin:0 0 1rem;color:#333}.progress-bar{position:relative;width:100%;height:30px;background:#f1f3f4;border-radius:15px;overflow:hidden;margin-bottom:1.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,#8B5CF6,#7C3AED);transition:width .5s ease}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#333;font-weight:600;font-size:.9rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:1rem}.stat{display:flex;flex-direction:column;gap:.25rem}.stat label{font-weight:600;color:#555;font-size:.85rem}.current-file{font-family:Courier New,monospace;background:#f8f9fa;padding:.5rem;border-radius:4px;font-size:.85rem;word-break:break-all;white-space:normal;overflow-wrap:anywhere;line-height:1.4;min-height:auto;max-width:100%}.current-file-stat{grid-column:1 / -1;width:100%}.current-file-stat .current-file{display:block;width:100%;margin-top:.25rem;box-sizing:border-box;overflow:visible;height:auto;min-height:1.5rem}.timestamps{margin-top:2rem;padding-top:1rem;border-top:1px solid #eee}.timestamp{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.9rem}.timestamp label{font-weight:500;color:#666}.running-summary{margin-top:3rem;padding-top:2rem;border-top:2px solid #f0f0f0}.running-summary h3{margin-bottom:1rem;color:#333}.running-list{display:flex;flex-direction:column;gap:.5rem}.running-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f8f9fa;border-radius:6px}.running-url{font-size:.9rem;color:#555;word-break:break-all}@media (prefers-color-scheme: dark){.analysis-selector h3,.details-header h3,.progress-stats h4,.running-summary h3{color:#e0e0e0}.analysis-item{background:#2a2a2a;border-color:#444}.analysis-item:hover{background:#333}.analysis-item.selected{background:#3a3a50}.analysis-url{color:#e0e0e0}.analysis-meta{color:#aaa}.progress-details{background:#2a2a2a;border-color:#444}.progress-details-dropdown{background:#2a2a2a;border-color:#8b5cf6}.progress-details-content{color:#e0e0e0}.progress-item label,.stat label,.timestamp label{color:#ccc}.current-file{background:#1a1a1a;color:#e0e0e0}.progress-bar{background:#333}.progress-text{color:#fff}.running-item{background:#333}.running-url{color:#ccc}}.report-viewer{max-width:1000px;margin:0 aut}.finding-item:hover{transform:translateY(-1px);box-shadow:0 4px 8px #8b5cf626;border-color:#8b5cf6}.finding-file{color:#1f2937;margin-bottom:.5rem;font-size:.9rem}.report-viewer h2{color:#8b5cf6;margin-bottom:2rem;text-align:center}.stat-item.clickable{cursor:pointer;transition:all .2s ease}.stat-item.clickable:hover{background:linear-gradient(135deg,#f3f0ff 0%,#ede9fe 100%);border-color:#8b5cf6;transform:translateY(-2px);box-shadow:0 4px 8px #8b5cf633}.findings-container{margin-top:1rem;border-top:2px solid rgba(139,92,246,.2);padding-top:1rem;background:rgba(139,92,246,.02);border-radius:8px;border:1px solid rgba(139,92,246,.1);padding:1rem;margin-top:1.5rem}.findings-list{margin-top:.5rem}.findings-list h5{color:#fff;margin-bottom:.75rem;font-size:1rem;font-weight:600;padding-bottom:.5rem;border-bottom:1px solid rgba(139,92,246,.2)}.finding-item{background:#333333;border:1px solid rgba(139,92,246,.3);border-radius:8px;padding:.75rem;margin-bottom:.75rem;box-shadow:0 2px 4px #8b5cf61a;transition:transform .2s ease,box-shadow .2s ease;color:#f0f0f0}.finding-file{color:#f0f0f0;margin-bottom:.5rem;font-size:.9rem}.finding-reason{color:#e8e8e8;margin-bottom:.5rem;font-size:.85rem;line-height:1.4}.finding-error{color:#dc2626;margin-bottom:.5rem;font-size:.85rem;background:#fef2f2;padding:.25rem .5rem;border-radius:4px}.finding-meta{color:#d0d0d0;font-size:.75rem;font-style:italic}.no-findings{color:#8b5cf6;font-style:italic;padding:1.5rem;text-align:center;background:linear-gradient(135deg,#f8f9ff 0%,#f3f0ff 100%);border-radius:8px;border:1px solid rgba(139,92,246,.2);font-weight:500}.report-viewer .progress-details-dropdown{margin-top:-1px!important;border:2px solid #8B5CF6!important;border-radius:0 0 12px 12px!important;background:#2a2a2a!important;background-color:#2a2a2a!important;animation:slideDown .2s ease-out;overflow:visible;box-shadow:0 4px 6px -1px #8b5cf61a,0 2px 4px -1px #8b5cf60f}.report-viewer .progress-details-content{padding:1.5rem!important;background:#2a2a2a!important;background-color:#2a2a2a!important}.report-viewer .report-summary{background:#2a2a2a!important;background-color:#2a2a2a!important}.report-summary{padding:1rem;background:#2a2a2a!important;border-radius:12px;border:2px solid #8B5CF6;box-shadow:0 4px 6px -1px #8b5cf61a,0 2px 4px -1px #8b5cf60f;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;max-height:0;transform:translateY(-10px)}to{opacity:1;max-height:1000px;transform:translateY(0)}}.report-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;border-bottom:2px solid #8B5CF6;padding-bottom:1rem;background:rgba(139,92,246,.1);border-radius:8px;padding:1rem;margin:-.5rem -.5rem 1.5rem}.report-header h3{margin:0;color:#fff;font-size:1.2rem}.recommendation-badge{padding:.5rem 1rem;border-radius:20px;font-weight:700;font-size:.9rem;text-transform:uppercase;box-shadow:0 2px 4px #0000001a;border:2px solid rgba(255,255,255,.3)}.risk-overview{margin-bottom:1.5rem}.risk-level{font-size:1.1rem;margin-bottom:1rem;padding:.75rem;background:#333333!important;border-radius:8px;border-left:4px solid;border:1px solid rgba(139,92,246,.2);box-shadow:0 2px 4px #8b5cf61a}.stats-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem;margin-top:1rem}.stat-item{background:#333333!important;padding:.75rem;border-radius:8px;border:1px solid rgba(139,92,246,.2);text-align:center;box-shadow:0 2px 4px #8b5cf61a;transition:transform .2s ease,box-shadow .2s ease}.stat-item.critical .stat-value{color:#991b1b!important;font-weight:700!important}.stat-item.high .stat-value{color:#dc2626!important;font-weight:700!important}.stat-item.medium .stat-value{color:#ea580c!important;font-weight:700!important}.stat-item.low .stat-value{color:#16a34a!important;font-weight:700!important}.stat-item.total .stat-value{color:#8b5cf6;font-weight:700}.stat-label{display:block;font-size:.8rem;color:#6b7280;margin-bottom:.25rem}.stat-value{display:block;font-size:1.1rem;font-weight:600}.summary-text{margin-bottom:1.5rem;background:rgba(139,92,246,.1);padding:1.25rem;border-radius:8px;border:1px solid rgba(139,92,246,.3)}.summary-text h4{color:#fff;margin-bottom:.8rem;font-size:1.15rem;font-weight:600;letter-spacing:.025em}.summary-text p{color:#f0f0f0;line-height:1.5;margin:0;font-size:.9rem;font-weight:400}.repository-info{background:#333333;padding:1.25rem;border-radius:8px;border:1px solid rgba(139,92,246,.3);box-shadow:0 2px 4px #8b5cf61a;color:#e0e0e0;margin-top:.5rem}.repository-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:.8rem;margin-top:1.2rem}.repository-info h4{margin:0 0 1rem;color:#8b5cf6;font-size:1rem;font-weight:600;letter-spacing:.025em}.repo-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.75rem}.repo-stat{display:flex;justify-content:space-between;align-items:center;white-space:nowrap;padding:.75rem 1rem;background:rgba(139,92,246,.08);border-radius:6px;border:1px solid rgba(139,92,246,.2);min-height:2.5rem;overflow:hidden}.repo-stat .label{font-size:.8rem;color:#e8e8e8;font-weight:500;margin-right:.75rem;flex-shrink:1;min-width:0}.repo-stat .value{font-weight:600!important;color:#fff!important;font-size:.8rem!important;display:inline-block!important;white-space:nowrap;flex-shrink:0;text-align:right;max-width:150px;overflow:hidden;text-overflow:ellipsis}.details-indicator{color:#6b7280;font-size:.8rem;transition:color .2s ease;-webkit-user-select:none;user-select:none}.analysis-item:hover .details-indicator,.analysis-item.expanded .details-indicator{color:#8b5cf6}.analysis-controls{display:flex;align-items:center;gap:.5rem}.empty-state{text-align:center;padding:3rem;color:#888}.empty-state p{margin-bottom:.5rem}.analysis-selector{margin-bottom:2rem}.analysis-selector h3{margin-bottom:1rem;color:#333}.analysis-list{display:flex;flex-direction:column;gap:.5rem}.analysis-item{padding:1rem;border:2px solid #ddd;border-radius:8px;cursor:pointer;transition:all .3s ease;background:#e0e0e0}.analysis-item:hover{border-color:#8b5cf6;background:linear-gradient(135deg,#f8f9ff 0%,#f3f0ff 100%);transform:translateY(-1px);box-shadow:0 4px 6px -1px #8b5cf61a,0 2px 4px -1px #8b5cf60f}.analysis-item.selected{border-color:#8b5cf6;background:linear-gradient(135deg,#f0f2ff 0%,#ede9fe 100%);box-shadow:0 4px 6px -1px #8b5cf61a,0 2px 4px -1px #8b5cf60f}.analysis-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.analysis-url{font-weight:500;color:#333;word-break:break-all;flex:1;margin-right:1rem}.analysis-date{font-size:.9rem;color:#666;white-space:nowrap}.analysis-meta{display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.analysis-id{color:#666}.risk-indicator{padding:.3rem .8rem;border-radius:20px;font-size:.8rem;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.1);box-shadow:0 2px 4px #0000001a;border:1px solid rgba(255,255,255,.2)}.risk-critical{background:linear-gradient(135deg,#B71C1C 0%,#8B0000 100%);border:2px solid rgba(255,255,255,.3);font-weight:700;text-transform:uppercase;box-shadow:0 2px 6px #b71c1c4d,inset 0 1px #ffffff1a}.risk-high{background:linear-gradient(135deg,#dc3545 0%,#c82333 100%);box-shadow:0 2px 6px #dc35454d,inset 0 1px #ffffff1a}.risk-medium{background:linear-gradient(135deg,#fd7e14 0%,#e8690b 100%);box-shadow:0 2px 6px #fd7e144d,inset 0 1px #ffffff1a}.risk-low{background:linear-gradient(135deg,#28a745 0%,#20923a 100%);box-shadow:0 2px 6px #28a7454d,inset 0 1px #ffffff1a}.error-message{background:#ffebee;color:#c62828;border:1px solid #ffcdd2;border-radius:8px;padding:1rem;margin:1rem 0;display:flex;align-items:center;gap:.5rem}.retry-button{margin-left:auto;padding:.5rem 1rem;background:#c62828;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.retry-button:hover{background:#b71c1c}.loading-state{text-align:center;padding:3rem}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #8B5CF6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.report-content{border:1px solid #ddd;border-radius:12px;padding:2rem;background:#e0e0e0}.report-header{margin-bottom:2rem;text-align:center}.report-header h3{margin:0 0 1rem;color:#333;font-size:2rem}.report-meta{display:flex;justify-content:center;gap:2rem;align-items:center;flex-wrap:wrap}.repo-name{font-weight:600;font-size:1.1rem;color:#8b5cf6}.analyzed-date{color:#666;font-size:.9rem}.security-assessment{margin-bottom:2rem}.assessment-card{background:linear-gradient(135deg,#e8e8e8 0%,#d4d4d4 100%);border:1px solid #c8d8ff;border-radius:12px;padding:1.5rem}.assessment-card h4{margin:0 0 1rem;color:#333;text-align:center}.assessment-main{display:flex;justify-content:center;gap:2rem;align-items:center;margin-bottom:1rem;flex-wrap:wrap}.risk-level{padding:.75rem 2rem;border-radius:25px;color:#fff;font-weight:600;font-size:1.1rem;text-transform:uppercase}.recommendation{padding:.75rem 1.5rem;background:#e0e0e0;border:2px solid #8B5CF6;color:#8b5cf6;border-radius:25px;font-weight:600}.assessment-summary{text-align:center;color:#555;font-size:1rem;line-height:1.6;margin:0}.statistics{margin-bottom:2rem}.statistics h4{margin-bottom:1rem;color:#333;text-align:center}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.stat-card{text-align:center;padding:1.5rem;border-radius:12px;color:#fff}.stat-card.high-risk{background:linear-gradient(135deg,#dc3545,#c82333)}.stat-card.medium-risk{background:linear-gradient(135deg,#fd7e14,#e8690b)}.stat-card.low-risk{background:linear-gradient(135deg,#28a745,#20923a)}.stat-card.total-issues{background:linear-gradient(135deg,#6c757d,#5a6268)}.stat-number{display:block;font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.stat-label{display:block;font-size:.9rem;opacity:.9}.repository-info{margin-bottom:2rem;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:1.5rem}.repository-info h4{margin:0 0 1rem;color:#333}.repo-stats{display:flex;flex-direction:column;gap:.75rem}.repo-stat{display:flex;justify-content:space-between;align-items:center}.repo-stat label{font-weight:600;color:#555}.repo-stat a{color:#8b5cf6;text-decoration:none;word-break:break-all}.repo-stat a:hover{text-decoration:underline}.findings-section{margin-bottom:2rem}.findings-section h4{margin-bottom:1.5rem;color:#333;padding-bottom:.5rem;border-bottom:2px solid #e9ecef}.findings-list{display:flex;flex-direction:column;gap:1.5rem}.finding{border:1px solid #ddd;border-radius:8px;padding:1.5rem;background:#e0e0e0}.finding-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.finding-file{margin:0;color:#333;font-family:Courier New,monospace;font-size:1rem;word-break:break-all}.finding-risk{padding:.5rem 1rem;color:#fff;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:uppercase}.finding-issues,.finding-recommendations{margin-bottom:1rem}.finding-issues h5,.finding-recommendations h5,.finding-lines h5{margin:0 0 .5rem;color:#555;font-size:.9rem}.finding-issues ul,.finding-recommendations ul{margin:0;padding-left:1.5rem}.finding-issues li,.finding-recommendations li{margin-bottom:.5rem;color:#333;line-height:1.5}.finding-lines{margin-bottom:1rem}.line-numbers{display:flex;flex-wrap:wrap;gap:.5rem}.line-number{background:#f8f9fa;padding:.25rem .5rem;border-radius:4px;font-family:Courier New,monospace;font-size:.9rem;color:#666;border:1px solid #e9ecef}.no-findings{text-align:center;background:linear-gradient(135deg,#e8f5e8,#d4edda);border:1px solid #c3e6cb;border-radius:12px;padding:2rem}.no-findings h4{color:#155724;margin-bottom:1rem}.no-findings p{color:#155724;margin:0}@media (prefers-color-scheme: dark){.analysis-selector h3,.report-header h3,.statistics h4,.repository-info h4,.findings-section h4{color:#e0e0e0}.analysis-item{background:#2a2a2a;border-color:#444}.analysis-item:hover{background:#333}.analysis-item.selected{background:#3a3a50}.analysis-url{color:#e0e0e0}.analysis-date,.analysis-id{color:#aaa}.report-content{background:#2a2a2a;border-color:#444}.assessment-card{background:linear-gradient(135deg,#2a2a3a 0%,#3a3a4a 100%);border-color:#4a4a5a}.assessment-card h4{color:#e0e0e0}.assessment-summary{color:#ccc}.repository-info{background:#333;border-color:#555}.repo-stat label{color:#ccc}.finding{background:#333;border-color:#555}.finding-file{color:#e0e0e0}.finding-issues h5,.finding-recommendations h5,.finding-lines h5{color:#ccc}.finding-issues li,.finding-recommendations li{color:#e0e0e0}.line-number{background:#1a1a1a;color:#ccc;border-color:#444}.error-message{background:#3a1f1f;color:#faa;border-color:#5a2a2a}.no-findings{background:linear-gradient(135deg,#1f3a1f,#2a4a2a);border-color:#4a6a4a}.no-findings h4,.no-findings p{color:#afa}}@media (max-width: 768px){.report-meta{flex-direction:column;gap:.5rem}.assessment-main{flex-direction:column;gap:1rem}.stats-grid{grid-template-columns:repeat(2,1fr)}.finding-header{flex-direction:column;align-items:flex-start}.repo-stat{flex-direction:column;align-items:flex-start;gap:.25rem}}: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;-webkit-text-size-adjust:100%}*{box-sizing:border-box}#root{width:100%;min-height:100vh;display:flex;flex-direction:column}a{font-weight:500;color:#8b5cf6;text-decoration:inherit}a:hover{color:#a78bfa}body{margin:0;padding:0;min-width:320px;min-height:100vh;background-color:#242424}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;color:#ffffffde;cursor:pointer;transition:border-color .25s}button:hover{border-color:#8b5cf6}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}body{background-color:#fff}a:hover{color:#7c3aed}button{background-color:#f9f9f9;color:#213547}}
