@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=Plus+Jakarta+Sans:wght@300;400;500;600;700&display=swap";:root{--font-main:"Plus Jakarta Sans", sans-serif;--font-title:"Outfit", sans-serif;--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-tertiary:#f1f5f9;--text-primary:#0f172a;--text-secondary:#475569;--text-tertiary:#94a3b8;--accent-primary:#6366f1;--accent-primary-hover:#4f46e5;--accent-secondary:#0ea5e9;--accent-success:#10b981;--accent-warning:#f59e0b;--accent-danger:#ef4444;--border-color:#e2e8f0;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000000d, 0 2px 4px -1px #00000008;--shadow-lg:0 10px 15px -3px #6366f10d, 0 4px 6px -2px #6366f105;--shadow-premium:0 20px 25px -5px #00000008, 0 10px 10px -5px #00000003;--glass-bg:#fffc;--glass-border:#e2e8f0cc;--glass-blur:12px;--transition-fast:.15s ease;--transition-normal:.25s cubic-bezier(.4, 0, .2, 1);--border-radius-sm:8px;--border-radius-md:12px;--border-radius-lg:16px;--border-radius-xl:24px}[data-theme=dark]{--bg-primary:#0b0f19;--bg-secondary:#121826;--bg-tertiary:#1f293d;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-tertiary:#64748b;--border-color:#262e3f;--shadow-sm:0 1px 2px 0 #00000080;--shadow-md:0 4px 6px -1px #0000004d, 0 2px 4px -1px #00000040;--shadow-lg:0 10px 15px -3px #0006, 0 4px 6px -2px #0000004d;--shadow-premium:0 20px 25px -5px #6366f114, 0 10px 10px -5px #6366f108;--glass-bg:#121826cc;--glass-border:#262e3fcc;--glass-blur:16px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-main);background-color:var(--bg-primary);color:var(--text-primary);transition:background-color var(--transition-normal), color var(--transition-normal);line-height:1.5;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-title);letter-spacing:-.02em;font-weight:600}.app-container{flex-direction:column;min-height:100vh;display:flex}.navbar{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);z-index:100;transition:background-color var(--transition-normal), border-color var(--transition-normal);justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex;position:sticky;top:0}.nav-brand{color:var(--text-primary);align-items:center;gap:.75rem;text-decoration:none;display:flex}.logo-icon{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));color:#fff;border-radius:var(--border-radius-md);justify-content:center;align-items:center;width:2.5rem;height:2.5rem;font-weight:700;display:flex;box-shadow:0 4px 10px #6366f14d}.logo-text{background:linear-gradient(135deg, var(--text-primary), var(--accent-primary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:1.25rem;font-weight:700}.nav-controls{align-items:center;gap:1rem;display:flex}.btn{font-family:var(--font-main);border-radius:var(--border-radius-md);cursor:pointer;transition:all var(--transition-fast);border:1px solid #0000;justify-content:center;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;text-decoration:none;display:inline-flex}.btn-primary{background-color:var(--accent-primary);color:#fff}.btn-primary:hover{background-color:var(--accent-primary-hover);transform:translateY(-1px)}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-secondary);border-color:var(--border-color)}.btn-secondary:hover{background-color:var(--border-color);color:var(--text-primary)}.btn-danger{color:var(--accent-danger);background-color:#ef44441a;border-color:#ef444433}.btn-danger:hover{background-color:var(--accent-danger);color:#fff}.btn-icon-only{border-radius:50%;width:2.5rem;height:2.5rem;padding:0}.tabs-container{background-color:var(--bg-tertiary);border-radius:var(--border-radius-md);border:1px solid var(--border-color);gap:.5rem;padding:.25rem;display:flex}.tab-btn{color:var(--text-secondary);font-family:var(--font-main);border-radius:var(--border-radius-sm);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;padding:.5rem 1.25rem;font-size:.875rem;font-weight:600}.tab-btn.active{background-color:var(--bg-secondary);color:var(--accent-primary);box-shadow:var(--shadow-sm)}.main-content{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:2rem}.view-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.view-title{color:var(--text-primary);font-size:1.875rem}.view-subtitle{color:var(--text-secondary);margin-top:.25rem;font-size:.875rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.stat-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);transition:transform var(--transition-fast), box-shadow var(--transition-fast);justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-info{flex-direction:column;display:flex}.stat-label{color:var(--text-secondary);font-size:.875rem;font-weight:500}.stat-value{font-size:1.75rem;font-family:var(--font-title);color:var(--text-primary);margin-top:.25rem;font-weight:700}.stat-icon{border-radius:var(--border-radius-md);width:3rem;height:3rem;color:var(--accent-primary);background-color:#6366f11a;justify-content:center;align-items:center;display:flex}.stat-icon.success{color:var(--accent-success);background-color:#10b9811a}.stat-icon.warning{color:var(--accent-warning);background-color:#f59e0b1a}.stat-icon.danger{color:var(--accent-danger);background-color:#ef44441a}.dashboard-grid{grid-template-columns:2fr 1fr;gap:1.5rem;margin-bottom:2rem;display:grid}@media (width<=1024px){.dashboard-grid{grid-template-columns:1fr}}.panel{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);padding:1.5rem}.panel-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:.75rem;display:flex}.panel-title{color:var(--text-primary);align-items:center;gap:.5rem;font-size:1.125rem;display:flex}.chart-container{justify-content:space-between;align-items:flex-end;height:250px;padding:1rem 0;display:flex;position:relative}.chart-bar-wrapper{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:.5rem;height:100%;display:flex}.chart-bar{background:linear-gradient(to top, var(--accent-primary), var(--accent-secondary));cursor:pointer;border-radius:6px 6px 0 0;width:40px;transition:height .5s ease-out;position:relative}.chart-bar:hover{filter:brightness(1.1)}.chart-bar-tooltip{background-color:var(--text-primary);color:var(--bg-primary);white-space:nowrap;opacity:0;transition:all var(--transition-fast);pointer-events:none;border-radius:4px;padding:.25rem .5rem;font-size:.75rem;font-weight:600;position:absolute;top:-2.5rem;transform:translateY(5px)}.chart-bar:hover .chart-bar-tooltip{opacity:1;transform:translateY(0)}.chart-bar-label{color:var(--text-secondary);font-size:.75rem;font-weight:500}.table-container{margin-top:1rem;overflow-x:auto}.custom-table{border-collapse:collapse;text-align:left;width:100%}.custom-table th{text-transform:uppercase;color:var(--text-secondary);border-bottom:2px solid var(--border-color);background-color:#00000005;padding:1rem;font-size:.75rem;font-weight:700}[data-theme=dark] .custom-table th{background-color:#ffffff03}.custom-table td{color:var(--text-primary);border-bottom:1px solid var(--border-color);vertical-align:middle;padding:1rem;font-size:.875rem}.custom-table tr:hover td{background-color:var(--bg-tertiary)}.badge{text-transform:capitalize;border-radius:9999px;align-items:center;gap:.25rem;padding:.25rem .625rem;font-size:.75rem;font-weight:600;display:inline-flex}.badge-blue{color:var(--accent-secondary);background-color:#0ea5e91a}.badge-indigo{color:var(--accent-primary);background-color:#6366f11a}.badge-green{color:var(--accent-success);background-color:#10b9811a}.badge-yellow{color:var(--accent-warning);background-color:#f59e0b1a}.badge-red{color:var(--accent-danger);background-color:#ef44441a}.filter-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.search-input-wrapper{flex:1;min-width:250px;max-width:400px;position:relative}.search-input-wrapper svg{color:var(--text-tertiary);position:absolute;top:50%;left:.75rem;transform:translateY(-50%)}.form-control{border-radius:var(--border-radius-md);border:1px solid var(--border-color);background-color:var(--bg-secondary);width:100%;color:var(--text-primary);font-family:var(--font-main);transition:all var(--transition-fast);padding:.625rem 1rem .625rem 2.5rem;font-size:.875rem}.form-control:focus{border-color:var(--accent-primary);outline:none;box-shadow:0 0 0 3px #6366f126}.select-control{border-radius:var(--border-radius-md);border:1px solid var(--border-color);background-color:var(--bg-secondary);color:var(--text-primary);font-family:var(--font-main);cursor:pointer;padding:.625rem 1.5rem .625rem 1rem;font-size:.875rem}.select-control:focus{border-color:var(--accent-primary);outline:none}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background-color:#0f172aa6;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.modal-content{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);width:100%;max-width:600px;box-shadow:var(--shadow-premium);flex-direction:column;animation:.25s cubic-bezier(.16,1,.3,1) modalEnter;display:flex;overflow:hidden}.modal-content-lg{max-width:900px}@keyframes modalEnter{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.modal-title{color:var(--text-primary);font-size:1.25rem}.modal-close{color:var(--text-secondary);cursor:pointer;width:2rem;height:2rem;transition:all var(--transition-fast);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.modal-close:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.modal-body{max-height:70vh;padding:1.5rem;overflow-y:auto}.modal-footer{border-top:1px solid var(--border-color);background-color:#00000003;justify-content:flex-end;gap:.75rem;padding:1.25rem 1.5rem;display:flex}.form-group{margin-bottom:1.25rem}.form-label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.875rem;font-weight:600;display:block}.form-help{color:var(--text-tertiary);margin-top:.25rem;font-size:.75rem}.pagination{border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-top:1.5rem;padding-top:1rem;display:flex}.pagination-info{color:var(--text-secondary);font-size:.875rem}.pagination-controls{gap:.5rem;display:flex}.scan-results-grid{grid-template-columns:1fr 2fr;gap:1.5rem;display:grid}@media (width<=768px){.scan-results-grid{grid-template-columns:1fr}}.results-sidebar{flex-direction:column;gap:1rem;display:flex}.results-main{flex-direction:column;gap:1.5rem;display:flex}.ssl-grade-card{background:linear-gradient(135deg, var(--bg-secondary), var(--bg-tertiary));border:1px solid var(--border-color);border-radius:var(--border-radius-lg);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:2rem;display:flex}.ssl-grade-val{font-family:var(--font-title);background:linear-gradient(135deg, var(--accent-success), var(--accent-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:5rem;font-weight:800;line-height:1}.ssl-grade-val.grade-F{background:linear-gradient(135deg, var(--accent-danger), var(--accent-warning));-webkit-text-fill-color:transparent;-webkit-background-clip:text}.ssl-grade-val.grade-C{background:linear-gradient(135deg, var(--accent-warning), var(--accent-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text}.tech-tag-cloud{flex-wrap:wrap;gap:.75rem;display:flex}.tech-tag-card{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);flex-direction:column;gap:.25rem;min-width:120px;padding:.75rem 1rem;display:flex}.tech-tag-name{color:var(--text-primary);font-size:.875rem;font-weight:700}.tech-tag-cat{color:var(--text-secondary);font-size:.75rem}.tech-tag-conf{color:var(--accent-primary);font-size:.75rem;font-weight:600}.code-block{color:#c9d1d9;border-radius:var(--border-radius-md);border:1px solid var(--border-color);background-color:#0d1117;max-height:400px;padding:1.25rem;font-family:Courier New,Courier,monospace;font-size:.8125rem;overflow-x:auto}.details-list{flex-direction:column;gap:.75rem;display:flex}.details-row{border-bottom:1px dashed var(--border-color);justify-content:space-between;padding-bottom:.5rem;display:flex}.details-key{color:var(--text-secondary);font-size:.875rem;font-weight:600}.details-val{color:var(--text-primary);text-align:right;word-break:break-all;font-size:.875rem}.progress-bar-bg{background-color:var(--bg-tertiary);border-radius:4px;width:100%;height:8px;position:relative;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--accent-primary), var(--accent-secondary));width:100%;height:100%;animation:2s linear infinite progressPulse;position:absolute}@keyframes progressPulse{0%{transform:translate(-100%)}to{transform:translate(100%)}}.map-placeholder{background-color:var(--bg-tertiary);border-radius:var(--border-radius-md);border:1px solid var(--border-color);height:180px;color:var(--text-secondary);justify-content:center;align-items:center;font-size:.875rem;font-weight:500;display:flex;position:relative;overflow:hidden}.map-placeholder-bg{background:radial-gradient(circle at center, transparent 30%, var(--bg-tertiary) 70%), repeating-linear-gradient(0deg, #00000008 0px, #00000008 1px, transparent 1px, transparent 20px), repeating-linear-gradient(90deg, #00000008 0px, #00000008 1px, transparent 1px, transparent 20px);position:absolute;inset:0}.loading-spinner{border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;width:2rem;height:2rem;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.alerts-container{position:relative}.alerts-badge{background-color:var(--accent-danger);color:#fff;border-radius:9999px;padding:2px 6px;font-size:10px;font-weight:700;animation:2s infinite pulseBadge;position:absolute;top:-4px;right:-4px;box-shadow:0 2px 4px #ef444466}@keyframes pulseBadge{0%{box-shadow:0 0 #ef4444b3}70%{box-shadow:0 0 0 6px #ef444400}to{box-shadow:0 0 #ef444400}}.alerts-dropdown{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);width:340px;box-shadow:var(--shadow-premium);z-index:1000;animation:.2s cubic-bezier(.16,1,.3,1) dropdownEnter;position:absolute;top:calc(100% + .5rem);right:0;overflow:hidden}@keyframes dropdownEnter{0%{opacity:0;transform:translateY(8px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.alerts-header{border-bottom:1px solid var(--border-color);background-color:var(--bg-secondary);justify-content:space-between;align-items:center;padding:.875rem 1rem;display:flex}.alerts-header h3{color:var(--text-primary);margin:0;font-size:.9rem;font-weight:600}.alerts-mark-read-btn{color:var(--accent-primary);cursor:pointer;border-radius:var(--border-radius-sm);transition:background-color var(--transition-fast);background:0 0;border:none;padding:.25rem .5rem;font-size:.75rem;font-weight:600}.alerts-mark-read-btn:hover{background-color:var(--bg-tertiary);color:var(--accent-primary-hover)}.alerts-list{background-color:var(--bg-secondary);max-height:320px;overflow-y:auto}.alerts-list::-webkit-scrollbar{width:6px}.alerts-list::-webkit-scrollbar-track{background:0 0}.alerts-list::-webkit-scrollbar-thumb{background-color:var(--border-color);border-radius:3px}.alert-item{border-bottom:1px solid var(--border-color);cursor:pointer;transition:background-color var(--transition-fast);flex-direction:column;gap:.25rem;padding:.875rem 1rem;display:flex}.alert-item:last-child{border-bottom:none}.alert-item:hover{background-color:var(--bg-tertiary)}.alert-item-title-row{align-items:flex-start;gap:.5rem;display:flex}.alert-item-icon{color:var(--accent-danger);flex-shrink:0;margin-top:2px}.alert-item-message{color:var(--text-primary);font-size:.8125rem;font-weight:500;line-height:1.4}.alert-item-time{color:var(--text-tertiary);padding-left:1.4rem;font-size:.7rem}.alerts-empty{text-align:center;color:var(--text-secondary);flex-direction:column;align-items:center;gap:.5rem;padding:2rem 1rem;font-size:.8125rem;display:flex}
