@import "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@300;400;500;600;700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;min-height:100vh;overflow-x:hidden}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:15px}body{color:#cbd5e1;letter-spacing:-.01em;background:#020617;font-family:JetBrains Mono,Fira Code,Cascadia Code,Consolas,monospace;line-height:1.65}a{color:#22c55e;text-decoration:none;transition:color .15s}a:hover{color:#4ade80}.app{max-width:1200px;margin:0 auto;padding:0 24px 80px;animation:.4s ease-out fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.topbar{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#020617;border-bottom:1px solid #1e293b;justify-content:space-between;align-items:center;margin-bottom:48px;padding:16px 0;display:flex;position:sticky;top:0}.topbar-brand{color:#f8fafc;align-items:center;gap:10px;font-size:.95rem;font-weight:600;display:flex}.topbar-brand-icon{color:#020617;background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;font-weight:700;display:flex}.topbar-links{color:#94a3b8;gap:24px;font-size:.8rem;display:flex}.topbar-links a{color:#94a3b8;transition:color .15s}.topbar-links a:hover{color:#f8fafc}.topbar-status{color:#64748b;align-items:center;gap:8px;font-size:.75rem;display:flex}.pulse-dot{background:#22c55e;border-radius:50%;width:8px;height:8px;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1;box-shadow:0 0 #22c55e66}50%{opacity:.7;box-shadow:0 0 0 6px #22c55e00}}.hero{text-align:center;margin-bottom:56px}.mascot-container{margin-bottom:24px}.ascii-mascot{color:#22c55e;text-align:left;opacity:.85;text-shadow:0 0 20px #22c55e4d;font-size:.65rem;line-height:1.15;display:inline-block}.hero-title{color:#f8fafc;letter-spacing:-.03em;margin-bottom:8px;font-size:2.2rem;font-weight:700}.hero-title .accent{color:#22c55e}.hero-subtitle{color:#64748b;max-width:500px;margin:0 auto;font-size:.9rem;font-weight:400}.section{margin-bottom:48px}.section-header{border-bottom:1px solid #1e293b;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:12px;display:flex}.section-title{color:#f8fafc;text-transform:uppercase;letter-spacing:.08em;align-items:center;gap:8px;font-size:.85rem;font-weight:600;display:flex}.section-title-icon{color:#22c55e;font-size:.9rem}.section-badge{color:#64748b;background:#0f172a;border:1px solid #1e293b;border-radius:9999px;padding:2px 10px;font-size:.7rem}.card{background:#0f172a;border:1px solid #1e293b;border-radius:12px;padding:24px;transition:border-color .2s,box-shadow .2s}.card:hover{border-color:#334155;box-shadow:0 0 0 1px #22c55e0d,0 8px 32px #0000004d}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-label{color:#64748b;text-transform:uppercase;letter-spacing:.06em;font-size:.75rem;font-weight:500}.card-value{color:#f8fafc;letter-spacing:-.03em;font-size:2rem;font-weight:700;line-height:1}.card-desc{color:#94a3b8;margin-top:4px;font-size:.78rem}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.gates-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.analysis-grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.two-col{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=900px){.stats-grid,.gates-grid{grid-template-columns:repeat(2,1fr)}.analysis-grid,.two-col{grid-template-columns:1fr}}@media (width<=600px){.stats-grid,.gates-grid{grid-template-columns:1fr}.app{padding:0 16px 60px}.hero-title{font-size:1.6rem}.topbar{flex-wrap:wrap;gap:12px}.topbar-links{display:none}}.stat-card{background:#0f172a;border:1px solid #1e293b;border-radius:12px;flex-direction:column;gap:8px;padding:20px 24px;transition:border-color .2s;display:flex;position:relative;overflow:hidden}.stat-card:before{content:"";opacity:0;background:linear-gradient(90deg,#0000,#22c55e,#0000);height:2px;transition:opacity .2s;position:absolute;top:0;left:0;right:0}.stat-card:hover:before{opacity:1}.stat-card:hover{border-color:#334155}.stat-label{color:#64748b;text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;font-weight:500}.stat-number{color:#f8fafc;letter-spacing:-.04em;font-size:1.8rem;font-weight:700;line-height:1}.stat-sub{color:#475569;font-size:.7rem}.gate-card{background:#0f172a;border:1px solid #1e293b;border-radius:12px;flex-direction:column;gap:12px;padding:20px;transition:border-color .2s;display:flex}.gate-card:hover{border-color:#334155}.gate-card.passed{border-left:3px solid #22c55e}.gate-card.partial{border-left:3px solid #eab308}.gate-card.missing{border-left:3px solid #ef4444}.gate-card.unknown{border-left:3px solid #64748b}.gate-top{justify-content:space-between;align-items:center;display:flex}.gate-name{color:#f8fafc;font-size:.82rem;font-weight:600}.gate-score{font-size:1.1rem;font-weight:700}.gate-score.high{color:#22c55e}.gate-score.medium{color:#eab308}.gate-score.low{color:#ef4444}.gate-score.na{color:#475569}.gate-detail{color:#94a3b8;font-size:.72rem;line-height:1.5}.gate-bar{background:#1e293b;border-radius:2px;height:4px;overflow:hidden}.gate-bar-fill{border-radius:2px;height:100%;transition:width .6s ease-out}.gate-bar-fill.high{background:#22c55e}.gate-bar-fill.medium{background:#eab308}.gate-bar-fill.low{background:#ef4444}.gate-bar-fill.na{background:#475569}.analysis-card{background:#0f172a;border:1px solid #1e293b;border-radius:12px;padding:24px}.analysis-card-title{color:#f8fafc;align-items:center;gap:8px;margin-bottom:16px;font-size:.82rem;font-weight:600;display:flex}.lang-list{flex-direction:column;gap:10px;display:flex}.lang-item{align-items:center;gap:12px;display:flex}.lang-name{color:#cbd5e1;min-width:90px;font-size:.78rem;font-weight:500}.lang-bar-track{background:#1e293b;border-radius:3px;flex:1;height:6px;overflow:hidden}.lang-bar-fill{background:#22c55e;border-radius:3px;height:100%;transition:width .5s ease-out}.lang-bar-fill.l2{background:#3b82f6}.lang-bar-fill.l3{background:#a855f7}.lang-bar-fill.l4{background:#eab308}.lang-bar-fill.l5{background:#ef4444}.lang-bar-fill.l6{background:#ec4899}.lang-bar-fill.l7{background:#06b6d4}.lang-pct{color:#64748b;text-align:right;min-width:42px;font-size:.72rem}.file-tree{color:#94a3b8;max-height:320px;font-size:.75rem;line-height:1.8;overflow-y:auto}.file-tree::-webkit-scrollbar{width:4px}.file-tree::-webkit-scrollbar-track{background:0 0}.file-tree::-webkit-scrollbar-thumb{background:#334155;border-radius:2px}.tree-line{align-items:center;gap:6px;padding:1px 0;display:flex}.tree-line:hover{color:#f8fafc}.tree-icon{text-align:center;flex-shrink:0;width:14px;font-size:.7rem}.tree-indent{display:inline-block}.tree-name{color:#cbd5e1}.tree-name.is-dir{color:#3b82f6;font-weight:500}.status-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}@media (width<=700px){.status-grid{grid-template-columns:1fr}}.status-card{background:#0f172a;border:1px solid #1e293b;border-radius:12px;flex-direction:column;gap:8px;padding:20px;display:flex}.status-indicator{align-items:center;gap:8px;display:flex}.status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.status-dot.green{background:#22c55e;box-shadow:0 0 6px #22c55e66}.status-dot.yellow{background:#eab308;box-shadow:0 0 6px #eab30866}.status-dot.red{background:#ef4444;box-shadow:0 0 6px #ef444466}.status-dot.blue{background:#3b82f6;box-shadow:0 0 6px #3b82f666}.status-label{color:#f8fafc;font-size:.78rem;font-weight:600}.status-value{color:#94a3b8;font-size:.72rem}.table-wrap{background:#0f172a;border:1px solid #1e293b;border-radius:12px;overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:.78rem}.data-table th{text-align:left;color:#64748b;text-transform:uppercase;letter-spacing:.06em;background:#0c1322;border-bottom:1px solid #1e293b;padding:12px 16px;font-size:.7rem;font-weight:500}.data-table td{color:#cbd5e1;border-bottom:1px solid #1e293b;padding:10px 16px}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#22c55e08}.table-badge{border-radius:4px;padding:2px 8px;font-size:.68rem;font-weight:500;display:inline-block}.table-badge.green{color:#22c55e;background:#22c55e1f}.table-badge.yellow{color:#eab308;background:#eab3081f}.table-badge.red{color:#ef4444;background:#ef44441f}.table-badge.blue{color:#3b82f6;background:#3b82f61f}.footer{color:#475569;border-top:1px solid #1e293b;justify-content:space-between;align-items:center;margin-top:64px;padding-top:24px;font-size:.72rem;display:flex}.footer a{color:#64748b}.footer a:hover{color:#22c55e}.loading-container{flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:60vh;display:flex}.spinner{border:3px solid #1e293b;border-top-color:#22c55e;border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:#64748b;font-size:.82rem}.error-card{text-align:center;background:#0f172a;border:1px solid #ef44444d;border-radius:12px;max-width:480px;margin:80px auto;padding:32px}.error-card h2{color:#ef4444;margin-bottom:8px;font-size:1.1rem}.error-card p{color:#94a3b8;margin-bottom:16px;font-size:.82rem}.retry-btn{color:#020617;cursor:pointer;background:#22c55e;border:none;border-radius:8px;padding:8px 20px;font-family:inherit;font-size:.78rem;font-weight:600;transition:background .15s;display:inline-block}.retry-btn:hover{background:#4ade80}.text-green{color:#22c55e}.text-blue{color:#3b82f6}.text-yellow{color:#eab308}.text-red{color:#ef4444}.text-muted{color:#64748b}.text-sm{font-size:.75rem}.text-xs{font-size:.7rem}.fw-600{font-weight:600}.fw-700{font-weight:700}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mb-16{margin-bottom:16px}.gap-8{gap:8px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.hidden{display:none}
