:root{color-scheme:light;--bg: #f4f6fa;--surface: #ffffff;--surface-2: #f8fafc;--surface-3: #eef2f7;--border: #dfe6ef;--border-strong: #c9d3df;--text: #101828;--muted: #667085;--subtle: #98a2b3;--brand: #2563eb;--green: #059669;--amber: #d97706;--red: #dc2626;--cyan: #0891b2;--shadow: 0 10px 30px rgba(15, 23, 42, .08);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;margin:0;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}body,#root{min-height:100vh}button,input{font:inherit}button{border:0}.app-shell{display:flex;min-height:100vh;background:linear-gradient(180deg,#2563eb0d,#2563eb00 240px),var(--bg)}.sidebar{position:sticky;top:0;display:flex;width:276px;height:100vh;flex-shrink:0;flex-direction:column;gap:18px;padding:18px 14px;background:#fffffff0;box-shadow:inset -1px 0 0 var(--border);z-index:20}.brand{display:flex;align-items:center;gap:12px;min-width:0}.login-brand{display:flex;align-items:center;gap:12px}.login-brand div{display:grid}.brand-mark,.metric-icon,.panel-icon,.flow-icon{display:inline-grid;place-items:center;flex-shrink:0;color:var(--brand);background:#eaf1ff}.brand-mark{width:38px;height:38px;border-radius:8px;overflow:hidden}.brand-mark img{width:100%;height:100%;display:block}.brand-copy{display:grid;min-width:0}.brand-copy strong{white-space:nowrap}.brand-copy span,.sidebar-status span,.panel-header>span,.event-meta,td span,.tenant-card span,.flow-row span,.metric-card small{color:var(--muted)}.nav-list{display:grid;gap:6px}.nav-item{display:flex;align-items:center;gap:10px;width:100%;min-height:40px;padding:9px 10px;border-radius:8px;background:transparent;color:var(--muted);cursor:pointer;text-align:left}.nav-item:hover,.nav-item.active{background:#edf4ff;color:var(--brand)}.sidebar-status{display:flex;align-items:center;gap:10px;margin-top:auto;padding:12px;border:1px solid var(--border);border-radius:8px;background:var(--surface-2)}.auth-scope{margin-top:0}.auth-scope svg{color:var(--brand)}.role-scope-list{display:grid;gap:8px;padding:12px;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.role-scope-list span{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:8px;color:var(--muted);font-size:12px}.role-scope-list svg{color:var(--green)}.sidebar-status div{display:grid;min-width:0}.sidebar-status strong,.sidebar-status span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-dot{width:9px;height:9px;border-radius:999px;background:var(--green);box-shadow:0 0 0 5px #0596691f}.status-dot-error{background:var(--red);box-shadow:0 0 0 5px #dc26261f}.workspace{display:grid;width:100%;min-width:0;align-content:start;gap:18px;padding:22px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px}.topbar h1{margin:0;font-size:24px;line-height:1.2}.topbar p{margin:4px 0 0;color:var(--muted)}.topbar-actions{display:flex;align-items:center;gap:10px}.search-box{display:flex;align-items:center;gap:8px;width:min(340px,36vw);min-height:38px;padding:0 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--muted)}.search-box input{width:100%;min-width:0;border:0;outline:0;background:transparent;color:var(--text)}.icon-button,.secondary-button{display:inline-flex;align-items:center;justify-content:center;min-height:38px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);cursor:pointer}.icon-button{width:38px}.secondary-button{gap:8px;padding:0 12px}.secondary-button:disabled{color:var(--subtle);cursor:not-allowed}.primary-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;border-radius:8px;background:var(--brand);color:#fff;cursor:pointer}.primary-button:disabled{opacity:.7;cursor:not-allowed}.alert-banner,.empty-state{border:1px solid var(--border);border-radius:8px;background:var(--surface)}.alert-banner{padding:11px 14px;color:var(--red);background:#fff0f0;border-color:#fecaca}.empty-state{display:grid;min-height:132px;place-content:center;gap:4px;padding:18px;text-align:center}.empty-state span{color:var(--muted)}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.metric-empty{grid-column:1 / -1}.metric-card,.panel,.tenant-card{border:1px solid var(--border);border-radius:8px;background:var(--surface);box-shadow:var(--shadow)}.metric-card{display:grid;grid-template-columns:auto 1fr;gap:8px 12px;min-height:126px;padding:16px}.metric-card .metric-icon{grid-row:span 3;width:38px;height:38px;border-radius:8px}.metric-card>span{color:var(--muted)}.metric-card strong{font-size:28px;line-height:1.05}.tone-green .metric-icon{color:var(--green);background:#e8f7ef}.tone-amber .metric-icon{color:var(--amber);background:#fff7e6}.tone-red .metric-icon{color:var(--red);background:#fff0f0}.content-grid{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(320px,.85fr);gap:18px}.single-column{display:grid;gap:18px}.panel{min-width:0;padding:16px}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.panel-header>div{display:flex;align-items:center;min-width:0;gap:10px}.panel-header h2{margin:0;font-size:16px}.panel-icon{width:32px;height:32px;border-radius:8px}.chart-wrap{height:292px}.flow-list,.event-list,.tenant-list,.timeline{display:grid;gap:10px}.tenant-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.flow-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;padding:11px;border:1px solid var(--border);border-radius:8px;background:var(--surface-2)}.flow-icon{width:34px;height:34px;border-radius:8px}.flow-row div:nth-child(2),.event-main,.tenant-card>div{display:grid;min-width:0}.event-row{--severity-color: var(--border);display:grid;grid-template-columns:74px minmax(0,1fr) 170px;gap:14px;padding:14px;border:1px solid var(--severity-color);border-radius:8px;background:var(--surface-2)}.severity-critical{--severity-color: var(--red)}.severity-high{--severity-color: var(--amber)}.severity-medium{--severity-color: var(--brand)}.severity-low{--severity-color: var(--green)}.event-score{display:grid;align-content:start;gap:2px}.event-score strong{font-size:24px;line-height:1}.event-score span{color:var(--muted);text-transform:uppercase;font-size:11px}.event-title{display:flex;align-items:center;gap:8px;min-width:0}.event-title span:nth-child(2){color:var(--muted)}.event-row p{margin:6px 0 8px;color:var(--muted)}.signal-list{display:flex;flex-wrap:wrap;gap:6px}.signal-list span,.pill{display:inline-flex;align-items:center;width:fit-content;min-height:24px;padding:0 8px;border-radius:999px;font-size:12px;line-height:1}.signal-list span{background:var(--surface-3);color:var(--muted)}.event-meta{display:grid;align-content:start;justify-items:end;gap:4px;font-size:12px}.pill{border:1px solid transparent}.action-block,.status-draft{color:var(--red);background:#fff0f0;border-color:#fecaca}.action-challenge,.status-shadow{color:var(--amber);background:#fff7e6;border-color:#fed7aa}.action-review{color:var(--brand);background:#edf4ff;border-color:#bfdbfe}.action-allow,.status-enforced{color:var(--green);background:#e8f7ef;border-color:#bbf7d0}.timeline-step{position:relative;display:grid;grid-template-columns:auto minmax(0,1fr);gap:10px;padding-bottom:4px}.timeline-marker{width:12px;height:12px;margin-top:6px;border-radius:999px;background:var(--green);box-shadow:0 0 0 5px #0596691a}.state-watch .timeline-marker{background:var(--amber);box-shadow:0 0 0 5px #d977061f}.state-blocked .timeline-marker{background:var(--red);box-shadow:0 0 0 5px #dc26261f}.timeline-title{display:flex;justify-content:space-between;gap:8px}.timeline-title span,.timeline p{color:var(--muted)}.timeline code{display:inline-block;margin-top:4px;padding:3px 6px;border-radius:6px;background:var(--surface-3);color:var(--brand);font-size:12px}.timeline p{margin:6px 0 0}.table-wrap{overflow-x:auto}table{width:100%;min-width:680px;border-collapse:collapse}th,td{padding:12px 10px;border:1px solid var(--border);text-align:left;white-space:nowrap}th{color:var(--muted);font-weight:600;background:var(--surface-2)}td:first-child{display:grid}.tenant-card{padding:12px}.tenant-card>div{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;margin-bottom:10px}.tenant-card dl{display:grid;grid-template-columns:48px minmax(0,1fr);gap:5px 10px;margin:0}.tenant-card dt{color:var(--subtle)}.tenant-card dd{min-width:0;margin:0;color:var(--muted)}.mobile-only{display:none}.login-layout{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(420px,.92fr);min-height:100vh;background:var(--surface)}.login-visual{position:relative;min-width:0;min-height:100vh;overflow:hidden;background:linear-gradient(90deg,#0610222e,#061022b8),url(/auth-hero.png) center / cover no-repeat}.login-visual:after{position:absolute;top:0;right:0;bottom:0;left:0;content:"";background:linear-gradient(180deg,#0307121a,#0307128a),radial-gradient(circle at 26% 18%,rgba(14,165,233,.22),transparent 32%)}.login-visual-overlay{position:relative;z-index:1;display:grid;align-content:space-between;min-height:100%;padding:42px;color:#fff}.login-visual-brand{display:flex;align-items:center;gap:12px}.login-visual-brand div{display:grid}.login-visual-brand span,.login-visual-overlay p{color:#ffffffc2}.login-visual-overlay h1{max-width:560px;margin:0 0 10px;font-size:40px;line-height:1.12}.login-visual-overlay p{max-width:520px;margin:0;font-size:16px}.login-feature-list{display:grid;gap:9px;max-width:620px;margin-top:22px}.login-feature-list span{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:start;gap:8px;color:#ffffffe0}.login-feature-list svg{margin-top:2px;color:#5eead4}.login-visual-stats{display:flex;flex-wrap:wrap;gap:8px}.login-visual-stats span{min-height:30px;padding:6px 10px;border:1px solid rgba(255,255,255,.18);border-radius:999px;background:#ffffff1a;color:#ffffffd6}.login-panel{display:grid;width:100%;min-width:0;align-content:center;justify-self:center;max-width:480px;min-height:100vh;background:var(--surface);padding:42px}.login-panel-header{display:grid;gap:6px;margin-bottom:22px}.login-panel-header h2{margin:0;font-size:24px;line-height:1.2}.login-panel-header span,.login-form label span{color:var(--muted)}.login-form{display:grid;gap:12px}.login-form label{display:grid;gap:6px}.login-form input{min-height:40px;width:100%;border:1px solid var(--border);border-radius:8px;padding:0 11px;background:var(--surface);color:var(--text);outline:0}.login-form input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #2563eb1a}.login-form input:disabled{background:var(--surface-3);color:var(--muted)}.login-error{border:1px solid #fecaca;border-radius:8px;padding:10px 11px;background:#fff0f0;color:var(--red)}.login-passkey{width:100%}.login-change-email{display:flex;align-items:center;gap:8px;color:var(--muted)}.login-change-email{width:fit-content;min-height:32px;padding:0;background:transparent;cursor:pointer}.login-change-email:hover{color:var(--brand)}@media(max-width:1120px){.metric-grid,.content-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.panel-large{grid-column:1 / -1}}@media(max-width:820px){.login-layout{grid-template-columns:1fr;background:var(--bg)}.login-visual{min-height:280px}.login-visual-overlay{min-height:280px;padding:24px}.login-visual-overlay h1{font-size:28px}.login-panel{max-width:none;min-height:auto;padding:24px}.sidebar{position:fixed;transform:translate(-100%);transition:transform .16s ease}.sidebar-open{transform:translate(0)}.sidebar-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10;background:#0f172a47}.mobile-only{display:inline-flex}.workspace{padding:14px}.topbar,.topbar-actions{align-items:stretch}.topbar{flex-wrap:wrap}.topbar-actions,.search-box{width:100%}.metric-grid,.content-grid,.event-row{grid-template-columns:1fr}.event-meta{justify-items:start}}@media(max-width:640px){body{font-size:13px}.sidebar{width:min(86vw,320px);padding:14px 12px}.brand-copy strong{white-space:normal}.workspace{gap:12px;padding:12px}.topbar{gap:12px}.topbar h1{font-size:21px}.topbar p{font-size:12px}.topbar-actions{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:8px}.search-box{grid-column:1 / -1;min-height:40px}.secondary-button{min-width:0;padding:0 10px}.secondary-button,.icon-button{min-height:40px}.metric-card{min-height:104px;padding:13px}.metric-card strong{font-size:24px}.panel{padding:13px}.panel-header{align-items:flex-start;flex-direction:column;gap:8px}.panel-header>span{font-size:12px}.chart-wrap{height:220px}.flow-row{grid-template-columns:auto minmax(0,1fr)}.flow-row>svg{display:none}.event-row{gap:10px;padding:12px}.event-title{align-items:flex-start;flex-direction:column;gap:5px}.signal-list span,.pill{min-height:26px}.tenant-grid{grid-template-columns:1fr}.tenant-card>div{grid-template-columns:1fr}.login-visual{min-height:220px}.login-visual-overlay{min-height:220px;padding:18px}.login-visual-overlay h1{font-size:24px}.login-visual-overlay p,.login-feature-list{font-size:13px}.login-visual-stats{display:none}.login-panel{padding:18px}}@media(max-width:420px){.workspace{padding:10px}.topbar-actions{grid-template-columns:1fr auto}.topbar-actions .secondary-button{width:100%}.topbar-actions .secondary-button:first-of-type{grid-column:1 / 2}.topbar-actions .secondary-button:not(:first-of-type){grid-column:1 / -1}.topbar-actions .icon-button{grid-column:2 / 3}.metric-card{grid-template-columns:1fr}.metric-card .metric-icon{grid-row:auto}.event-score strong{font-size:22px}.table-wrap{margin-inline:-4px}table{min-width:620px}th,td{padding:10px 8px}.login-feature-list{display:none}}
