@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";
:root{--bg-primary:#0a0a0a;--bg-secondary:#111;--bg-tertiary:#1a1a1a;--bg-elevated:#222;--bg-hover:#2a2a2a;--text-primary:#e5e5e5;--text-secondary:#a0a0a0;--text-tertiary:#6b6b6b;--text-muted:#444;--border-subtle:#ffffff12;--border-medium:#ffffff1f;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--radius-full:9999px;--shadow-sm:0 1px 2px #0006;--shadow-md:0 2px 8px #00000080;--duration-fast:.12s;--duration-normal:.2s}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}body{min-height:100vh;overflow-x:hidden}.bg-grid{z-index:0;pointer-events:none;position:fixed;inset:0}.mono{font-family:JetBrains Mono,monospace}.card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg)}.btn-primary{background:var(--text-primary);color:var(--bg-primary);border-radius:var(--radius-md);cursor:pointer;transition:opacity var(--duration-fast);border:none;justify-content:center;align-items:center;gap:6px;padding:10px 24px;font-size:14px;font-weight:600;display:inline-flex}.btn-primary:hover{opacity:.85}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-ghost{color:var(--text-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;transition:color var(--duration-fast), border-color var(--duration-fast);background:0 0;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:500;display:inline-flex}.btn-ghost:hover{color:var(--text-primary);border-color:var(--border-medium)}.input-wrapper{width:100%;position:relative}.input-field{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);width:100%;color:var(--text-primary);transition:border-color var(--duration-fast);outline:none;padding:14px 130px 14px 18px;font-family:JetBrains Mono,monospace;font-size:14px}.input-field::placeholder{color:var(--text-muted)}.input-field:focus{border-color:var(--border-medium)}.input-field.error{border-color:#b91c1c}.chip{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:color var(--duration-fast), border-color var(--duration-fast);white-space:nowrap;align-items:center;gap:6px;padding:5px 12px;font-family:JetBrains Mono,monospace;font-size:13px;display:inline-flex}.chip:hover{color:var(--text-primary);border-color:var(--border-medium)}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.skeleton{background:linear-gradient(90deg, var(--bg-tertiary) 25%, var(--bg-elevated) 50%, var(--bg-tertiary) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}.spinner{border:2px solid var(--border-subtle);border-top-color:var(--text-secondary);border-radius:50%;width:18px;height:18px;animation:.6s linear infinite spin}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.tooltip{pointer-events:none;z-index:100;background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:var(--radius-md);box-shadow:var(--shadow-md);max-width:280px;padding:10px 14px;font-size:13px;position:fixed}.tooltip .tooltip-name{color:var(--text-primary);word-break:break-all;margin-bottom:3px;font-weight:600}.tooltip .tooltip-path{color:var(--text-tertiary);word-break:break-all;margin-bottom:5px;font-family:JetBrains Mono,monospace;font-size:11px}.tooltip .tooltip-meta{color:var(--text-secondary);align-items:center;gap:8px;font-size:12px;display:flex}.tooltip .color-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.treemap-container{border-radius:var(--radius-lg);background:var(--bg-secondary);border:1px solid var(--border-subtle);width:100%;height:100%;position:relative;overflow:hidden}.treemap-container svg{display:block}.treemap-rect{cursor:pointer;transition:opacity var(--duration-fast);stroke:var(--bg-primary);stroke-width:1px}.treemap-rect:hover{opacity:.85;stroke:var(--text-primary);stroke-width:2px}.treemap-label{pointer-events:none;fill:#000c;font-family:Inter,sans-serif;font-weight:500}.treemap-label-light{fill:#ffffffe6}.stats-grid{background:var(--border-subtle);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:1px;display:grid;overflow:hidden}.stat-card{text-align:center;background:var(--bg-secondary);padding:14px}.stat-value{color:var(--text-primary);font-size:22px;font-weight:700;line-height:1.2}.stat-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;margin-top:2px;font-size:11px}.breadcrumb{flex-wrap:wrap;align-items:center;gap:4px;padding:8px 12px;font-family:JetBrains Mono,monospace;font-size:13px;display:flex}.breadcrumb-item{color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--duration-fast);padding:2px 6px}.breadcrumb-item:hover{color:var(--text-primary)}.breadcrumb-item.active{color:var(--text-primary);font-weight:600}.breadcrumb-separator{color:var(--text-muted);font-size:11px}.sidebar{background:var(--bg-secondary);border-left:1px solid var(--border-subtle);flex-direction:column;flex-shrink:0;gap:16px;width:280px;padding:16px;display:flex;overflow-y:auto}.sidebar-section{flex-direction:column;gap:8px;display:flex}.sidebar-section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:11px;font-weight:600}.file-detail-row{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:6px 0;font-size:13px;display:flex}.file-detail-label{color:var(--text-tertiary)}.file-detail-value{color:var(--text-primary);font-family:JetBrains Mono,monospace;font-size:12px;font-weight:500}.lang-bar{background:var(--bg-tertiary);border-radius:3px;width:100%;height:6px;display:flex;overflow:hidden}.lang-bar-segment{height:100%;transition:width var(--duration-normal)}.lang-bar-segment:first-child{border-radius:3px 0 0 3px}.lang-bar-segment:last-child{border-radius:0 3px 3px 0}.lang-list{flex-direction:column;gap:5px;display:flex}.lang-item{align-items:center;gap:8px;font-size:12px;display:flex}.lang-item .color-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.lang-item .lang-name{color:var(--text-secondary);flex:1}.lang-item .lang-count{color:var(--text-tertiary);font-family:JetBrains Mono,monospace;font-size:11px}.lang-more-toggle{width:100%;font:inherit;text-align:left;cursor:pointer;color:var(--text-tertiary);transition:color var(--duration-fast);background:0 0;border:none;align-items:center;gap:8px;margin:0;padding:4px 0;font-size:12px;display:flex}.lang-more-toggle:hover{color:var(--text-primary)}.visualize-layout{flex-direction:column;height:100vh;display:flex;overflow:hidden}.visualize-header{border-bottom:1px solid var(--border-subtle);background:var(--bg-secondary);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:10px 16px;display:flex}.visualize-body{flex:1;display:flex;overflow:hidden}.visualize-main{flex-direction:column;flex:1;gap:8px;padding:10px;display:flex;overflow:hidden}.treemap-wrapper{flex:1;min-height:0}.error-card{text-align:center;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);max-width:440px;margin:0 auto;padding:40px 28px}.error-icon{background:var(--bg-tertiary);width:40px;height:40px;color:var(--text-secondary);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 12px;display:flex}.error-title{margin-bottom:6px;font-size:16px;font-weight:600}.error-message{color:var(--text-secondary);font-size:14px;line-height:1.5}.logo{color:var(--text-primary);align-items:center;gap:8px;font-weight:700;text-decoration:none;display:flex}.logo-icon{border-radius:var(--radius-sm);background:var(--bg-elevated);border:1px solid var(--border-subtle);width:28px;height:28px;color:var(--text-secondary);justify-content:center;align-items:center;display:flex}.logo-text{color:var(--text-primary);font-size:14px;font-weight:700}.visualize-footer{border-top:1px solid var(--border-subtle);color:var(--text-muted);background:var(--bg-secondary);flex-shrink:0;justify-content:space-between;align-items:center;padding:6px 16px;font-size:11px;display:flex}.visualize-footer a{color:var(--text-tertiary);text-decoration:none}.visualize-footer a:hover{color:var(--text-secondary)}.stats-report{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);height:100%;padding:12px 16px 24px;overflow-y:auto}.stats-report-section{margin-bottom:28px}.stats-report-section:last-child{margin-bottom:0}.stats-report-heading{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:10px;font-size:11px;font-weight:600}.stats-report-note{color:var(--text-tertiary);margin-bottom:10px;font-size:12px;line-height:1.45}.stats-report-row{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:baseline;gap:16px;padding:8px 0;font-size:13px;display:flex}.stats-report-label{color:var(--text-tertiary);flex-shrink:0}.stats-report-value{color:var(--text-primary);text-align:right;word-break:break-word;font-family:JetBrains Mono,monospace;font-size:12px}.stats-report-table-wrap{-webkit-overflow-scrolling:touch;margin:0 -4px;padding:0 4px;overflow-x:auto}.stats-report-table{border-collapse:collapse;width:100%;min-width:320px;font-size:12px}.stats-report-table th{text-align:left;border-bottom:1px solid var(--border-medium);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;padding:8px 10px 8px 0;font-size:11px;font-weight:600}.stats-report-table td{border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);vertical-align:top;padding:8px 10px 8px 0}.stats-report-table td.mono{font-family:JetBrains Mono,monospace;font-size:11px}.stats-report-dot{vertical-align:middle;border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-right:8px;display:inline-block}.viz-header-toolbar-desktop{align-items:center;gap:6px;display:flex}.viz-mobile-nav-trigger{background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;justify-content:center;align-items:center;padding:0;display:none}.viz-mobile-nav-trigger:hover{color:var(--text-primary);border-color:var(--border-medium)}.viz-mobile-nav-root{z-index:200;justify-content:flex-end;display:flex;position:fixed;inset:0}.viz-mobile-nav-backdrop{cursor:pointer;background:#0000008c;border:none;padding:0;position:absolute;inset:0}.viz-mobile-nav-panel{background:var(--bg-secondary);border-left:1px solid var(--border-subtle);width:min(320px,92vw);max-width:100%;height:100%;box-shadow:var(--shadow-md);flex-direction:column;display:flex;position:relative}.viz-mobile-nav-header{border-bottom:1px solid var(--border-subtle);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.viz-mobile-nav-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);font-size:13px;font-weight:600}.viz-mobile-nav-close{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex}.viz-mobile-nav-close:hover{color:var(--text-primary)}.viz-mobile-nav-body{flex:1;padding:12px 14px 24px;overflow-y:auto}.viz-mobile-nav-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:12px 0 8px;font-size:11px;font-weight:600}.viz-mobile-nav-section-label:first-child{margin-top:0}.viz-mobile-nav-views{grid-template-columns:1fr 1fr;gap:6px;display:grid}.viz-mobile-nav-view-btn{border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:var(--bg-primary);color:var(--text-tertiary);cursor:pointer;padding:10px 12px;font-size:13px;font-weight:500}.viz-mobile-nav-view-btn:hover{border-color:var(--border-medium);color:var(--text-primary)}.viz-mobile-nav-view-btn.active{background:var(--bg-elevated);border-color:var(--border-medium);color:var(--text-primary)}.viz-mobile-nav-meta{color:var(--text-secondary);margin-bottom:8px;font-size:12px;line-height:1.45}.viz-mobile-nav-links{flex-direction:column;gap:4px;margin-bottom:12px;display:flex}.viz-mobile-nav-link{color:var(--text-primary);border-bottom:1px solid var(--border-subtle);padding:10px 0;font-size:13px;text-decoration:none}.viz-mobile-nav-link.secondary{color:var(--text-tertiary);border-bottom:none;padding-top:4px;font-size:12px}.viz-mobile-nav-link:hover{color:var(--text-secondary)}.viz-mobile-nav-details-btn{border-radius:var(--radius-md);border:1px solid var(--border-medium);background:var(--bg-tertiary);width:100%;color:var(--text-primary);cursor:pointer;margin-top:8px;padding:12px 14px;font-size:13px;font-weight:500}.viz-mobile-nav-details-btn:hover{background:var(--bg-hover)}.home-nav-inline{align-items:center;gap:8px;display:flex}.mobile-info-toggle{display:none!important}.mobile-sidebar-panel{display:none}@media (max-width:768px){.input-field{padding:12px 110px 12px 14px;font-size:14px}.stats-grid{grid-template-columns:repeat(2,1fr)}.logo-text{display:none}.home-views-grid{grid-template-columns:1fr!important}.home-steps-grid{grid-template-columns:1fr!important;gap:16px!important}.visualize-header{flex-wrap:wrap;gap:8px;padding:8px 10px}.visualize-header .header-left{flex:1;min-width:0}.visualize-header .header-left h1{text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:13px;overflow:hidden}.visualize-header .header-right{gap:4px!important}.visualize-header .header-right .desktop-only{display:none}.viz-header-toolbar-desktop{display:none!important}.viz-mobile-nav-trigger{display:flex}.visualize-main{gap:6px;padding:6px}.view-toggle button{padding:3px 6px;font-size:11px}.home-header-source{display:none!important}.sidebar{display:none}.mobile-sidebar-panel{z-index:50;background:var(--bg-secondary);border-top:1px solid var(--border-medium);max-height:60vh;display:block;position:fixed;bottom:0;left:0;right:0;overflow-y:auto;box-shadow:0 -4px 20px #00000080}.mobile-sidebar-panel .sidebar{border-left:none;width:100%;display:flex}.mobile-panel-header{border-bottom:1px solid var(--border-subtle);background:var(--bg-secondary);z-index:1;justify-content:space-between;align-items:center;padding:10px 16px;display:flex;position:sticky;top:0}.mobile-panel-header span{text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);font-size:12px;font-weight:600}.mobile-panel-close{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex}.visualize-footer{padding:5px 10px;font-size:10px}}.home-mnav-root{z-index:150;justify-content:flex-end;display:flex;position:fixed;inset:0}.home-mnav-backdrop{cursor:pointer;background:#0000008c;border:none;position:absolute;inset:0}.home-mnav-panel{background:var(--bg-secondary);border-left:1px solid var(--border-subtle);width:min(280px,88vw);height:100%;box-shadow:var(--shadow-md);flex-direction:column;display:flex;position:relative}.home-mnav-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.home-mnav-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);font-size:13px;font-weight:600}.home-mnav-close{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;padding:4px;display:flex}.home-mnav-body{padding:16px 14px}.home-mnav-link{color:var(--text-primary);border-bottom:1px solid var(--border-subtle);padding:12px 0;font-size:14px;text-decoration:none;display:block}.home-mnav-link:hover{color:var(--text-secondary)}
