@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg-primary: #eaf2fb;--bg-secondary: #dfe9f5;--bg-tertiary: #d4dfef;--bg-card: rgba(255, 255, 255, .65);--bg-card-hover: rgba(255, 255, 255, .82);--bg-glass: rgba(255, 255, 255, .45);--bg-glass-strong: rgba(255, 255, 255, .6);--bg-sidebar: rgba(235, 243, 255, .92);--border-subtle: rgba(0, 50, 120, .08);--border-medium: rgba(0, 50, 120, .14);--border-accent: rgba(37, 99, 195, .3);--text-primary: #1a2940;--text-secondary: #4a6080;--text-muted: #8298b5;--text-inverse: #f0f4f9;--accent: #2563c4;--accent-light: #3b82f6;--accent-dark: #1d4ed8;--accent-glow: rgba(37, 99, 196, .12);--success: #16a34a;--success-bg: rgba(22, 163, 74, .1);--warning: #ca8a04;--warning-bg: rgba(202, 138, 4, .1);--danger: #dc2626;--danger-bg: rgba(220, 38, 38, .08);--danger-glow: rgba(220, 38, 38, .2);--info: #2563eb;--info-bg: rgba(37, 99, 235, .08);--score-excellent: #16a34a;--score-good: #2563c4;--score-fair: #ca8a04;--score-poor: #dc2626;--font-family: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--fs-xs: .75rem;--fs-sm: .8125rem;--fs-base: .9375rem;--fs-md: 1.0625rem;--fs-lg: 1.25rem;--fs-xl: 1.5rem;--fs-2xl: 2rem;--fs-3xl: 2.5rem;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 50%;--shadow-sm: 0 1px 3px rgba(0, 30, 80, .06);--shadow-md: 0 4px 12px rgba(0, 30, 80, .08);--shadow-lg: 0 8px 32px rgba(0, 30, 80, .1);--shadow-glow: 0 0 40px rgba(37, 99, 196, .08);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease;--sidebar-width: 260px;--header-height: 64px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);background:linear-gradient(160deg,#dce8f8,#e6eef8 30%,#edf2f9,#f0f3f8 80%,#e8edf5);color:var(--text-primary);min-height:100vh;line-height:1.6}#root{display:flex;min-height:100vh}a{color:var(--accent-dark);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent)}.app-layout{display:flex;width:100%}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px)}.sidebar-header{padding:var(--space-xl);border-bottom:1px solid var(--border-subtle)}.sidebar-logo{font-size:var(--fs-xl);font-weight:800;letter-spacing:-.5px;background:linear-gradient(135deg,#1d4ed8,#2563c4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-subtitle{font-size:var(--fs-xs);color:var(--text-muted);letter-spacing:2px;text-transform:uppercase;margin-top:var(--space-xs)}.sidebar-nav{flex:1;padding:var(--space-lg) var(--space-md);display:flex;flex-direction:column;gap:var(--space-xs)}.nav-link{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--fs-sm);font-weight:500;transition:all var(--transition-fast)}.nav-link:hover{background:var(--bg-glass);color:var(--text-primary)}.nav-link.active{background:var(--accent-glow);color:var(--accent-light);border:1px solid var(--border-accent)}.nav-icon{font-size:var(--fs-lg);width:24px;text-align:center}.main-content{flex:1;margin-left:var(--sidebar-width);padding:var(--space-2xl);max-width:1400px}.page-header{margin-bottom:var(--space-2xl)}.page-title{font-size:var(--fs-2xl);font-weight:700;letter-spacing:-.5px}.page-subtitle{color:var(--text-secondary);font-size:var(--fs-base);margin-top:var(--space-xs)}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-xl);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:all var(--transition-base)}.card:hover{background:var(--bg-card-hover);border-color:var(--border-medium);box-shadow:var(--shadow-glow)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.card-title{font-size:var(--fs-md);font-weight:600}.score-gauge{position:relative;display:flex;align-items:center;justify-content:center}.score-gauge-ring{border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;transition:all 1s ease-out}.score-gauge-inner{border-radius:var(--radius-full);background:#eef3fa;display:flex;flex-direction:column;align-items:center;justify-content:center}.score-gauge-value{font-weight:800;letter-spacing:-1px;line-height:1}.score-gauge-label{font-size:var(--fs-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-top:var(--space-xs)}.score-gauge--lg .score-gauge-ring{width:180px;height:180px}.score-gauge--lg .score-gauge-inner{width:148px;height:148px}.score-gauge--lg .score-gauge-value{font-size:var(--fs-3xl)}.score-gauge--md .score-gauge-ring{width:120px;height:120px}.score-gauge--md .score-gauge-inner{width:96px;height:96px}.score-gauge--md .score-gauge-value{font-size:var(--fs-xl)}.score-gauge--sm .score-gauge-ring{width:72px;height:72px}.score-gauge--sm .score-gauge-inner{width:56px;height:56px}.score-gauge--sm .score-gauge-value{font-size:var(--fs-base)}.score-gauge--sm .score-gauge-label{display:none}.badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--fs-xs);font-weight:600;letter-spacing:.5px;text-transform:uppercase}.badge--success{background:var(--success-bg);color:var(--success)}.badge--warning{background:var(--warning-bg);color:var(--warning)}.badge--danger{background:var(--danger-bg);color:var(--danger)}.badge--info{background:var(--info-bg);color:var(--info)}.badge--accent{background:var(--accent-glow);color:var(--accent-light)}.badge--neutral{background:var(--bg-glass);color:var(--text-secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--fs-sm);font-weight:600;cursor:pointer;border:none;transition:all var(--transition-fast);white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;box-shadow:0 2px 8px #2563c433}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #2563c44d}.btn-secondary{background:var(--bg-glass-strong);color:var(--text-primary);border:1px solid var(--border-medium)}.btn-secondary:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--border-accent)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-glass);color:var(--text-primary)}.btn-sm{padding:var(--space-xs) var(--space-md);font-size:var(--fs-xs)}.btn-lg{padding:var(--space-md) var(--space-xl);font-size:var(--fs-base)}.form-group{display:flex;flex-direction:column;gap:var(--space-xs)}.form-label{font-size:var(--fs-sm);font-weight:500;color:var(--text-secondary)}.form-input,.form-select{padding:var(--space-md);background:var(--bg-glass);border:1px solid var(--border-medium);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-family);font-size:var(--fs-sm);transition:all var(--transition-fast)}.form-input:focus,.form-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.form-input::placeholder{color:var(--text-muted)}.modal-backdrop{position:fixed;inset:0;background:#0014324d;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal{background:#f5f8fc;border:1px solid var(--border-medium);border-radius:var(--radius-xl);padding:var(--space-2xl);width:90%;max-width:480px;box-shadow:var(--shadow-lg);animation:slideUp .3s ease}.modal-title{font-size:var(--fs-xl);font-weight:700;margin-bottom:var(--space-lg)}.modal-actions{display:flex;gap:var(--space-md);justify-content:flex-end;margin-top:var(--space-xl)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.grid{display:grid;gap:var(--space-lg)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.gap-xl{gap:var(--space-xl)}.code-block{background:#1e293b;border:1px solid rgba(30,41,59,.2);border-radius:var(--radius-md);overflow:hidden}.code-block-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);background:#162033;border-bottom:1px solid rgba(255,255,255,.06)}.code-block-lang{font-size:var(--fs-xs);color:#94a3b8;font-family:var(--font-mono)}.code-block-content{padding:var(--space-md);overflow-x:auto}.code-block-content pre{font-family:var(--font-mono);font-size:var(--fs-xs);color:#93c5fd;white-space:pre;line-height:1.7}.btn-copy{padding:var(--space-xs) var(--space-sm);font-size:var(--fs-xs);background:#ffffff1a;color:#94a3b8;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.btn-copy:hover{color:#e2e8f0;border-color:#3b82f6}.btn-copy.copied{color:var(--success);border-color:var(--success)}.table-container{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border-subtle)}table{width:100%;border-collapse:collapse}th{text-align:left;padding:var(--space-md) var(--space-lg);font-size:var(--fs-xs);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;background:#0028640a;border-bottom:1px solid var(--border-subtle)}td{padding:var(--space-md) var(--space-lg);font-size:var(--fs-sm);border-bottom:1px solid var(--border-subtle)}tr:hover td{background:var(--bg-glass)}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-lg);margin-bottom:var(--space-2xl)}.stat-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-xl);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.stat-value{font-size:var(--fs-2xl);font-weight:800;letter-spacing:-.5px}.stat-label{font-size:var(--fs-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-top:var(--space-xs)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-3xl);color:var(--text-muted)}.spinner{width:40px;height:40px;border:3px solid var(--border-subtle);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:var(--space-md)}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:var(--space-3xl)}.empty-state-icon{font-size:3rem;margin-bottom:var(--space-md)}.empty-state-title{font-size:var(--fs-lg);font-weight:600;margin-bottom:var(--space-sm)}.empty-state-text{color:var(--text-secondary);font-size:var(--fs-sm)}.expandable-toggle{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:var(--fs-sm);transition:transform var(--transition-fast)}.expandable-toggle.open{transform:rotate(90deg)}.expandable-content{padding:var(--space-md) var(--space-lg) var(--space-lg);background:#00286408;border-bottom:1px solid var(--border-subtle)}@media(max-width:1024px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.sidebar{display:none}.main-content{margin-left:0;padding:var(--space-lg)}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.stats-row{grid-template-columns:repeat(2,1fr)}}.severity-bar{height:6px;background:var(--bg-glass);border-radius:3px;overflow:hidden;width:60px}.severity-fill{height:100%;border-radius:3px;transition:width var(--transition-base)}.toggle{position:relative;width:44px;height:24px;cursor:pointer}.toggle input{display:none}.toggle-slider{position:absolute;inset:0;background:var(--bg-glass-strong);border-radius:12px;border:1px solid var(--border-medium);transition:all var(--transition-fast)}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;border-radius:50%;background:var(--text-secondary);top:2px;left:2px;transition:all var(--transition-fast)}.toggle input:checked+.toggle-slider{background:var(--accent-glow);border-color:var(--accent)}.toggle input:checked+.toggle-slider:before{transform:translate(20px);background:var(--accent-light)}.qa-list{display:flex;flex-direction:column;gap:var(--space-md)}.qa-card{background:var(--bg-glass);border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden;transition:all var(--transition-base)}.qa-card:hover{border-color:var(--border-medium)}.qa-card--expanded{border-color:var(--border-accent);box-shadow:0 0 20px #2563c40f}.qa-card-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-lg);background:none;border:none;color:var(--text-primary);font-family:var(--font-family);cursor:pointer;text-align:left;gap:var(--space-md);transition:background var(--transition-fast)}.qa-card-header:hover{background:var(--bg-glass)}.qa-card-left{display:flex;align-items:flex-start;gap:var(--space-md);flex:1;min-width:0}.qa-number{display:flex;align-items:center;justify-content:center;width:28px;height:28px;min-width:28px;border-radius:var(--radius-full);background:var(--accent-glow);color:var(--accent-light);font-size:var(--fs-xs);font-weight:700}.qa-question-text{flex:1;min-width:0}.qa-prompt{font-size:var(--fs-sm);font-weight:500;line-height:1.5;display:block;margin-bottom:var(--space-sm)}.qa-meta{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.qa-chevron{font-size:var(--fs-lg);color:var(--text-muted);transition:transform var(--transition-fast);flex-shrink:0}.qa-chevron--open{transform:rotate(90deg)}.qa-card-body{padding:0 var(--space-lg) var(--space-lg);border-top:1px solid var(--border-subtle);animation:fadeIn .2s ease}.qa-section{margin-top:var(--space-lg)}.qa-section-label{font-size:var(--fs-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--space-sm)}.qa-response{background:#001e500a;border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-lg);font-size:var(--fs-sm);color:var(--text-secondary);line-height:1.8;white-space:pre-wrap;word-wrap:break-word;font-family:var(--font-family)}.qa-citations{display:flex;flex-direction:column;gap:var(--space-md)}.qa-citation{background:#001e5008;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:var(--space-md)}.qa-citation-badges{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-bottom:var(--space-sm)}.qa-citation-context{font-size:var(--fs-xs);color:var(--text-secondary);font-style:italic;line-height:1.6;padding-left:var(--space-md);border-left:2px solid var(--accent-glow)}.tips-grid{display:flex;flex-direction:column;gap:var(--space-md)}.tip-card{background:var(--bg-glass);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-lg);transition:all var(--transition-base)}.tip-card:hover{border-color:var(--border-medium);background:var(--bg-card-hover)}.tip-header{display:flex;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-md)}.tip-icon{font-size:1.5rem;flex-shrink:0;margin-top:2px}.tip-title-group{flex:1;min-width:0}.tip-title{font-size:var(--fs-md);font-weight:600;margin-bottom:var(--space-xs)}.tip-description{color:var(--text-secondary);font-size:var(--fs-sm);line-height:1.7;padding-left:calc(1.5rem + var(--space-md))}@media(max-width:768px){.qa-card-header{padding:var(--space-md)}.qa-card-body{padding:0 var(--space-md) var(--space-md)}.tip-description{padding-left:0}}.issue-alert-banner{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:#dc26260f;border:1px solid rgba(220,38,38,.2);border-left:4px solid var(--danger);border-radius:var(--radius-md);margin-bottom:var(--space-lg);animation:issueSlideIn .3s ease}.issue-alert-banner .issue-alert-icon{font-size:1.3rem;flex-shrink:0}.issue-alert-banner .issue-alert-text{flex:1}.issue-alert-banner .issue-alert-title{font-weight:700;font-size:var(--fs-sm);color:var(--danger)}.issue-alert-banner .issue-alert-desc{font-size:var(--fs-xs);color:var(--text-secondary);margin-top:2px}.issue-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;border-radius:11px;font-size:.7rem;font-weight:700;color:#fff;background:var(--danger);box-shadow:0 0 6px var(--danger-glow),0 1px 3px #00000026;animation:issuePulse 2s ease-in-out infinite;letter-spacing:.3px}.issue-count-badge--lg{min-width:32px;height:32px;padding:0 10px;border-radius:16px;font-size:var(--fs-sm)}.issue-row-highlight td{background:var(--danger-bg)!important;border-bottom-color:#f8514926}.issue-row-highlight:hover td{background:#f851492e!important}.issue-severity-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:var(--radius-sm);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.issue-severity-chip--critical{background:#dc262614;color:var(--danger);border:1px solid rgba(220,38,38,.2)}.issue-severity-chip--warning{background:#ca8a0414;color:var(--warning);border:1px solid rgba(202,138,4,.2)}.issue-severity-chip--info{background:#2563eb0f;color:var(--info);border:1px solid rgba(37,99,235,.15)}.issue-dot-pulse{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--danger);box-shadow:0 0 0 0 var(--danger-glow);animation:dotPulse 1.5s ease-in-out infinite}.card--has-issues{border-color:#dc262633;box-shadow:0 0 20px #dc26260a,inset 0 1px #dc26260f}.card--has-issues:hover{border-color:#dc262659;box-shadow:0 0 30px #dc26260f}.stat-card--issues{border-color:#dc262633;background:linear-gradient(135deg,rgba(220,38,38,.04),var(--bg-card))}.stat-card--issues .stat-value{color:var(--danger)}@keyframes issuePulse{0%,to{box-shadow:0 0 6px var(--danger-glow),0 1px 3px #00000026}50%{box-shadow:0 0 14px var(--danger-glow),0 1px 4px #00000026}}@keyframes dotPulse{0%{box-shadow:0 0 #dc262673}70%{box-shadow:0 0 0 8px #dc262600}to{box-shadow:0 0 #dc262600}}@keyframes issueSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
