@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap";
:root{--bg-base:#080d1a;--bg-surface:#0d1526;--bg-elevated:#111d36;--bg-card:#111d36b3;--bg-card-hover:#162646d9;--bg-input:#ffffff0a;--bg-input-focus:#6395ff14;--border-subtle:#ffffff0f;--border-card:#ffffff17;--border-accent:#6395ff66;--accent-primary:#6395ff;--accent-secondary:#a78bfa;--accent-cyan:#22d3ee;--accent-glow:#6395ff26;--status-success:#10b981;--status-warning:#f59e0b;--status-danger:#ef4444;--status-info:#6395ff;--status-ambiguous:#f97316;--text-primary:#f0f4ff;--text-secondary:#f0f4ffa6;--text-muted:#f0f4ff59;--text-accent:#6395ff;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-card:0 1px 3px #00000080,0 0 0 1px #ffffff0d;--shadow-glow:0 0 40px #6395ff1f;--shadow-hover:0 8px 32px #0006;--shadow-modal:0 24px 80px #000000b3;--transition-fast:.1s ease;--transition-normal:.2s ease;--transition-slow:.35s cubic-bezier(.4,0,.2,1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;width:100%;font-size:16px;overflow-x:hidden}body{background:var(--bg-base);color:var(--text-primary);background-image:radial-gradient(80% 50% at 50% -20%,#6395ff12 0%,#0000 60%),radial-gradient(60% 40% at 80% 80%,#a78bfa0d 0%,#0000 50%);min-height:100vh;font-family:Inter,system-ui,sans-serif;line-height:1.6;overflow-x:hidden}a{color:var(--accent-primary);text-decoration:none}a:hover{text-decoration:underline}img,svg{display:block}.text-xs{font-size:.75rem;line-height:1.5}.text-sm{font-size:.875rem;line-height:1.5}.text-base{font-size:1rem;line-height:1.6}.text-lg{font-size:1.125rem;line-height:1.5}.text-xl{font-size:1.25rem;line-height:1.4}.text-2xl{font-size:1.5rem;line-height:1.3}.text-3xl{font-size:1.875rem;line-height:1.25}.text-4xl{font-size:2.25rem;line-height:1.15}.font-light{font-weight:300}.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-extrabold{font-weight:800}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-accent{color:var(--accent-primary)}.mono{font-family:JetBrains Mono,monospace}.container{max-width:1240px;padding:0 var(--space-6);margin:0 auto}.page{min-height:100vh;padding:var(--space-8)0}.card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);-webkit-backdrop-filter:blur(12px);transition:box-shadow var(--transition-normal),border-color var(--transition-normal),transform var(--transition-slow)}.card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-hover),var(--shadow-glow)}.card-clickable{cursor:pointer}.card-clickable:hover{transform:translateY(-2px)}.card-body{padding:var(--space-6)}.card-header{padding:var(--space-5)var(--space-6);border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;gap:var(--space-4);display:flex}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3)var(--space-5);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-normal);white-space:nowrap;-webkit-user-select:none;user-select:none;border:1px solid #0000;font-family:inherit;font-size:.875rem;font-weight:600;line-height:1;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.btn-primary{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;border-color:#0000;box-shadow:0 2px 12px #6395ff4d}.btn-primary:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 4px 20px #6395ff80}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border-card)}.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--border-accent);color:var(--text-primary)}.btn-ghost{color:var(--text-secondary);background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--bg-input);color:var(--text-primary)}.btn-danger{color:var(--status-danger);background:#ef444426;border-color:#ef444433}.btn-danger:hover{background:#ef444440}.btn-sm{padding:var(--space-2)var(--space-3);font-size:.8rem}.btn-lg{padding:var(--space-4)var(--space-8);border-radius:var(--radius-md);font-size:1rem}.input{background:var(--bg-input);width:100%;color:var(--text-primary);padding:var(--space-3)var(--space-4);border:1px solid var(--border-card);border-radius:var(--radius-md);transition:border-color var(--transition-fast),background var(--transition-fast),box-shadow var(--transition-fast);outline:none;font-family:inherit;font-size:.875rem}.input:focus{background:var(--bg-input-focus);border-color:var(--accent-primary);box-shadow:0 0 0 3px #6395ff26}.input::placeholder{color:var(--text-muted)}select.input{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}select.input option{background:var(--bg-elevated);color:var(--text-primary)}.label{color:var(--text-secondary);margin-bottom:var(--space-2);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:600;display:block}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:5px;padding:3px 10px;font-size:.73rem;font-weight:600;line-height:1.4;display:inline-flex}.badge-success{color:var(--status-success);background:#10b98126;border:1px solid #10b98140}.badge-warning{color:var(--status-warning);background:#f59e0b26;border:1px solid #f59e0b40}.badge-danger{color:var(--status-danger);background:#ef444426;border:1px solid #ef444440}.badge-info{color:var(--status-info);background:#6395ff26;border:1px solid #6395ff40}.badge-neutral{color:var(--text-secondary);border:1px solid var(--border-subtle);background:#ffffff0f}.badge-amber{color:var(--status-ambiguous);background:#f9731626;border:1px solid #f9731640}.score-ring{width:140px;height:140px;position:relative}.score-ring svg{width:100%;height:100%;transform:rotate(-90deg)}.score-ring .score-value{text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.status-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.status-dot-success{background:var(--status-success);box-shadow:0 0 6px var(--status-success)}.status-dot-warning{background:var(--status-warning);box-shadow:0 0 6px var(--status-warning)}.status-dot-danger{background:var(--status-danger);box-shadow:0 0 6px var(--status-danger)}.status-dot-info{background:var(--status-info);box-shadow:0 0 6px var(--status-info)}.status-dot-muted{background:var(--text-muted)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.animate-pulse{animation:2s ease-in-out infinite pulse}.progress{background:var(--bg-elevated);border-radius:var(--radius-full);height:6px;overflow:hidden}.progress-bar{border-radius:var(--radius-full);background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));height:100%;transition:width .7s cubic-bezier(.4,0,.2,1)}.progress-bar-success{background:linear-gradient(90deg,#059669,#10b981)}.progress-bar-warning{background:linear-gradient(90deg,#d97706,#f59e0b)}.progress-bar-danger{background:linear-gradient(90deg,#dc2626,#ef4444)}.table-wrapper{border-radius:var(--radius-md);border:1px solid var(--border-subtle);width:100%;overflow-x:auto}table{border-collapse:collapse;width:100%}th{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:var(--space-3)var(--space-4);text-align:left;border-bottom:1px solid var(--border-subtle);background:#ffffff05;font-size:.75rem;font-weight:600}td{color:var(--text-secondary);padding:var(--space-3)var(--space-4);border-bottom:1px solid var(--border-subtle);font-size:.875rem}tr:last-child td{border-bottom:none}tr:hover td{background:#ffffff05}code{color:var(--accent-primary);border-radius:var(--radius-sm);background:#6395ff1a;padding:2px 6px;font-family:JetBrains Mono,monospace;font-size:.82em}.upload-zone{border:2px dashed var(--border-card);border-radius:var(--radius-lg);padding:var(--space-12)var(--space-8);text-align:center;cursor:pointer;transition:all var(--transition-normal);background:var(--bg-input);position:relative}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--accent-primary);background:var(--bg-input-focus);box-shadow:0 0 30px #6395ff1a}.upload-zone input[type=file]{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;inset:0}.navbar{z-index:50;-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-subtle);padding:0 var(--space-6);background:#080d1ad9;position:sticky;top:0}.navbar-inner{justify-content:space-between;align-items:center;gap:var(--space-6);max-width:1240px;height:60px;margin:0 auto;display:flex}.navbar-brand{align-items:center;gap:var(--space-3);text-decoration:none;display:flex}.navbar-logo-text{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-text-fill-color:transparent;letter-spacing:-.02em;-webkit-background-clip:text;background-clip:text;font-size:1.1rem;font-weight:800}.section-heading{color:var(--text-primary);letter-spacing:-.01em;font-size:1.5rem;font-weight:700}.section-subheading{color:var(--text-secondary);margin-top:var(--space-2);font-size:.95rem}.grid-2{gap:var(--space-6);grid-template-columns:repeat(auto-fit,minmax(min(100%,400px),1fr));display:grid}.grid-3{gap:var(--space-6);grid-template-columns:repeat(auto-fit,minmax(min(100%,320px),1fr));display:grid}.grid-4{gap:var(--space-6);grid-template-columns:repeat(auto-fit,minmax(min(100%,240px),1fr));display:grid}@media (max-width:640px){.container{padding:0 var(--space-4)}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-5{margin-bottom:var(--space-5)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.divider{background:var(--border-subtle);height:1px;margin:var(--space-6)0}.toast{bottom:var(--space-6);right:var(--space-6);z-index:100;align-items:center;gap:var(--space-3);padding:var(--space-4)var(--space-5);border-radius:var(--radius-md);box-shadow:var(--shadow-modal);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border-card);max-width:380px;animation:.3s cubic-bezier(.4,0,.2,1) slideUp;display:flex;position:fixed}.toast-success{background:#10b98126;border-color:#10b9814d}.toast-error{background:#ef444426;border-color:#ef44444d}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:2px solid var(--border-card);border-top-color:var(--accent-primary);border-radius:50%;flex-shrink:0;width:20px;height:20px;animation:.7s linear infinite spin}.spinner-lg{border-width:3px;width:40px;height:40px}.collapsible-trigger{cursor:pointer;width:100%;color:var(--text-primary);text-align:left;padding:var(--space-4)var(--space-5);border-radius:var(--radius-md);transition:background var(--transition-fast);background:0 0;border:none;justify-content:space-between;align-items:center;font-family:inherit;display:flex}.collapsible-trigger:hover{background:#ffffff08}.collapsible-icon{color:var(--text-muted);transition:transform var(--transition-normal)}.collapsible-trigger[aria-expanded=true] .collapsible-icon{transform:rotate(180deg)}.prose{color:var(--text-secondary);line-height:1.75}.prose h1,.prose h2,.prose h3{color:var(--text-primary);letter-spacing:-.01em;margin-top:var(--space-8);margin-bottom:var(--space-4);font-weight:700}.prose h1{font-size:1.75rem}.prose h2{border-bottom:1px solid var(--border-subtle);padding-bottom:var(--space-3);font-size:1.35rem}.prose h3{color:var(--text-primary);font-size:1.1rem}.prose p{margin-bottom:var(--space-4)}.prose ul,.prose ol{padding-left:var(--space-6);margin-bottom:var(--space-4)}.prose li{margin-bottom:var(--space-2)}.prose strong{color:var(--text-primary);font-weight:600}.prose blockquote{border-left:3px solid var(--accent-primary);padding-left:var(--space-4);color:var(--text-secondary);margin:var(--space-6)0;font-style:italic}.prose hr{border:none;border-top:1px solid var(--border-subtle);margin:var(--space-8)0}.prose table{margin:var(--space-6)0}.empty-state{justify-content:center;align-items:center;gap:var(--space-4);padding:var(--space-16)var(--space-8);text-align:center;flex-direction:column;display:flex}.empty-state-icon{opacity:.3;font-size:3rem}.gradient-text{background:linear-gradient(135deg,var(--accent-primary)0%,var(--accent-secondary)50%,var(--accent-cyan)100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.card-shine{position:relative;overflow:hidden}.card-shine:before{content:"";background:linear-gradient(90deg,#0000,#ffffff1f,#0000);width:100%;height:1px;transition:left .5s;position:absolute;top:0;left:-100%}.card-shine:hover:before{left:100%}.tier-not-ready{color:var(--status-danger)}.tier-partially-ready{color:var(--status-warning)}.tier-ai-ready{color:var(--status-success)}.tier-bg-not-ready{background:#ef44441f;border-color:#ef444433}.tier-bg-partially-ready{background:#f59e0b1f;border-color:#f59e0b33}.tier-bg-ai-ready{background:#10b9811f;border-color:#10b98133}.drawer-overlay{-webkit-backdrop-filter:blur(4px);z-index:100;opacity:0;visibility:hidden;transition:opacity var(--transition-normal),visibility var(--transition-normal);background:#0009;position:fixed;inset:0}.drawer-overlay.open{opacity:1;visibility:visible}.drawer-panel{background:var(--bg-surface);border-left:1px solid var(--border-subtle);z-index:101;visibility:hidden;width:100%;max-width:650px;transition:transform var(--transition-slow),visibility 0s linear .35s;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;right:0;transform:translate(100%);box-shadow:-10px 0 40px #00000080}.drawer-panel.open{visibility:visible;transition:transform var(--transition-slow),visibility 0s linear 0s;transform:translate(0)}.drawer-header{padding:var(--space-5)var(--space-6);border-bottom:1px solid var(--border-subtle);-webkit-backdrop-filter:blur(10px);background:#111d36f2;justify-content:space-between;align-items:flex-start;display:flex}.drawer-body{padding:var(--space-6);scrollbar-width:thin;scrollbar-color:var(--border-accent)transparent;flex:1;overflow-y:auto}.drawer-body::-webkit-scrollbar{width:6px}.drawer-body::-webkit-scrollbar-track{background:0 0}.drawer-body::-webkit-scrollbar-thumb{background-color:var(--border-card);border-radius:var(--radius-full)}.drawer-body::-webkit-scrollbar-thumb:hover{background-color:var(--border-accent)}.drawer-close{color:var(--text-muted);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-sm);transition:background var(--transition-fast),color var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;margin-top:-4px;margin-right:-8px;display:flex}.drawer-close:hover{color:var(--text-primary);background:#ffffff1a}.drawer-close:focus{outline:2px solid var(--accent-primary);outline-offset:2px}.framework-badge{border-radius:var(--radius-sm);background:var(--bg-input);color:var(--text-secondary);border:1px solid var(--border-subtle);letter-spacing:.02em;justify-content:center;align-items:center;padding:3px 10px;font-size:.75rem;font-weight:600;display:inline-flex}
