@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&family=Source+Serif+4:opsz,wght@8..60,400;8..60,600&display=swap";:root{--ink-950: #070B14;--ink-900: #0B1220;--ink-800: #111A2E;--ink-700: #1B2540;--ink-600: #27324F;--slate-900: #0F172A;--slate-800: #1E293B;--slate-700: #334155;--slate-600: #475569;--slate-500: #64748B;--slate-400: #94A3B8;--slate-300: #CBD5E1;--slate-200: #E2E8F0;--slate-100: #F1F5F9;--slate-50: #F8FAFC;--blue-700: #1D4ED8;--blue-600: #2563EB;--blue-500: #3B82F6;--blue-400: #60A5FA;--blue-300: #93C5FD;--blue-100: #DBEAFE;--cyan-600: #0891B2;--cyan-500: #06B6D4;--cyan-400: #22D3EE;--cyan-300: #67E8F9;--cyan-100: #CFFAFE;--green-600: #16A34A;--green-500: #22C55E;--green-100: #DCFCE7;--amber-600: #D97706;--amber-500: #F59E0B;--amber-100: #FEF3C7;--red-600: #DC2626;--red-500: #EF4444;--red-100: #FEE2E2;--violet-500:#8B5CF6;--violet-100:#EDE9FE;--font-sans: "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--font-serif: "Source Serif 4", ui-serif, Georgia, serif;--text-xs: 11px;--text-sm: 12px;--text-base: 14px;--text-md: 15px;--text-lg: 17px;--text-xl: 20px;--text-2xl: 24px;--text-3xl: 30px;--text-4xl: 38px;--text-5xl: 48px;--text-6xl: 64px;--leading-tight: 1.15;--leading-snug: 1.35;--leading-normal: 1.5;--leading-loose: 1.7;--tracking-tight: -.02em;--tracking-normal: 0;--tracking-wide: .04em;--tracking-caps: .08em;--sp-0: 0;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--sp-12: 48px;--sp-16: 64px;--sp-20: 80px;--radius-xs: 3px;--radius-sm: 5px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-pill: 999px;--shadow-xs: 0 1px 0 rgba(15,23,42,.04);--shadow-sm: 0 1px 2px rgba(15,23,42,.06), 0 1px 1px rgba(15,23,42,.04);--shadow-md: 0 4px 12px rgba(15,23,42,.08), 0 1px 2px rgba(15,23,42,.04);--shadow-lg: 0 12px 32px rgba(15,23,42,.12), 0 2px 6px rgba(15,23,42,.06);--shadow-focus: 0 0 0 3px rgba(59,130,246,.3);--ease-standard: cubic-bezier(.2, 0, 0, 1);--ease-emphasize: cubic-bezier(.2, 0, 0, 1.2);--dur-fast: .12s;--dur-base: .18s;--dur-slow: .26s}html,body{font-family:var(--font-sans)}.ds-display{font-family:var(--font-sans);font-weight:700;font-size:var(--text-5xl);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight)}.ds-h1{font-family:var(--font-sans);font-weight:700;font-size:var(--text-3xl);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight)}.ds-h2{font-family:var(--font-sans);font-weight:600;font-size:var(--text-2xl);line-height:var(--leading-snug);letter-spacing:-.01em}.ds-h3{font-family:var(--font-sans);font-weight:600;font-size:var(--text-lg);line-height:var(--leading-snug)}.ds-h4{font-family:var(--font-sans);font-weight:600;font-size:var(--text-md);line-height:var(--leading-snug)}.ds-body{font-family:var(--font-sans);font-weight:400;font-size:var(--text-base);line-height:var(--leading-normal)}.ds-body-sm{font-family:var(--font-sans);font-weight:400;font-size:var(--text-sm);line-height:var(--leading-normal)}.ds-caption{font-family:var(--font-sans);font-weight:500;font-size:var(--text-xs);line-height:var(--leading-normal)}.ds-eyebrow{font-family:var(--font-sans);font-weight:600;font-size:var(--text-xs);line-height:1;letter-spacing:var(--tracking-caps);text-transform:uppercase}.ds-mono,.ds-code{font-family:var(--font-mono);font-size:.92em;font-feature-settings:"ss02","cv11"}*,*:before,*:after{box-sizing:border-box}:root{font-family:var(--font-sans, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif);color-scheme:dark;--accent: #2F81F7;--accent-soft: rgba(47,129,247,.15);--card-bg: #161b22;--card-border: #30363d;--row-hover: #1c2128;--green: #3fb950;--red: #f85149;--orange: #d29922;--grey: #6e7681;--severity-critical: #f85149;--severity-high: #f0883e;--severity-medium: #d29922;--severity-low: #3fb950;--severity-unknown: #6e7681}body{margin:0;padding:0;min-height:100vh;font-size:14px;background:var(--bg-base, #0d1117);color:var(--text-body, #c9d1d9);transition:background .4s,color .4s}[data-theme=clay]{color-scheme:light}components-dashboard{display:block;height:calc(100vh - 120px);overflow:hidden}[data-layout=separation] components-dashboard{height:calc(100vh - 150px)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.db-layout{display:flex;height:100%;overflow:hidden}.db-sidebar{width:220px;min-width:180px;flex-shrink:0;background:var(--bg-layer-1, #161b22);border-right:1px solid var(--border, #30363d);display:flex;flex-direction:column;overflow:hidden}.db-sidebar-controls{display:flex;flex-direction:column;gap:.4rem;padding:.75rem .75rem .5rem;border-bottom:1px solid var(--border-muted, #21262d)}.db-summary{padding:.5rem .75rem;font-size:.75rem;color:var(--text-secondary, #8b949e);border-bottom:1px solid var(--border-muted, #21262d)}.db-summary strong{color:var(--accent, #2f81f7);font-family:var(--font-mono, ui-monospace, monospace)}.db-project-list{list-style:none;margin:0;padding:.4rem 0;overflow-y:auto;flex:1}.db-project-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;cursor:pointer;transition:background 80ms;border-left:2px solid transparent}.db-project-item:hover{background:var(--bg-hover, #252d38)}.db-project-item.active{background:var(--bg-hover, #252d38);border-left-color:var(--accent, #2f81f7)}.db-gate-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.db-dot-green{background:var(--green, #3fb950)}.db-dot-red{background:var(--red, #f85149)}.db-dot-loading{background:var(--text-secondary, #8b949e)}.db-project-name{flex:1;font-size:.82rem;color:var(--text-body, #c9d1d9);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.db-project-item.active .db-project-name{color:var(--text-primary, #f0f6fc);font-weight:500}.db-component-count{font-size:.72rem;color:var(--text-secondary, #8b949e);background:var(--bg-base, #0d1117);border-radius:10px;padding:.1rem .4rem;flex-shrink:0}.db-main{flex:1;overflow-y:auto;padding:1.25rem 1.5rem}.lang-select{background:var(--bg-layer-1, var(--card-bg));color:var(--text-body, #c9d1d9);border:1px solid var(--border, var(--card-border));border-radius:var(--card-radius, 6px);padding:.5rem .75rem;font-size:.9rem;cursor:pointer;transition:border-color .12s,background .3s,color .3s;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.lang-select:hover,.lang-select:focus{border-color:var(--accent);outline:none}.lang-select,.project-gitlab,.feature-count,.business-service-chip,.business-service-close,.feature-file-link{min-height:44px}.dashboard-header .summary{margin:0;color:var(--text-secondary, #8b949e);font-size:.85rem}.dashboard-header .summary strong{color:var(--accent);font-family:var(--font-mono, ui-monospace, monospace)}.project-group{margin-bottom:1rem;background:var(--bg-layer-1, var(--card-bg));border:1px solid var(--border, var(--card-border));border-radius:var(--card-radius, 8px);box-shadow:var(--shadow, none);overflow:hidden;transition:background .3s,border .3s,box-shadow .3s}.project-group>summary{list-style:none}.project-group>summary::-webkit-details-marker{display:none}.project-group-header{display:flex;flex-direction:column;align-items:flex-start;gap:.4rem;padding:.6rem 7rem .6rem .75rem;background:var(--bg-layer-2, #1c2128);border-bottom:1px solid var(--border, var(--card-border));transition:background .3s}.project-group-header h2{margin:0;font-size:1rem;color:var(--text-primary, #f0f6fc)}.project-slug{color:var(--text-secondary, #8b949e);font-family:var(--font-mono, ui-monospace, "SF Mono", monospace);font-size:.75rem;background:var(--bg-base, #0d1117);padding:.1rem .4rem;border-radius:4px}.project-meta{color:var(--text-secondary, #8b949e);font-size:.8rem}.project-group{position:relative}.project-header-actions{position:absolute;top:.4rem;right:4.5rem;display:flex;align-items:center;gap:.5rem;padding:.25rem .5rem;z-index:2}.project-gitlab{display:inline-flex;align-items:center;color:var(--accent);text-decoration:none}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:16px 0}.detail-card{background:var(--bg-layer-2, #1c2128);border:1px solid var(--border, #30363d);border-radius:8px;padding:16px}.detail-card-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary, #8b949e);margin:0 0 12px}.gate-rules{display:flex;flex-direction:column;gap:8px}.gate-rule{display:flex;align-items:center;gap:10px;padding:6px 0;border-bottom:1px solid var(--border, #30363d)}.gate-rule:last-child{border-bottom:none}.gate-rule-icon{width:20px;text-align:center;font-size:14px}.gate-rule-icon.rule-ok{color:var(--green, #3fb950)}.gate-rule-icon.rule-err{color:var(--red, #f85149)}.gate-rule-icon.rule-warn{color:var(--orange, #d29922)}.gate-rule-name{flex:1;font-size:13px;color:var(--text-body, #c9d1d9)}.gate-rule-value{font-size:13px;font-weight:600;font-family:var(--font-mono, monospace)}.gate-rule-value.rule-ok{color:var(--green, #3fb950)}.gate-rule-value.rule-err{color:var(--red, #f85149)}.gate-rule-value.rule-warn{color:var(--orange, #d29922)}.services-metier-list{display:flex;flex-direction:column;gap:8px}.service-metier-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--bg-base, #0d1117);border-radius:6px}.service-metier-name{font-size:13px;font-weight:600;color:var(--text-primary, #f0f6fc)}.service-metier-component{font-size:11px;color:var(--text-secondary, #8b949e);margin-top:2px}.service-metier-badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:12px;font-size:11px;font-weight:700;background:#3fb95026;color:var(--green, #3fb950);text-transform:uppercase;letter-spacing:.5px}.section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary, #8b949e);margin:20px 0 8px}.project-gitlab-path{font-size:12px;color:var(--text-secondary, #8b949e);display:flex;align-items:center;gap:6px;text-decoration:none}.project-gitlab-path:hover{color:var(--accent)}.project-gitlab-path svg{width:14px;height:14px}.links-row{display:inline-flex;align-items:center;justify-content:center;gap:6px}.links-cell{text-align:center;white-space:nowrap}.links-col,.gherkin-cell,.gate-cell{text-align:center}.component-gate{display:inline-flex;padding:2px 10px;border-radius:4px;font-size:11px;font-weight:700;letter-spacing:.5px}.component-gate.status-green{background:#3fb95026;color:var(--green, #3fb950)}.component-gate.status-red{background:#f8514926;color:var(--red, #f85149)}.component-gate.status-loading{color:var(--text-secondary, #8b949e)}.feature-count-zero{font-size:12px;color:var(--text-secondary, #8b949e)}.gherkin-section{margin-top:16px}.gherkin-file-list{display:flex;flex-direction:column;gap:2px}.gherkin-file-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-layer-2, #1c2128);border:1px solid var(--border, #30363d);border-radius:4px;cursor:pointer;font-size:13px;color:var(--text-body, #c9d1d9);transition:background .12s}.gherkin-file-item:first-child{background:var(--accent, #2f81f7);color:#fff;border-color:var(--accent)}.gherkin-file-item:hover{background:var(--bg-hover, #1c2128)}.project-gitlab svg{width:20px;height:20px}.project-gitlab:hover{color:#fff}.branch-select{background:var(--bg-layer-1, var(--card-bg));color:var(--text-body, #c9d1d9);border:1px solid var(--border, var(--card-border));border-radius:var(--card-radius, 6px);padding:.25rem .5rem;font-size:.75rem;cursor:pointer;transition:border-color .12s,background .3s,color .3s}.branch-select:hover,.branch-select:focus{border-color:var(--accent);outline:none}.project-gate-badge{position:absolute;top:.4rem;right:.75rem;font-family:var(--font-mono, ui-monospace, monospace);font-size:.75rem;font-weight:700;letter-spacing:.05em;padding:.2rem .5rem;border-radius:4px}.project-gate-badge.status-green{background:#3fb95026;color:var(--green);border:1px solid var(--green)}.project-gate-badge.status-red{background:#f8514926;color:var(--red);border:1px solid var(--red)}.no-components{margin:0;padding:.75rem 1rem;color:var(--text-secondary, #8b949e);font-style:italic}.components-table{display:block;width:100%}.components-table thead{display:none}.components-table tbody{display:block}.components-table tr.component-row{display:grid;grid-template-columns:auto 1fr auto;gap:.2rem .5rem;padding:.6rem .75rem;margin:.4rem;border:1px solid var(--border-muted, #21262d);border-radius:6px;background:var(--bg-base, #0d1117)}.components-table td{display:flex;align-items:center;padding:0}.components-table td.kind-cell{grid-column:1;grid-row:1}.components-table td.name-cell{grid-column:2;grid-row:1}.components-table td.features-cell{grid-column:3;grid-row:1;justify-content:flex-end}.components-table td.quality-cell{grid-column:1 / -1;grid-row:2;gap:.5rem;padding:.1rem 0;text-align:left}.components-table td.links-cell{grid-column:1 / -1;grid-row:3;gap:.4rem;padding:.1rem 0}.components-table td.trivy-cell{grid-column:1 / -1;grid-row:4;padding:.1rem 0}.components-table td.quality-cell,.components-table td.trivy-cell{flex-direction:column;align-items:flex-start;gap:.2rem}.components-table td.links-cell{flex-wrap:wrap}.components-table td.quality-cell:before,.components-table td.links-cell:before,.components-table td.trivy-cell:before{content:attr(data-label);width:100%;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary, #8b949e)}.kind-badge{display:inline-block;font-family:var(--font-mono, ui-monospace, monospace);font-size:.7rem;font-weight:700;letter-spacing:.05em;padding:.15rem .5rem;border-radius:3px;background:var(--border-muted, #21262d);color:var(--text-secondary, #8b949e);border:1px solid var(--card-border)}.kind-badge.kind-backend{color:#58a6ff;border-color:#1f6feb}.kind-badge.kind-frontend{color:#d2a8ff;border-color:#6e40c9}.kind-badge.kind-e2e{color:#ffa657;border-color:#d29922}.kind-badge.kind-library{color:#79c0ff;border-color:#388bfd}.name-cell code{font-family:var(--font-mono, ui-monospace, "SF Mono", monospace);font-size:.8rem;color:var(--text-primary, #f0f6fc);overflow-wrap:break-word;word-break:break-word}.access-cell{white-space:nowrap}.access-link{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;text-decoration:none;border-radius:4px;margin-right:.25rem;transition:background 80ms}.access-link svg{width:16px;height:16px}.access-link.access-gitlab{color:#fc6d26;border:1px solid #fc6d26}.access-link.access-gitlab:hover{background:#fc6d26;color:#fff}.access-link.access-sonar{color:#4e9bcd;border:1px solid #4e9bcd}.access-link.access-sonar:hover{background:#4e9bcd;color:#fff}.access-link.access-compliance{color:#3fb950;border:1px solid #3fb950}.access-link.access-compliance:hover{background:#3fb950;color:#fff}.access-link.disabled{opacity:.25;cursor:default;pointer-events:none;border-color:var(--grey)}.quality-cell{font-family:var(--font-mono, ui-monospace, monospace);font-size:.8rem}.quality-status{font-weight:700;letter-spacing:.03em}.quality-status.status-passed{color:var(--green)}.quality-status.status-failed{color:var(--red)}.quality-status.status-none{color:var(--grey)}.quality-gate-line{display:flex;align-items:center;justify-content:flex-start;gap:.5rem;margin-bottom:.2rem}.coverage{color:var(--text-secondary, #8b949e);font-size:.8rem}.quality-metrics{display:flex;justify-content:flex-start;gap:.5rem;font-size:.75rem;color:var(--text-secondary, #8b949e)}.quality-metrics .metric{display:inline-flex;align-items:center;gap:.2rem}.quality-metrics .metric svg{opacity:.7;vertical-align:middle}.quality-metrics .metric-bugs{color:#f85149}.quality-metrics .metric-vulns{color:#f0883e}.quality-metrics .metric-smells{color:#d29922}.quality-metrics a.metric{text-decoration:none;color:inherit}.quality-metrics a.metric:hover{text-decoration:underline;opacity:.85}.trivy-cell{font-family:var(--font-mono, ui-monospace, monospace);font-size:.78rem}.trivy-compact{display:inline-flex;align-items:center;gap:.35rem;font-size:.8rem}.trivy-clean{color:var(--green);font-weight:600}.trivy-noscan{color:var(--grey);font-style:italic}.severity-inline{font-weight:700;font-size:.75rem;padding:.1rem .35rem;border-radius:3px}.severity-inline.severity-critical{color:var(--severity-critical);background:#f851491a}.severity-inline.severity-high{color:var(--severity-high);background:#f0883e1a}.severity-inline.severity-medium{color:var(--severity-medium);background:#d299221a}.severity-inline.severity-low{color:var(--severity-low);background:#3fb9501a}.no-scan{color:var(--grey)}.blocking-rules-details{padding:.5rem .75rem;background:var(--bg-layer-1, #161b22);border-top:1px solid var(--card-border)}.blocking-rules-details summary{cursor:pointer;font-size:.85rem;color:var(--red);font-weight:700}.blocking-rules{margin:.5rem 0 0;padding:0 0 0 1rem;font-size:.85rem;color:var(--text-body, #c9d1d9)}.blocking-rule{margin:.25rem 0}.blocking-rule code{font-family:var(--font-mono, ui-monospace, monospace);color:var(--accent);background:var(--bg-base, #0d1117);padding:.05rem .3rem;border-radius:3px}.feature-count{display:inline-flex;align-items:center;gap:.25rem;cursor:pointer;font-size:.75rem;color:var(--accent);background:#58a6ff1a;border:1px solid var(--accent-soft);border-radius:10px;padding:.1rem .5rem;margin-left:.5rem;vertical-align:middle;transition:background .12s}.feature-count:hover{background:#58a6ff33}.feature-detail-row td{padding:0 1rem .75rem!important;background:var(--bg-base, #0d1117)}.feature-file-list{display:flex;flex-direction:column;gap:.25rem}.feature-file-link{cursor:pointer;font-family:var(--font-mono, ui-monospace, monospace);font-size:.8rem;color:var(--accent);padding:.25rem .5rem;border-radius:4px;transition:background .12s}.feature-file-link:hover{background:#58a6ff1a}.feature-file-content{margin:.5rem 0 .25rem}.feature-file-content pre{margin:0;padding:.75rem;background:var(--bg-layer-1, #161b22);border:1px solid var(--card-border);border-radius:6px;overflow-x:auto;font-size:.8rem;line-height:1.5;color:var(--text-body, #c9d1d9)}.business-services-section{padding:.75rem;border-top:1px solid var(--card-border);background:var(--bg-layer-1, #161b22)}.business-services-title{margin:0 0 .5rem;font-size:.85rem;font-weight:600;color:var(--text-primary, #f0f6fc);display:flex;align-items:center;gap:.5rem}.business-services-count{font-family:var(--font-mono, ui-monospace, monospace);font-size:.7rem;background:var(--accent-soft);color:var(--accent);padding:.1rem .4rem;border-radius:10px}.business-services-list{display:flex;flex-wrap:wrap;gap:.4rem}.business-service-chip{display:inline-flex;flex-direction:column;align-items:flex-start;gap:.1rem;cursor:pointer;font-size:.8rem;color:var(--text-body, #c9d1d9);background:var(--bg-base, #0d1117);border:1px solid var(--card-border);border-radius:6px;padding:.35rem .6rem;transition:border-color .12s,background .12s}.business-service-chip:hover{border-color:var(--accent-soft);background:#58a6ff14}.business-service-chip.active{border-color:var(--accent);background:#58a6ff26;color:var(--accent)}.business-service-component{font-family:var(--font-mono, ui-monospace, monospace);font-size:.65rem;color:var(--text-secondary, #8b949e)}.business-service-viewer{margin-top:.5rem}.business-service-loading{color:var(--text-secondary, #8b949e);font-size:.8rem;padding:.5rem}.business-service-content{border:1px solid var(--card-border);border-radius:6px;overflow:hidden}.business-service-content-header{display:flex;align-items:center;justify-content:space-between;padding:.4rem .75rem;background:var(--bg-layer-2, #1c2128);border-bottom:1px solid var(--card-border)}.business-service-content-header code{font-family:var(--font-mono, ui-monospace, monospace);font-size:.75rem;color:var(--text-secondary, #8b949e)}.business-service-close{cursor:pointer;font-size:.75rem;color:var(--accent);padding:.15rem .4rem;border-radius:3px;transition:background 80ms}.business-service-close:hover{background:#58a6ff26}.business-service-content pre{margin:0;padding:.75rem;background:var(--bg-base, #0d1117);overflow-x:auto;font-size:.8rem;line-height:1.5;color:var(--text-body, #c9d1d9);max-height:400px;overflow-y:auto}.gherkin-keyword{color:#cba6f7;font-weight:700}.gherkin-tag{color:#94e2d5}.gherkin-string{color:#a6e3a1}.gherkin-comment{color:#6c7086;font-style:italic}.gherkin-label-assumed{color:#fab387;font-style:italic}.gherkin-label-source{color:#a6e3a1;font-style:italic}.gherkin-table{color:#fab387}.loading,.error,.empty-state{max-width:600px;margin:2rem auto;padding:1rem;background:var(--card-bg);border:1px solid var(--card-border);border-radius:8px;text-align:center}.error{border-color:var(--red)}.error strong{color:var(--red)}@media(min-width:1025px){.lang-select{padding:.35rem .6rem;font-size:.85rem}.project-group-header{flex-direction:row;align-items:center;flex-wrap:nowrap;gap:.75rem;padding:.75rem 1rem}.project-group-header h2{font-size:1.05rem}.project-slug{font-size:.8rem}.project-meta{font-size:.85rem}.project-header-actions{top:0;right:5.5rem;height:2.55rem;padding:0 .5rem}.project-gate-badge{top:.75rem;right:1rem}.project-gate-badge{font-size:.8rem;padding:.25rem .6rem}.components-table{display:table;border-collapse:collapse;table-layout:fixed}.components-table thead{display:table-header-group}.components-table tbody{display:table-row-group}.components-table .kind-col{width:6%;text-align:center}.components-table .name-col{width:15%}.components-table .features-col{width:12%;text-align:center}.components-table .access-col{width:10%;text-align:center}.components-table .quality-col{width:27%;text-align:center}.components-table .trivy-col{width:30%;text-align:center}.components-table thead th{text-align:inherit;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary, #8b949e);padding:.5rem 1rem;border-bottom:1px solid var(--card-border);background:var(--bg-layer-1, #161b22)}.components-table tr.component-row{display:table-row;border-bottom:1px solid var(--border-muted, #21262d);transition:background 80ms;padding:0;margin:0;border-radius:0;background:transparent;border:none}.components-table tbody tr.component-row:last-child{border-bottom:none}.components-table tbody tr.component-row:hover{background:var(--row-hover)}.components-table td{display:table-cell;padding:.5rem 1rem;vertical-align:middle}.components-table td:before{display:none}.components-table td.kind-cell,.components-table td.name-cell,.components-table td.features-cell,.components-table td.quality-cell,.components-table td.links-cell,.components-table td.trivy-cell{grid-column:unset;grid-row:unset}.components-table td.name-cell code{font-size:.85rem;word-break:normal;overflow-wrap:normal}.components-table td.features-cell{text-align:center}.components-table td.features-cell .feature-count{min-height:unset}.components-table td.kind-cell{text-align:center}.components-table td.links-cell{text-align:center;justify-content:center}.components-table td.quality-cell,.components-table td.trivy-cell{text-align:center}.components-table td.trivy-cell .trivy-compact,.quality-gate-line{justify-content:center}.quality-metrics{justify-content:center;gap:.6rem}.access-link{width:26px;height:26px}.severity{font-size:.85rem;min-width:32px;padding:.15rem .4rem}.loading,.error,.empty-state{margin:4rem auto;padding:1.5rem}}sidebar-nav{display:block}.sidebar{background:var(--card-bg);border-right:1px solid var(--card-border);padding:1rem 0;min-height:100vh}.sidebar-links{list-style:none;margin:0;padding:0}.sidebar-links a{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;color:var(--text-body, #c9d1d9);text-decoration:none;font-size:.9rem;transition:background 80ms,color 80ms;min-height:44px}.sidebar-links a:hover{background:var(--row-hover);color:var(--text-primary, #f0f6fc)}.sidebar-links a.active{background:#58a6ff1a;color:var(--accent);border-left:3px solid var(--accent)}.sidebar-section{margin-top:1rem;padding-top:.5rem;border-top:1px solid var(--card-border)}.sidebar-section-title{margin:0;padding:.25rem 1rem .5rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary, #8b949e)}.sidebar-bottom{margin-top:1rem;padding-top:.5rem;border-top:1px solid var(--card-border)}.health-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.health-green{background:var(--green)}.health-red{background:var(--red)}.health-grey{background:var(--grey)}breadcrumb-nav{display:block}.breadcrumb-list{display:flex;align-items:center;gap:.25rem;list-style:none;margin:0;padding:.5rem 0;font-size:.85rem}.breadcrumb-item a{color:var(--accent);text-decoration:none}.breadcrumb-item a:hover{text-decoration:underline}.breadcrumb-item:last-child{color:var(--text-primary, #f0f6fc);font-weight:500}.breadcrumb-separator{color:var(--text-secondary, #8b949e);padding:0 .25rem}activity-feed{display:block}.activity-list{list-style:none;margin:0;padding:0}.activity-item{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.5rem .75rem;border-bottom:1px solid var(--card-border);font-size:.85rem}.activity-item:last-child{border-bottom:none}.activity-type{display:inline-block;font-family:var(--font-mono, ui-monospace, monospace);font-size:.7rem;font-weight:700;letter-spacing:.05em;padding:.1rem .4rem;border-radius:3px;background:var(--border-muted, #21262d);color:var(--accent);border:1px solid var(--card-border)}.activity-summary{flex:1;color:var(--text-body, #c9d1d9)}.activity-time{color:var(--text-secondary, #8b949e);font-size:.75rem;white-space:nowrap}.activity-empty,.activity-error{padding:1rem;color:var(--text-secondary, #8b949e);font-size:.85rem;text-align:center}.activity-error{color:var(--red)}monitoring-view{display:block;padding:1.5rem;max-width:1300px;margin:0 auto}.mon-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-5, 20px);flex-wrap:wrap;gap:var(--sp-3, 12px)}.mon-title{font-size:20px;font-weight:600;color:var(--text-primary, #f0f6fc);margin:0}.mon-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-3, 12px);margin-bottom:var(--sp-5, 20px)}@media(max-width:800px){.mon-kpi-row{grid-template-columns:repeat(2,1fr)}}.mon-kpi{background:var(--bg-layer-1, #161b22);border:1px solid var(--border, #30363d);border-radius:var(--card-radius, 8px);padding:var(--sp-4, 16px)}.mon-kpi-label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary, #8b949e);margin-bottom:var(--sp-2, 8px);display:flex;align-items:center;gap:var(--sp-2, 8px)}.mon-kpi-label svg{stroke:currentColor}.mon-kpi-value{font-size:28px;font-weight:700;letter-spacing:-.02em;color:var(--text-primary, #f0f6fc);font-variant-numeric:tabular-nums}.mon-kpi-value small{font-size:14px;font-weight:500;color:var(--text-secondary, #8b949e)}.mon-kpi-trend{font-family:var(--font-mono, monospace);font-size:11px;margin-top:4px}.mon-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4, 16px);margin-bottom:var(--sp-4, 16px)}@media(max-width:800px){.mon-grid{grid-template-columns:1fr}}.mon-card{background:var(--bg-layer-1, #161b22);border:1px solid var(--border, #30363d);border-radius:var(--card-radius, 8px);overflow:hidden}.mon-card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3, 12px) var(--sp-4, 16px);border-bottom:1px solid var(--border, #30363d);background:var(--bg-layer-2, #1c2128)}.mon-card-title{font-size:12px;font-weight:600;color:var(--text-primary, #f0f6fc)}.alert-row{display:flex;align-items:center;gap:var(--sp-3, 12px);padding:var(--sp-3, 12px) var(--sp-4, 16px);border-bottom:1px solid var(--border, #30363d);font-size:12.5px;transition:background .18s}.alert-row:last-child{border-bottom:none}.alert-row:hover{background:var(--bg-hover, #252d38)}.alert-sev{width:8px;height:8px;border-radius:50%;flex-shrink:0}.alert-sev.critical{background:var(--red, #f85149)}.alert-sev.warning{background:var(--orange, #d29922)}.alert-sev.info{background:var(--accent, #2f81f7)}.alert-name{flex:1;color:var(--text-primary, #f0f6fc);font-weight:500}.alert-target{font-family:var(--font-mono, monospace);font-size:11px;color:var(--text-secondary, #8b949e)}.alert-time{font-family:var(--font-mono, monospace);font-size:10.5px;color:var(--text-secondary, #8b949e);flex-shrink:0}.health-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--sp-3, 12px);padding:var(--sp-4, 16px)}.health-item{display:flex;align-items:center;gap:var(--sp-3, 12px);padding:var(--sp-3, 12px);background:var(--bg-layer-2, #1c2128);border-radius:var(--radius-sm, 5px)}.health-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.health-name{font-size:12px;font-weight:500;color:var(--text-primary, #f0f6fc);flex:1}.health-ms{font-family:var(--font-mono, monospace);font-size:11px;color:var(--text-secondary, #8b949e)}.log-viewer{background:var(--bg-base, #0d1117);padding:var(--sp-3, 12px) var(--sp-4, 16px);font-family:var(--font-mono, monospace);font-size:11px;line-height:1.7;color:var(--text-body, #c9d1d9);max-height:320px;overflow-y:auto}.log-line{display:flex;gap:var(--sp-3, 12px)}.log-ts{color:var(--text-secondary, #8b949e);flex-shrink:0;min-width:70px}.log-level{font-weight:700;flex-shrink:0;min-width:45px}.log-level.INFO{color:var(--accent, #2f81f7)}.log-level.WARN{color:var(--orange, #d29922)}.log-level.ERROR{color:var(--red, #f85149)}.log-msg{color:var(--text-primary, #f0f6fc);word-break:break-all}.monitoring-iframe-wrap{border-radius:var(--card-radius, 8px);overflow:hidden;border:1px solid var(--border, #30363d);background:var(--bg-layer-1, #161b22)}.monitoring-iframe{width:100%;height:600px;border:none}activity-view{display:block;padding:1.5rem;max-width:1300px;margin:0 auto}.act-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:var(--sp-5, 20px);flex-wrap:wrap}.act-title{font-size:20px;font-weight:600;color:var(--text-primary, #f0f6fc);margin:0}.act-filters{display:flex;gap:var(--sp-2, 8px);flex-wrap:wrap}.act-filter{font-size:12px;font-weight:500;padding:5px 12px;border-radius:999px;border:1px solid var(--border, #30363d);color:var(--text-secondary, #8b949e);cursor:pointer;background:transparent;transition:all .18s}.act-filter:hover{border-color:var(--accent, #2f81f7);color:var(--text-primary, #f0f6fc)}.act-filter.on{background:var(--accent-soft, rgba(47,129,247,.15));border-color:var(--accent, #2f81f7);color:var(--accent, #2f81f7)}.act-timeline{display:flex;flex-direction:column;gap:0;position:relative;padding-left:28px}.act-timeline:before{content:"";position:absolute;left:6px;top:0;bottom:0;width:2px;background:var(--border, #30363d)}.act-event{display:flex;align-items:flex-start;gap:var(--sp-3, 12px);padding:var(--sp-3, 12px) var(--sp-4, 16px);border:1px solid var(--border, #30363d);border-radius:var(--card-radius, 8px);background:var(--bg-layer-1, #161b22);margin-bottom:var(--sp-2, 8px);transition:border-color .18s}.act-event:hover{border-color:var(--accent, #2f81f7)}.act-event-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:5px;position:relative;z-index:1}.act-event-dot.deploy{background:var(--green, #3fb950)}.act-event-dot.gate{background:var(--accent, #2f81f7)}.act-event-dot.incident{background:var(--red, #f85149)}.act-event-dot.feature{background:var(--orange, #d29922)}.act-event-dot.security{background:#a78bfa}.act-event-dot.event{background:var(--text-secondary, #8b949e)}.act-event-body{flex:1;min-width:0}.act-event-head{display:flex;align-items:center;gap:var(--sp-2, 8px);flex-wrap:wrap}.act-event-type{font-family:var(--font-mono, monospace);font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:2px 6px;border-radius:4px}.act-event-type.deploy{background:color-mix(in srgb,var(--green, #3fb950) 15%,transparent);color:var(--green, #3fb950)}.act-event-type.gate{background:var(--accent-soft, rgba(47,129,247,.15));color:var(--accent, #2f81f7)}.act-event-type.incident{background:color-mix(in srgb,var(--red, #f85149) 15%,transparent);color:var(--red, #f85149)}.act-event-type.feature{background:color-mix(in srgb,var(--orange, #d29922) 15%,transparent);color:var(--orange, #d29922)}.act-event-type.security{background:color-mix(in srgb,#A78BFA 15%,transparent);color:#a78bfa}.act-event-type.event{background:var(--bg-layer-2, #1c2128);color:var(--text-secondary, #8b949e)}.act-event-project{font-size:13px;font-weight:600;color:var(--text-primary, #f0f6fc)}.act-event-desc{font-size:12.5px;color:var(--text-body, #c9d1d9);margin-top:4px;line-height:1.4}.act-event-meta{display:flex;gap:var(--sp-3, 12px);margin-top:6px;font-family:var(--font-mono, monospace);font-size:10.5px;color:var(--text-secondary, #8b949e)}.act-event-time{margin-left:auto;font-family:var(--font-mono, monospace);font-size:11px;color:var(--text-secondary, #8b949e);flex-shrink:0;white-space:nowrap;align-self:flex-start}.add-component-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;min-width:28px;border-radius:var(--card-radius, 4px);border:1px solid var(--border, var(--card-border));background:var(--bg-layer-1, var(--card-bg));color:var(--accent);font-size:16px;font-weight:700;cursor:pointer;transition:background .15s,border-color .15s,box-shadow .15s}.add-component-btn:hover{background:var(--accent-soft);border-color:var(--accent);color:#fff}.add-component-dialog{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center}.add-component-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0009}.add-component-modal{position:relative;background:var(--card-bg);border:1px solid var(--card-border);border-radius:8px;padding:1.5rem;min-width:360px;max-width:90vw;box-shadow:0 8px 32px #0006}.add-component-modal h3{margin:0 0 1rem;font-size:1.1rem;color:#e6edf3}.add-component-form{display:flex;flex-direction:column;gap:1rem}.add-field{display:flex;flex-direction:column;gap:.25rem}.add-field span{font-size:.8rem;color:var(--text-secondary, #8b949e)}.add-field input,.add-field select{padding:.5rem .75rem;border-radius:4px;border:1px solid var(--card-border);background:var(--bg-base, #0d1117);color:var(--text-body, #c9d1d9);font-size:.9rem}.add-field input:focus,.add-field select:focus{outline:none;border-color:var(--accent)}.add-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.5rem}.add-cancel-btn,.add-submit-btn{padding:.5rem 1rem;border-radius:4px;border:1px solid var(--card-border);font-size:.85rem;cursor:pointer}.add-cancel-btn{background:transparent;color:var(--text-secondary, #8b949e)}.add-cancel-btn:hover{color:var(--text-body, #c9d1d9);border-color:var(--text-secondary, #8b949e)}.add-submit-btn{background:var(--accent-soft);color:#fff;border-color:var(--accent)}.add-submit-btn:hover{background:var(--accent)}.add-submit-btn:disabled{opacity:.6;cursor:not-allowed}.add-result{min-height:0}.add-success{display:flex;align-items:center;gap:.5rem;color:var(--green);font-size:.85rem}.add-success a{color:var(--accent);text-decoration:none}.add-error{color:var(--red);font-size:.85rem}.app-header{position:sticky;top:0;z-index:100;height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;background:var(--bg-layer-1, #161b22);border-bottom:1px solid var(--border, #30363d);transition:background .3s,border-color .3s}.app-brand{text-decoration:none;display:flex;align-items:center;gap:12px}.app-brand-mark{display:grid;place-items:center;width:34px;height:34px;border-radius:8px;background:var(--accent-soft, rgba(47, 129, 247, .15));color:var(--accent, #2f81f7);flex-shrink:0;transition:background .3s}[data-theme=carbon] .app-brand-mark{border-radius:0}[data-theme=clay] .app-brand-mark{border-radius:12px}.app-brand-title{font-family:var(--font-sans, system-ui);font-size:15px;font-weight:700;letter-spacing:-.01em;color:var(--text-primary, #f0f6fc)}.app-brand-sub{font-family:var(--font-mono, monospace);font-size:11px;color:var(--text-secondary, #8b949e);margin-top:1px}.app-header-controls{display:flex;gap:8px;align-items:center}.app-select{font-family:var(--font-sans, system-ui);font-size:12px;font-weight:500;background:var(--bg-layer-1, #161b22);color:var(--text-primary, #f0f6fc);border:1px solid var(--border, #30363d);border-radius:5px;padding:5px 28px 5px 10px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239198A1' stroke-width='2'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 8px center;transition:border-color .18s;min-height:32px}.app-select:hover{border-color:var(--accent, #2f81f7)}.search-trigger{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary, #8b949e);background:var(--bg-layer-1, #161b22);border:1px solid var(--border, #30363d);border-radius:5px;padding:5px 10px;cursor:pointer;min-height:32px;transition:border-color .18s}.search-trigger:hover{border-color:var(--accent, #2f81f7)}.search-trigger kbd{font-size:10px;padding:1px 5px;border:1px solid var(--border, #30363d);border-radius:3px;background:var(--bg-base, #0d1117);color:var(--text-secondary, #8b949e);font-family:inherit}.notif-btn,.settings-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--bg-layer-1, #161b22);border:1px solid var(--border, #30363d);border-radius:5px;color:var(--text-secondary, #8b949e);cursor:pointer;transition:border-color .18s,color .18s;position:relative}.notif-btn:hover,.settings-btn:hover{border-color:var(--accent, #2f81f7);color:var(--text-primary, #f0f6fc)}.notif-badge{position:absolute;top:3px;right:3px;width:8px;height:8px;background:var(--red, #f85149);border-radius:50%}.demo-badge{font-size:11px;font-weight:700;letter-spacing:.5px;padding:3px 10px;border-radius:4px;background:var(--accent, #2f81f7);color:#fff;white-space:nowrap;animation:demo-pulse 2s ease-in-out infinite}@keyframes demo-pulse{0%,to{opacity:1}50%{opacity:.7}}.nav-badge{font-size:9px;font-weight:700;padding:1px 5px;border-radius:8px;background:var(--red, #f85149);color:#fff;margin-left:4px}.sep-bar{position:sticky;top:50px;z-index:99;background:var(--bg-base, #0d1117);border-bottom:1px solid var(--border, #30363d)}.sep-spaces{display:flex;align-items:center;gap:0;padding:0 24px;border-bottom:1px solid var(--border, #30363d)}.sep-nav-item{display:flex;align-items:center;gap:6px;padding:9px 16px;font-size:13px;font-weight:500;color:var(--text-secondary, #8b949e);cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap;transition:color .15s,border-color .15s;-webkit-user-select:none;user-select:none}.sep-nav-item:hover{color:var(--text-primary, #f0f6fc)}.sep-nav-item.active{color:var(--text-primary, #f0f6fc);border-bottom-color:var(--accent, #2f81f7)}.sep-subtabs-row{display:flex;align-items:center;gap:0;padding:0 24px;overflow-x:auto}.sep-subtab{padding:7px 14px;font-size:12px;color:var(--text-secondary, #8b949e);cursor:pointer;white-space:nowrap;border-bottom:2px solid transparent;transition:color .15s;display:none}.sep-subtab:hover{color:var(--text-primary, #f0f6fc)}.sep-subtab.active{color:var(--accent, #2f81f7);border-bottom-color:var(--accent, #2f81f7)}.sep-subtab.visible{display:block}[data-layout=separation] .page-nav,[data-layout=bloc] .sep-bar{display:none!important}.main-content{padding:20px}[data-theme=carbon] .app-select{border-radius:0}[data-theme=clay] .app-select{border-radius:8px}user-menu{display:flex;align-items:center;gap:8px;margin-left:4px}.user-name{font-size:12px;font-weight:500;color:var(--text-secondary, #8b949e)}.page-nav{position:sticky;top:56px;z-index:99;display:flex;align-items:center;padding:0 1.5rem;background:var(--bg-layer-1, #161b22);border-bottom:1px solid var(--border, #30363d);overflow-x:auto;transition:background .3s,border-color .3s}.nav-tab{display:flex;align-items:center;gap:8px;padding:10px 16px;font-size:13px;font-weight:500;color:var(--text-secondary, #8b949e);border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;transition:color .18s,border-color .18s;-webkit-user-select:none;user-select:none}.nav-tab:hover{color:var(--text-primary, #f0f6fc)}.nav-tab.active{color:var(--text-primary, #f0f6fc);border-bottom-color:var(--accent, #2f81f7)}[data-theme=carbon] .nav-tab.active{border-bottom-color:var(--accent, #0f62fe);border-bottom-width:3px}@media(max-width:640px){.app-brand-sub,.app-select{display:none}.page-nav,.app-header{padding:0 1rem}}portal-landing{display:block;padding:1.5rem;position:relative;z-index:1}.landing-loading{text-align:center;padding:3rem;color:var(--text-secondary, #8b949e)}.landing-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.landing-header h1{margin:0 0 .25rem;font-size:1.4rem;font-weight:700;letter-spacing:-.01em;color:var(--text-primary, #f0f6fc);font-family:var(--font-heading, var(--font-sans))}.landing-summary{margin:0;font-size:.85rem;color:var(--text-secondary, #8b949e)}.landing-summary strong{color:var(--accent, #2f81f7);font-family:var(--font-mono, ui-monospace, monospace)}.landing-controls{display:flex;gap:.5rem;align-items:center;flex-shrink:0;flex-wrap:wrap}.bento-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:140px;gap:14px}@media(max-width:1100px){.bento-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.bento-grid{grid-template-columns:repeat(2,1fr)}.bento-hero{grid-row:auto;grid-column:auto}.bento-wide{grid-column:auto}}@media(max-width:480px){.bento-grid{grid-template-columns:1fr}}.landing-tile{background:var(--bg-layer-1, #161b22);border:1px solid var(--border, #30363d);border-radius:var(--card-radius, 8px);box-shadow:var(--card-shadow, none);padding:1.25rem;display:flex;flex-direction:column;overflow:hidden;position:relative;transition:transform .18s cubic-bezier(.2,0,0,1),box-shadow .18s,background .3s,border-color .3s}.landing-tile.clickable:hover{transform:translateY(-2px);border-color:var(--accent, #2f81f7)}.bento-hero{grid-row:span 2;grid-column:span 2}.tile-eyebrow{font-size:10.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary, #8b949e);margin-bottom:.5rem;display:flex;align-items:center;gap:6px}.tile-eyebrow svg{stroke:currentColor;flex-shrink:0}.tile-value{font-size:2rem;font-weight:700;letter-spacing:-.02em;line-height:1;color:var(--text-primary, #f0f6fc);font-variant-numeric:tabular-nums;margin-top:4px}.tile-value small{font-size:14px;font-weight:500;color:var(--text-secondary, #8b949e);margin-left:6px;letter-spacing:0}.tile-sub{font-size:11.5px;color:var(--text-secondary, #8b949e);margin-top:.5rem}.tile-sub.ok{color:var(--green, #3fb950)}.tile-sub.err{color:var(--red, #f85149)}.tile-hero{background:var(--bg-layer-2, #1c2128)}.tile-hero-head{display:flex;justify-content:space-between;align-items:flex-start}.hero-count{font-size:2.75rem;font-weight:700;letter-spacing:-.03em;line-height:1;color:var(--text-primary, #f0f6fc)}.hero-count small{font-size:15px;color:var(--text-secondary, #8b949e);margin-left:4px}.hero-arrow{color:var(--text-secondary, #8b949e);transition:all .18s}.landing-tile.clickable:hover .hero-arrow{color:var(--accent, #2f81f7);transform:translate(2px,-2px)}.project-list{flex:1;overflow-y:auto;margin-top:.5rem;display:flex;flex-direction:column;gap:4px}.project-row{display:flex;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid var(--border, #30363d);font-size:13px}.project-row:last-child{border-bottom:none}.dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.project-name{flex:1;color:var(--text-primary, #f0f6fc);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gate-pill{font-family:var(--font-mono, ui-monospace, monospace);font-size:10px;font-weight:700;letter-spacing:.06em;padding:2px 7px;border-radius:4px;flex-shrink:0}.gate-ok{background:#3fb95026;color:var(--green, #3fb950)}.gate-err{background:#f8514926;color:var(--red, #f85149)}.gate-warn{background:#d2992226;color:var(--orange, #d29922)}.chips{display:flex;gap:5px;margin-top:.5rem;flex-wrap:wrap}.chip{font-family:var(--font-mono, ui-monospace, monospace);font-size:10px;font-weight:700;padding:2px 7px;border-radius:4px;letter-spacing:.04em}.chip-crit{background:#f851492e;color:var(--red, #f85149)}.chip-high{background:#d299222e;color:var(--orange, #d29922)}.chip-med{background:var(--accent-soft, rgba(47,129,247,.15));color:var(--accent, #2f81f7)}.chip-ok{background:#3fb95026;color:var(--green, #3fb950)}.bars{display:flex;align-items:flex-end;gap:4px;flex:1;margin-top:.5rem;min-height:50px}.bar{flex:1;min-height:4px;border-radius:2px 2px 0 0;transition:opacity .18s}.bar:hover{opacity:.75}.bar-ok{background:var(--green, #3fb950)}.bar-fail{background:var(--red, #f85149)}.bar-warn{background:var(--orange, #d29922)}.ring-wrap{display:flex;align-items:center;gap:.75rem;margin-top:.5rem;flex:1}.ring-wrap svg{width:60px;height:60px;flex-shrink:0}.ring-val{font-size:1.625rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary, #f0f6fc);font-variant-numeric:tabular-nums}.ring-lbl{font-family:var(--font-mono, ui-monospace, monospace);font-size:10.5px;color:var(--text-secondary, #8b949e)}.types{display:flex;flex-direction:column;gap:6px;margin-top:.5rem;flex:1}.type-row{display:flex;justify-content:space-between;font-size:12.5px}.type-name{font-family:var(--font-mono, ui-monospace, monospace);color:var(--text-secondary, #8b949e)}.type-count{color:var(--text-primary, #f0f6fc);font-weight:600;font-variant-numeric:tabular-nums}.tile-cta{background:linear-gradient(135deg,var(--accent-soft, rgba(47,129,247,.15)),transparent 70%)}.cta-title{font-size:1.125rem;font-weight:700;letter-spacing:-.01em;line-height:1.2;color:var(--text-primary, #f0f6fc)}.cta-path{font-family:var(--font-mono, ui-monospace, monospace);font-size:11px;color:var(--text-secondary, #8b949e);margin-top:4px}.cta-arrow{position:absolute;bottom:1rem;right:1rem;width:32px;height:32px;border-radius:50%;background:var(--accent, #2f81f7);color:#fff;display:grid;place-items:center;transition:transform .18s cubic-bezier(.2,0,0,1)}.landing-tile.clickable:hover .cta-arrow{transform:translate(3px,-1px)}.platform-name{font-size:1.375rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary, #f0f6fc)}.platform-name .acc{color:var(--accent, #2f81f7)}.platform-desc{font-size:12px;color:var(--text-secondary, #8b949e);margin-top:.5rem;line-height:1.5}.platform-meta{font-family:var(--font-mono, ui-monospace, monospace);font-size:10.5px;color:var(--text-secondary, #8b949e);margin-top:.75rem;opacity:.7}[data-theme=carbon] .landing-tile.clickable:hover{transform:none;border-left:3px solid var(--accent, #0f62fe)}[data-theme=carbon] .bar,[data-theme=carbon] .cta-arrow{border-radius:0}services-directory{max-width:1100px;margin:0 auto;padding:2rem 1.5rem}.sd-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:2rem}.sd-title{margin:0 0 .25rem;font-size:1.5rem;font-weight:600;color:var(--text-primary, #e6edf3)}.sd-subtitle{margin:0;font-size:.85rem;color:var(--text-secondary, #8b949e)}.sd-mode-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .75rem;font-size:.75rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:var(--text-secondary, #8b949e);background:var(--card-bg, #161b22);border:1px solid var(--card-border, #30363d);border-radius:999px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:border-color .2s;white-space:nowrap;flex-shrink:0}.sd-mode-badge:hover{border-color:var(--accent, #2F81F7)}.sd-mode-dot{width:8px;height:8px;border-radius:50%}.sd-mode-local{background:var(--green, #3fb950);box-shadow:0 0 6px var(--green, #3fb950)}.sd-mode-kubernetes{background:var(--accent, #2F81F7);box-shadow:0 0 6px var(--accent, #2F81F7)}.sd-category{margin-bottom:2rem}.sd-category-title{display:flex;align-items:center;gap:.5rem;margin:0 0 .75rem;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary, #8b949e)}.sd-category-count{font-size:.7rem;font-weight:500;background:var(--card-border, #30363d);color:var(--text-secondary, #8b949e);padding:.1rem .4rem;border-radius:999px}.sd-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem}.sd-card{display:flex;flex-direction:column;gap:.5rem;padding:1rem 1.25rem;background:var(--card-bg, #161b22);border:1px solid var(--card-border, #30363d);border-radius:10px;text-decoration:none;color:inherit;transition:border-color .2s,transform .15s,box-shadow .2s}.sd-card:hover{border-color:var(--accent, #2F81F7);transform:translateY(-2px);box-shadow:0 4px 16px #0000004d}.sd-card-current{border-color:var(--accent, #2F81F7);border-style:dashed}.sd-card-head{display:flex;align-items:center;gap:.5rem}.sd-card-name{font-weight:600;font-size:1rem;color:var(--text-primary, #e6edf3)}.sd-card-current-badge{font-size:.6rem;text-transform:uppercase;letter-spacing:.05em;padding:.1rem .35rem;background:var(--accent-soft, rgba(47,129,247,.15));color:var(--accent, #2F81F7);border-radius:4px}.sd-card-arrow{margin-left:auto;opacity:0;color:var(--accent, #2F81F7);transition:opacity .2s;flex-shrink:0}.sd-card:hover .sd-card-arrow{opacity:1}.sd-card-desc{margin:0;font-size:.8rem;line-height:1.45;color:var(--text-secondary, #8b949e)}.sd-card-footer{margin-top:auto;padding-top:.25rem}.sd-card-url{font-size:.7rem;color:var(--grey, #6e7681);background:transparent}.settings-page{max-width:640px;margin:0 auto;padding:2rem}.settings-title{margin:0 0 .25rem;font-size:1.4rem;font-weight:700;color:var(--text-heading, #e6edf3)}.settings-subtitle{margin:0 0 2rem;font-size:.85rem;color:var(--text-secondary, #8b949e)}.settings-section{background:var(--card-bg, #161b22);border:1px solid var(--card-border, #30363d);border-radius:8px;padding:1.5rem}.settings-section-heading{margin:0 0 .25rem;font-size:1rem;font-weight:600;color:var(--text-heading, #e6edf3)}.settings-section-desc{margin:0 0 1.25rem;font-size:.8rem;color:var(--text-secondary, #8b949e)}.settings-field{display:flex;align-items:center;gap:1rem}.settings-label{font-size:.85rem;font-weight:500;white-space:nowrap;color:var(--text-body, #c9d1d9)}.settings-select{flex:1;max-width:280px}.settings-saved{font-size:.75rem;color:var(--green, #3fb950);animation:settings-fade-in .2s ease}@keyframes settings-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.settings-grid{display:grid;grid-template-columns:200px 1fr;gap:var(--sp-5);min-height:calc(100vh - 200px)}@media(max-width:700px){.settings-grid{grid-template-columns:1fr}}.settings-nav{display:flex;flex-direction:column;gap:2px;position:sticky;top:80px;align-self:start}.settings-nav-item{padding:10px 16px;font-size:13px;font-weight:500;color:var(--fg-2);border-radius:var(--radius-sm);cursor:pointer;transition:background .12s}.settings-nav-item:hover{background:var(--bg-hover);color:var(--fg-1)}.settings-nav-item.active{background:var(--accent-soft);color:var(--accent);font-weight:600}.settings-sections{display:flex;flex-direction:column;gap:var(--sp-4)}.settings-section-header{margin-bottom:var(--sp-4)}.settings-section-header h3{font-size:16px;font-weight:600;color:var(--fg-1);margin:0 0 4px}.settings-section-header p{font-size:12.5px;color:var(--fg-2);margin:0}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);padding:var(--sp-3) 0;border-bottom:1px solid var(--border)}.settings-row:last-child{border-bottom:none}.settings-desc{font-size:11px;color:var(--fg-3);margin-top:2px}.settings-control{flex-shrink:0}.input-field{font-family:var(--font-mono);font-size:12px;color:var(--fg-2);background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 10px;min-width:200px}.toggle{position:relative;display:inline-block;width:36px;height:20px}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;right:0;bottom:0;left:0;background:var(--bg-layer-2);border:1px solid var(--border);border-radius:10px;transition:background .2s}.toggle-slider:before{content:"";position:absolute;width:14px;height:14px;left:2px;bottom:2px;background:var(--fg-3);border-radius:50%;transition:transform .2s,background .2s}.toggle input:checked+.toggle-slider{background:var(--accent);border-color:var(--accent)}.toggle input:checked+.toggle-slider:before{transform:translate(16px);background:#fff}.theme-swatches{display:flex;gap:6px}.theme-swatch{width:28px;height:28px;border-radius:var(--radius-sm);border:2px solid var(--border);cursor:pointer;font-size:12px;display:grid;place-items:center;color:#fff;transition:border-color .1s}.theme-swatch.active,.theme-swatch:hover{border-color:var(--accent)}@media(max-width:640px){services-directory{padding:1rem}.sd-header{flex-direction:column}.sd-grid{grid-template-columns:1fr}.settings-page{padding:1rem}.settings-field{flex-direction:column;align-items:stretch;gap:.5rem}.settings-select{max-width:100%}}.shell{padding:24px 32px;max-width:1400px;margin:0 auto}@media(max-width:768px){.shell{padding:16px}}.dot{width:8px;height:8px;border-radius:50%;display:inline-block}.dot-ok{background:var(--green, #3fb950)}.dot-err{background:var(--red, #f85149)}.dot-warn{background:var(--orange, #d29922)}.dot-fg-3{background:var(--grey, #6e7681)}.kind-badge{font-family:var(--font-mono, monospace);font-size:10px;font-weight:600;padding:2px 7px;border-radius:4px;letter-spacing:.04em;background:var(--bg-layer-2, #1c2128);color:var(--fg-2, #8b949e);border:1px solid var(--border, #30363d)}.section-title{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-3, #6e7681);margin:24px 0 12px;padding-bottom:8px;border-bottom:1px solid var(--border, #30363d)}.org-header{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}.org-title{font-size:22px;font-weight:700;letter-spacing:-.02em;margin:0}.org-sub{font-size:12.5px;color:var(--fg-2);font-family:var(--font-mono)}.org-controls{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.view-toggle{display:flex;background:var(--bg-layer-1);border:1px solid var(--border);border-radius:var(--radius-sm);padding:2px;gap:2px}[data-theme=carbon] .view-toggle{border-radius:0}.view-toggle .vt-btn{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;font-size:12px;font-weight:500;color:var(--fg-2);background:transparent;border:none;border-radius:3px;cursor:pointer;font-family:var(--font-sans);transition:all .12s}[data-theme=carbon] .view-toggle .vt-btn{border-radius:0}.view-toggle .vt-btn.on{background:var(--accent-soft);color:var(--accent)}.view-toggle .vt-btn:hover:not(.on){color:var(--fg-1)}.org-view{display:none}.org-view.active{display:block}.org-summary{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--border);border-radius:var(--card-radius);overflow:hidden;margin-bottom:20px}[data-theme=carbon] .org-summary{border-radius:0}@media(max-width:900px){.org-summary{grid-template-columns:repeat(3,1fr)}}@media(max-width:500px){.org-summary{grid-template-columns:repeat(2,1fr)}}.sum-cell{background:var(--bg-layer-1);padding:14px 18px}.sum-lbl{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-3)}.sum-val{font-size:22px;font-weight:700;letter-spacing:-.02em;color:var(--fg-1);margin-top:4px;font-variant-numeric:tabular-nums}.sum-sub{font-size:11px;color:var(--fg-2);margin-top:2px}.org-legend{display:flex;gap:16px;flex-wrap:wrap;padding:12px 16px;background:var(--bg-layer-1);border:1px solid var(--border);border-radius:var(--card-radius);margin-bottom:20px;font-size:12px}[data-theme=carbon] .org-legend{border-radius:0}.legend-group{display:flex;align-items:center;gap:7px;color:var(--fg-2)}.chip-level{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.08em;padding:2px 7px;border-radius:3px}[data-theme=carbon] .chip-level{border-radius:0}.chip-level.l0{background:color-mix(in srgb,var(--fg-1) 12%,transparent);color:var(--fg-1)}.chip-level.l1{background:var(--accent-soft);color:var(--accent)}.chip-level.l2{background:color-mix(in srgb,var(--ok) 15%,transparent);color:var(--ok)}.chip-level.l3{background:color-mix(in srgb,var(--warn) 15%,transparent);color:var(--warn)}.chip-level.l4{background:color-mix(in srgb,var(--fg-2) 15%,transparent);color:var(--fg-2)}.org-tree{display:flex;flex-direction:column;gap:2px;font-family:var(--font-mono);font-size:13px}.onode{display:grid;grid-template-columns:22px 24px 1fr auto auto;align-items:center;gap:10px;padding:9px 14px;background:var(--bg-layer-1);border:1px solid var(--border);border-radius:var(--card-radius);cursor:pointer;transition:background .12s,border-color .12s;position:relative}[data-theme=carbon] .onode{border-left:3px solid transparent}[data-theme=carbon] .onode:hover{border-left-color:var(--accent);background:var(--bg-hover)}.onode:hover{background:var(--bg-hover);border-color:var(--accent)}.onode.leaf{cursor:default}.onode.level-0{background:linear-gradient(135deg,var(--accent-soft),transparent 60%);border-color:color-mix(in srgb,var(--accent) 30%,var(--border))}.onode.level-1{margin-left:22px}.onode.level-2{margin-left:56px}.onode.level-3{margin-left:90px}.onode.level-4{margin-left:124px}@media(max-width:900px){.onode.level-1{margin-left:12px}.onode.level-2{margin-left:28px}.onode.level-3{margin-left:44px}.onode.level-4{margin-left:60px}}.onode-chev{width:18px;height:18px;display:grid;place-items:center;border-radius:4px;color:var(--fg-3);transition:transform .16s,background .12s}[data-theme=carbon] .onode-chev{border-radius:0}.onode.open>.onode-chev{transform:rotate(90deg);color:var(--accent)}.onode.leaf .onode-chev{opacity:0}.onode:hover .onode-chev{background:var(--accent-soft);color:var(--accent)}.icon-badge{width:24px;height:24px;display:grid;place-items:center;border-radius:var(--radius-sm);flex-shrink:0;font-size:13px}[data-theme=carbon] .icon-badge{border-radius:0}.ib-company{background:color-mix(in srgb,var(--fg-1) 12%,transparent);color:var(--fg-1)}.ib-domain{background:var(--accent-soft);color:var(--accent)}.ib-entity{background:color-mix(in srgb,var(--ok) 15%,transparent);color:var(--ok)}.ib-project{background:color-mix(in srgb,var(--warn) 15%,transparent);color:var(--warn)}.ib-service{background:color-mix(in srgb,var(--fg-2) 18%,transparent);color:var(--fg-2)}.onode-main{display:flex;flex-direction:column;min-width:0}.onode-name{font-family:var(--font-sans);font-size:13.5px;font-weight:600;color:var(--fg-1);letter-spacing:-.005em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.onode-meta{font-size:11px;color:var(--fg-3);margin-top:1px;display:flex;gap:8px;align-items:center}.onode-meta .k{font-family:var(--font-mono)}.onode-meta .mdot{width:3px;height:3px;border-radius:50%;background:var(--fg-3);opacity:.5}.onode-right{display:flex;align-items:center;gap:8px}.count-pill{font-family:var(--font-mono);font-size:10.5px;font-weight:600;padding:2px 7px;border-radius:999px;background:color-mix(in srgb,var(--fg-1) 8%,transparent);color:var(--fg-2);min-width:22px;text-align:center}[data-theme=carbon] .count-pill{border-radius:0}.onode.leaf .onode-name{font-family:var(--font-mono);font-size:12px;font-weight:500;color:var(--fg-2)}.onode.leaf .onode-name .ext{color:var(--fg-3)}.ochildren{display:flex;flex-direction:column;gap:2px;overflow:hidden;max-height:0;transition:max-height .3s ease}.ochildren.open{max-height:4000px}.ochildren>*{margin-top:2px}.onode-actions{display:flex;align-items:center;gap:4px}.onode-action-btn{width:26px;height:26px;display:grid;place-items:center;border:1px solid var(--accent);background:var(--accent-soft);border-radius:5px;cursor:pointer;color:var(--accent);transition:background .1s,color .1s,border-color .1s;padding:0;flex-shrink:0;opacity:1}[data-theme=carbon] .onode-action-btn{border-radius:0}.onode-action-btn:hover{background:var(--accent-soft);color:var(--accent);border-color:var(--accent);opacity:1}.onode-action-btn.add-btn{color:var(--ok);border-color:color-mix(in srgb,var(--ok) 30%,transparent)}.onode-action-btn.add-btn:hover{background:color-mix(in srgb,var(--ok) 15%,transparent);color:var(--ok);border-color:var(--ok);opacity:1}.onode-name-input{font-family:var(--font-sans);font-size:13.5px;font-weight:600;color:var(--fg-1);background:var(--bg-base);border:1.5px solid var(--accent);border-radius:4px;padding:2px 6px;outline:none;width:100%;min-width:80px;max-width:300px}[data-theme=carbon] .onode-name-input{border-radius:0}.onode-name-input:focus{box-shadow:0 0 0 2px var(--accent-soft)}.onode-url-input{font-family:var(--font-mono);font-size:11px;color:var(--fg-2);background:var(--bg-base);border:1.5px solid var(--accent);border-radius:4px;padding:2px 6px;outline:none;width:100%;min-width:120px;max-width:400px;margin-top:2px}[data-theme=carbon] .onode-url-input{border-radius:0}.onode-url-input:focus{box-shadow:0 0 0 2px var(--accent-soft)}.onode-gitlab-link{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-mono);font-size:10.5px;color:var(--fg-3);text-decoration:none;transition:color .1s;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:260px}.onode-gitlab-link:hover{color:var(--accent)}.onode-gitlab-link svg{flex-shrink:0}.org-url-combo{position:relative;display:inline-flex;flex-direction:column;margin-top:2px;width:100%;max-width:420px}.org-url-combo-input{font-family:var(--font-mono);font-size:11.5px;color:var(--fg-1);background:var(--bg-base);border:1.5px solid var(--accent);border-radius:4px;padding:5px 28px 5px 8px;outline:none;width:100%}[data-theme=carbon] .org-url-combo-input{border-radius:0}.org-url-combo-input:focus{box-shadow:0 0 0 2px var(--accent-soft)}.org-url-combo-chevron{position:absolute;right:6px;top:6px;pointer-events:none;color:var(--fg-3)}.org-url-combo-list{position:absolute;top:100%;left:0;right:0;z-index:100;background:var(--bg-layer-1);border:1.5px solid var(--accent);border-top:none;border-radius:0 0 4px 4px;max-height:220px;overflow-y:auto;box-shadow:0 8px 24px #0000004d;display:none}[data-theme=carbon] .org-url-combo-list{border-radius:0}.org-url-combo-list.open{display:block}.org-url-combo-item{padding:6px 10px;font-family:var(--font-mono);font-size:11px;color:var(--fg-2);cursor:pointer;display:flex;align-items:center;gap:8px;transition:background 80ms}.org-url-combo-item:hover,.org-url-combo-item.highlighted{background:var(--accent-soft);color:var(--accent)}.org-url-combo-item .combo-icon{flex-shrink:0;opacity:.6}.org-url-combo-item .combo-label{font-family:var(--font-sans);font-size:11px;font-weight:600;color:var(--fg-1);margin-right:4px}.org-url-combo-item .combo-path{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.org-url-combo-separator{padding:4px 10px;font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-3);border-top:1px solid var(--border);pointer-events:none}.org-url-combo-empty{padding:8px 10px;font-size:11px;color:var(--fg-3);font-style:italic}.graph-wrap{position:relative;overflow:hidden;height:520px;background:var(--bg-base);background-image:radial-gradient(circle at 1px 1px,color-mix(in srgb,var(--fg-1) 6%,transparent) 1px,transparent 0);background-size:24px 24px;border:1px solid var(--border);border-radius:var(--card-radius);cursor:grab;-webkit-user-select:none;user-select:none}[data-theme=carbon] .graph-wrap{border-radius:0}.graph-wrap:active{cursor:grabbing}svg.org-graph{position:absolute;top:0;left:0}.gnode{background:var(--bg-layer-1);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:8px 12px;font-family:var(--font-sans);color:var(--fg-1);display:flex;align-items:center;gap:8px;transition:border-color .14s,background .14s;cursor:pointer;box-shadow:0 2px 6px #0000002e;height:100%;overflow:hidden}[data-theme=carbon] .gnode{border-radius:0;border-left-width:3px}[data-theme=clay] .gnode{border-radius:var(--radius-lg)}.gnode:hover{border-color:var(--accent)}.gn-ic{width:22px;height:22px;display:grid;place-items:center;flex-shrink:0;font-size:13px;border-radius:var(--radius-sm)}[data-theme=carbon] .gn-ic{border-radius:0}.gn-ic.company{background:color-mix(in srgb,var(--fg-1) 12%,transparent);color:var(--fg-1)}.gn-ic.domain{background:var(--accent-soft);color:var(--accent)}.gn-ic.entity{background:color-mix(in srgb,var(--ok) 15%,transparent);color:var(--ok)}.gn-ic.project{background:color-mix(in srgb,var(--warn) 15%,transparent);color:var(--warn)}.gn-ic.service{background:color-mix(in srgb,var(--fg-3) 18%,transparent);color:var(--fg-2)}.gn-text{flex:1;min-width:0}.gn-name{font-size:12.5px;font-weight:600;letter-spacing:-.005em;color:var(--fg-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gn-meta{font-size:10.5px;color:var(--fg-3);font-family:var(--font-mono);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gnode.kind-service .gn-name{font-family:var(--font-mono);font-size:11.5px;font-weight:500;color:var(--fg-2)}.gnode.kind-company .gn-name{font-size:14px}.gn-gate{font-family:var(--font-mono);font-size:9.5px;font-weight:600;letter-spacing:.06em;padding:1px 6px;border-radius:3px;flex-shrink:0}[data-theme=carbon] .gn-gate{border-radius:0}.gn-gate.gg{background:color-mix(in srgb,var(--ok) 15%,transparent);color:var(--ok)}.gn-gate.gr{background:color-mix(in srgb,var(--err) 15%,transparent);color:var(--err)}.gn-gate.gw{background:color-mix(in srgb,var(--warn) 15%,transparent);color:var(--warn)}.edge{fill:none;stroke:var(--fg-3);stroke-width:1.25;opacity:.4}.graph-zoom{position:absolute;bottom:12px;right:12px;display:flex;flex-direction:column;gap:4px}.graph-zoom button{width:28px;height:28px;display:grid;place-items:center;background:var(--bg-layer-1);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--fg-1);cursor:pointer;font-family:var(--font-mono);font-size:13px}[data-theme=carbon] .graph-zoom button{border-radius:0}.graph-zoom button:hover{background:var(--bg-hover)}.graph-zoom-display{position:absolute;bottom:12px;left:12px;font-family:var(--font-mono);font-size:11px;color:var(--fg-2);background:var(--bg-layer-1);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 10px}[data-theme=carbon] .graph-zoom-display{border-radius:0}.diagram-outer{position:relative;height:calc(100vh - 380px);min-height:400px;border:1px solid var(--border);border-radius:var(--card-radius);background:var(--bg-base);background-image:radial-gradient(circle at 1px 1px,color-mix(in srgb,var(--fg-1) 6%,transparent) 1px,transparent 0);background-size:24px 24px}[data-theme=carbon] .diagram-outer{border-radius:0}.diagram-wrap{overflow:scroll;height:100%;width:100%;border-radius:inherit}.diagram-wrap::-webkit-scrollbar{width:10px;height:10px}.diagram-wrap::-webkit-scrollbar-track{background:var(--bg-layer-1)}.diagram-wrap::-webkit-scrollbar-thumb{background:var(--fg-3);border-radius:5px;border:2px solid var(--bg-layer-1)}.diagram-wrap::-webkit-scrollbar-thumb:hover{background:var(--fg-2)}.diagram-wrap::-webkit-scrollbar-corner{background:var(--bg-layer-1)}.diagram-inner{min-width:max-content;padding:40px 60px 60px}.diagram-scale{transform-origin:top left;transition:transform .18s}.diagram-toolbar{display:flex;align-items:center;gap:6px;padding:var(--sp-2) 0;margin-bottom:var(--sp-2)}.diagram-toolbar button{height:28px;padding:0 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-layer-1);color:var(--fg-1);font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:4px;transition:background var(--dur-base)}.diagram-toolbar button:hover{background:var(--bg-hover)}.diagram-toolbar .dz-label{font-family:var(--font-mono);font-size:11px;color:var(--fg-2);min-width:40px;text-align:center}.ocn{display:flex;flex-direction:column;align-items:center;position:relative}.ocn-children{display:flex;justify-content:center;align-items:flex-start;gap:18px;padding-top:46px;position:relative}.ocn-child{display:flex;flex-direction:column;align-items:center}.diagram-connectors{position:absolute;top:0;left:0;pointer-events:none;z-index:1}.diagram-connectors line{stroke:var(--fg-3);stroke-width:2.5}.leaves{display:flex;flex-direction:column;align-items:stretch;gap:6px;padding-top:20px;position:relative;min-width:220px}.leaves:before{content:"";position:absolute;top:0;left:50%;width:2px;height:10px;background:var(--border);transform:translate(-1px);z-index:1}.dcard{background:var(--bg-layer-1);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:10px 14px;min-width:170px;max-width:240px;box-shadow:var(--card-shadow);text-align:center;transition:border-color .14s,transform .14s;cursor:default;position:relative}[data-theme=carbon] .dcard{border-radius:0;border-left-width:4px}[data-theme=clay] .dcard{border-radius:var(--radius-lg)}.dcard:hover{border-color:var(--accent);transform:translateY(-1px)}.dcard.company{border-color:var(--fg-1);background:color-mix(in srgb,var(--fg-1) 8%,var(--bg-layer-1));min-width:260px;padding:14px 22px}.dcard.domain{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--bg-layer-1));min-width:210px}.dcard.entity{border-color:var(--ok);background:color-mix(in srgb,var(--ok) 6%,var(--bg-layer-1))}.dcard.project{border-color:var(--warn);background:color-mix(in srgb,var(--warn) 6%,var(--bg-layer-1))}.dcard.service{border-color:var(--border);background:var(--bg-layer-1);border-style:dashed;padding:6px 10px;min-width:200px;max-width:260px;text-align:left}[data-theme=carbon] .dcard.service{border-style:solid;border-left-style:dashed}.dcard-ic{font-size:18px;margin-bottom:4px;line-height:1}.dcard.service .dcard-ic{display:inline-block;margin-right:8px;margin-bottom:0;font-size:14px;vertical-align:middle}.dcard-name{font-size:13.5px;font-weight:600;letter-spacing:-.005em;color:var(--fg-1);overflow:hidden;text-overflow:ellipsis}.dcard.company .dcard-name{font-size:16px;font-weight:700}.dcard.domain .dcard-name{font-size:14.5px}.dcard.service .dcard-name{font-family:var(--font-mono);font-size:11.5px;font-weight:500;color:var(--fg-2);display:inline-block;vertical-align:middle}.dcard-name .ext{color:var(--fg-3);font-weight:400}.dcard-meta{font-size:10.5px;color:var(--fg-3);font-family:var(--font-mono);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dcard-badges{display:flex;justify-content:center;gap:6px;margin-top:6px}.dcard-kind{font-family:var(--font-mono);font-size:9px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:2px 6px;border-radius:3px}[data-theme=carbon] .dcard-kind{border-radius:0}.dcard.company .dcard-kind{background:color-mix(in srgb,var(--fg-1) 15%,transparent);color:var(--fg-1)}.dcard.domain .dcard-kind{background:var(--accent-soft);color:var(--accent)}.dcard.entity .dcard-kind{background:color-mix(in srgb,var(--ok) 15%,transparent);color:var(--ok)}.dcard.project .dcard-kind{background:color-mix(in srgb,var(--warn) 15%,transparent);color:var(--warn)}.diagram-zoom{position:fixed;bottom:20px;right:20px;display:flex;gap:4px;background:var(--bg-layer-1);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px;box-shadow:0 4px 12px #0003;z-index:50}[data-theme=carbon] .diagram-zoom{border-radius:0}.diagram-zoom button{width:28px;height:28px;display:grid;place-items:center;background:transparent;border:none;color:var(--fg-1);cursor:pointer;border-radius:3px;font-family:var(--font-mono);font-size:13px}.diagram-zoom button:hover{background:var(--bg-hover)}.diagram-zoom .dz-display{display:grid;place-items:center;font-family:var(--font-mono);font-size:11px;color:var(--fg-2);padding:0 8px;min-width:44px}.dora-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:var(--sp-5);flex-wrap:wrap}.dora-title{font-size:20px;font-weight:600;color:var(--fg-1);margin:0}.dora-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-4);margin-bottom:var(--sp-5)}@media(max-width:900px){.dora-cards{grid-template-columns:repeat(2,1fr)}}.dora-card{background:var(--bg-layer-1);border:1px solid var(--border);border-radius:var(--card-radius);padding:var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-2)}.dora-card-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-3);display:flex;align-items:center;gap:var(--sp-2)}.dora-card-value{font-size:32px;font-weight:700;letter-spacing:-.02em;color:var(--fg-1);font-variant-numeric:tabular-nums}.dora-card-value small{font-size:14px;font-weight:500;color:var(--fg-2);margin-left:4px}.dora-card-trend{font-family:var(--font-mono);font-size:11px;margin-top:2px}.dora-card-bar{height:6px;border-radius:3px;background:var(--bg-layer-2);margin-top:var(--sp-2);overflow:hidden}.dora-card-bar-fill{height:100%;border-radius:3px;transition:width .6s var(--ease-standard)}.dora-card-target{font-family:var(--font-mono);font-size:10px;color:var(--fg-3);margin-top:2px;display:flex;justify-content:space-between}.dora-sparkline{display:flex;align-items:flex-end;gap:3px;height:40px;margin-top:var(--sp-2)}.dora-sparkline .spark-bar{flex:1;min-width:4px;border-radius:2px 2px 0 0;transition:opacity var(--dur-base)}.dora-sparkline .spark-bar:hover{opacity:.7}.dora-bench{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4)}@media(max-width:700px){.dora-bench{grid-template-columns:1fr}}.dora-bench-card{background:var(--bg-layer-1);border:1px solid var(--border);border-radius:var(--card-radius);overflow:hidden}.dora-bench-header{padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--border);background:var(--bg-layer-2);font-size:12px;font-weight:600;color:var(--fg-1)}.dora-bench-row{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--border);font-size:12.5px}.dora-bench-row:last-child{border-bottom:none}.dora-bench-name{flex:1;color:var(--fg-1);font-weight:500}.dora-bench-val{font-family:var(--font-mono);font-size:12px;font-weight:600}.dora-level{font-family:var(--font-mono);font-size:9px;font-weight:700;letter-spacing:.06em;padding:2px 7px;border-radius:4px}.dora-level.elite{background:color-mix(in srgb,var(--ok) 15%,transparent);color:var(--ok)}.dora-level.high{background:var(--accent-soft);color:var(--accent)}.dora-level.medium{background:color-mix(in srgb,var(--warn) 15%,transparent);color:var(--warn)}.dora-level.low{background:color-mix(in srgb,var(--err) 15%,transparent);color:var(--err)}.sec-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:var(--sp-5);flex-wrap:wrap}.sec-title{font-size:20px;font-weight:600;color:var(--fg-1);margin:0}.sec-score-row{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--sp-3);margin-bottom:var(--sp-5)}@media(max-width:900px){.sec-score-row{grid-template-columns:repeat(3,1fr)}}@media(max-width:500px){.sec-score-row{grid-template-columns:repeat(2,1fr)}}.sec-score-card{background:var(--bg-layer-1);border:1px solid var(--border);border-radius:var(--card-radius);padding:var(--sp-4);text-align:center}.sec-score-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-3);margin-bottom:var(--sp-2)}.sec-score-value{font-size:28px;font-weight:700;font-variant-numeric:tabular-nums}.sec-score-sub{font-family:var(--font-mono);font-size:10.5px;color:var(--fg-2);margin-top:4px}.fw-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-4);margin-bottom:var(--sp-5)}@media(max-width:700px){.fw-grid{grid-template-columns:1fr}}.fw-card{background:var(--bg-layer-1);border:1px solid var(--border);border-radius:var(--card-radius);padding:var(--sp-5)}.fw-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-3)}.fw-card-name{font-size:14px;font-weight:700;color:var(--fg-1)}.fw-card-pct{font-family:var(--font-mono);font-size:18px;font-weight:700}.fw-bar{height:8px;border-radius:4px;background:var(--bg-layer-2);overflow:hidden;margin-bottom:var(--sp-3)}.fw-bar-fill{height:100%;border-radius:4px}.fw-controls{display:flex;flex-direction:column;gap:var(--sp-2)}.fw-control{display:flex;align-items:center;gap:var(--sp-2);font-size:12px;padding:var(--sp-1) 0}.fw-control-icon{width:16px;height:16px;flex-shrink:0;display:grid;place-items:center}.fw-control-name{flex:1;color:var(--fg-1)}.fw-control-status{font-family:var(--font-mono);font-size:10px;font-weight:600}.fb-layout{display:grid;grid-template-columns:1fr 240px;gap:var(--sp-4);min-height:calc(100vh - 180px)}@media(max-width:900px){.fb-layout{grid-template-columns:1fr}}.fb-files{background:var(--bg-layer-1);border:1px solid var(--border);border-radius:var(--card-radius);padding:var(--sp-3) 0;align-self:start;position:sticky;top:120px}.fb-files-title{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-3);padding:var(--sp-2) var(--sp-4) var(--sp-3)}.fb-project-select-wrap{padding:var(--sp-2) var(--sp-3);border-bottom:1px solid var(--border)}.fb-project-select{width:100%;padding:6px 8px;font-size:12px;font-family:var(--font-mono);background:var(--bg-layer-2);color:var(--fg-1);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;outline:none}.fb-project-select:focus{border-color:var(--accent)}.fb-project-loading{padding:var(--sp-2) var(--sp-3);font-size:11px;color:var(--fg-3);font-style:italic}.fb-source-badge{font-size:9px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--fg-3);padding:2px var(--sp-3);display:flex;align-items:center;gap:4px}.fb-source-badge.live{color:var(--ok)}.fb-branch-select{width:100%;padding:4px 6px;font-size:11px;font-family:var(--font-mono);background:var(--bg-layer-2);color:var(--fg-1);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;outline:none;margin-top:4px}.fb-branch-select:focus{border-color:var(--accent)}.fb-editor-wrap{display:flex;flex-direction:column;gap:var(--sp-2)}.fb-toolbar{display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap;padding:var(--sp-2) var(--sp-4);background:var(--bg-layer-1);border:1px solid var(--border);border-radius:var(--card-radius)}.fb-toolbar .btn{padding:5px 12px;font-size:11px}.fb-toolbar-sep{width:1px;height:20px;background:var(--border)}.fb-status{margin-left:auto;font-family:var(--font-mono);font-size:11px;color:var(--fg-3);display:flex;align-items:center;gap:6px}.fb-provider-wrap{display:flex;align-items:center;gap:6px}.fb-provider-label{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--fg-3)}.fb-provider-select{font-family:var(--font-mono);font-size:11px;padding:4px 22px 4px 8px;background:var(--bg-base);color:var(--fg-1);border:1px solid var(--border);border-radius:var(--radius-sm);-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' fill='none' stroke='%23888' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center}.fb-provider-select:focus{outline:none;border-color:var(--accent)}.fb-provider-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.fb-provider-dot.connected{background:var(--ok)}.fb-provider-dot.disconnected{background:var(--err)}.fb-refine-area{display:flex;gap:var(--sp-2);margin-top:var(--sp-1)}.fb-interview-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-base);z-index:10000;display:flex;align-items:center;justify-content:center}.fb-interview-modal{background:var(--bg-layer-1);border:1px solid var(--border);border-radius:12px;box-shadow:0 16px 48px #0006;width:min(620px,90vw);max-height:80vh;display:flex;flex-direction:column;position:relative;z-index:10001}.fb-interview-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.fb-interview-title{font-size:14px;font-weight:600;color:var(--accent);display:flex;align-items:center;gap:8px}.fb-interview-close{background:transparent;border:none;color:var(--fg-3);font-size:1.4rem;cursor:pointer;padding:0 4px;line-height:1}.fb-interview-close:hover{color:var(--fg-1)}.fb-interview-body{flex:1;overflow-y:auto;padding:16px 20px}.fb-interview-q{margin-bottom:16px}.fb-interview-q-label{font-size:13px;color:var(--fg-1);font-weight:500;margin-bottom:6px;display:flex;gap:6px;line-height:1.5}.fb-interview-q-num{color:var(--accent);font-weight:700;flex-shrink:0}.fb-interview-q-input{width:100%;background:var(--bg-base);border:1px solid var(--border);border-radius:6px;color:var(--fg-1);font-size:13px;padding:8px 10px;resize:vertical;min-height:40px;font-family:inherit;box-sizing:border-box}.fb-interview-q-input:focus{outline:none;border-color:var(--accent)}.fb-interview-q-input::placeholder{color:var(--fg-3)}.fb-interview-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;gap:var(--sp-2);justify-content:flex-end}.fb-interview-footer .btn{min-width:120px}.fb-loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:9999;display:flex;align-items:center;justify-content:center}.fb-loading-box{background:var(--bg-layer-1);border:1px solid var(--border);border-radius:12px;padding:24px 36px;box-shadow:0 8px 32px #0006;display:flex;align-items:center;gap:16px}.fb-loading-spinner{width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:fb-spin .8s linear infinite;flex-shrink:0}@keyframes fb-spin{to{transform:rotate(360deg)}}.fb-loading-text{color:var(--fg-1);font-size:14px;font-weight:500}.fb-diff-overlay{position:absolute;top:0;left:0;width:100%;height:100%;padding:var(--sp-5);font-family:var(--font-mono);font-size:12.5px;line-height:1.8;-moz-tab-size:2;tab-size:2;white-space:pre;overflow:auto;background:var(--bg-base);z-index:3;border-radius:var(--card-radius);box-sizing:border-box}.fb-diff-removed{background:#f8514926;color:#f85149;text-decoration:line-through;display:inline}.fb-diff-added{background:#3fb95026;color:#3fb950;display:inline}.fb-diff-unchanged{color:var(--fg-3);display:inline}.fb-diff-actions{position:sticky;bottom:0;background:var(--bg-layer-1);border-top:1px solid var(--border);padding:8px 12px;display:flex;gap:var(--sp-2);justify-content:flex-end;z-index:4;margin:0 calc(-1 * var(--sp-5));padding-left:var(--sp-5);padding-right:var(--sp-5)}.fb-diff-actions .btn{min-width:100px}.fb-refine-area .btn{flex:1}.fb-editor-overlay{position:relative;min-height:400px;flex:1;border:1px solid var(--border);border-radius:var(--card-radius);background:var(--bg-layer-1);overflow:hidden}.fb-editor,.fb-editor-highlight{position:absolute;top:0;left:0;width:100%;height:100%;padding:var(--sp-5);font-family:var(--font-mono);font-size:12.5px;line-height:1.8;-moz-tab-size:2;tab-size:2;white-space:pre;overflow:auto;border:none;border-radius:var(--card-radius);margin:0;box-sizing:border-box}.fb-editor{background:transparent;color:transparent;caret-color:var(--fg-1);resize:none;outline:none;z-index:1}.fb-editor-highlight{background:var(--bg-layer-1);color:var(--fg-2);pointer-events:none;z-index:0}.fb-editor-highlight code{font-family:inherit;font-size:inherit;line-height:inherit}.fb-ai-panel{background:var(--bg-layer-1);border:1px solid var(--border);border-radius:var(--card-radius);padding:var(--sp-4);align-self:start;position:sticky;top:120px;display:flex;flex-direction:column;gap:var(--sp-3)}.fb-ai-title{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);display:flex;align-items:center;gap:var(--sp-2)}.fb-ai-prompt{width:100%;font-family:var(--font-sans);font-size:12px;background:var(--bg-layer-1);color:var(--fg-1);border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--sp-3);resize:vertical;min-height:60px}.fb-ai-prompt:focus{outline:none;border-color:var(--accent)}.fb-suggestion{padding:var(--sp-3);background:var(--bg-layer-2);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--dur-base)}.fb-suggestion:hover{border-color:var(--accent);background:var(--accent-soft)}.fb-suggestion-title{font-size:12px;font-weight:600;color:var(--fg-1);margin-bottom:4px}.fb-suggestion-body{font-size:11px;color:var(--fg-2);font-family:var(--font-mono);line-height:1.5}.fb-validation{background:var(--bg-layer-1);border:1px solid var(--border);border-radius:var(--card-radius);padding:var(--sp-4)}.fb-validation:empty{display:none}.fb-val-row{display:flex;align-items:center;gap:var(--sp-2);padding:4px 0;font-size:12px}.fb-val-row svg{flex-shrink:0}.tpl-header{margin-bottom:var(--sp-5)}.tpl-title{font-size:20px;font-weight:600;color:var(--fg-1);margin:0}.tpl-subtitle{font-size:13px;color:var(--fg-2);margin-top:4px}.tpl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--sp-4);margin-bottom:var(--sp-6)}.tpl-card{background:var(--bg-layer-1);border:1px solid var(--border);border-radius:var(--card-radius);padding:var(--sp-5);cursor:pointer;display:flex;flex-direction:column;gap:var(--sp-3);transition:border-color var(--dur-base),transform var(--dur-base)}.tpl-card:hover{border-color:var(--accent);transform:translateY(-2px)}[data-theme=carbon] .tpl-card:hover{transform:none;border-left-color:var(--accent)}.tpl-card-head{display:flex;align-items:center;gap:var(--sp-3)}.tpl-card-icon{width:40px;height:40px;border-radius:var(--radius-md);display:grid;place-items:center;font-size:20px;flex-shrink:0}[data-theme=carbon] .tpl-card-icon{border-radius:0}.tpl-card-icon.java{background:color-mix(in srgb,#E76F00 15%,transparent)}.tpl-card-icon.ts{background:color-mix(in srgb,#3178C6 15%,transparent)}.tpl-card-icon.py{background:color-mix(in srgb,#3776AB 15%,transparent)}.tpl-card-icon.go{background:color-mix(in srgb,#00ADD8 15%,transparent)}.tpl-card-name{font-size:14px;font-weight:600;color:var(--fg-1)}.tpl-card-stack{font-family:var(--font-mono);font-size:11px;color:var(--fg-3)}.tpl-card-desc{font-size:12.5px;color:var(--fg-2);line-height:1.5;flex:1}.tpl-card-footer{display:flex;gap:var(--sp-2);flex-wrap:wrap}.tpl-tag{font-family:var(--font-mono);font-size:10px;font-weight:600;padding:2px 7px;border-radius:4px;letter-spacing:.04em;background:var(--bg-layer-2);color:var(--fg-2);border:1px solid var(--border)}.tpl-tag.featured{background:var(--accent-soft);color:var(--accent);border-color:transparent}.wizard-card{background:var(--bg-layer-1);border:1px solid var(--border);border-radius:var(--card-radius);padding:var(--sp-6)}.wizard-title{font-size:16px;font-weight:700;color:var(--fg-1);margin-bottom:var(--sp-4)}.wizard-steps{display:flex;gap:var(--sp-3);margin-bottom:var(--sp-5)}.wizard-step{display:flex;align-items:center;gap:var(--sp-2);font-size:12px;font-weight:500;color:var(--fg-3)}.wizard-step.active{color:var(--accent)}.wizard-step.done{color:var(--ok)}.wizard-step-num{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:700;background:var(--bg-layer-2);border:1px solid var(--border)}.wizard-step.active .wizard-step-num{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.wizard-step.done .wizard-step-num{background:color-mix(in srgb,var(--ok) 15%,transparent);border-color:var(--ok);color:var(--ok)}.wizard-step-line{width:24px;height:1px;background:var(--border)}.wizard-form{display:flex;flex-direction:column;gap:var(--sp-4)}.wizard-field label{display:block;font-size:12px;font-weight:600;color:var(--fg-2);margin-bottom:var(--sp-1)}.tpl-card.selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}[data-theme=carbon] .tpl-card.selected{border-left:3px solid var(--accent);box-shadow:none}.wizard-step-body{display:none}.wizard-step-body.active{display:block}.wizard-actions{display:flex;gap:var(--sp-3);margin-top:var(--sp-3)}.gen-progress{padding:var(--sp-4);border-radius:var(--radius-md);background:var(--bg-layer-2);margin-top:var(--sp-3)}.gen-progress .gen-status{display:flex;align-items:center;gap:var(--sp-3);font-size:13px;color:var(--fg-2)}.gen-progress .gen-status.pending{color:var(--warn)}.gen-progress .gen-status.completed{color:var(--ok)}.gen-progress .gen-status.failed{color:var(--err)}.gen-spinner{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.tpl-preview{background:var(--bg-layer-2);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--sp-4);margin-bottom:var(--sp-4)}.tpl-preview-title{font-size:13px;font-weight:600;color:var(--fg-2);margin-bottom:var(--sp-3);display:flex;align-items:center;gap:var(--sp-2);cursor:pointer;-webkit-user-select:none;user-select:none}.tpl-preview-title .chevron{transition:transform .2s;display:inline-block;font-size:10px}.tpl-preview-title .chevron.open{transform:rotate(90deg)}.tpl-tree{font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:12px;color:var(--fg-2);line-height:1.8}.tpl-tree ul{list-style:none;padding-left:20px;margin:0}.tpl-tree>ul{padding-left:0}.tpl-tree li{position:relative;white-space:nowrap}.tpl-tree li:before{content:"";position:absolute;left:-14px;top:0;bottom:0;width:1px;background:var(--border)}.tpl-tree li:after{content:"";position:absolute;left:-14px;top:11px;width:10px;height:1px;background:var(--border)}.tpl-tree>ul>li:before,.tpl-tree>ul>li:after{display:none}.tpl-tree li:last-child:before{height:12px}.tpl-tree .tree-dir{color:var(--accent);font-weight:500}.tpl-tree .tree-file{color:var(--fg-2)}.feature-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--sp-2)}.feature-list li{display:flex;align-items:center;gap:var(--sp-2);font-size:13px;color:var(--fg-2)}.feature-list li label{display:flex;align-items:center;gap:var(--sp-2);cursor:pointer;margin-bottom:0;font-weight:400}.feature-list input[type=checkbox]{accent-color:var(--accent)}.gen-result-link{color:var(--accent);text-decoration:none;font-weight:600}.gen-result-link:hover{text-decoration:underline}.btn:disabled,.btn-primary:disabled{opacity:.4;cursor:not-allowed}deployments-view{display:flex;flex-direction:column;height:calc(100vh - 120px);overflow:hidden}[data-layout=separation] deployments-view{height:calc(100vh - 150px)}.dv-bar{flex-shrink:0;display:flex;align-items:center;gap:14px;padding:12px 24px;border-bottom:1px solid var(--border, #30363d);background:var(--bg-layer-1, #161b22);flex-wrap:wrap}.dv-field{display:flex;flex-direction:column;gap:3px;min-width:0}.dv-field>.dv-lbl{font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--fg-3, #6e7681);font-weight:600;font-family:var(--font-mono, monospace)}.dv-field .select{min-width:200px;padding:7px 28px 7px 12px;font-size:13px}.dv-spacer{flex:1}.dv-summary-pill{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border-radius:var(--card-radius, 6px);background:var(--accent-soft, rgba(47,129,247,.15));color:var(--accent, #2f81f7);font-family:var(--font-mono, monospace);font-size:12px;font-weight:500}.dv-summary-pill .dv-num{font-weight:700;font-size:13px}.dv-env-radio{display:inline-flex;gap:0;background:var(--bg-base, #0d1117);border:1px solid var(--border, #30363d);border-radius:var(--card-radius, 6px);padding:2px}.dv-env-radio button{background:transparent;border:none;color:var(--fg-2, #8b949e);font-family:var(--font-sans, inherit);font-size:12px;font-weight:500;padding:5px 11px;border-radius:4px;cursor:pointer;display:inline-flex;align-items:center;gap:5px}.dv-env-radio button:hover{color:var(--fg-1, #c9d1d9)}.dv-env-radio button.active{background:var(--bg-hover, #1c2128);color:var(--fg-1, #c9d1d9);box-shadow:inset 0 0 0 1px var(--border, #30363d)}.dv-env-radio button.active.dev{color:#6dccff;box-shadow:inset 0 0 0 1px #6dccff66}.dv-env-radio button.active.staging{color:var(--orange, #d29922);box-shadow:inset 0 0 0 1px #d2992280}.dv-env-radio button.active.prod{color:var(--red, #f85149);box-shadow:inset 0 0 0 1px #f8514980}.dv-env-dot{width:7px;height:7px;border-radius:50%}.dv-env-dot.dev{background:#6dccff}.dv-env-dot.staging{background:var(--orange, #d29922)}.dv-env-dot.prod{background:var(--red, #f85149)}.dv-main{flex:1;min-height:0;display:grid;grid-template-columns:280px 1fr 480px;gap:1px;background:var(--border, #30363d)}.dv-col{background:var(--bg-base, #0d1117);display:flex;flex-direction:column;min-height:0;min-width:0}.dv-col-head{flex-shrink:0;padding:14px 18px 10px;display:flex;align-items:center;gap:8px;justify-content:space-between;border-bottom:1px solid var(--border, #30363d)}.dv-col-title{font-size:13px;font-weight:600;letter-spacing:-.005em;color:var(--fg-1, #c9d1d9);display:flex;align-items:center;gap:8px}.dv-col-title svg{color:var(--accent, #2f81f7)}.dv-col-meta{font-size:11px;color:var(--fg-3, #6e7681);font-family:var(--font-mono, monospace)}.dv-col-body{flex:1;overflow-y:auto;min-height:0}.dv-search{margin:10px 14px;display:flex;align-items:center;gap:8px;background:var(--bg-layer-1, #161b22);border:1px solid var(--border, #30363d);border-radius:var(--card-radius, 6px);padding:6px 10px}.dv-search input{flex:1;border:none;background:transparent;outline:none;color:var(--fg-1, #c9d1d9);font-family:var(--font-sans, inherit);font-size:12.5px}.dv-search input::placeholder{color:var(--fg-3, #6e7681)}.dv-search .dv-kbd{font-family:var(--font-mono, monospace);font-size:10px;color:var(--fg-3, #6e7681);padding:1px 6px;border:1px solid var(--border, #30363d);border-radius:3px;background:var(--bg-base, #0d1117)}.dv-project-list{padding:4px 8px 12px;display:flex;flex-direction:column;gap:2px}.dv-group-label{font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-3, #6e7681);font-family:var(--font-mono, monospace);font-weight:600;padding:12px 12px 6px}.dv-project-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--card-radius, 6px);cursor:pointer;transition:background .12s;border:1px solid transparent}.dv-project-item:hover{background:var(--bg-layer-1, #161b22)}.dv-project-item.active{background:var(--accent-soft, rgba(47,129,247,.15));border-color:color-mix(in srgb,var(--accent, #2f81f7) 30%,transparent)}.dv-project-item .dv-pi-icon{width:28px;height:28px;flex-shrink:0;border-radius:5px;display:grid;place-items:center;font-size:13px;background:color-mix(in srgb,var(--fg-1, #c9d1d9) 8%,transparent)}.dv-project-item .dv-pi-text{min-width:0;flex:1}.dv-project-item .dv-pi-name{font-size:12.5px;font-weight:600;color:var(--fg-1, #c9d1d9);font-family:var(--font-mono, monospace);letter-spacing:-.01em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dv-project-item .dv-pi-meta{font-size:10.5px;color:var(--fg-3, #6e7681);font-family:var(--font-mono, monospace)}.dv-project-item .dv-pi-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.dv-pi-dot.green{background:var(--green, #3fb950);box-shadow:0 0 6px color-mix(in srgb,var(--green, #3fb950) 60%,transparent)}.dv-pi-dot.warn{background:var(--orange, #d29922)}.dv-pi-dot.red{background:var(--red, #f85149)}.dv-comp-toolbar{padding:8px 14px;display:flex;align-items:center;justify-content:space-between;gap:10px;border-bottom:1px solid var(--border, #30363d);flex-shrink:0}.dv-comp-toolbar-left{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.dv-filter-chip{font-family:var(--font-mono, monospace);font-size:11px;font-weight:500;padding:4px 10px;border-radius:999px;background:var(--bg-layer-1, #161b22);color:var(--fg-2, #8b949e);border:1px solid var(--border, #30363d);cursor:pointer}.dv-filter-chip.active{background:var(--accent-soft, rgba(47,129,247,.15));color:var(--accent, #2f81f7);border-color:color-mix(in srgb,var(--accent, #2f81f7) 40%,transparent)}.dv-filter-chip:hover{color:var(--fg-1, #c9d1d9)}.dv-filter-divider{width:1px;height:14px;background:var(--border, #30363d);margin:0 4px}.dv-components{padding:0}.dv-component-row{display:grid;grid-template-columns:36px 1fr 90px 130px 90px;align-items:center;padding:12px 16px;gap:12px;border-bottom:1px solid var(--border, #30363d);cursor:pointer;transition:background .12s;position:relative}.dv-component-row:hover{background:var(--bg-layer-1, #161b22)}.dv-component-row.selected{background:var(--accent-soft, rgba(47,129,247,.15))}.dv-checkbox{width:18px;height:18px;border:1.5px solid var(--border, #30363d);border-radius:4px;display:grid;place-items:center;background:var(--bg-layer-1, #161b22);transition:all .12s;flex-shrink:0}.dv-component-row.selected .dv-checkbox{background:var(--accent, #2f81f7);border-color:var(--accent, #2f81f7)}.dv-checkbox svg{opacity:0;color:#fff}.dv-component-row.selected .dv-checkbox svg{opacity:1}.dv-comp-info{min-width:0}.dv-comp-name{font-family:var(--font-mono, monospace);font-size:13px;font-weight:600;color:var(--fg-1, #c9d1d9);display:flex;align-items:center;gap:8px}.dv-comp-desc{font-size:11.5px;color:var(--fg-2, #8b949e);margin-top:2px}.dv-kind-badge{display:inline-flex;align-items:center;gap:5px;padding:2px 7px 2px 5px;border-radius:4px;font-family:var(--font-mono, monospace);font-size:10.5px;font-weight:600;letter-spacing:.01em;background:color-mix(in srgb,var(--dv-kind-color) 14%,transparent);color:var(--dv-kind-color);border:1px solid color-mix(in srgb,var(--dv-kind-color) 30%,transparent);white-space:nowrap}.dv-kind-badge .dv-glyph{width:14px;height:14px;border-radius:3px;background:var(--dv-kind-color);color:#fff;font-size:9px;font-weight:700;display:grid;place-items:center;font-family:var(--font-sans, inherit)}.dv-comp-version{font-family:var(--font-mono, monospace);font-size:11px;color:var(--fg-2, #8b949e);text-align:right;display:flex;flex-direction:column;gap:1px}.dv-comp-version .dv-v-current{color:var(--fg-1, #c9d1d9);font-weight:600}.dv-comp-version .dv-v-target{color:var(--accent, #2f81f7);font-weight:600}.dv-comp-version .dv-v-arrow{color:var(--fg-3, #6e7681)}.dv-version-select{font-family:var(--font-mono, monospace);font-size:11.5px;background:var(--bg-base, #0d1117);color:var(--fg-1, #c9d1d9);border:1px solid var(--border, #30363d);border-radius:4px;padding:4px 22px 4px 8px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%239198A1' stroke-width='2'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 6px center;width:100%}.dv-gate-pill{font-family:var(--font-mono, monospace);font-size:9.5px;font-weight:600;letter-spacing:.08em;padding:2px 7px;border-radius:3px;text-align:center}.dv-gate-pill.g{background:color-mix(in srgb,var(--green, #3fb950) 15%,transparent);color:var(--green, #3fb950)}.dv-gate-pill.r{background:color-mix(in srgb,var(--red, #f85149) 15%,transparent);color:var(--red, #f85149)}.dv-gate-pill.w{background:color-mix(in srgb,var(--orange, #d29922) 15%,transparent);color:var(--orange, #d29922)}.dv-empty-state{padding:60px 24px;text-align:center;color:var(--fg-3, #6e7681);font-size:13px}.dv-empty-state .dv-icon{font-size:32px;margin-bottom:10px;opacity:.6}.dv-console{background:#08090c;color:#c9d1d9;font-family:var(--font-mono, monospace);font-size:12px;line-height:1.55;padding:14px 16px 80px;overflow-y:auto;flex:1;min-height:0;scroll-behavior:smooth}[data-theme=clay] .dv-console{background:#1b1810;color:#e8ded0}.dv-console-line{display:flex;gap:8px;padding:1px 0;word-break:break-word}.dv-console-line .dv-ts{color:#6e7681;flex-shrink:0;min-width:60px}.dv-console-line .dv-lvl{flex-shrink:0;min-width:36px;font-weight:600}.dv-console-line .dv-lvl.cmd{color:#79c0ff}.dv-console-line .dv-lvl.out{color:#8b949e}.dv-console-line .dv-lvl.err{color:#f85149}.dv-console-line .dv-lvl.ok{color:#3fb950}.dv-console-line .dv-lvl.warn{color:#d29922}.dv-console-line .dv-msg{flex:1;white-space:pre-wrap}.dv-console-line.cmd-line{padding-top:6px}.dv-console-line.cmd-line .dv-msg{color:#ffa657;font-weight:600}.dv-console-line.cmd-line .dv-msg:before{content:"$ ";color:#3fb950;margin-right:2px}.dv-console-line.section{margin:10px 0 4px;padding:4px 8px;background:#2f81f714;border-left:2px solid #2F81F7;color:#79c0ff}.dv-console-line.section .dv-ts,.dv-console-line.section .dv-lvl{display:none}.dv-console-foot{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 14px;border-top:1px solid var(--border, #30363d);background:var(--bg-layer-1, #161b22);font-family:var(--font-mono, monospace);font-size:11px;color:var(--fg-2, #8b949e)}.dv-console-foot-left{display:flex;gap:14px;align-items:center}.dv-stat{display:flex;align-items:center;gap:5px}.dv-stat .dv-dot{width:7px;height:7px;border-radius:50%;background:var(--fg-3, #6e7681)}.dv-stat.running .dv-dot{background:var(--accent, #2f81f7);animation:dv-pulse 1.4s ease-in-out infinite}.dv-stat.done .dv-dot{background:var(--green, #3fb950)}.dv-stat.error .dv-dot{background:var(--red, #f85149)}@keyframes dv-pulse{0%,to{opacity:1}50%{opacity:.4}}.dv-icon-btn{background:transparent;border:none;color:var(--fg-2, #8b949e);cursor:pointer;padding:4px 6px;border-radius:4px;display:inline-flex;align-items:center;gap:5px;font-family:var(--font-mono, monospace);font-size:11px}.dv-icon-btn:hover{background:var(--bg-hover, #1c2128);color:var(--fg-1, #c9d1d9)}.dv-modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:100}.dv-modal-bg.open{display:flex}.dv-modal{background:var(--bg-layer-1, #161b22);border:1px solid var(--border, #30363d);border-radius:var(--card-radius, 10px);padding:22px 26px;max-width:460px;width:90%}.dv-modal h3{margin:0 0 6px;font-size:16px;display:flex;align-items:center;gap:8px}.dv-modal p{margin:0 0 16px;color:var(--fg-2, #8b949e);font-size:13px}.dv-modal .dv-modal-actions{display:flex;justify-content:flex-end;gap:8px}.dv-modal .dv-err-icon{color:var(--red, #f85149)}.dv-modal-summary{font-family:var(--font-mono, monospace);font-size:12px;background:var(--bg-base, #0d1117);border:1px solid var(--border, #30363d);padding:10px 12px;border-radius:var(--card-radius, 6px);margin-bottom:14px;white-space:pre-wrap}.dv-toast{position:fixed;bottom:24px;right:24px;z-index:600;padding:10px 20px;border-radius:var(--radius-sm, 4px);font-size:13px;font-weight:500;color:#fff;opacity:0;transition:opacity .3s;pointer-events:none}@media(max-width:1200px){.dv-main{grid-template-columns:240px 1fr 380px}}@media(max-width:980px){.dv-main{grid-template-columns:1fr;grid-template-rows:auto auto auto;overflow:auto}.dv-col{max-height:50vh}}.logs-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-3);flex-wrap:wrap;gap:var(--sp-2)}.logs-title{font-size:1.4rem;font-weight:700;color:var(--fg-1)}.logs-subtitle{font-size:13px;color:var(--fg-2);margin:4px 0 0}.logs-toolbar{display:flex;gap:var(--sp-2);align-items:center}.logs-count{font-size:12px;color:var(--fg-3);background:var(--bg-layer-1);border:1px solid var(--border);border-radius:6px;padding:4px 10px}.logs-table{width:100%;border-collapse:collapse;font-size:13px}.logs-table th{text-align:left;padding:8px 12px;background:var(--bg-layer-1);color:var(--fg-2);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:1}.logs-table td{padding:8px 12px;border-bottom:1px solid var(--border);vertical-align:top;color:var(--fg-1)}.logs-table tr:hover td{background:var(--bg-layer-1)}.logs-type{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.05em;padding:2px 6px;border-radius:4px;text-transform:uppercase}.logs-type-js{background:color-mix(in srgb,var(--err) 15%,transparent);color:var(--err)}.logs-type-api{background:color-mix(in srgb,var(--warn) 15%,transparent);color:var(--warn)}.logs-type-net{background:color-mix(in srgb,var(--info, var(--accent)) 15%,transparent);color:var(--info, var(--accent))}.logs-type-ai{background:color-mix(in srgb,#a855f7 15%,transparent);color:#a855f7}.logs-msg{max-width:500px;word-break:break-word}.logs-detail{font-size:11px;color:var(--fg-3);margin-top:2px;font-family:monospace}.logs-empty{text-align:center;padding:48px 20px;color:var(--fg-3)}.logs-empty svg{margin-bottom:12px;opacity:.4}.logs-badge{position:absolute;top:2px;right:-2px;background:var(--err);color:#fff;font-size:9px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1}.logs-scroll{max-height:calc(100vh - 200px);overflow-y:auto;border:1px solid var(--border);border-radius:8px}.logs-filter{display:flex;gap:var(--sp-1);margin-bottom:var(--sp-2);flex-wrap:wrap}.logs-filter-btn{font-size:11px;padding:4px 10px;border-radius:4px;border:1px solid var(--border);background:var(--bg-layer-1);color:var(--fg-2);cursor:pointer;transition:all .15s}.logs-filter-btn:hover,.logs-filter-btn.on{background:var(--accent-soft);color:var(--accent);border-color:var(--accent)}:root{--bg-base: #0d1117;--bg-layer-1: #161b22;--bg-layer-2: #1c2128;--bg-hover: #252d38;--bg-input: #0d1117;--text-primary: #f0f6fc;--text-body: #c9d1d9;--text-secondary: #8b949e;--border: #30363d;--border-muted: #21262d;--shadow: 0 1px 3px rgba(0, 0, 0, .3);--card-radius: 8px;--card-effect: none;--card-backdrop: none;--landing-bg: var(--bg-base);--landing-fg: none;--font-heading: var(--font-sans, "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif)}.aurora-layer{display:none}.aurora-blob{position:absolute;border-radius:50%;filter:blur(100px);opacity:.55;animation:aurora-drift 20s ease-in-out infinite alternate}@keyframes aurora-drift{0%{transform:translate(0) scale(1)}to{transform:translate(60px,-40px) scale(1.15)}}portal-landing{display:block;max-width:1300px;margin:0 auto;padding:1.5rem}.landing-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:.75rem}.landing-header h1{margin:0;font-family:var(--font-heading);font-size:1.4rem;font-weight:700;color:var(--text-primary)}.landing-summary{font-size:.85rem;color:var(--text-secondary);margin:0}.landing-summary strong{color:var(--accent);font-family:ui-monospace,monospace}.landing-controls{display:flex;gap:.5rem;align-items:center}.theme-select{background:var(--bg-layer-1);border:1px solid var(--border);color:var(--text-body);padding:.35rem .75rem;border-radius:var(--card-radius);cursor:pointer;font-size:.75rem;font-weight:500;transition:all .2s;min-height:32px;min-width:120px}.theme-select:hover{border-color:var(--accent);color:var(--text-primary)}.theme-select:focus{outline:2px solid var(--accent);outline-offset:2px}.theme-btn{background:var(--bg-layer-1);border:1px solid var(--border);color:var(--text-body);padding:.35rem .75rem;border-radius:var(--card-radius);cursor:pointer;font-size:.75rem;font-weight:500;transition:all .2s;min-height:32px}.theme-btn:hover{background:var(--bg-hover);border-color:var(--accent);color:var(--text-primary)}.theme-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.bento-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(140px,auto);gap:12px}.bento-hero{grid-column:span 2;grid-row:span 2}.bento-wide{grid-column:span 2}.bento-tall{grid-row:span 2}@media(max-width:900px){.bento-grid{grid-template-columns:repeat(2,1fr)}.bento-hero{grid-column:span 2;grid-row:span 1}}@media(max-width:500px){.bento-grid{grid-template-columns:1fr}.bento-hero,.bento-wide{grid-column:span 1}}.landing-tile{background:var(--bg-layer-1);border:1px solid var(--border);border-radius:var(--card-radius);box-shadow:var(--shadow);padding:1.25rem;display:flex;flex-direction:column;transition:all .25s;cursor:default;overflow:hidden}.landing-tile.clickable{cursor:pointer}.landing-tile:hover{transform:translateY(-2px);border-color:var(--accent)}.tile-label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-secondary);margin-bottom:.5rem}.tile-value{font-family:var(--font-heading);font-size:2.5rem;font-weight:700;line-height:1;color:var(--text-primary)}.tile-sub{font-size:.8rem;color:var(--text-secondary);margin-top:.35rem}.tile-trend{font-size:.75rem;font-weight:600;margin-top:.25rem}.tile-trend.up{color:var(--green)}.tile-trend.down{color:var(--red)}.tile-bars{display:flex;align-items:flex-end;gap:3px;flex:1;margin-top:.75rem;min-height:50px}.tile-bars .bar{flex:1;border-radius:3px 3px 0 0;min-height:4px;transition:opacity .2s}.tile-bars .bar:hover{opacity:1!important}.tile-bars .bar-ok{background:var(--green);opacity:.6}.tile-bars .bar-warn{background:var(--orange);opacity:.7}.tile-bars .bar-fail{background:var(--red);opacity:.7}.tile-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.tile-dot-green{background:var(--green)}.tile-dot-red{background:var(--red)}.tile-dot-orange{background:var(--orange)}.tile-dot-blue{background:var(--accent);animation:tile-pulse 1.5s infinite}@keyframes tile-pulse{0%,to{opacity:1}50%{opacity:.3}}.tile-gate{font-family:ui-monospace,monospace;font-size:.6rem;font-weight:700;padding:.1rem .35rem;border-radius:4px;letter-spacing:.05em}.tile-gate-green{background:#3fb95026;color:var(--green)}.tile-gate-red{background:#f8514926;color:var(--red)}.tile-project-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:.75rem;flex:1;overflow-y:auto}.tile-project-item{display:flex;align-items:center;justify-content:space-between;padding:.4rem .6rem;border-radius:calc(var(--card-radius) * .5);background:var(--bg-layer-2);font-size:.75rem;color:var(--text-body);transition:background .15s;gap:.4rem}.tile-project-item:hover{background:var(--bg-hover)}.tile-project-name{display:flex;align-items:center;gap:.4rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tile-sev-row{display:flex;gap:4px;flex-wrap:wrap;margin-top:.5rem}.tile-sev{font-family:ui-monospace,monospace;font-size:.6rem;font-weight:700;padding:.15rem .4rem;border-radius:4px;letter-spacing:.03em}.tile-sev-crit{background:#f8514926;color:var(--severity-critical)}.tile-sev-high{background:#f0883e26;color:var(--severity-high)}.tile-sev-med{background:#d2992226;color:var(--severity-medium)}.tile-sev-low{background:#3fb95026;color:var(--severity-low)}.tile-ring{display:flex;align-items:center;gap:.75rem;margin-top:.5rem}.tile-ring svg{width:56px;height:56px}.tile-ring-label{font-size:1.2rem;font-weight:700;color:var(--text-primary)}.tile-ring-sub{font-size:.7rem;color:var(--text-secondary)}[data-theme=github],[data-theme=github-dark]{color-scheme:dark;--bg-base: #0D1117;--bg-layer-1: #161B22;--bg-layer-2: #1C2128;--bg-hover: #252D38;--bg-input: #0D1117;--text-primary: #F0F6FC;--text-body: #C9D1D9;--text-secondary: #8B949E;--border: #30363D;--border-muted: #21262D;--shadow: 0 0 0 1px rgba(240,246,252,.02), 0 2px 4px rgba(0,0,0,.2);--card-radius: 8px;--accent: #2F81F7;--accent-soft: rgba(47,129,247,.15);--green: #3FB950;--red: #F85149;--orange: #D29922;--grey: #6E7681;--severity-critical: #F85149;--severity-high: #F0883E;--severity-medium: #D29922;--severity-low: #3FB950;--severity-unknown: #6E7681;--card-bg: var(--bg-layer-1);--card-border: var(--border);--row-hover: var(--bg-layer-2);--fg-1: var(--text-primary);--fg-2: var(--text-body);--fg-3: var(--text-secondary);--ok: var(--green);--warn: var(--orange);--err: var(--red);--card-shadow: var(--shadow)}[data-theme=aurora]{color-scheme:dark;--bg-base: #0A0A14;--bg-layer-1: rgba(255,255,255,.04);--bg-layer-2: rgba(255,255,255,.07);--bg-hover: rgba(255,255,255,.1);--bg-input: rgba(0,0,0,.3);--text-primary: #F5F5FF;--text-body: rgba(245,245,255,.88);--text-secondary: rgba(245,245,255,.6);--border: rgba(255,255,255,.1);--border-muted: rgba(255,255,255,.06);--shadow: 0 8px 24px rgba(0,0,0,.35);--card-radius: 14px;--accent: #A78BFA;--accent-soft: rgba(167,139,250,.18);--green: #34D399;--red: #FB7185;--orange: #FBBF24;--grey: rgba(245,245,255,.4);--severity-critical: #FB7185;--severity-high: #FBBF24;--severity-medium: #A78BFA;--severity-low: #34D399;--severity-unknown: rgba(245,245,255,.4);--card-bg: var(--bg-layer-1);--card-border: var(--border);--row-hover: var(--bg-hover);--card-effect: blur(12px) saturate(140%);--card-backdrop: rgba(10,10,20,.4);--fg-1: var(--text-primary);--fg-2: var(--text-body);--fg-3: var(--text-secondary);--ok: var(--green);--warn: var(--orange);--err: var(--red);--card-shadow: var(--shadow)}[data-theme=aurora] .aurora-layer{display:block;position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden}[data-theme=aurora] .aurora-blob:nth-child(1){background:radial-gradient(circle,#7C3AED 0%,transparent 70%);width:700px;height:700px;top:-250px;left:-200px;animation-duration:22s}[data-theme=aurora] .aurora-blob:nth-child(2){background:radial-gradient(circle,#2563EB 0%,transparent 70%);width:600px;height:600px;bottom:-200px;right:-200px;animation-duration:28s;animation-direction:alternate-reverse}[data-theme=aurora] .aurora-blob:nth-child(3){background:radial-gradient(circle,#BE185D 0%,transparent 70%);width:400px;height:400px;top:40%;left:55%;animation-duration:35s;opacity:.35}[data-theme=carbon]{color-scheme:dark;--bg-base: #161616;--bg-layer-1: #262626;--bg-layer-2: #323232;--bg-hover: #3A3A3A;--bg-input: #161616;--text-primary: #F4F4F4;--text-body: #C6C6C6;--text-secondary: #A8A8A8;--border: #393939;--border-muted: #2A2A2A;--shadow: none;--card-radius: 0px;--accent: #0F62FE;--accent-soft: rgba(15,98,254,.2);--green: #24A148;--red: #DA1E28;--orange: #F1C21B;--grey: #8D8D8D;--severity-critical: #DA1E28;--severity-high: #F1C21B;--severity-medium: #0F62FE;--severity-low: #24A148;--severity-unknown: #8D8D8D;--card-bg: var(--bg-layer-1);--card-border: var(--border);--row-hover: var(--bg-hover);--fg-1: var(--text-primary);--fg-2: var(--text-body);--fg-3: var(--text-secondary);--ok: var(--green);--warn: var(--orange);--err: var(--red);--card-shadow: var(--shadow)}[data-theme=carbon] .landing-tile{border-left:3px solid transparent;transition:border-left-color .12s,background .12s}[data-theme=carbon] .landing-tile.clickable:hover{transform:none;border-left-color:var(--accent);border-color:var(--border)}[data-theme=clay]{color-scheme:light;--bg-base: #F5EFE6;--bg-layer-1: #FFFAF2;--bg-layer-2: #FFFFFF;--bg-hover: #FFF5E8;--bg-input: #FFFFFF;--text-primary: #2E241B;--text-body: #4A3D32;--text-secondary: #6B5D4C;--border: #E8DFD0;--border-muted: #F0E8DC;--shadow: 0 2px 0 rgba(120,90,60,.06), 0 8px 24px rgba(120,90,60,.08);--card-radius: 20px;--accent: #C9745B;--accent-soft: rgba(201,116,91,.15);--green: #7C9A5C;--red: #C15858;--orange: #D4A04C;--grey: #958777;--severity-critical: #C15858;--severity-high: #D4A04C;--severity-medium: #C9745B;--severity-low: #7C9A5C;--severity-unknown: #958777;--card-bg: var(--bg-layer-1);--card-border: var(--border);--row-hover: var(--bg-hover);--fg-1: var(--text-primary);--fg-2: var(--text-body);--fg-3: var(--text-secondary);--ok: var(--green);--warn: var(--orange);--err: var(--red);--card-shadow: var(--shadow)}[data-theme=clay] .landing-tile{box-shadow:var(--shadow)}[data-theme=clay] .landing-tile.clickable:hover{box-shadow:0 4px #785a3c1a,0 16px 32px #785a3c1f}
