:root{--bg: #09090b;--bg-elevated: #131316;--surface: #1c1c21;--surface-soft: rgba(255,255,255,.04);--surface-hover: rgba(255,255,255,.07);--surface-muted: #111113;--text-primary: #f4f4f5;--text-secondary: #a1a1aa;--text-tertiary: #71717a;--accent: #2563eb;--accent-hover: #60a5fa;--accent-muted: #1d4ed8;--accent-subtle: rgba(59, 130, 246, .12);--error: #ef4444;--error-bg: rgba(239, 68, 68, .1);--warning: #f59e0b;--success: #22c55e;--border-subtle: rgba(255,255,255,.07);--border-strong: rgba(255,255,255,.14);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-section: 64px;--max-width: 1200px;--radius: 8px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 12px;--radius-xl: 16px;--ease-smooth: cubic-bezier(.4, 0, .2, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--duration-fast: .12s;--duration-normal: .2s;--duration-slow: .4s;--shadow-xs: 0 1px 2px rgba(0,0,0,.2);--shadow-sm: 0 1px 3px rgba(0,0,0,.3), 0 1px 2px rgba(0,0,0,.2);--shadow-md: 0 4px 14px rgba(0,0,0,.35), 0 2px 4px rgba(0,0,0,.2);--shadow-lg: 0 10px 30px rgba(0,0,0,.4), 0 4px 8px rgba(0,0,0,.25);--shadow-glow: 0 0 20px rgba(59, 130, 246, .15)}.no-js #scanner,.no-js #results{display:none!important}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:16px;font-weight:400;line-height:1.6;color:var(--text-primary);background:var(--bg);min-height:100vh}h1{font-size:1.875rem;font-weight:600;letter-spacing:-.025em;line-height:1.3}h2{font-size:1.375rem;font-weight:600;letter-spacing:-.02em;line-height:1.35;color:var(--text-primary)}h3{font-size:1.1rem;font-weight:500;letter-spacing:-.01em;line-height:1.4;color:var(--text-primary)}h4,h5,h6{font-size:.9375rem;font-weight:500;line-height:1.5}p{font-size:.9375rem;font-weight:400;line-height:1.6;color:var(--text-secondary)}code,pre,.code-content{font-family:JetBrains Mono,monospace;font-size:.8125rem}#app{max-width:var(--max-width);margin:0 auto;padding:var(--space-lg)}section{margin-bottom:var(--space-section)}#landing{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 56px);padding:24px;background:radial-gradient(ellipse at 50% 20%,rgba(59,130,246,.06) 0%,transparent 65%)}.landing-tagline{font-size:.9375rem;color:var(--text-tertiary);margin-bottom:var(--space-lg);text-align:center}#url-input{display:block;width:100%;max-width:560px;height:54px;padding:0 22px;font-family:inherit;font-size:1rem;font-weight:400;color:var(--text-primary);background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);outline:none;box-sizing:border-box;-webkit-appearance:none;appearance:none;transition:border-color var(--duration-normal) var(--ease-smooth),box-shadow var(--duration-normal) var(--ease-smooth),background var(--duration-normal) var(--ease-smooth)}.scan-input-row{display:flex;align-items:center;gap:10px;width:100%;max-width:680px;margin:0 auto;justify-content:center}.scan-input-row #url-input{flex:1;max-width:none;margin:0}.scan-btn{display:inline-flex;align-items:center;gap:6px;height:54px;padding:0 24px;font-size:1rem;font-weight:600;white-space:nowrap;border-radius:var(--radius-lg);cursor:pointer;flex-shrink:0}.scan-btn svg{flex-shrink:0}#url-input:disabled{opacity:.6;cursor:not-allowed}#url-input::placeholder{color:var(--text-tertiary)}#url-input:hover{border-color:var(--border-strong);background:var(--bg-elevated)}#url-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #3b82f626;background:var(--bg-elevated)}#scanner{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 48px)}.scan-container{display:flex;flex-direction:column;align-items:center;gap:var(--space-xl);max-width:400px;width:100%}.scan-ring{position:relative;width:160px;height:160px}.scan-ring svg{width:100%;height:100%;transform:rotate(-90deg)}.ring-bg{fill:none;stroke:var(--surface);stroke-width:2}.ring-progress{fill:none;stroke:var(--accent-muted);stroke-width:2;stroke-linecap:round;stroke-dasharray:339.292;stroke-dashoffset:339.292;transition:stroke-dashoffset var(--duration-slow) var(--ease-smooth),stroke 1.5s var(--ease-smooth)}.ring-progress.phase-1{stroke:var(--accent-muted)}.ring-progress.phase-2{stroke:var(--warning)}.ring-progress.phase-3{stroke:var(--success)}.ring-progress.phase-error{stroke:var(--error)}.ring-pulse{fill:none;stroke:var(--accent);stroke-width:1;stroke-opacity:0;animation:ring-expand 3s ease-out infinite}.ring-pulse-2{animation-delay:1.5s}@keyframes ring-expand{0%{r:50;stroke-opacity:.3;stroke-width:2}to{r:70;stroke-opacity:0;stroke-width:0}}.scan-percentage{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:28px;font-weight:500;color:var(--text-primary);font-variant-numeric:tabular-nums}.scan-info{text-align:center}.scan-status{font-size:12px;font-weight:400;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.12em;opacity:.65;margin-bottom:var(--space-xs)}.scan-sub-status{font-size:12px;color:var(--text-tertiary);opacity:.5}.scan-phases{display:flex;flex-direction:column;gap:var(--space-sm);width:100%;padding:var(--space-md);background:var(--surface-soft);border-radius:var(--radius-sm)}.phase{display:flex;align-items:center;gap:var(--space-sm);font-size:12px;color:var(--text-tertiary);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);transition:opacity var(--duration-normal) var(--ease-smooth),color var(--duration-normal) var(--ease-smooth)}.phase-text{flex:1;position:relative}.phase.active{color:var(--text-secondary)}.phase.active .phase-text:before{content:"\25cb";position:absolute;left:-16px;color:var(--accent);animation:pulse-soft 2s ease-in-out infinite}.phase.complete{color:var(--text-tertiary)}.phase.complete .phase-text:before{content:"\2713";position:absolute;left:-16px;color:var(--success)}@keyframes pulse-soft{0%,to{opacity:1}50%{opacity:.5}}.scan-footer{width:100%}.scan-activity{display:flex;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);font-size:12px;color:var(--text-tertiary);opacity:.6}.scan-dots{display:flex;gap:4px}.scan-dot{width:4px;height:4px;background:var(--text-tertiary);border-radius:50%;animation:dot-pulse 1.8s ease-in-out infinite}.scan-dot:nth-child(2){animation-delay:.3s}.scan-dot:nth-child(3){animation-delay:.6s}@keyframes dot-pulse{0%,80%,to{transform:scale(.8);opacity:.4}40%{transform:scale(1);opacity:.8}}.scan-timing{color:var(--text-tertiary)}.scan-skip{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);margin-top:var(--space-sm)}.skip-message{color:var(--text-muted);font-size:13px}.btn-skip{background:transparent;color:var(--text-muted);border:1px solid var(--border);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:12px;cursor:pointer}.btn-skip:hover{color:var(--text-primary);border-color:var(--text-muted)}#results{padding-top:var(--space-xl)}.results-section{margin-bottom:var(--space-section)}.section-label{display:inline-block;font-size:.6875rem;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-sm);padding:3px 8px;background:var(--accent-subtle);border-radius:var(--radius-sm)}.results-section h2{font-size:1.375rem;font-weight:600;margin-bottom:var(--space-sm);padding-bottom:var(--space-md);border-bottom:1px solid var(--border-subtle)}.results-section h3{font-size:1rem;font-weight:500;margin-bottom:var(--space-md)}.overview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--space-md);margin-bottom:var(--space-xl)}.overview-card{padding:var(--space-lg);background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:border-color var(--duration-normal) var(--ease-smooth),box-shadow var(--duration-normal) var(--ease-smooth)}.overview-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.card-label{font-size:.8125rem;color:var(--text-tertiary);margin-bottom:var(--space-sm);font-weight:500}.card-value{font-size:2rem;font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums;letter-spacing:-.02em}.card-value.good{color:var(--success)}.card-value.warning{color:var(--warning)}.card-value.poor{color:var(--error)}.card-metrics{margin-top:var(--space-xs);font-size:12px;color:var(--text-tertiary)}.estimation-warning{margin-top:var(--space-sm);font-size:11px;color:var(--text-tertiary);opacity:.7}.estimation-warning.warning-error{color:#ff6b6b;font-weight:500;opacity:1}.core-vitals{margin-top:var(--space-xl)}.core-vitals h3{font-size:.8125rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-md);font-weight:600}.vitals-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-md)}.vital-item{padding:var(--space-md);background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius);transition:border-color var(--duration-normal) var(--ease-smooth)}.vital-item:hover{border-color:var(--border-strong)}.vital-name{font-size:.8125rem;color:var(--text-tertiary);margin-bottom:var(--space-xs)}.vital-value{font-size:1.0625rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:var(--space-sm)}.vital-rating{font-size:.625rem;font-weight:600;padding:2px 8px;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.05em}.vital-rating.good{background:#5dd39e26;color:var(--success)}.vital-rating.warning{background:#ffb02026;color:var(--warning)}.vital-rating.poor{background:#ff6b6b26;color:var(--error)}.graph-controls{display:flex;gap:var(--space-sm);margin-bottom:var(--space-lg)}.graph-btn{padding:var(--space-sm) var(--space-md);font-family:inherit;font-size:.8125rem;font-weight:500;color:var(--text-tertiary);background:transparent;border:1px solid transparent;border-radius:var(--radius);cursor:pointer;transition:color var(--duration-normal) var(--ease-smooth),background var(--duration-normal) var(--ease-smooth),border-color var(--duration-normal) var(--ease-smooth)}.graph-btn:hover{color:var(--text-secondary);background:var(--surface-soft)}.graph-btn.active{color:var(--text-primary);background:var(--surface);border-color:var(--border-subtle)}#execution-graph{width:100%;height:450px;background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:auto;position:relative}#execution-graph svg{min-width:100%;min-height:100%;display:block}.graph-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-tertiary);font-size:12px}.graph-legend{display:flex;gap:var(--space-lg);margin-top:var(--space-md);font-size:.75rem;color:var(--text-tertiary);font-weight:500}.legend-item{display:flex;align-items:center;gap:6px}.legend-color{width:8px;height:8px;border-radius:50%}.node circle{stroke-width:1.5;cursor:pointer;transition:opacity var(--duration-fast) var(--ease-smooth);opacity:.8}.node circle:hover{opacity:1}.node text{font-size:10px;fill:var(--text-tertiary);pointer-events:none}.link{fill:none;stroke:var(--text-tertiary);stroke-opacity:.15;stroke-width:1;transition:stroke-opacity var(--duration-fast) var(--ease-smooth)}.link.highlighted{stroke:var(--accent);stroke-opacity:.6;stroke-width:1.5}.explorer-container{display:grid;grid-template-columns:260px 1fr;gap:var(--space-lg);height:480px}.file-tree{background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow-y:auto;padding:var(--space-md)}.tree-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-sm);color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-sm);font-size:.8125rem;transition:background var(--duration-fast) var(--ease-smooth),color var(--duration-fast) var(--ease-smooth)}.tree-item:hover{color:var(--text-secondary);background:var(--surface-hover)}.tree-item.active{color:var(--text-primary);background:var(--accent-subtle)}.tree-item.folder{color:var(--text-secondary)}.tree-item .icon{width:14px;font-size:11px;text-align:center;opacity:.6}.tree-children{padding-left:var(--space-md)}.tree-children.collapsed{display:none}.code-viewer{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden}.code-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-lg);background:var(--surface);border-bottom:1px solid var(--border-subtle)}.code-filename{font-family:JetBrains Mono,monospace;font-size:.8125rem;color:var(--text-tertiary)}.code-size{font-size:.6875rem;color:var(--text-tertiary);opacity:.6}.code-content{flex:1;padding:var(--space-lg);overflow:auto;color:var(--text-secondary);white-space:pre;tab-size:2;font-size:13px;line-height:1.6}.code-content .keyword{color:#8a9ccc}.code-content .string{color:#8fbf8f}.code-content .number{color:#d4a574}.code-content .comment{color:#5a5a5a}.code-content .function{color:#9cb4d4}.explorer-cta{margin-top:var(--space-lg);padding:var(--space-md);text-align:center}.explorer-cta p{color:var(--text-tertiary);font-size:13px;margin:0}.ai-chat-section{margin-top:var(--space-xl)}.ai-chat-section h3{font-size:.8125rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-md)}.ai-chat-container{background:var(--surface);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-subtle)}.ai-chat-messages{height:280px;overflow-y:auto;padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md)}.ai-message{display:flex;gap:var(--space-sm);max-width:85%}.ai-message.user{align-self:flex-end;flex-direction:row-reverse}.ai-message-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent-subtle);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:.625rem;font-weight:600;flex-shrink:0}.ai-message.user .ai-message-avatar{background:var(--surface)}.ai-message-content{padding:var(--space-sm) var(--space-md);font-size:.875rem;line-height:1.6;color:var(--text-secondary)}.ai-message.user .ai-message-content{color:var(--text-primary)}.ai-message-content code{background:var(--surface);padding:2px 6px;border-radius:3px;font-family:JetBrains Mono,monospace;font-size:12px}.ai-message-content pre{background:var(--surface);padding:var(--space-sm);border-radius:var(--radius-sm);overflow-x:auto;margin:var(--space-sm) 0}.ai-message.typing .ai-message-content:after{content:"...";animation:typing-dots 1.5s infinite}@keyframes typing-dots{0%,20%{content:"."}40%{content:".."}60%,to{content:"..."}}.ai-chat-input-container{display:flex;padding:var(--space-md);background:var(--surface);border-top:1px solid var(--border-subtle)}.ai-chat-input{flex:1;padding:var(--space-sm) var(--space-md);font-family:JetBrains Mono,monospace;font-size:13px;color:var(--text-primary);background:var(--bg);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);outline:none;transition:border-color var(--duration-fast) var(--ease-smooth)}.ai-chat-input:focus{border-color:var(--accent-muted)}.ai-chat-input::placeholder{color:var(--text-tertiary)}.ai-chat-send{display:flex;align-items:center;justify-content:center;width:36px;height:36px;margin-left:var(--space-sm);background:var(--accent);border:none;border-radius:var(--radius);color:#fff;cursor:pointer;flex-shrink:0;transition:background var(--duration-fast) var(--ease-smooth)}.ai-chat-send:hover{background:var(--accent-hover)}.ai-chat-send svg{width:16px;height:16px}.surgeon-chat{margin-top:var(--space-xl);padding-top:var(--space-xl);border-top:1px solid var(--border-subtle)}.issues-tabs{display:flex;gap:var(--space-sm);margin-bottom:var(--space-lg)}.issue-tab{padding:var(--space-sm) var(--space-md);font-family:inherit;font-size:.8125rem;font-weight:500;color:var(--text-tertiary);background:transparent;border:1px solid transparent;border-radius:var(--radius);cursor:pointer;transition:color var(--duration-normal) var(--ease-smooth),background var(--duration-normal) var(--ease-smooth),border-color var(--duration-normal) var(--ease-smooth)}.issue-tab:hover{color:var(--text-secondary);background:var(--surface-soft)}.issue-item.selected{background:#3b82f60f;border-left:3px solid var(--accent);padding-left:12px}.issue-tab.active{color:var(--text-primary);background:var(--surface);border-color:var(--border-subtle)}.issues-list{display:flex;flex-direction:column;gap:var(--space-sm)}.issue-item{padding:var(--space-md) var(--space-lg);background:transparent;border-radius:var(--radius);cursor:pointer;transition:background var(--duration-fast) var(--ease-smooth)}.issue-item:hover{background:var(--surface-soft)}.issue-item.selected{background:var(--accent-subtle);border-left:3px solid var(--accent)}.issue-header{display:flex;align-items:center;gap:var(--space-sm)}.issue-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.issue-dot.breaks{background:var(--error);opacity:.7}.issue-dot.security{background:var(--warning);opacity:.7}.issue-dot.seo{background:var(--accent);opacity:.7}.issue-title{font-size:.9375rem;font-weight:500;color:var(--text-primary)}.issue-details{padding-left:calc(6px + var(--space-sm));margin-top:var(--space-sm);max-height:0;overflow:hidden;transition:max-height var(--duration-normal) var(--ease-smooth)}.issue-item.expanded .issue-details{max-height:300px}.issue-trigger,.issue-affected,.issue-impact{font-size:.8125rem;color:var(--text-tertiary);margin-bottom:var(--space-xs)}.issue-trigger strong,.issue-affected strong,.issue-impact strong{color:var(--text-secondary);font-weight:400}.issue-code{margin-top:var(--space-md);padding:var(--space-md);background:var(--bg-elevated);border-radius:var(--radius-sm);font-family:JetBrains Mono,monospace;font-size:12px;color:var(--text-tertiary);overflow-x:auto}.seo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--space-lg)}.seo-card{padding:var(--space-lg);background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:border-color var(--duration-normal) var(--ease-smooth)}.seo-card:hover{border-color:var(--border-strong)}.seo-card h3{font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-subtle)}.seo-content{font-size:.875rem;color:var(--text-secondary)}.seo-item{display:flex;justify-content:space-between;padding:var(--space-xs) 0}.seo-item .label{color:var(--text-tertiary)}.seo-item .value{color:var(--text-primary)}.seo-item .value.missing{color:var(--error);opacity:.7}.seo-item .value.present{color:var(--success);opacity:.8}.surgeon-container{display:flex;flex-direction:column;gap:var(--space-xl)}.drop-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-section);background:transparent;border:1.5px dashed var(--border-strong);border-radius:var(--radius-lg);cursor:pointer;transition:border-color var(--duration-normal) var(--ease-smooth),background var(--duration-normal) var(--ease-smooth)}.drop-zone:hover,.drop-zone:focus{border-color:var(--accent);background:var(--accent-subtle)}.drop-zone.drag-over{border-color:var(--accent);border-style:solid;background:var(--accent-subtle)}.drop-icon{width:40px;height:40px;margin-bottom:var(--space-md);color:var(--text-tertiary);opacity:.5}.drop-text{text-align:center;color:var(--text-tertiary);line-height:1.6;font-size:13px}.drop-subtext{font-size:11px;color:var(--text-tertiary);opacity:.6}.drop-limits{margin-top:var(--space-md);font-size:11px;color:var(--text-tertiary);opacity:.4}.upload-summary{padding:var(--space-lg);background:var(--surface-soft);border-radius:var(--radius)}.upload-summary h3{font-size:12px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-md)}.summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg);margin-bottom:var(--space-lg)}.summary-item{display:flex;flex-direction:column;gap:var(--space-xs)}.summary-label{font-size:.75rem;color:var(--text-tertiary)}.summary-value{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.file-breakdown{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-lg)}.file-type-badge{font-size:.6875rem;padding:var(--space-xs) var(--space-sm);background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-tertiary)}.upload-actions{display:flex;gap:var(--space-md);justify-content:flex-end}.btn-primary,.btn-secondary{padding:var(--space-sm) var(--space-lg);font-family:inherit;font-size:.875rem;font-weight:500;border-radius:var(--radius);cursor:pointer;transition:all var(--duration-fast) var(--ease-smooth)}.btn-primary{color:#fff;background:var(--accent);border:1px solid var(--accent)}.btn-primary:hover{background:var(--accent-muted);border-color:var(--accent-muted);box-shadow:var(--shadow-sm)}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.btn-secondary{color:var(--text-secondary);background:transparent;border:1px solid var(--border-strong)}.btn-secondary:hover{color:var(--text-primary);border-color:var(--text-tertiary);background:var(--surface-hover)}.ai-analysis{padding:var(--space-lg);background:var(--surface-soft);border-radius:var(--radius)}.ai-loading{padding:var(--space-lg)}.analysis-progress{width:100%}.analysis-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.analysis-status{font-size:12px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em}.btn-stop{padding:var(--space-xs) var(--space-md);font-family:inherit;font-size:11px;color:var(--error);background:transparent;border:1px solid var(--error);border-radius:var(--radius-sm);cursor:pointer;opacity:.7;transition:opacity var(--duration-fast) var(--ease-smooth)}.btn-stop:hover{opacity:1}.analysis-file-progress{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:var(--space-sm)}.analysis-current{display:flex;flex-direction:column;gap:2px}.analysis-label{font-size:11px;color:var(--text-tertiary)}.analysis-filename{font-family:JetBrains Mono,monospace;font-size:13px;color:var(--text-primary);max-width:400px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.analysis-counter{font-size:13px;color:var(--text-secondary);font-variant-numeric:tabular-nums}.analysis-bar-container{height:2px;background:var(--surface);border-radius:1px;overflow:hidden;margin-bottom:var(--space-lg)}.analysis-bar{height:100%;width:0%;background:var(--accent);border-radius:1px;transition:width var(--duration-normal) var(--ease-smooth)}.analysis-files-list{max-height:200px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.analysis-file-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:12px;transition:background var(--duration-fast) var(--ease-smooth)}.analysis-file-item.pending{color:var(--text-tertiary)}.analysis-file-item.analyzing{color:var(--text-primary);background:var(--accent-subtle)}.analysis-file-item.complete{color:var(--text-tertiary)}.analysis-file-item.stopped{color:var(--text-tertiary);opacity:.5}.analysis-file-icon{width:14px;font-size:10px;text-align:center;flex-shrink:0}.analysis-file-item.pending .analysis-file-icon:before{content:"\25cb";color:var(--text-tertiary)}.analysis-file-item.analyzing .analysis-file-icon:before{content:"\25d0";color:var(--accent);animation:spin 1s linear infinite}.analysis-file-item.complete .analysis-file-icon:before{content:"\2713";color:var(--success)}.analysis-file-item.stopped .analysis-file-icon:before{content:"\2014";color:var(--text-tertiary)}.analysis-file-name{font-family:JetBrains Mono,monospace;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ai-spinner{width:16px;height:16px;border:1.5px solid var(--surface);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.ai-results{font-size:.875rem;line-height:1.6;color:var(--text-secondary)}.ai-section{margin-bottom:var(--space-lg)}.ai-section h4{font-size:12px;font-weight:400;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-sm)}.ai-summary{border-bottom:1px solid var(--border-subtle);padding-bottom:var(--space-lg)}.ai-score{font-size:16px;color:var(--text-secondary);margin-bottom:var(--space-sm)}.ai-score strong{color:var(--accent)}.ai-files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-md)}.ai-file-card{background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:var(--space-md);transition:border-color var(--duration-fast) var(--ease-smooth),box-shadow var(--duration-fast) var(--ease-smooth)}.ai-file-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-xs)}.ai-file-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xs)}.ai-file-name{font-family:JetBrains Mono,monospace;font-size:12px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ai-file-score{font-family:JetBrains Mono,monospace;font-size:12px;font-weight:500;padding:2px 6px;border-radius:var(--radius-sm)}.ai-file-score.good{color:var(--success);background:#5dd39e1a}.ai-file-score.warning{color:var(--warning);background:#ffb0201a}.ai-file-score.bad{color:var(--error);background:#ff6b6b1a}.ai-file-summary{font-size:12px;color:var(--text-tertiary);margin:var(--space-xs) 0;line-height:1.4}.ai-file-issues{font-size:11px;color:var(--text-tertiary)}.ai-file-issues.clean{color:var(--success)}.ai-issues-group{margin-bottom:var(--space-md);padding:var(--space-md);border-radius:var(--radius-sm)}.ai-issues-group.high{background:#ff6b6b0d;border-left:3px solid var(--error)}.ai-issues-group.medium{background:#ffb0200d;border-left:3px solid var(--warning)}.ai-issues-group.low{background:#6b8cff0d;border-left:3px solid var(--accent)}.ai-issues-group h5{font-size:12px;font-weight:500;margin-bottom:var(--space-sm);color:var(--text-secondary)}.ai-issue-item{padding:var(--space-sm) 0;border-bottom:1px solid var(--border-subtle)}.ai-issue-item:last-child{border-bottom:none}.ai-issue-item .issue-type{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);background:var(--surface);padding:2px 6px;border-radius:var(--radius-sm);margin-right:var(--space-sm)}.ai-issue-item p{font-size:13px;color:var(--text-secondary);margin-top:var(--space-xs);line-height:1.5}.ai-issue-item .issue-suggestion{font-size:12px;color:var(--text-tertiary);margin-top:var(--space-xs);padding-left:var(--space-sm);border-left:2px solid var(--success)}.spinner-mini{width:12px;height:12px;border:1.5px solid var(--surface);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}.patch-viewer{padding:var(--space-lg);background:var(--surface-soft);border-radius:var(--radius-lg)}.patch-viewer h3{font-size:12px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-md)}.diff-container{margin:var(--space-lg) 0;max-height:400px;overflow:auto}.diff-file{margin-bottom:var(--space-lg)}.diff-header{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--text-tertiary);padding:var(--space-sm) var(--space-md);background:var(--surface);border-radius:var(--radius-sm) var(--radius-sm) 0 0}.diff-content{font-family:JetBrains Mono,monospace;font-size:12px;padding:var(--space-md);background:var(--bg-elevated);border-radius:0 0 var(--radius-sm) var(--radius-sm);overflow-x:auto}.diff-line{white-space:pre;line-height:1.5}.diff-line.add{background:#5dd39e1a;color:var(--success)}.diff-line.remove{background:#ff6b6b1a;color:var(--error)}.diff-line.context{color:var(--text-tertiary)}.patch-actions{display:flex;gap:var(--space-md)}[hidden]{display:none!important}.fade-in{animation:fadeIn var(--duration-normal) var(--ease-smooth)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-tertiary);border-radius:3px;opacity:.3}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.error-message{color:var(--error);font-size:.8125rem;padding:var(--space-md);background:var(--error-bg);border:1px solid rgba(239,68,68,.15);border-radius:var(--radius);margin-top:var(--space-md)}@media(max-width:768px){:root{--space-section: 48px}.explorer-container{grid-template-columns:1fr;height:auto}.file-tree{max-height:200px}.code-viewer{height:360px}.overview-grid{grid-template-columns:repeat(2,1fr)}.summary-grid{grid-template-columns:1fr}.ai-chat-messages{height:220px}}.comprehensive-container,.comprehensive-bottom-container{display:grid;gap:var(--space-lg);grid-template-columns:repeat(2,1fr)}.session-video{background:var(--surface);padding:var(--space-lg);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);grid-column:1 / -1}#sessionVideo{width:100%!important;height:auto!important;aspect-ratio:16 / 9;max-height:560px;display:none;background:#000;border-radius:8px}.video-skeleton{position:relative;width:100%;padding-top:56.25%;background:linear-gradient(180deg,#ffffff05,#0000000a);border-radius:8px;overflow:hidden;display:none;align-items:center;justify-content:center}.video-skeleton.visible{display:flex}.video-skeleton:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,#ffffff05,#ffffff0a,#ffffff05);animation:shimmer 1.6s linear infinite}.skeleton-spinner{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:48px;height:48px;border-radius:50%;border:4px solid rgba(255,255,255,.06);border-top-color:var(--accent);box-sizing:border-box;animation:spin 1s linear infinite}@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.view-video-link{display:inline-block;margin-top:8px;color:var(--accent);text-decoration:none;font-weight:600}.view-video-link[hidden]{display:none}.validation-results,.api-checks-results,.no-js-results,.interaction-results,.test-results{background:var(--surface);padding:var(--space-lg);border-radius:var(--radius-lg);border:1px solid var(--border-subtle)}.validation-item,.api-check-item,.no-js-item{margin-bottom:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius);background:var(--surface-hover)}.validation-item h4,.api-check-item,.no-js-item{margin:0 0 var(--space-sm) 0;font-size:16px;font-weight:500}.api-check-item{display:flex;justify-content:space-between;align-items:center}.api-check-item.configured{background:#5dd39e1a;border-left:3px solid var(--success)}.api-check-item.not-configured{background:#ff6b6b1a;border-left:3px solid var(--error)}.api-name{font-weight:500}.api-status{font-size:14px}.interaction-item,.test-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-sm);border-radius:var(--radius);font-family:var(--font-mono);font-size:.8125rem}.interaction-item.success{background:#5dd39e1a;border-left:3px solid var(--success)}.interaction-item.error{background:#ff6b6b1a;border-left:3px solid var(--error)}.test-item.success{background:#5dd39e1a;border-left:3px solid var(--success)}.test-item.error{background:#ff6b6b1a;border-left:3px solid var(--error)}.interaction-type,.test-type{font-weight:500;min-width:120px}.test-details{flex:1;opacity:.8}.test-status{font-weight:700;min-width:20px;text-align:center}.test-item.success .test-status{color:var(--success)}.test-item.error .test-status{color:var(--error)}.interaction-element{color:var(--accent);min-width:40px}.interaction-text{flex:1;opacity:.8;font-style:italic}.offline-banner{display:none}.offline-banner.visible{display:block}
