.sai-app { min-height: 100vh; display: flex; flex-direction: column; background: var(--site-bg-gradient, linear-gradient(180deg, var(--bg-start), var(--bg-end))); color: var(--text-primary); } .sai-header { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 18px 28px; border-bottom: 1px solid var(--card-border); background: color-mix(in srgb, var(--card-bg) 70%, transparent); backdrop-filter: blur(var(--blur, 16px)); position: sticky; top: 0; z-index: 30; } .sai-brand { display: flex; align-items: center; gap: 14px; } .sai-brand img { height: 36px; width: auto; } .sai-brand-title { display: flex; flex-direction: column; line-height: 1.1; } .sai-brand-title b { font-size: 15px; letter-spacing: .02em; color: var(--text-primary); } .sai-brand-title small { font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: color-mix(in srgb, var(--primary) 80%, var(--text-primary) 20%); font-weight: 600; } .sai-header-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; } .sai-tabs { display: inline-flex; gap: 4px; padding: 4px; border-radius: 10px; background: var(--surface-muted); border: 1px solid var(--ui-border); } .sai-tab { padding: 7px 14px; font-size: 13px; font-weight: 500; border-radius: 8px; background: transparent; color: var(--text-muted); border: none; cursor: pointer; transition: background .18s ease, color .18s ease; } .sai-tab:hover { color: var(--text-primary); background: var(--surface-hover); } .sai-tab.is-active { background: color-mix(in srgb, var(--primary) 18%, transparent); color: var(--text-primary); box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--primary) 38%, transparent); } .sai-btn { padding: 7px 14px; font-size: 13px; font-weight: 500; border-radius: 8px; background: var(--surface-muted); color: var(--text-primary); border: 1px solid var(--ui-border); cursor: pointer; transition: background .18s ease, transform .12s ease; } .sai-btn:hover { background: var(--surface-hover); } .sai-btn:active { transform: translateY(1px); } .sai-btn-primary { background: color-mix(in srgb, var(--primary) 22%, transparent); border-color: color-mix(in srgb, var(--primary) 50%, transparent); } .sai-btn-ghost { background: transparent; } .sai-empty { flex: 1; display: flex; align-items: center; justify-content: center; padding: 40px 24px; } .sai-drop { width: min(640px, 100%); border: 1.5px dashed color-mix(in srgb, var(--primary) 50%, transparent); border-radius: 16px; padding: 48px 28px; text-align: center; background: color-mix(in srgb, var(--card-bg) 60%, transparent); cursor: pointer; transition: background .2s ease, border-color .2s ease; } .sai-drop:hover, .sai-drop.is-drag { background: color-mix(in srgb, var(--primary) 10%, var(--card-bg) 70%); border-color: var(--primary); } .sai-drop-icon { width: 56px; height: 56px; opacity: .85; margin: 0 auto 16px; display: block; color: var(--primary); } .sai-drop h2 { margin: 0 0 8px; font-size: 18px; font-weight: 600; } .sai-drop p { margin: 6px 0 0; font-size: 13px; color: var(--text-muted); } .sai-drop small { font-size: 12px; color: color-mix(in srgb, var(--text-muted) 70%, transparent); } .sai-main { flex: 1; padding: 24px clamp(16px, 3vw, 36px); } .sai-kpi-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; margin-bottom: 22px; } .sai-kpi { background: var(--card-bg); border: 1px solid var(--card-border); border-radius: 14px; padding: 16px 18px; box-shadow: 0 1px 0 color-mix(in srgb, var(--text-primary) 4%, transparent) inset; } .sai-kpi-label { font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--text-muted); margin-bottom: 8px; } .sai-kpi-value { font-size: 28px; font-weight: 600; color: var(--text-primary); display: flex; align-items: baseline; gap: 8px; } .sai-kpi-value small { font-size: 12px; font-weight: 500; color: var(--text-muted); } .sai-kpi-bar { margin-top: 10px; height: 4px; border-radius: 999px; background: color-mix(in srgb, var(--text-primary) 8%, transparent); overflow: hidden; } .sai-kpi-bar > i { display: block; height: 100%; background: linear-gradient(90deg, var(--primary), color-mix(in srgb, var(--primary) 60%, var(--secondary, #1ec676))); } .sai-grid-2 { display: grid; grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr); gap: 20px; } @media (max-width: 980px) { .sai-grid-2 { grid-template-columns: 1fr; } } .sai-panel { background: var(--card-bg); border: 1px solid var(--card-border); border-radius: 14px; padding: 20px 22px; margin-bottom: 20px; } .sai-panel-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; } .sai-panel-title { font-size: 14px; font-weight: 600; letter-spacing: .02em; color: var(--text-primary); margin: 0; } .sai-panel-sub { font-size: 12px; color: var(--text-muted); margin: 2px 0 0; } .sai-insights { display: flex; flex-direction: column; gap: 12px; } .sai-insight { border: 1px solid var(--card-border); border-left: 3px solid var(--primary); border-radius: 10px; padding: 14px 16px; background: color-mix(in srgb, var(--surface-muted) 80%, transparent); display: grid; grid-template-columns: 1fr auto; gap: 8px 14px; align-items: start; } .sai-insight[data-sev="critical"] { border-left-color: var(--danger, #ff7a7a); } .sai-insight[data-sev="high"] { border-left-color: #ff9866; } .sai-insight[data-sev="medium"] { border-left-color: var(--warning, #f59e0b); } .sai-insight[data-sev="low"] { border-left-color: var(--secondary, #2ecc71); } .sai-insight-title { font-size: 13.5px; font-weight: 600; color: var(--text-primary); margin: 0; } .sai-insight-body { font-size: 12.5px; color: var(--text-muted); margin: 4px 0 0; line-height: 1.5; } .sai-insight-meta { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; font-size: 11px; } .sai-chip { display: inline-flex; align-items: center; gap: 4px; padding: 2px 8px; border-radius: 999px; font-size: 11px; font-weight: 500; background: color-mix(in srgb, var(--text-primary) 6%, transparent); color: var(--text-muted); border: 1px solid var(--card-border); } .sai-chip[data-conf="confirmed"] { background: color-mix(in srgb, var(--danger, #ff7a7a) 14%, transparent); color: var(--danger, #ff7a7a); border-color: color-mix(in srgb, var(--danger, #ff7a7a) 40%, transparent); } .sai-chip[data-conf="probable"] { background: color-mix(in srgb, var(--warning, #f59e0b) 14%, transparent); color: var(--warning, #f59e0b); border-color: color-mix(in srgb, var(--warning, #f59e0b) 40%, transparent); } .sai-chip[data-conf="to_verify"] { background: color-mix(in srgb, var(--primary) 12%, transparent); color: color-mix(in srgb, var(--primary) 80%, var(--text-primary) 20%); border-color: color-mix(in srgb, var(--primary) 38%, transparent); } .sai-chip[data-conf="noise"] { background: color-mix(in srgb, var(--text-primary) 6%, transparent); color: var(--text-muted); } .sai-sev-badge { display: inline-block; padding: 2px 8px; border-radius: 6px; font-size: 10.5px; font-weight: 600; text-transform: uppercase; letter-spacing: .08em; background: color-mix(in srgb, var(--text-primary) 8%, transparent); color: var(--text-muted); } .sai-sev-badge[data-sev="critical"] { background: color-mix(in srgb, var(--danger, #ff7a7a) 22%, transparent); color: var(--danger, #ff7a7a); } .sai-sev-badge[data-sev="high"] { background: color-mix(in srgb, #ff9866 22%, transparent); color: #ff9866; } .sai-sev-badge[data-sev="medium"] { background: color-mix(in srgb, var(--warning, #f59e0b) 22%, transparent); color: var(--warning, #f59e0b); } .sai-sev-badge[data-sev="low"] { background: color-mix(in srgb, var(--secondary, #2ecc71) 22%, transparent); color: var(--secondary, #2ecc71); } .sai-arch { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 10px; } .sai-arch-node { border: 1px solid var(--card-border); border-radius: 10px; padding: 12px; text-align: center; background: color-mix(in srgb, var(--surface-muted) 60%, transparent); } .sai-arch-node b { display: block; font-size: 13px; margin-bottom: 4px; } .sai-arch-node small { font-size: 11px; color: var(--text-muted); } .sai-arch-node[data-active="true"] { border-color: color-mix(in srgb, var(--primary) 50%, transparent); box-shadow: 0 0 0 1px color-mix(in srgb, var(--primary) 30%, transparent); } .sai-arch-node[data-risk="high"] { border-color: color-mix(in srgb, var(--danger, #ff7a7a) 50%, transparent); } .sai-flow { display: flex; flex-direction: column; gap: 8px; } .sai-flow-step { display: grid; grid-template-columns: 28px 1fr; gap: 12px; align-items: center; padding: 8px 12px; border-radius: 8px; background: color-mix(in srgb, var(--surface-muted) 50%, transparent); } .sai-flow-step .dot { width: 10px; height: 10px; border-radius: 50%; background: var(--primary); margin: 0 auto; } .sai-flow-step.is-risk .dot { background: var(--danger, #ff7a7a); } .sai-flow-step .lbl { font-size: 12.5px; color: var(--text-primary); } .sai-flow-step .lbl small { color: var(--text-muted); display: block; font-size: 11px; } .sai-filters { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 14px; } .sai-filters input[type="search"] { flex: 1; min-width: 200px; padding: 8px 12px; border-radius: 8px; background: var(--input-bg); color: var(--input-text); border: 1px solid var(--ui-border); font-size: 13px; } .sai-filters input[type="search"]:focus { outline: none; box-shadow: var(--ui-focus); } .sai-filters select { padding: 8px 10px; border-radius: 8px; font-size: 13px; background: var(--input-bg); color: var(--input-text); border: 1px solid var(--ui-border); } .sai-table-wrap { border: 1px solid var(--card-border); border-radius: 12px; overflow: hidden; background: var(--card-bg); } .sai-table-scroll { max-height: 70vh; overflow: auto; } .sai-table { width: 100%; border-collapse: collapse; font-size: 13px; } .sai-table thead th { position: sticky; top: 0; z-index: 1; background: color-mix(in srgb, var(--card-bg) 96%, var(--primary) 4%); text-align: left; padding: 10px 12px; font-weight: 600; font-size: 11.5px; text-transform: uppercase; letter-spacing: .08em; color: var(--text-muted); border-bottom: 1px solid var(--card-border); } .sai-table tbody td { padding: 10px 12px; border-bottom: 1px solid color-mix(in srgb, var(--card-border) 70%, transparent); vertical-align: top; color: var(--text-primary); } .sai-table tbody tr:hover td { background: var(--surface-hover); } .sai-table .file { font-family: 'Inter','SF Mono','Menlo',monospace; font-size: 12px; word-break: break-all; } .sai-table .desc { color: var(--text-muted); font-size: 12px; max-width: 480px; } .sai-pager { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; border-top: 1px solid var(--card-border); font-size: 12px; color: var(--text-muted); background: color-mix(in srgb, var(--card-bg) 92%, transparent); } .sai-status-bar { display: flex; gap: 16px; align-items: center; flex-wrap: wrap; padding: 10px 24px; border-top: 1px solid var(--card-border); font-size: 12px; color: var(--text-muted); background: color-mix(in srgb, var(--card-bg) 80%, transparent); } .sai-status-bar .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--secondary, #2ecc71); } .report-actions #sai-report-toggle-btn.core-btn, #sai-report-toggle-btn.core-btn.sai-report-toggle-btn { order: 90 !important; background: linear-gradient(135deg, #ff8a3d, #ff6a00) !important; color: #fff !important; border: 1.5px solid #ffbd86 !important; font-weight: 800 !important; letter-spacing: .02em; text-transform: uppercase; box-shadow: 0 0 14px rgba(255, 138, 61, .65), 0 0 34px rgba(255, 106, 0, .38) !important; position: relative; } #eve-analyze-report-btn { order: 91 !important; } .report-actions #sai-report-toggle-btn.core-btn::before { content: "★"; margin-right: 7px; color: #fff6e8; text-shadow: 0 0 8px rgba(255, 220, 160, .95); } .report-actions #sai-report-toggle-btn.core-btn:hover, .report-actions #sai-report-toggle-btn.core-btn:focus { background: linear-gradient(135deg, #ffa45f, #ff7a1a) !important; border-color: #ffd3ad !important; box-shadow: 0 0 20px rgba(255, 138, 61, .85), 0 0 48px rgba(255, 106, 0, .55) !important; transform: translateY(-1px); } .report-actions #sai-report-toggle-btn.is-active.core-btn { background: linear-gradient(135deg, #253244, #162233) !important; border-color: color-mix(in srgb, var(--primary) 55%, transparent) !important; color: var(--primary) !important; box-shadow: 0 0 18px color-mix(in srgb, var(--primary) 32%, transparent) !important; } .report-actions #sai-report-toggle-btn.is-active.core-btn::before { content: "↩"; } .sai-embedded-panel[hidden] { display: none !important; } .sai-embedded { display: flex; flex-direction: column; gap: 18px; padding: 6px 0 18px; } .sai-embedded-hero { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 18px; align-items: stretch; padding: 24px; border: 1px solid color-mix(in srgb, var(--primary) 24%, var(--card-border)); border-radius: 16px; background: linear-gradient(135deg, color-mix(in srgb, var(--card-bg) 92%, #ff8a3d 8%), var(--card-bg)), var(--card-bg); box-shadow: inset 0 1px 0 rgba(255,255,255,.05), 0 18px 55px rgba(0,0,0,.18); } .sai-hero-copy { display: flex; flex-direction: column; justify-content: center; min-width: 0; } .sai-eyebrow { color: #ffb06f; font-size: 11px; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; } .sai-hero-copy h2 { margin: 6px 0 8px; color: var(--text-primary); font-size: clamp(1.45rem, 2vw, 2rem); line-height: 1.12; } .sai-hero-copy p { margin: 0; max-width: 760px; color: var(--text-muted); line-height: 1.55; } .sai-exposure-orb { width: 150px; min-height: 150px; border-radius: 16px; display: grid; place-items: center; align-content: center; border: 1px solid color-mix(in srgb, #ff8a3d 55%, transparent); background: radial-gradient(circle at 50% 35%, rgba(255,138,61,.26), rgba(255,106,0,.08) 58%, transparent 72%); box-shadow: 0 0 28px rgba(255,106,0,.24); } .sai-exposure-orb strong { font-size: 42px; line-height: 1; color: #ffb06f; } .sai-exposure-orb small, .sai-orb-label { color: var(--text-muted); font-size: 12px; } .sai-orb-label { text-transform: uppercase; letter-spacing: .09em; font-weight: 700; } .sai-embedded-metrics { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 10px; } .sai-embedded-metric { border: 1px solid var(--card-border); border-radius: 12px; background: color-mix(in srgb, var(--card-bg) 92%, transparent); padding: 13px 15px; } .sai-embedded-metric span { display: block; color: var(--text-muted); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 6px; } .sai-embedded-metric strong { color: var(--text-primary); font-size: 24px; } .sai-embedded-metric[data-tone="orange"] { border-color: rgba(255,138,61,.42); } .sai-embedded-metric[data-tone="red"] { border-color: color-mix(in srgb, var(--danger) 50%, transparent); } .sai-embedded-metric[data-tone="blue"] { border-color: color-mix(in srgb, var(--primary) 42%, transparent); } .sai-embedded-metric[data-tone="green"] { border-color: color-mix(in srgb, var(--secondary) 42%, transparent); } .sai-cockpit-grid { display: grid; grid-template-columns: minmax(280px, .9fr) minmax(420px, 1.45fr); gap: 16px; } .sai-cockpit-panel { border: 1px solid var(--card-border); border-radius: 14px; background: var(--card-bg); padding: 18px; min-width: 0; } .sai-cockpit-panel:nth-child(3), .sai-cockpit-panel:nth-child(4) { grid-column: 1 / -1; } .sai-cockpit-panel-head { margin-bottom: 14px; } .sai-cockpit-panel-head h3 { margin: 0 0 4px; font-size: 15px; color: var(--text-primary); } .sai-cockpit-panel-head p { margin: 0; color: var(--text-muted); font-size: 12.5px; } .sai-lanes { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; } .sai-lane { min-height: 118px; display: flex; flex-direction: column; justify-content: space-between; border-radius: 12px; padding: 14px; border: 1px solid var(--card-border); background: color-mix(in srgb, var(--surface-muted) 80%, transparent); } .sai-lane[data-lane="security"] { border-color: color-mix(in srgb, var(--danger) 42%, transparent); } .sai-lane[data-lane="routes"] { border-color: color-mix(in srgb, var(--primary) 42%, transparent); } .sai-lane[data-lane="flows"] { border-color: color-mix(in srgb, #ff8a3d 45%, transparent); } .sai-lane[data-lane="sockets"] { border-color: color-mix(in srgb, var(--secondary) 40%, transparent); } .sai-lane-label { color: var(--text-muted); font-size: 12px; font-weight: 700; } .sai-lane strong { color: var(--text-primary); font-size: 28px; } .sai-lane small { color: var(--text-muted); } .sai-embedded-arch { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 10px; } .sai-embedded-arch-node { padding: 18px 12px; text-align: center; border-radius: 12px; border: 1px solid var(--card-border); background: color-mix(in srgb, var(--surface-muted) 68%, transparent); opacity: .62; } .sai-embedded-arch-node[data-active="true"] { opacity: 1; border-color: color-mix(in srgb, var(--primary) 48%, transparent); box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--primary) 18%, transparent); } .sai-embedded-arch-node strong { display: block; color: var(--text-primary); margin-bottom: 5px; } .sai-embedded-arch-node span { display: block; color: var(--text-muted); font-size: 12px; } .sai-priority-board { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 10px; } .sai-priority-card { position: relative; min-height: 128px; border-radius: 12px; border: 1px solid var(--card-border); border-left: 4px solid var(--primary); background: color-mix(in srgb, var(--surface-muted) 62%, transparent); padding: 16px 15px 14px; } .sai-priority-card[data-sev="critical"] { border-left-color: var(--danger); } .sai-priority-card[data-sev="high"] { border-left-color: #ff8a3d; } .sai-priority-card[data-sev="medium"] { border-left-color: var(--warning); } .sai-card-rank { position: absolute; top: 12px; right: 12px; color: var(--text-muted); font-weight: 800; font-size: 12px; } .sai-priority-card h3 { margin: 0 36px 8px 0; color: var(--text-primary); font-size: 13.5px; line-height: 1.35; } .sai-priority-card p { margin: 0 0 10px; color: var(--text-muted); font-size: 12.5px; } .sai-card-meta { display: flex; flex-wrap: wrap; gap: 6px; } .sai-embedded-table { border: 1px solid var(--card-border); border-radius: 12px; overflow: hidden; } .sai-embedded-row { display: grid; grid-template-columns: 92px 120px minmax(140px, .8fr) minmax(180px, .95fr) minmax(260px, 1.35fr); gap: 10px; align-items: start; padding: 10px 12px; border-bottom: 1px solid color-mix(in srgb, var(--card-border) 65%, transparent); } .sai-embedded-row:last-child { border-bottom: 0; } .sai-embedded-row-head { position: sticky; top: 0; z-index: 1; background: color-mix(in srgb, var(--card-bg) 92%, var(--primary) 8%); color: var(--text-muted); font-size: 11px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; } .sai-rule-cell, .sai-file-cell { word-break: break-word; } .sai-file-cell { font-family: 'SF Mono','Menlo','Consolas',monospace; font-size: 12px; color: var(--text-muted); } .sai-message-cell { color: var(--text-muted); line-height: 1.45; } .sai-empty-note { color: var(--text-muted); margin: 0; } @media (max-width: 980px) { .sai-embedded-hero, .sai-cockpit-grid { grid-template-columns: 1fr; } .sai-exposure-orb { width: 100%; min-height: 120px; } .sai-embedded-arch { grid-template-columns: repeat(2, minmax(0, 1fr)); } .sai-embedded-row { grid-template-columns: 80px 100px minmax(130px, 1fr); } .sai-embedded-row span:nth-child(4), .sai-embedded-row span:nth-child(5) { grid-column: 1 / -1; } } @media (max-width: 620px) { .sai-lanes, .sai-embedded-arch { grid-template-columns: 1fr; } .sai-embedded-row { grid-template-columns: 1fr; } .sai-embedded-row-head { display: none; } } .sai-mode-app { --sai-panel: color-mix(in srgb, var(--card-bg) 94%, #05070d 6%); --sai-hairline: color-mix(in srgb, var(--card-border) 82%, var(--primary) 8%); --sai-orange: #ff8a3d; --sai-red: var(--danger, #ff6b80); --sai-blue: var(--primary, #14d7ff); --sai-green: var(--secondary, #2ecc71); gap: 14px; } .sai-mode-tabs { display: inline-flex; align-self: flex-end; gap: 4px; padding: 4px; border: 1px solid var(--sai-hairline); border-radius: 10px; background: color-mix(in srgb, var(--card-bg) 92%, transparent); } .sai-mode-tab { border: 0; border-radius: 8px; padding: 8px 14px; background: transparent; color: var(--text-muted); font-weight: 750; cursor: pointer; } .sai-mode-tab.is-active { color: var(--text-primary); background: color-mix(in srgb, var(--primary) 18%, transparent); box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--primary) 32%, transparent); } .sai-mode-view { min-width: 0; } .sai-hero-system { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(280px, .95fr) 160px; gap: 16px; align-items: stretch; padding: 22px; border: 1px solid var(--sai-hairline); border-radius: 16px; background: radial-gradient(700px 260px at 12% -12%, rgba(255,138,61,.10), transparent 60%), radial-gradient(520px 240px at 92% 4%, rgba(20,215,255,.08), transparent 58%), var(--sai-panel); box-shadow: 0 18px 48px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.04); } .sai-hero-brand { display: flex; align-items: center; gap: 14px; min-width: 0; } .sai-hero-brand img { width: 42px; height: 42px; object-fit: contain; filter: drop-shadow(0 0 12px color-mix(in srgb, var(--primary) 42%, transparent)); } .sai-hero-brand h2 { margin: 4px 0 6px; font-size: clamp(1.3rem, 1.8vw, 1.85rem); line-height: 1.15; color: var(--text-primary); } .sai-hero-brand p { margin: 0; max-width: 820px; color: var(--text-muted); line-height: 1.5; } .sai-hero-meta { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; } .sai-hero-meta-item { min-width: 0; border: 1px solid var(--sai-hairline); border-radius: 10px; padding: 10px 12px; background: color-mix(in srgb, var(--surface-muted) 55%, transparent); } .sai-hero-meta-item span { display: block; color: var(--text-muted); font-size: 10.5px; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 4px; } .sai-hero-meta-item strong { display: block; color: var(--text-primary); font-size: 13px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .sai-hero-meta-item[data-tone="red"] strong { color: var(--sai-red); } .sai-hero-meta-item[data-tone="orange"] strong { color: var(--sai-orange); } .sai-hero-meta-item[data-tone="yellow"] strong { color: var(--warning); } .sai-hero-meta-item[data-tone="green"] strong { color: var(--sai-green); } .sai-kpi-premium-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); gap: 10px; } .sai-kpi-premium { border: 1px solid var(--sai-hairline); border-radius: 13px; background: var(--sai-panel); padding: 15px 16px; min-height: 118px; } .sai-kpi-premium-label { display: block; color: var(--text-muted); font-size: 11px; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 8px; } .sai-kpi-premium strong { display: block; color: var(--text-primary); font-size: 25px; line-height: 1.1; } .sai-kpi-premium p { margin: 8px 0 0; color: var(--text-muted); font-size: 12px; line-height: 1.4; } .sai-kpi-premium[data-tone="red"] { border-color: color-mix(in srgb, var(--sai-red) 42%, transparent); } .sai-kpi-premium[data-tone="orange"] { border-color: color-mix(in srgb, var(--sai-orange) 45%, transparent); } .sai-kpi-premium[data-tone="blue"] { border-color: color-mix(in srgb, var(--sai-blue) 42%, transparent); } .sai-kpi-premium[data-tone="green"] { border-color: color-mix(in srgb, var(--sai-green) 42%, transparent); } .sai-overview-grid { display: grid; grid-template-columns: minmax(310px, .92fr) minmax(420px, 1.28fr); gap: 16px; } .sai-overview-grid .sai-cockpit-panel:nth-child(n+3) { grid-column: 1 / -1; } .sai-impact-map { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; } .sai-impact-zone { min-height: 106px; text-align: left; border-radius: 12px; border: 1px solid var(--sai-hairline); background: color-mix(in srgb, var(--surface-muted) 62%, transparent); color: var(--text-primary); padding: 13px; cursor: pointer; transition: border-color .16s ease, transform .16s ease, background .16s ease; } .sai-impact-zone:hover { transform: translateY(-1px); background: color-mix(in srgb, var(--primary) 9%, var(--surface-muted)); } .sai-impact-zone strong { display: block; font-size: 24px; margin: 8px 0 3px; } .sai-impact-label { display: block; color: var(--text-primary); font-weight: 800; } .sai-impact-zone small { color: var(--text-muted); } .sai-impact-zone[data-impact="high"] { border-color: color-mix(in srgb, var(--sai-red) 52%, transparent); } .sai-impact-zone[data-impact="medium"] { border-color: color-mix(in srgb, var(--sai-orange) 52%, transparent); } .sai-impact-zone[data-impact="low"] { border-color: color-mix(in srgb, var(--sai-blue) 42%, transparent); } .sai-impact-zone[data-impact="neutral"] { opacity: .58; } .sai-system-map { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; } .sai-system-node { position: relative; min-height: 108px; border: 1px solid var(--sai-hairline); border-radius: 12px; background: color-mix(in srgb, var(--surface-muted) 58%, transparent); padding: 14px; opacity: .58; } .sai-system-node[data-active="true"] { opacity: 1; border-color: color-mix(in srgb, var(--primary) 45%, transparent); box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--primary) 12%, transparent); } .sai-system-node strong { display: block; margin-bottom: 8px; color: var(--text-primary); } .sai-system-node span { color: var(--text-muted); font-size: 12px; } .sai-exposure-timeline { display: flex; flex-direction: column; gap: 9px; } .sai-timeline-step { display: grid; grid-template-columns: 34px 1fr; gap: 10px; align-items: start; padding: 10px; border: 1px solid var(--sai-hairline); border-radius: 10px; background: color-mix(in srgb, var(--surface-muted) 55%, transparent); } .sai-timeline-step[data-risk="true"] { border-color: color-mix(in srgb, var(--sai-orange) 45%, transparent); } .sai-timeline-dot { width: 26px; height: 26px; border-radius: 999px; display: inline-grid; place-items: center; background: color-mix(in srgb, var(--primary) 22%, transparent); color: var(--primary); font-size: 12px; font-weight: 800; } .sai-timeline-step strong { color: var(--text-primary); } .sai-timeline-step small { display: block; margin-top: 3px; color: var(--text-muted); } .sai-root-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 8px; } .sai-root-row { text-align: left; border: 1px solid var(--sai-hairline); border-left: 4px solid var(--primary); border-radius: 10px; background: color-mix(in srgb, var(--surface-muted) 55%, transparent); color: var(--text-primary); padding: 12px; cursor: pointer; } .sai-root-row[data-sev="critical"] { border-left-color: var(--danger); } .sai-root-row[data-sev="high"] { border-left-color: var(--sai-orange); } .sai-root-row strong, .sai-root-row span, .sai-root-row small { display: block; } .sai-root-row span { margin: 5px 0; color: var(--text-muted); } .sai-root-row small { color: var(--primary); font-weight: 750; } .sai-mini-action { margin-top: 10px; border: 1px solid color-mix(in srgb, var(--primary) 42%, transparent); border-radius: 8px; background: color-mix(in srgb, var(--primary) 13%, transparent); color: var(--text-primary); padding: 7px 10px; cursor: pointer; } .sai-investigation-view { display: flex; flex-direction: column; gap: 12px; } .sai-investigation-filters { display: grid; grid-template-columns: minmax(260px, 1.5fr) repeat(5, minmax(140px, 1fr)); gap: 8px; align-items: center; padding: 12px; border: 1px solid var(--sai-hairline); border-radius: 14px; background: var(--sai-panel); } .sai-investigation-filters input[type="search"], .sai-investigation-filters select { width: 100%; min-width: 0; border: 1px solid var(--ui-border); border-radius: 8px; background: var(--input-bg); color: var(--input-text); padding: 8px 10px; font-size: 12.5px; } .sai-filter-check { display: inline-flex; align-items: center; gap: 6px; color: var(--text-muted); font-size: 12px; white-space: nowrap; } .sai-investigation-summary { display: flex; justify-content: space-between; gap: 12px; flex-wrap: wrap; color: var(--text-muted); font-size: 12.5px; } .sai-investigation-summary strong { color: var(--text-primary); } .sai-investigation-table-wrap { border: 1px solid var(--sai-hairline); border-radius: 14px; overflow: hidden; background: var(--sai-panel); } .sai-investigation-table { min-width: 920px; } .sai-investigation-row { display: grid; grid-template-columns: 124px minmax(190px, .9fr) minmax(210px, 1fr) minmax(300px, 1.45fr) 138px 78px; gap: 10px; align-items: start; padding: 13px 14px; border-bottom: 1px solid color-mix(in srgb, var(--card-border) 70%, transparent); font-size: 12px; } .sai-investigation-row:not(.sai-investigation-head) { border-left: 3px solid transparent; background: color-mix(in srgb, var(--card-bg) 72%, transparent); } .sai-investigation-row:not(.sai-investigation-head)[data-sev="critical"] { border-left-color: color-mix(in srgb, var(--danger) 88%, #fff 4%); } .sai-investigation-row:not(.sai-investigation-head)[data-sev="high"] { border-left-color: color-mix(in srgb, var(--sai-orange) 88%, #fff 4%); } .sai-investigation-row:not(.sai-investigation-head)[data-sev="medium"] { border-left-color: color-mix(in srgb, var(--sai-amber) 76%, #fff 8%); } .sai-investigation-head { position: sticky; top: 0; z-index: 1; background: color-mix(in srgb, var(--card-bg) 92%, var(--primary) 7%); color: var(--text-muted); font-weight: 850; text-transform: uppercase; letter-spacing: .06em; } .sai-investigation-group { padding: 8px 12px; color: var(--primary); background: color-mix(in srgb, var(--primary) 10%, transparent); font-weight: 850; border-bottom: 1px solid var(--sai-hairline); } .sai-priority-num { color: var(--sai-orange); font-weight: 850; } .sai-triage-cell, .sai-signal-cell, .sai-location-cell { display: grid; gap: 5px; min-width: 0; } .sai-triage-cell { justify-items: start; } .sai-signal-cell strong, .sai-location-cell strong, .sai-layer-cell, .sai-message-cell { min-width: 0; overflow-wrap: anywhere; } .sai-message-cell, .sai-layer-cell { display: grid; gap: 6px; line-height: 1.42; } .sai-message-title, .sai-layer-cell strong { color: var(--text-primary); font-weight: 800; } .sai-message-context { display: block; padding: 7px 9px; border-left: 2px solid color-mix(in srgb, var(--sai-amber) 46%, transparent); border-radius: 8px; background: color-mix(in srgb, var(--sai-amber) 8%, transparent); color: color-mix(in srgb, var(--text-muted) 82%, var(--text-primary) 18%); line-height: 1.45; } .sai-layer-cell small { color: var(--text-muted); } .sai-signal-cell small, .sai-location-cell small { color: var(--text-muted); line-height: 1.35; } .sai-line-stack-badge { display: inline-flex; width: fit-content; border: 1px solid color-mix(in srgb, var(--sai-amber) 28%, rgba(255,255,255,.08)); border-radius: 999px; padding: 2px 7px; color: color-mix(in srgb, var(--sai-amber) 84%, #fff 10%); background: rgba(0,0,0,.18); font-style: normal; font-size: 10.5px; font-weight: 750; } .sai-row-expand { width: 100%; min-width: 66px; height: 28px; border-radius: 8px; border: 1px solid color-mix(in srgb, var(--primary) 42%, transparent); background: color-mix(in srgb, var(--primary) 12%, transparent); color: var(--text-primary); cursor: pointer; font-weight: 850; font-size: 11.5px; } .sai-row-details { padding: 12px 16px 14px 104px; background: color-mix(in srgb, var(--surface-muted) 48%, transparent); border-bottom: 1px solid var(--sai-hairline); color: var(--text-muted); } .sai-row-details p { margin: 6px 0; line-height: 1.45; } .sai-row-details strong { color: var(--text-primary); } .sai-pager-50 { display: flex; justify-content: flex-end; align-items: center; gap: 8px; padding: 10px 12px; color: var(--text-muted); font-size: 12px; } @media (max-width: 1180px) { .sai-hero-system, .sai-overview-grid { grid-template-columns: 1fr; } .sai-exposure-orb { width: 100%; min-height: 120px; } .sai-investigation-table-wrap { overflow-x: auto; } } @media (max-width: 760px) { .sai-mode-tabs { align-self: stretch; } .sai-mode-tab { flex: 1; } .sai-hero-brand { align-items: flex-start; } .sai-hero-meta, .sai-impact-map, .sai-system-map, .sai-investigation-filters { grid-template-columns: 1fr; } } .sai-mode-app { --sai-amber: #d9a441; --sai-amber-soft: rgba(217,164,65,.13); --sai-ink: color-mix(in srgb, var(--card-bg) 88%, #07090d 12%); --sai-deep: color-mix(in srgb, var(--card-bg) 78%, #050609 22%); --sai-line: color-mix(in srgb, var(--card-border) 78%, var(--sai-amber) 16%); --sai-muted-line: color-mix(in srgb, var(--card-border) 88%, transparent); --sai-accent-cool: color-mix(in srgb, var(--primary) 58%, #f0c36a 42%); display: flex; flex-direction: column; gap: 18px; } .sai-lens-switcher { align-self: stretch; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); padding: 5px; border-radius: 14px; background: linear-gradient(180deg, color-mix(in srgb, var(--card-bg) 86%, transparent), color-mix(in srgb, var(--card-bg) 62%, transparent)); border-color: var(--sai-line); } .sai-lens-switcher .sai-mode-tab { min-height: 56px; border-radius: 11px; display: flex; flex-direction: column; align-items: flex-start; justify-content: center; padding: 10px 14px; color: var(--text-muted); background: transparent; } .sai-lens-switcher .sai-mode-tab.is-active { color: var(--text-primary); background: linear-gradient(135deg, color-mix(in srgb, var(--sai-amber) 18%, transparent), color-mix(in srgb, var(--primary) 8%, transparent)); box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--sai-amber) 34%, transparent); } .sai-tab-main { font-size: 13px; font-weight: 850; } .sai-tab-sub { margin-top: 2px; color: var(--text-muted); font-size: 11px; font-weight: 650; } .sai-mode-tab.is-active .sai-tab-sub { color: color-mix(in srgb, var(--text-primary) 72%, var(--sai-amber) 28%); } .sai-system-opening { display: grid; grid-template-columns: minmax(340px, 1.45fr) minmax(280px, .82fr) minmax(240px, .58fr); gap: 16px; align-items: stretch; padding: 22px; border: 1px solid var(--sai-line); border-radius: 18px; background: linear-gradient(135deg, color-mix(in srgb, var(--card-bg) 92%, #06080d 8%), color-mix(in srgb, var(--card-bg) 72%, #0c0b09 28%)); box-shadow: 0 18px 48px rgba(0,0,0,.24), inset 0 1px 0 rgba(255,255,255,.04); } .sai-system-identity { display: flex; gap: 15px; align-items: flex-start; min-width: 0; } .sai-system-identity img { width: 44px; height: 44px; object-fit: contain; filter: drop-shadow(0 0 10px color-mix(in srgb, var(--sai-amber) 38%, transparent)); } .sai-system-identity h2 { margin: 4px 0 8px; color: var(--text-primary); font-size: clamp(1.35rem, 1.7vw, 1.9rem); line-height: 1.12; } .sai-system-identity p { margin: 0; max-width: 820px; color: var(--text-muted); line-height: 1.55; } .sai-system-reading-card { border: 1px solid color-mix(in srgb, var(--sai-amber) 32%, var(--card-border)); border-radius: 14px; padding: 16px; background: linear-gradient(180deg, color-mix(in srgb, var(--sai-amber) 10%, transparent), color-mix(in srgb, var(--surface-muted) 52%, transparent)); } .sai-system-reading-card[data-tone="red"] { border-color: color-mix(in srgb, var(--danger) 48%, var(--card-border)); } .sai-system-reading-card[data-tone="orange"] { border-color: color-mix(in srgb, var(--sai-amber) 58%, var(--card-border)); } .sai-reading-label, .sai-section-kicker { display: block; color: var(--sai-amber); font-size: 10.5px; font-weight: 850; text-transform: uppercase; letter-spacing: .12em; } .sai-system-reading-card strong { display: block; margin-top: 8px; font-size: 26px; color: var(--text-primary); line-height: 1.1; } .sai-system-reading-card p { margin: 9px 0 0; color: var(--text-muted); line-height: 1.45; font-size: 13px; } .sai-reading-focus { margin-top: 13px; border: 1px solid color-mix(in srgb, var(--sai-amber) 46%, transparent); border-radius: 999px; background: color-mix(in srgb, var(--sai-amber) 12%, transparent); color: var(--text-primary); padding: 7px 12px; cursor: pointer; font-weight: 750; } .sai-system-facts { display: grid; gap: 8px; } .sai-system-fact { border-left: 2px solid color-mix(in srgb, var(--sai-amber) 58%, transparent); padding: 8px 0 8px 12px; min-width: 0; } .sai-system-fact span { display: block; color: var(--text-muted); font-size: 10.5px; text-transform: uppercase; letter-spacing: .08em; } .sai-system-fact strong { display: block; color: var(--text-primary); font-size: 15px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .sai-system-fact small { display: block; margin-top: 3px; color: var(--text-muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .sai-system-telemetry { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 1px; overflow: hidden; border: 1px solid var(--sai-line); border-radius: 14px; background: var(--sai-muted-line); } .sai-telemetry-item { padding: 14px 15px; background: var(--sai-ink); min-width: 0; } .sai-telemetry-item span { display: block; color: var(--text-muted); font-size: 11px; text-transform: uppercase; letter-spacing: .08em; } .sai-telemetry-item strong { display: block; margin-top: 6px; color: var(--text-primary); font-size: 24px; line-height: 1; } .sai-telemetry-item small { display: block; margin-top: 5px; color: var(--text-muted); } .sai-system-atlas, .sai-flow-panel, .sai-root-constellation, .sai-impact-matrix, .sai-analyst-workbench { border: 1px solid var(--sai-line); border-radius: 16px; background: var(--sai-deep); box-shadow: inset 0 1px 0 rgba(255,255,255,.035); } .sai-system-atlas { padding: 18px; } .sai-system-section-head { margin-bottom: 14px; } .sai-system-section-head h3 { margin: 5px 0 4px; color: var(--text-primary); font-size: 1.12rem; } .sai-system-section-head p { margin: 0; color: var(--text-muted); line-height: 1.45; } .sai-atlas-body { display: grid; grid-template-columns: minmax(0, 1.22fr) minmax(320px, .78fr); gap: 16px; } .sai-layer-map { position: relative; display: grid; grid-template-columns: repeat(7, minmax(126px, 1fr)); gap: 8px; min-width: 0; } .sai-layer-map::before { content: ""; position: absolute; left: 4%; right: 4%; top: 48%; height: 1px; background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--sai-amber) 42%, transparent), transparent); pointer-events: none; } .sai-layer-node { position: relative; min-height: 172px; padding: 14px; border: 1px solid var(--sai-muted-line); border-radius: 12px; background: linear-gradient(180deg, color-mix(in srgb, var(--surface-muted) 48%, transparent), color-mix(in srgb, var(--card-bg) 78%, transparent)); color: var(--text-primary); cursor: pointer; outline: none; overflow: hidden; } .sai-layer-node::after { content: ""; position: absolute; inset: auto 12px 10px 12px; height: 1px; background: color-mix(in srgb, var(--sai-amber) 30%, transparent); } .sai-layer-node[data-tone="idle"] { opacity: .54; } .sai-layer-node[data-tone="active"] { border-color: color-mix(in srgb, var(--sai-amber) 34%, var(--card-border)); } .sai-layer-node[data-tone="hot"] { border-color: color-mix(in srgb, var(--danger) 48%, var(--sai-amber) 20%); box-shadow: inset 0 0 0 1px rgba(255,255,255,.025); } .sai-layer-node:hover, .sai-layer-node:focus-visible { transform: translateY(-1px); border-color: color-mix(in srgb, var(--sai-amber) 62%, var(--card-border)); } .sai-layer-index { display: block; color: var(--sai-amber); font-size: 10px; font-weight: 850; letter-spacing: .12em; } .sai-layer-node strong { display: block; margin-top: 10px; color: var(--text-primary); font-size: 15px; } .sai-layer-node small { display: block; margin-top: 6px; color: var(--text-muted); line-height: 1.35; min-height: 36px; } .sai-layer-node em { position: absolute; right: 14px; top: 12px; color: var(--text-primary); font-style: normal; font-weight: 900; font-size: 20px; } .sai-layer-meter { height: 4px; margin-top: 18px; background: color-mix(in srgb, var(--card-border) 55%, transparent); border-radius: 999px; overflow: hidden; } .sai-layer-meter i { display: block; height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--sai-amber), color-mix(in srgb, var(--danger) 58%, var(--sai-amber))); } .sai-system-readings { display: grid; gap: 8px; } .sai-reading-row { border: 1px solid var(--sai-muted-line); border-radius: 11px; padding: 11px 12px; background: color-mix(in srgb, var(--surface-muted) 43%, transparent); } .sai-reading-row span { display: block; color: var(--sai-amber); font-size: 11px; font-weight: 850; text-transform: uppercase; letter-spacing: .08em; } .sai-reading-row p { margin: 5px 0 0; color: var(--text-muted); line-height: 1.42; } .sai-system-story-grid { display: grid; grid-template-columns: minmax(0, 1.18fr) minmax(300px, .82fr); gap: 16px; } .sai-flow-panel { grid-column: 1 / -1; padding: 18px; } .sai-root-constellation, .sai-impact-matrix { padding: 18px; } .sai-flow-track { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 10px; align-items: stretch; } .sai-flow-cell { position: relative; min-height: 118px; border: 1px solid color-mix(in srgb, var(--sai-amber) 26%, var(--card-border)); border-radius: 12px; padding: 12px; background: linear-gradient(180deg, color-mix(in srgb, var(--sai-amber) 8%, transparent), color-mix(in srgb, var(--surface-muted) 45%, transparent)); } .sai-flow-cell:not(:last-child)::after { content: ""; position: absolute; right: -11px; top: 50%; width: 12px; height: 1px; background: color-mix(in srgb, var(--sai-amber) 52%, transparent); } .sai-flow-cell span { display: inline-grid; place-items: center; width: 24px; height: 24px; border-radius: 50%; background: var(--sai-amber-soft); color: var(--sai-amber); font-weight: 900; } .sai-flow-cell strong { display: block; margin-top: 11px; color: var(--text-primary); } .sai-flow-cell small { display: block; margin-top: 6px; color: var(--text-muted); line-height: 1.35; word-break: break-word; } .sai-root-constellation-list { display: grid; gap: 8px; } .sai-root-constellation-row { display: grid; grid-template-columns: 44px minmax(0, 1fr) 44px; gap: 10px; align-items: center; padding: 11px; border: 1px solid var(--sai-muted-line); border-radius: 11px; background: color-mix(in srgb, var(--surface-muted) 40%, transparent); cursor: pointer; } .sai-root-constellation-row[data-sev="critical"] { border-left: 3px solid var(--danger); } .sai-root-constellation-row[data-sev="high"] { border-left: 3px solid var(--sai-amber); } .sai-root-rank { color: var(--sai-amber); font-weight: 900; } .sai-root-constellation-row strong { display: block; color: var(--text-primary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .sai-root-constellation-row small { display: block; margin-top: 3px; color: var(--text-muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .sai-root-constellation-row em { color: var(--text-primary); font-style: normal; font-weight: 900; text-align: right; } .sai-root-bar { margin-top: 8px; height: 3px; background: color-mix(in srgb, var(--card-border) 58%, transparent); border-radius: 999px; overflow: hidden; } .sai-root-bar i { display: block; height: 100%; background: linear-gradient(90deg, var(--sai-amber), var(--danger)); border-radius: inherit; } .sai-impact-matrix-list { display: grid; gap: 7px; } .sai-impact-line { display: grid; grid-template-columns: minmax(0, 1fr) 52px 96px; gap: 8px; align-items: center; border: 1px solid var(--sai-muted-line); border-radius: 10px; background: color-mix(in srgb, var(--surface-muted) 36%, transparent); color: var(--text-primary); padding: 9px 10px; text-align: left; cursor: pointer; } .sai-impact-line[data-impact="high"] { border-color: color-mix(in srgb, var(--danger) 42%, var(--card-border)); } .sai-impact-line[data-impact="medium"] { border-color: color-mix(in srgb, var(--sai-amber) 45%, var(--card-border)); } .sai-impact-line span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .sai-impact-line strong { text-align: right; color: var(--text-primary); } .sai-impact-line small { color: var(--text-muted); text-align: right; } .sai-analyst-workbench { padding: 16px; } .sai-investigation-view { animation: saiFocusAppear .24s ease; } .sai-analyst-header { display: grid; grid-template-columns: minmax(0, 1fr) minmax(340px, auto); gap: 16px; align-items: end; margin-bottom: 12px; } .sai-analyst-header h3 { margin: 5px 0 5px; color: var(--text-primary); font-size: 1.18rem; } .sai-analyst-header p { margin: 0; color: var(--text-muted); } .sai-analyst-stats { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1px; border: 1px solid var(--sai-muted-line); border-radius: 12px; overflow: hidden; background: var(--sai-muted-line); } .sai-analyst-stat { padding: 10px 12px; background: var(--sai-ink); } .sai-analyst-stat span { display: block; color: var(--text-muted); font-size: 10.5px; text-transform: uppercase; letter-spacing: .08em; } .sai-analyst-stat strong { display: block; margin-top: 5px; color: var(--text-primary); font-size: 20px; line-height: 1; } .sai-analyst-stat small { display: block; margin-top: 4px; color: var(--text-muted); } .sai-analyst-pulse { margin-bottom: 12px; border: 1px solid rgba(255,255,255,.065); border-radius: 12px; padding: 12px; background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(0,0,0,.14)), rgba(2,4,8,.24); } .sai-investigation-breadcrumb { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 10px; } .sai-breadcrumb-chip { display: inline-flex; align-items: center; min-height: 28px; padding: 0 10px; border-radius: 999px; border: 1px solid color-mix(in srgb, var(--sai-amber) 18%, rgba(255,255,255,.08)); background: rgba(0,0,0,.18); color: color-mix(in srgb, var(--text-primary) 88%, var(--sai-amber) 12%); font-size: 11.5px; font-weight: 700; } .sai-dynamic-score-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 8px; } .sai-dynamic-score { border: 1px solid rgba(255,255,255,.06); border-radius: 11px; padding: 11px 12px; background: rgba(0,0,0,.18); min-width: 0; } .sai-dynamic-score span { display: block; color: var(--text-muted); font-size: 10.5px; text-transform: uppercase; letter-spacing: .08em; } .sai-dynamic-score strong { display: block; margin-top: 6px; color: var(--text-primary); font-size: 20px; line-height: 1; } .sai-dynamic-score small { display: block; margin-top: 5px; color: var(--text-muted); } .sai-dynamic-score[data-metric="criticality"] { border-color: color-mix(in srgb, var(--danger) 28%, rgba(255,255,255,.08)); } .sai-dynamic-score[data-metric="propagation"] { border-color: color-mix(in srgb, var(--sai-amber) 30%, rgba(255,255,255,.08)); } .sai-dynamic-score[data-metric="exposure"] { border-color: color-mix(in srgb, var(--sai-amber) 22%, rgba(255,255,255,.08)); } .sai-dynamic-score[data-metric="density"] { border-color: color-mix(in srgb, var(--text-primary) 14%, rgba(255,255,255,.08)); } .sai-analyst-commandbar { grid-template-columns: repeat(auto-fit, minmax(min(100%, 180px), 1fr)); border-radius: 12px; border-color: var(--sai-muted-line); background: color-mix(in srgb, var(--card-bg) 72%, transparent); padding: 10px; align-items: start; } .sai-analyst-commandbar input[type="search"], .sai-analyst-commandbar select { min-height: 34px; border-radius: 8px; border-color: color-mix(in srgb, var(--ui-border) 82%, var(--sai-amber) 10%); font-size: 12px; width: 100%; min-width: 0; padding-right: 30px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .sai-filter-field { min-width: 0; } .sai-filter-field-search, .sai-filter-field-file { grid-column: span 2; } .sai-filter-field-groupBy { grid-column: span 2; } .sai-filter-search { font-weight: 650; } .sai-filter-toggle { min-height: 34px; display: inline-flex; align-items: center; padding: 0 2px; } .sai-analyst-body { display: grid; grid-template-columns: 250px minmax(0, 1fr); gap: 12px; margin-top: 12px; min-width: 0; } .sai-analyst-context { border: 1px solid var(--sai-muted-line); border-radius: 12px; background: color-mix(in srgb, var(--surface-muted) 38%, transparent); padding: 13px; align-self: start; } .sai-analyst-context h4 { margin: 0 0 7px; color: var(--text-primary); } .sai-analyst-context p { margin: 0 0 10px; color: var(--text-muted); line-height: 1.4; font-size: 12px; } .sai-context-focus { border: 1px solid color-mix(in srgb, var(--sai-amber) 38%, var(--card-border)); border-radius: 10px; padding: 10px; background: var(--sai-amber-soft); cursor: pointer; } .sai-context-focus span, .sai-context-filter-note { color: var(--text-muted); font-size: 11px; } .sai-context-focus strong { display: block; margin: 5px 0; color: var(--text-primary); line-height: 1.25; } .sai-context-focus small { color: var(--sai-amber); } .sai-context-chips { display: grid; gap: 6px; margin-top: 10px; } .sai-context-chip { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 8px; align-items: center; border: 1px solid var(--sai-muted-line); border-radius: 9px; background: color-mix(in srgb, var(--card-bg) 68%, transparent); color: var(--text-primary); padding: 7px 9px; text-align: left; cursor: pointer; } .sai-context-chip span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .sai-context-chip strong { color: var(--sai-amber); } .sai-analyst-body .sai-investigation-table-wrap { min-width: 0; overflow-x: auto; border-radius: 12px; } .sai-analyst-body .sai-investigation-table { min-width: 1040px; } .sai-investigation-row { grid-template-columns: 124px minmax(180px,.9fr) minmax(170px,.82fr) minmax(250px,1.24fr) minmax(128px,.78fr) 78px; } .sai-investigation-head { background: color-mix(in srgb, var(--card-bg) 88%, var(--sai-amber) 6%); color: color-mix(in srgb, var(--text-muted) 84%, var(--sai-amber) 16%); } .sai-row-expand { border-color: color-mix(in srgb, var(--sai-amber) 36%, transparent); background: color-mix(in srgb, var(--sai-amber) 10%, transparent); } .sai-rule-cell, .sai-message-title { display: -webkit-box; overflow: hidden; -webkit-box-orient: vertical; -webkit-line-clamp: 2; } .sai-signal-subtitle, .sai-layer-cell small { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .sai-file-cell { font-family: 'SF Mono','Menlo','Consolas',monospace; font-size: 12px; } .sai-evidence-drawer { padding: 0; } .sai-evidence-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 10px 14px; border-bottom: 1px solid var(--sai-muted-line); background: color-mix(in srgb, var(--sai-amber) 7%, transparent); } .sai-evidence-head strong { color: var(--text-primary); } .sai-evidence-head span { color: var(--text-muted); font-family: 'SF Mono','Menlo','Consolas',monospace; font-size: 12px; } .sai-evidence-relations { display: grid; grid-template-columns: repeat(auto-fit, minmax(126px, 1fr)); gap: 7px; padding: 9px 14px 0; } .sai-evidence-relation { border: 1px solid rgba(255,255,255,.07); border-radius: 9px; padding: 8px 9px; background: rgba(0,0,0,.18); min-width: 0; } .sai-evidence-relation span { display: block; color: var(--text-muted); font-size: 10.5px; text-transform: uppercase; letter-spacing: .08em; } .sai-evidence-relation strong { display: block; margin-top: 5px; color: var(--text-primary); line-height: 1.3; word-break: break-word; } .sai-evidence-relation[data-tone="scope"] { border-color: color-mix(in srgb, var(--sai-amber) 28%, rgba(255,255,255,.08)); } .sai-evidence-relation[data-tone="root"] { border-color: color-mix(in srgb, var(--danger) 20%, rgba(255,255,255,.08)); } .sai-evidence-relation[data-tone="entry"] { border-color: color-mix(in srgb, var(--sai-amber) 20%, rgba(255,255,255,.08)); } .sai-evidence-relation[data-tone="impact"] { border-color: color-mix(in srgb, var(--danger) 26%, rgba(255,255,255,.08)); } .sai-evidence-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; padding: 10px 14px 12px; } .sai-detail-card { min-width: 0; border: 1px solid var(--sai-muted-line); border-radius: 10px; padding: 9px 10px; background: color-mix(in srgb, var(--card-bg) 66%, transparent); } .sai-detail-card-full { grid-column: 1 / -1; } .sai-detail-label { display: block; margin-bottom: 5px; color: color-mix(in srgb, var(--text-muted) 78%, var(--sai-amber) 22%); font-size: 10.5px; font-weight: 850; letter-spacing: .06em; text-transform: uppercase; } .sai-detail-value { margin: 0; min-width: 0; color: var(--text-primary); line-height: 1.42; overflow-wrap: anywhere; } .sai-detail-card-trace, .sai-detail-card-full { grid-column: 1 / -1; } .sai-detail-timeline { display: grid; gap: 8px; margin: 0; padding: 0; list-style: none; } .sai-detail-timeline li { display: grid; grid-template-columns: minmax(120px, .32fr) minmax(0, 1fr); gap: 10px; padding: 8px 0; border-top: 1px solid color-mix(in srgb, var(--sai-muted-line) 72%, transparent); } .sai-detail-timeline li:first-child { border-top: 0; padding-top: 0; } .sai-detail-timeline strong { color: var(--text-primary); } .sai-detail-timeline span { color: var(--text-muted); overflow-wrap: anywhere; } .sai-detail-trace-grid { display: grid; gap: 6px; } .sai-detail-trace-row { display: grid; grid-template-columns: minmax(96px, .28fr) minmax(0, 1fr); gap: 10px; padding: 7px 0; border-top: 1px solid color-mix(in srgb, var(--sai-muted-line) 72%, transparent); } .sai-detail-trace-row:first-child { border-top: 0; padding-top: 0; } .sai-detail-trace-row strong { color: var(--text-primary); font-size: 12px; } .sai-detail-trace-row span { color: var(--text-muted); overflow-wrap: anywhere; } .sai-advanced-details { margin: 0 14px 12px; border: 1px solid color-mix(in srgb, var(--sai-amber) 26%, var(--sai-muted-line)); border-radius: 10px; background: rgba(0,0,0,.18); overflow: hidden; } .sai-advanced-details summary { padding: 10px 12px; color: var(--text-primary); cursor: pointer; font-weight: 800; } .sai-advanced-body { display: grid; gap: 10px; padding: 10px 12px 12px; } .sai-advanced-summary { display: grid; gap: 7px; } .sai-advanced-row { display: grid; grid-template-columns: minmax(120px, .34fr) minmax(0, 1fr); gap: 10px; } .sai-advanced-row span { color: color-mix(in srgb, var(--text-muted) 78%, var(--sai-amber) 22%); font-size: 11px; font-weight: 800; letter-spacing: .04em; text-transform: uppercase; } .sai-advanced-row strong { color: var(--text-primary); overflow-wrap: anywhere; line-height: 1.4; } .sai-advanced-actions { display: flex; flex-wrap: wrap; gap: 8px; } .sai-advanced-action { border: 1px solid color-mix(in srgb, var(--sai-amber) 32%, transparent); border-radius: 999px; padding: 7px 10px; background: color-mix(in srgb, var(--sai-amber) 10%, transparent); color: var(--text-primary); font: inherit; font-size: 12px; font-weight: 700; cursor: pointer; } .sai-advanced-json { margin: 0; padding: 10px 11px; max-height: 240px; overflow: auto; border-top: 1px solid var(--sai-muted-line); color: color-mix(in srgb, var(--text-muted) 82%, var(--text-primary) 18%); font-size: 11.5px; line-height: 1.45; white-space: pre-wrap; word-break: break-word; } .sai-advanced-json[data-open="false"] { display: none; } @media (max-width: 1280px) { .sai-system-opening, .sai-atlas-body, .sai-analyst-header, .sai-analyst-body { grid-template-columns: 1fr; } .sai-layer-map { grid-template-columns: repeat(4, minmax(150px, 1fr)); } .sai-system-telemetry { grid-template-columns: repeat(3, minmax(0, 1fr)); } .sai-analyst-commandbar { grid-template-columns: repeat(auto-fit, minmax(min(100%, 200px), 1fr)); } .sai-dynamic-score-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } } @media (max-width: 820px) { .sai-lens-switcher, .sai-system-telemetry, .sai-layer-map, .sai-flow-track, .sai-system-story-grid, .sai-analyst-stats, .sai-analyst-commandbar, .sai-dynamic-score-grid, .sai-evidence-grid { grid-template-columns: 1fr; } .sai-detail-trace-row, .sai-advanced-row { grid-template-columns: 1fr; } .sai-filter-field-search, .sai-filter-field-file, .sai-filter-field-groupBy { grid-column: auto; } .sai-system-opening, .sai-system-atlas, .sai-flow-panel, .sai-root-constellation, .sai-impact-matrix, .sai-analyst-workbench { border-radius: 12px; padding: 13px; } .sai-analyst-body .sai-investigation-table { min-width: 0; } .sai-investigation-head { display: none; } .sai-investigation-row { grid-template-columns: 1fr; gap: 8px; padding: 12px; } .sai-row-expand { justify-self: stretch; min-height: 32px; } .sai-evidence-head { flex-direction: column; } .sai-detail-timeline li { grid-template-columns: 1fr; gap: 4px; } .sai-layer-map::before, .sai-flow-cell:not(:last-child)::after { display: none; } .sai-system-identity { flex-direction: column; } } .sai-mode-app { --sai-black-control: rgba(2, 4, 8, .32); --sai-black-control-hover: rgba(10, 13, 18, .58); --sai-black-control-active: rgba(18, 16, 11, .72); --sai-premium-line: color-mix(in srgb, var(--card-border) 70%, var(--sai-amber) 18%); --sai-premium-glow: color-mix(in srgb, var(--sai-amber) 28%, transparent); --sai-danger-glow: color-mix(in srgb, var(--danger) 26%, transparent); --sai-accent-cool: var(--sai-amber); } .sai-mode-app button { appearance: none; -webkit-appearance: none; transition: border-color .18s ease, background .18s ease, box-shadow .18s ease, transform .18s ease, opacity .18s ease; } .sai-mode-app button:focus-visible, .sai-mode-app [role="button"]:focus-visible { outline: 1px solid color-mix(in srgb, var(--sai-amber) 58%, transparent); outline-offset: 3px; } .sai-lens-switcher .sai-mode-tab, .sai-reading-focus, .sai-impact-line, .sai-context-chip, .sai-context-focus, .sai-row-expand, .sai-mini-action, .sai-pager-50 .sai-btn { background: var(--sai-black-control); border-color: color-mix(in srgb, var(--card-border) 76%, var(--sai-amber) 14%); color: var(--text-primary); box-shadow: inset 0 1px 0 rgba(255,255,255,.025); } .sai-lens-switcher .sai-mode-tab:hover, .sai-reading-focus:hover, .sai-impact-line:hover, .sai-context-chip:hover, .sai-context-focus:hover, .sai-row-expand:hover, .sai-mini-action:hover, .sai-pager-50 .sai-btn:hover { background: var(--sai-black-control-hover); border-color: color-mix(in srgb, var(--sai-amber) 42%, var(--card-border)); box-shadow: 0 0 0 1px color-mix(in srgb, var(--sai-amber) 12%, transparent), 0 10px 26px rgba(0,0,0,.18); } .sai-lens-switcher .sai-mode-tab.is-active { background: linear-gradient(135deg, rgba(12,12,10,.76), rgba(4,5,8,.56)); border-color: color-mix(in srgb, var(--sai-amber) 46%, var(--card-border)); box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--sai-amber) 22%, transparent), 0 0 28px color-mix(in srgb, var(--sai-amber) 10%, transparent); } .sai-reading-focus { border-radius: 999px; } .sai-impact-line[disabled], .sai-impact-line[aria-disabled="true"], .sai-layer-node[aria-disabled="true"] { cursor: default; opacity: .42; filter: grayscale(.45); } .sai-impact-line[disabled]:hover, .sai-impact-line[aria-disabled="true"]:hover, .sai-layer-node[aria-disabled="true"]:hover { transform: none; box-shadow: none; border-color: var(--sai-muted-line); } .sai-system-atlas { position: relative; overflow: hidden; background: radial-gradient(520px 240px at 18% 18%, rgba(217,164,65,.07), transparent 68%), radial-gradient(460px 260px at 80% 62%, rgba(255,107,128,.045), transparent 65%), linear-gradient(180deg, color-mix(in srgb, var(--sai-deep) 96%, #000 4%), color-mix(in srgb, var(--sai-deep) 82%, #000 18%)); } .sai-atlas-body { grid-template-columns: minmax(620px, 1.35fr) minmax(300px, .65fr); align-items: stretch; } .sai-layer-map.sai-topology-map { display: block; position: relative; min-height: 440px; border: 1px solid color-mix(in srgb, var(--card-border) 64%, transparent); border-radius: 16px; overflow: hidden; background: linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px), linear-gradient(180deg, rgba(255,255,255,.02) 1px, transparent 1px), radial-gradient(circle at 48% 46%, rgba(217,164,65,.085), transparent 35%), rgba(0,0,0,.16); background-size: 48px 48px, 48px 48px, auto, auto; } .sai-layer-map.sai-topology-map::before { content: ""; display: block; position: absolute; inset: 18px; height: auto; border: 1px solid rgba(255,255,255,.035); border-radius: 999px; background: radial-gradient(circle at center, transparent 54%, rgba(217,164,65,.045) 55%, transparent 58%); pointer-events: none; } .sai-layer-map.sai-topology-map::after { content: ""; position: absolute; inset: 11% 8%; border-radius: 50%; border: 1px dashed rgba(217,164,65,.13); pointer-events: none; } .sai-topology-link { position: absolute; height: 1px; transform-origin: left center; background: linear-gradient(90deg, transparent, rgba(217,164,65,.42), rgba(255,255,255,.12), transparent); box-shadow: 0 0 16px rgba(217,164,65,.11); pointer-events: none; opacity: .38; transition: opacity .24s ease, box-shadow .24s ease, filter .24s ease; animation: saiTopologyPulse 3.8s ease-in-out infinite; } .sai-topology-link::after { content: ""; position: absolute; right: 18%; top: -2px; width: 5px; height: 5px; border-radius: 50%; background: rgba(217,164,65,.62); box-shadow: 0 0 12px rgba(217,164,65,.22); } .sai-topology-link[data-link="front-api"] { left: 17%; top: 35%; width: 18%; transform: rotate(-24deg); } .sai-topology-link[data-link="api-services"] { left: 34%; top: 28%; width: 21%; transform: rotate(25deg); } .sai-topology-link[data-link="services-data"] { left: 55%; top: 41%; width: 19%; transform: rotate(-23deg); } .sai-topology-link[data-link="services-realtime"] { left: 35%; top: 58%; width: 20%; transform: rotate(145deg); } .sai-topology-link[data-link="realtime-ci"] { left: 36%; top: 79%; width: 22%; transform: rotate(8deg); } .sai-topology-link[data-link="data-deps"] { left: 73%; top: 36%; width: 27%; transform: rotate(74deg); } .sai-topology-link[data-link="services-deps"] { left: 54%; top: 48%; width: 31%; transform: rotate(23deg); } .sai-topology-map .sai-layer-node { position: absolute; left: var(--x); top: var(--y); width: clamp(126px, 16vw, 176px); min-height: 128px; transform: translate(-50%, -50%); border-radius: 16px; background: linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.012)), rgba(3,5,9,.58); backdrop-filter: blur(10px); border-color: color-mix(in srgb, var(--card-border) 70%, transparent); box-shadow: 0 18px 42px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.04); transition: opacity .26s ease, transform .26s ease, box-shadow .26s ease, filter .26s ease, background .26s ease; animation: saiTopologyBreathe 7s ease-in-out infinite; } .sai-topology-map .sai-layer-node::before { content: ""; position: absolute; inset: -16px; border-radius: 24px; background: radial-gradient(circle, color-mix(in srgb, var(--sai-amber) 10%, transparent), transparent 62%); opacity: .16; pointer-events: none; } .sai-topology-map .sai-layer-node[data-tone="hot"] { border-color: color-mix(in srgb, var(--danger) 44%, var(--sai-amber) 28%); box-shadow: 0 20px 50px rgba(0,0,0,.26), 0 0 34px var(--sai-danger-glow), inset 0 1px 0 rgba(255,255,255,.045); } .sai-topology-map .sai-layer-node[data-tone="active"] { border-color: color-mix(in srgb, var(--sai-amber) 42%, var(--card-border)); box-shadow: 0 18px 42px rgba(0,0,0,.22), 0 0 26px var(--sai-premium-glow), inset 0 1px 0 rgba(255,255,255,.04); } .sai-topology-map .sai-layer-node:hover, .sai-topology-map .sai-layer-node:focus-visible { transform: translate(-50%, -52%); background: linear-gradient(180deg, rgba(255,255,255,.052), rgba(255,255,255,.018)), rgba(6,8,12,.72); } .sai-topology-map[data-focus] .sai-layer-node { opacity: .26; filter: saturate(.68) brightness(.82); } .sai-topology-map[data-focus] .sai-layer-node[data-related="true"] { opacity: 1; filter: none; } .sai-topology-map[data-focus] .sai-topology-link { opacity: .12; filter: blur(.25px); } .sai-topology-map[data-focus] .sai-topology-link[data-related="true"] { opacity: .96; filter: none; box-shadow: 0 0 20px rgba(217,164,65,.2); } .sai-topology-map .sai-layer-meter { background: rgba(255,255,255,.06); } .sai-topology-map .sai-layer-meter i { background: linear-gradient(90deg, color-mix(in srgb, var(--sai-amber) 72%, #fff 8%), color-mix(in srgb, var(--danger) 52%, var(--sai-amber) 48%)); } .sai-impact-matrix { background: linear-gradient(180deg, rgba(255,255,255,.018), rgba(0,0,0,.16)), var(--sai-deep); } .sai-impact-line { border-radius: 12px; background: rgba(0,0,0,.24); border-color: rgba(255,255,255,.075); } .sai-impact-line[data-impact="high"] { border-color: color-mix(in srgb, var(--danger) 38%, rgba(255,255,255,.08)); } .sai-impact-line[data-impact="medium"] { border-color: color-mix(in srgb, var(--sai-amber) 38%, rgba(255,255,255,.08)); } .sai-impact-line[data-impact="low"] { border-color: color-mix(in srgb, var(--sai-amber) 20%, rgba(255,255,255,.08)); } .sai-impact-line small { color: color-mix(in srgb, var(--text-muted) 86%, var(--sai-amber) 14%); } .sai-analyst-context { background: linear-gradient(180deg, rgba(255,255,255,.025), rgba(0,0,0,.16)), rgba(2,4,8,.34); border-color: rgba(255,255,255,.075); box-shadow: inset 0 1px 0 rgba(255,255,255,.03); } .sai-context-scope { margin-bottom: 10px; border: 1px solid color-mix(in srgb, var(--sai-amber) 34%, rgba(255,255,255,.08)); border-radius: 12px; padding: 10px; background: rgba(0,0,0,.22); } .sai-context-scope span, .sai-context-scope small { display: block; color: var(--text-muted); font-size: 11px; } .sai-context-scope strong { display: block; margin: 5px 0; color: var(--text-primary); line-height: 1.25; } .sai-context-focus { background: rgba(0,0,0,.20); border-color: color-mix(in srgb, var(--sai-amber) 30%, rgba(255,255,255,.08)); } .sai-context-chip { background: rgba(0,0,0,.18); border-color: rgba(255,255,255,.075); } .sai-context-chip strong { color: color-mix(in srgb, var(--sai-amber) 86%, var(--text-primary) 14%); } .sai-row-expand { background: rgba(0,0,0,.26); border-color: color-mix(in srgb, var(--sai-amber) 30%, rgba(255,255,255,.08)); } @keyframes saiTopologyPulse { 0%, 100% { opacity: .28; } 50% { opacity: .56; } } @keyframes saiTopologyBreathe { 0%, 100% { transform: translate(-50%, -50%) scale(1); } 50% { transform: translate(-50%, -50%) scale(1.012); } } @keyframes saiFocusAppear { 0% { opacity: 0; transform: translateY(6px); } 100% { opacity: 1; transform: translateY(0); } } @media (max-width: 1280px) { .sai-atlas-body { grid-template-columns: 1fr; } .sai-layer-map.sai-topology-map { min-height: 510px; } } @media (max-width: 820px) { .sai-layer-map.sai-topology-map { display: grid; min-height: auto; grid-template-columns: 1fr; gap: 8px; padding: 10px; } .sai-layer-map.sai-topology-map::before, .sai-layer-map.sai-topology-map::after, .sai-topology-link { display: none; } .sai-topology-map .sai-layer-node { position: relative; left: auto; top: auto; width: auto; min-height: 118px; transform: none; } .sai-topology-map .sai-layer-node:hover, .sai-topology-map .sai-layer-node:focus-visible { transform: none; } } @media (prefers-reduced-motion: reduce) { .sai-topology-link, .sai-topology-map .sai-layer-node, .sai-investigation-view { animation: none !important; } } .sai-mode-app .sai-lens-switcher .sai-mode-tab, .sai-mode-app .sai-reading-focus, .sai-mode-app .sai-impact-line, .sai-mode-app .sai-context-chip, .sai-mode-app .sai-context-focus, .sai-mode-app .sai-row-expand, .sai-mode-app .sai-mini-action, .sai-mode-app .sai-pager-50 .sai-btn { background: rgba(2,4,8,.34) !important; background-image: none !important; border-color: color-mix(in srgb, var(--card-border) 76%, var(--sai-amber) 14%) !important; color: var(--text-primary) !important; box-shadow: inset 0 1px 0 rgba(255,255,255,.025) !important; } .sai-mode-app .sai-lens-switcher .sai-mode-tab.is-active { background: linear-gradient(135deg, rgba(12,12,10,.78), rgba(4,5,8,.58)) !important; border-color: color-mix(in srgb, var(--sai-amber) 48%, var(--card-border)) !important; box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--sai-amber) 22%, transparent), 0 0 28px color-mix(in srgb, var(--sai-amber) 10%, transparent) !important; } .sai-mode-app .sai-reading-focus:hover, .sai-mode-app .sai-impact-line:hover, .sai-mode-app .sai-context-chip:hover, .sai-mode-app .sai-context-focus:hover, .sai-mode-app .sai-row-expand:hover, .sai-mode-app .sai-mini-action:hover, .sai-mode-app .sai-pager-50 .sai-btn:hover { background: rgba(10,13,18,.62) !important; background-image: none !important; border-color: color-mix(in srgb, var(--sai-amber) 42%, var(--card-border)) !important; box-shadow: 0 0 0 1px color-mix(in srgb, var(--sai-amber) 12%, transparent), 0 10px 26px rgba(0,0,0,.18) !important; } .sai-mode-app .sai-impact-line[disabled], .sai-mode-app .sai-impact-line[aria-disabled="true"] { background: rgba(2,4,8,.18) !important; border-color: var(--sai-muted-line) !important; color: var(--text-muted) !important; box-shadow: none !important; }