
:root{
  --brand-blue:#2547D9;--brand-blue-bright:#4665FF;--brand-blue-deep:#1A36B5;--brand-blue-shadow:#0F1E5C;
  --brand-gold:#C9A368;--brand-gold-bright:#E8C988;--brand-gold-soft:#8B6F3F;
  --bg-base:#07091A;--bg-canvas:#0A0E1F;--bg-elev-1:#11152A;--bg-elev-2:#161B33;--bg-elev-3:#1D2342;--bg-overlay:rgba(7,9,26,.85);
  --border-subtle:rgba(255,255,255,.06);--border-default:rgba(255,255,255,.09);--border-strong:rgba(255,255,255,.14);
  --border-brand:rgba(70,101,255,.35);--border-gold:rgba(201,163,104,.35);
  --text-hi:#F5F7FA;--text-mid:#B8BFD4;--text-lo:#6E7693;--text-dim:#4A5170;
  --critical:#FF4D6A;--critical-bg:rgba(255,77,106,.12);--warning:#F4A847;--warning-bg:rgba(244,168,71,.12);
  --success:#3EE08A;--success-bg:rgba(62,224,138,.12);--info:#5BA3FF;--info-bg:rgba(91,163,255,.12);
  --shadow-card:0 1px 0 rgba(255,255,255,.04) inset,0 12px 32px -16px rgba(0,0,0,.6);
  --shadow-pop:0 24px 64px -24px rgba(0,0,0,.8);
  --sidebar-w:244px;--topbar-h:60px;--r-sm:6px;--r-md:10px;--r-lg:14px;
  --font-ui:'Geist',-apple-system,system-ui,sans-serif;--font-mono:'JetBrains Mono',ui-monospace,monospace;--font-display:'Instrument Serif','Geist',serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:var(--font-ui);font-size:14px;line-height:1.5;color:var(--text-hi);background:var(--bg-base);-webkit-font-smoothing:antialiased;overflow-x:hidden;font-feature-settings:'cv11','ss01','ss02'}
body::before{content:'';position:fixed;inset:0;background-image:linear-gradient(rgba(70,101,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(70,101,255,.025) 1px,transparent 1px);background-size:32px 32px;pointer-events:none;z-index:0}
body::after{content:'';position:fixed;top:-200px;right:-200px;width:600px;height:600px;background:radial-gradient(circle,rgba(70,101,255,.18),transparent 70%);pointer-events:none;z-index:0;filter:blur(60px)}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:none}
input,select,textarea{font:inherit;color:inherit}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
img,svg{display:block;max-width:100%}
::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:8px;border:2px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.16);background-clip:padding-box}


/* IndoAI Logo (embedded) */
.indoai-logo{display:inline-block;background:url('img/logo.png') center/contain no-repeat;flex-shrink:0;filter:drop-shadow(0 2px 8px rgba(0,0,0,.35))}
.indoai-logo.sm{width:80px;height:28px}
.indoai-logo.md{width:100px;height:100px}
.indoai-logo.lg{width:160px;height:56px}
/* AUTH */
.auth-shell{position:relative;min-height:100vh;display:grid;grid-template-columns:1fr 1fr;z-index:1}
.auth-shell.is-hidden{display:none}
.auth-form-side{display:flex;align-items:center;justify-content:center;padding:48px;background:var(--bg-canvas);position:relative}
.auth-brand-side{position:relative;background:radial-gradient(ellipse at 30% 20%,rgba(70,101,255,.4),transparent 60%),radial-gradient(ellipse at 80% 90%,rgba(201,163,104,.18),transparent 50%),linear-gradient(135deg,var(--brand-blue-deep),var(--brand-blue-shadow));overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;padding:56px}
.auth-brand-side::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:40px 40px;pointer-events:none}
.auth-brand-side::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 60%,rgba(0,0,0,.5));pointer-events:none}
.auth-card{width:100%;max-width:420px;position:relative;z-index:1}
.auth-logo-row{display:flex;align-items:center;gap:10px;margin-bottom:48px}
.auth-product{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-lo);border-left:1px solid var(--border-default);padding-left:10px}
.auth-title{font-family:var(--font-display);font-size:36px;line-height:1.1;margin-bottom:8px;letter-spacing:-.02em;font-weight:400}
.auth-title em{font-style:italic;color:var(--brand-gold);font-weight:400}
.auth-subtitle{color:var(--text-mid);margin-bottom:36px;font-size:14px}
.field{margin-bottom:16px}
.field-label{display:block;font-size:12px;font-weight:500;color:var(--text-mid);margin-bottom:6px;letter-spacing:.02em}
.field-input,.field-select,.field-textarea{width:100%;background:var(--bg-elev-1);border:1px solid var(--border-default);border-radius:var(--r-md);padding:11px 14px;color:var(--text-hi);font-size:14px;transition:all .16s ease;font-family:inherit}
.field-input:focus,.field-select:focus,.field-textarea:focus{outline:none;border-color:var(--brand-blue-bright);box-shadow:0 0 0 3px rgba(70,101,255,.15);background:var(--bg-elev-2)}
.field-input::placeholder{color:var(--text-dim)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;border-radius:var(--r-md);font-weight:500;font-size:14px;transition:all .16s ease;white-space:nowrap;border:1px solid transparent}
.btn-primary{background:linear-gradient(180deg,var(--brand-blue-bright),var(--brand-blue));color:#fff;box-shadow:0 1px 0 rgba(255,255,255,.2) inset,0 4px 16px -4px rgba(70,101,255,.5)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 1px 0 rgba(255,255,255,.25) inset,0 8px 24px -4px rgba(70,101,255,.6)}
.btn-secondary{background:var(--bg-elev-2);border-color:var(--border-default);color:var(--text-hi)}
.btn-secondary:hover{background:var(--bg-elev-3);border-color:var(--border-strong)}
.btn-ghost{background:transparent;color:var(--text-mid)}
.btn-ghost:hover{background:var(--bg-elev-1);color:var(--text-hi)}
.btn-gold{background:linear-gradient(180deg,var(--brand-gold-bright),var(--brand-gold));color:#1a1304;font-weight:600}
.btn-gold:hover{transform:translateY(-1px)}
.btn-danger{background:var(--critical-bg);color:var(--critical);border-color:rgba(255,77,106,.3)}
.btn-block{width:100%}
.btn-sm{padding:7px 12px;font-size:13px}
.auth-divider{display:flex;align-items:center;gap:14px;margin:22px 0;color:var(--text-lo);font-size:12px}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border-default)}
.sso-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.sso-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;background:var(--bg-elev-1);border:1px solid var(--border-default);border-radius:var(--r-md);font-size:13px;color:var(--text-hi);transition:all .16s ease}
.sso-btn:hover{background:var(--bg-elev-2);border-color:var(--border-strong)}
.sso-btn svg{width:16px;height:16px}
.auth-foot{margin-top:28px;text-align:center;color:var(--text-mid);font-size:13px}
.auth-foot a,.auth-foot button{color:var(--brand-blue-bright);font-weight:500}
.auth-foot a:hover,.auth-foot button:hover{color:var(--brand-gold)}
.auth-brand-content{position:relative;z-index:1;color:#fff}
.auth-brand-tag{display:inline-flex;align-items:center;gap:8px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--brand-gold-bright);margin-bottom:22px}
.auth-brand-tag::before{content:'';width:24px;height:1px;background:var(--brand-gold)}
.auth-brand-headline{font-family:var(--font-display);font-size:60px;line-height:1;letter-spacing:-.03em;margin-bottom:24px;font-weight:400}
.auth-brand-headline em{color:var(--brand-gold-bright)}
.auth-brand-sub{font-size:16px;color:rgba(255,255,255,.75);max-width:460px;line-height:1.6}
.auth-stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px;padding-top:28px;border-top:1px solid rgba(255,255,255,.12)}
.auth-stat-num{font-family:var(--font-display);font-size:36px;letter-spacing:-.02em;color:var(--brand-gold-bright)}
.auth-stat-label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.65);margin-top:4px}
.auth-foot-meta{position:relative;z-index:1;display:flex;justify-content:space-between;font-size:12px;color:rgba(255,255,255,.55);font-family:var(--font-mono)}
.signup-stepper{display:flex;gap:4px;margin-bottom:28px}
.signup-step{flex:1;height:3px;background:var(--bg-elev-2);border-radius:2px;position:relative;overflow:hidden}
.signup-step.is-done,.signup-step.is-active{background:var(--brand-blue)}
.signup-step.is-active::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,var(--brand-gold-bright),transparent);animation:shimmer 1.6s infinite}
@keyframes shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
.step-label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-lo);margin-bottom:6px}
.signup-step-pane{display:none}
.signup-step-pane.is-active{display:block;animation:fadein .3s ease}
@keyframes fadein{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.industry-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}
.industry-tile{background:var(--bg-elev-1);border:1px solid var(--border-default);border-radius:var(--r-md);padding:14px;text-align:left;transition:all .16s ease;position:relative}
.industry-tile:hover{border-color:var(--border-strong);background:var(--bg-elev-2)}
.industry-tile.is-selected{border-color:var(--brand-blue-bright);background:rgba(70,101,255,.08);box-shadow:0 0 0 1px rgba(70,101,255,.4),0 0 24px -4px rgba(70,101,255,.5)}
.industry-tile svg{width:22px;height:22px;color:var(--brand-gold);margin-bottom:8px}
.industry-name{font-weight:500;font-size:14px;margin-bottom:2px}
.industry-desc{font-size:12px;color:var(--text-lo)}
.plan-grid{display:grid;gap:10px;margin-bottom:16px}
.plan-tile{background:var(--bg-elev-1);border:1px solid var(--border-default);border-radius:var(--r-md);padding:16px;text-align:left;display:flex;justify-content:space-between;align-items:center;transition:all .16s ease}
.plan-tile:hover{border-color:var(--border-strong)}
.plan-tile.is-selected{border-color:var(--brand-gold);background:rgba(201,163,104,.06)}
.plan-name{font-weight:600;font-size:15px}
.plan-features{font-size:12px;color:var(--text-lo);margin-top:3px}
.plan-price{font-family:var(--font-mono);font-size:16px;color:var(--brand-gold-bright)}
.plan-tag{display:inline-block;font-size:10px;letter-spacing:.1em;text-transform:uppercase;background:var(--brand-blue);color:#fff;padding:2px 6px;border-radius:3px;margin-left:6px;vertical-align:middle}

/* APP SHELL */
.app-shell{position:relative;display:grid;grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--topbar-h) 1fr;min-height:100vh;z-index:1}
.app-shell.is-hidden{display:none}
.sidebar{grid-row:1/3;grid-column:1;background:var(--bg-canvas);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;z-index:20}
.sidebar-brand{height:var(--topbar-h);display:flex;align-items:center;padding:0 18px;border-bottom:1px solid var(--border-subtle);gap:10px;position:relative}
.sidebar-brand::after{content:'';position:absolute;bottom:-1px;left:18px;right:18px;height:1px;background:linear-gradient(90deg,var(--brand-gold),transparent);opacity:.4}
.sidebar-org{margin:14px 12px 6px;padding:10px 12px;background:var(--bg-elev-1);border:1px solid var(--border-default);border-radius:var(--r-md);display:flex;align-items:center;gap:10px;cursor:pointer;transition:all .16s}
.sidebar-org:hover{border-color:var(--border-strong)}
.sidebar-org-icon{width:28px;height:28px;background:linear-gradient(135deg,var(--brand-blue-bright),var(--brand-blue-deep));border-radius:6px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;color:#fff;border:1px solid var(--brand-gold)}
.sidebar-org-info{flex:1;min-width:0}
.sidebar-org-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-org-plan{font-size:11px;color:var(--text-lo);font-family:var(--font-mono)}
.sidebar-org svg{width:14px;color:var(--text-lo)}
.sidebar-nav{flex:1;overflow-y:auto;padding:14px 8px}
.nav-section{margin-bottom:16px}
.nav-section-label{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-dim);padding:0 12px;margin-bottom:6px;font-weight:500}
.nav-link{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;color:var(--text-mid);font-size:13.5px;font-weight:400;transition:all .12s;position:relative;margin-bottom:1px;width:100%;text-align:left}
.nav-link:hover{background:var(--bg-elev-1);color:var(--text-hi)}
.nav-link.is-active{background:linear-gradient(90deg,rgba(70,101,255,.16),transparent);color:var(--text-hi)}
.nav-link.is-active::before{content:'';position:absolute;left:0;top:8px;bottom:8px;width:2px;background:var(--brand-gold);border-radius:2px;box-shadow:0 0 8px var(--brand-gold)}
.nav-link svg{width:17px;height:17px;flex-shrink:0}
.nav-link-badge{margin-left:auto;background:var(--critical);color:#fff;font-size:10px;font-family:var(--font-mono);font-weight:600;padding:1px 5px;border-radius:4px;min-width:16px;text-align:center}
.nav-link-badge.is-info{background:var(--brand-blue)}
.sidebar-foot{border-top:1px solid var(--border-subtle);padding:12px;display:flex;align-items:center;gap:10px}
.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--brand-gold),var(--brand-gold-soft));display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;color:#1a1304;border:1px solid var(--brand-gold-bright)}
.user-info{flex:1;min-width:0}
.user-name{font-size:13px;font-weight:500}
.user-role{font-size:11px;color:var(--text-lo)}
.tb-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid transparent;border-radius:8px;color:var(--text-mid);position:relative;transition:all .12s}
.tb-btn:hover{background:var(--bg-elev-1);color:var(--text-hi)}
.tb-btn svg{width:17px;height:17px}
.tb-btn-dot{position:absolute;top:7px;right:7px;width:7px;height:7px;background:var(--critical);border:2px solid var(--bg-base);border-radius:50%}
.topbar{grid-row:1;grid-column:2;height:var(--topbar-h);background:var(--bg-base);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;padding:0 24px;gap:16px;position:sticky;top:0;z-index:15;backdrop-filter:blur(12px)}
.topbar-search{flex:1;max-width:480px;position:relative}
.topbar-search-input{width:100%;background:var(--bg-elev-1);border:1px solid var(--border-default);border-radius:8px;padding:8px 12px 8px 38px;font-size:13px;transition:all .16s}
.topbar-search-input:focus{outline:none;border-color:var(--border-brand);background:var(--bg-elev-2)}
.topbar-search svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:15px;color:var(--text-lo)}
.topbar-search-shortcut{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-family:var(--font-mono);font-size:11px;color:var(--text-dim);background:var(--bg-base);padding:2px 5px;border:1px solid var(--border-default);border-radius:3px}
.topbar-actions{display:flex;align-items:center;gap:8px;margin-left:auto}
.topbar-status{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-lo);padding:0 10px;border-left:1px solid var(--border-subtle);margin-left:4px;height:28px}
.status-dot{width:8px;height:8px;background:var(--success);border-radius:50%;position:relative}
.status-dot::after{content:'';position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--success);opacity:.4;animation:pulse-ring 2s infinite}
@keyframes pulse-ring{0%{transform:scale(.6);opacity:.6}100%{transform:scale(1.4);opacity:0}}
.canvas{grid-row:2;grid-column:2;padding:24px 28px 48px;position:relative;min-height:calc(100vh - var(--topbar-h))}
.page{display:none;animation:pagein .25s ease}
.page.is-active{display:block}
@keyframes pagein{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.page-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:24px;gap:24px;flex-wrap:wrap}
.page-title-block{min-width:0}
.page-eyebrow{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--brand-gold);margin-bottom:6px;font-weight:500;display:flex;align-items:center;gap:8px}
.page-eyebrow::before{content:'';width:16px;height:1px;background:var(--brand-gold);opacity:.5}
.page-title{font-family:var(--font-display);font-size:36px;letter-spacing:-.02em;line-height:1.05;font-weight:400;margin-bottom:4px}
.page-title em{font-style:italic;color:var(--brand-gold)}
.page-sub{color:var(--text-mid);font-size:14px;max-width:560px}
.page-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}

/* Card */
.card{background:var(--bg-elev-1);border:1px solid var(--border-subtle);border-radius:var(--r-lg);padding:18px;position:relative;box-shadow:var(--shadow-card)}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;gap:12px}
.card-title{font-size:13px;font-weight:500;color:var(--text-hi);display:flex;align-items:center;gap:8px}
.card-title-eyebrow{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-lo);font-weight:500}
.card-action{font-size:12px;color:var(--text-lo);padding:4px 8px;border-radius:5px}
.card-action:hover{color:var(--text-hi);background:var(--bg-elev-2)}
.brackets{position:relative}
.brackets::before,.brackets::after{content:'';position:absolute;width:14px;height:14px;border:1px solid var(--brand-gold);opacity:.5;pointer-events:none}
.brackets::before{top:-1px;left:-1px;border-right:0;border-bottom:0}
.brackets::after{bottom:-1px;right:-1px;border-left:0;border-top:0}

.kpi-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:22px}
.kpi{background:var(--bg-elev-1);border:1px solid var(--border-subtle);border-radius:var(--r-lg);padding:18px;position:relative;overflow:hidden}
.kpi::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--brand-blue-bright),transparent);opacity:.4}
.kpi-label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-lo);font-weight:500;display:flex;align-items:center;gap:6px;margin-bottom:12px}
.kpi-label svg{width:13px;height:13px}
.kpi-value{font-family:var(--font-display);font-size:38px;line-height:1;letter-spacing:-.02em;margin-bottom:8px;font-weight:400}
.kpi-value-mono{font-family:var(--font-mono);font-weight:500;font-size:30px}
.kpi-meta{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-mid);flex-wrap:wrap}
.kpi-delta{font-family:var(--font-mono);font-size:11px;padding:2px 6px;border-radius:4px}
.kpi-delta.up{color:var(--success);background:var(--success-bg)}
.kpi-delta.down{color:var(--critical);background:var(--critical-bg)}
.sparkline{position:absolute;right:14px;top:50%;transform:translateY(-50%);height:32px;width:70px;opacity:.6}

.event-row{display:grid;grid-template-columns:80px 1fr auto auto;gap:14px;padding:12px;border-radius:var(--r-md);align-items:center;transition:background .14s;border:1px solid transparent;cursor:pointer}
.event-row:hover{background:var(--bg-elev-2);border-color:var(--border-default)}
.event-row+.event-row{border-top:1px solid var(--border-subtle);border-radius:0}
.event-thumb{width:80px;height:50px;border-radius:6px;background:linear-gradient(135deg,#0a0e1a,#1a2447);position:relative;overflow:hidden;border:1px solid var(--border-default)}
.event-thumb::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:8px 8px}
.event-thumb-rec{position:absolute;top:4px;left:4px;display:flex;align-items:center;gap:3px;font-family:var(--font-mono);font-size:8px;color:var(--critical);font-weight:600}
.event-thumb-rec::before{content:'';width:5px;height:5px;background:var(--critical);border-radius:50%;animation:pulse-dot 1s infinite}
@keyframes pulse-dot{0%,100%{opacity:1}50%{opacity:.3}}
.event-thumb-bbox{position:absolute;border:1.5px solid var(--brand-gold);border-radius:2px}
.event-info{min-width:0}
.event-type{font-size:13px;font-weight:500;margin-bottom:2px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.event-loc{font-size:12px;color:var(--text-lo);font-family:var(--font-mono)}
.severity-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}
.severity-dot.critical{background:var(--critical);box-shadow:0 0 6px var(--critical)}
.severity-dot.warning{background:var(--warning);box-shadow:0 0 6px var(--warning)}
.severity-dot.info{background:var(--info)}
.event-time{font-family:var(--font-mono);font-size:11px;color:var(--text-mid);text-align:right}
.event-time-ago{color:var(--text-lo);font-size:10px}

.chip{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:4px;font-size:11px;font-weight:500;font-family:var(--font-mono);border:1px solid}
.chip-critical{color:var(--critical);background:var(--critical-bg);border-color:rgba(255,77,106,.25)}
.chip-warning{color:var(--warning);background:var(--warning-bg);border-color:rgba(244,168,71,.25)}
.chip-success{color:var(--success);background:var(--success-bg);border-color:rgba(62,224,138,.25)}
.chip-info{color:var(--info);background:var(--info-bg);border-color:rgba(91,163,255,.25)}
.chip-neutral{color:var(--text-mid);background:var(--bg-elev-2);border-color:var(--border-default)}
.chip-gold{color:var(--brand-gold-bright);background:rgba(201,163,104,.1);border-color:var(--border-gold)}

.heatmap{display:grid;grid-template-columns:30px repeat(24,1fr);gap:2px;font-family:var(--font-mono);font-size:10px}
.heatmap-hr{text-align:center;color:var(--text-dim);padding-top:4px;font-size:9px}
.heatmap-day{color:var(--text-lo);padding-right:8px;padding-top:6px;text-align:right}
.heatmap-cell{aspect-ratio:1;border-radius:2px;background:var(--bg-elev-2);position:relative;cursor:pointer;transition:transform .1s}
.heatmap-cell:hover{transform:scale(1.4);z-index:2}
.heatmap-cell.l1{background:rgba(70,101,255,.18)}
.heatmap-cell.l2{background:rgba(70,101,255,.4)}
.heatmap-cell.l3{background:rgba(70,101,255,.65)}
.heatmap-cell.l4{background:rgba(201,163,104,.7)}
.heatmap-cell.l5{background:var(--critical)}

.donut-wrap{display:flex;align-items:center;gap:18px}
.donut{width:100px;height:100px;position:relative}
.donut svg{transform:rotate(-90deg)}
.donut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:var(--font-display);font-size:22px;letter-spacing:-.02em}
.donut-center-sub{font-family:var(--font-ui);font-size:10px;color:var(--text-lo);letter-spacing:.1em;text-transform:uppercase}
.legend{display:flex;flex-direction:column;gap:8px;flex:1}
.legend-item{display:flex;align-items:center;gap:8px;font-size:12px}
.legend-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}
.legend-val{margin-left:auto;font-family:var(--font-mono);color:var(--text-mid)}

.bar-list{display:flex;flex-direction:column;gap:12px}
.bar-item-head{display:flex;justify-content:space-between;font-size:12px;margin-bottom:4px}
.bar-item-name{color:var(--text-hi);font-weight:500}
.bar-item-val{font-family:var(--font-mono);color:var(--text-mid)}
.bar-track{height:4px;background:var(--bg-elev-2);border-radius:2px;overflow:hidden}
.bar-fill{height:100%;background:linear-gradient(90deg,var(--brand-blue),var(--brand-blue-bright));border-radius:2px}
.bar-fill.gold{background:linear-gradient(90deg,var(--brand-gold-soft),var(--brand-gold))}

.site-map{position:relative;background:var(--bg-elev-2);border-radius:var(--r-md);height:220px;overflow:hidden;border:1px solid var(--border-default)}
.site-map::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 40%,rgba(70,101,255,.2),transparent 30%),radial-gradient(circle at 70% 60%,rgba(201,163,104,.15),transparent 25%)}
.site-map::after{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:20px 20px}
.site-pin{position:absolute;width:10px;height:10px;background:var(--brand-blue-bright);border:2px solid var(--bg-canvas);border-radius:50%;box-shadow:0 0 12px var(--brand-blue-bright);z-index:2;cursor:pointer}
.site-pin.is-alert{background:var(--critical);box-shadow:0 0 12px var(--critical)}
.site-pin::after{content:'';position:absolute;inset:-8px;border-radius:50%;border:1px solid currentColor;opacity:.4;animation:pulse-ring 2s infinite;color:inherit}
.site-tag{position:absolute;font-family:var(--font-mono);font-size:10px;background:var(--bg-overlay);border:1px solid var(--border-default);padding:2px 6px;border-radius:3px;color:var(--text-mid);white-space:nowrap;z-index:1}

.cam-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.cam-tile{position:relative;aspect-ratio:16/9;background:linear-gradient(135deg,#060912,#0d1428);border:1px solid var(--border-default);border-radius:var(--r-md);overflow:hidden;cursor:pointer;transition:all .16s}
.cam-tile:hover{border-color:var(--brand-gold);transform:translateY(-2px)}
.cam-tile-bg{position:absolute;inset:0;opacity:.6}
.cam-tile-bg.scene-1{background:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px),radial-gradient(ellipse at center,#1a3870,#07091a 80%);background-size:14px 14px,14px 14px,100% 100%}
.cam-tile-bg.scene-2{background:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(180deg,#1f2950,#0a0f25);background-size:14px 14px,14px 14px,100% 100%}
.cam-tile-bg.scene-3{background:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px),radial-gradient(ellipse at 70% 30%,#2a3a6a,#0a0f25 70%);background-size:14px 14px,14px 14px,100% 100%}
.cam-tile-bg.scene-warm{background:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px),radial-gradient(ellipse at 60% 70%,#4a3520,#1a1208 70%);background-size:14px 14px,14px 14px,100% 100%}
.cam-tile-scan{position:absolute;left:0;right:0;top:0;height:2px;background:linear-gradient(90deg,transparent,rgba(70,101,255,.4),transparent);animation:scan 4s linear infinite;pointer-events:none}
@keyframes scan{0%{top:0}100%{top:100%}}
.cam-tile-rec{position:absolute;top:8px;left:10px;display:flex;align-items:center;gap:4px;font-family:var(--font-mono);font-size:10px;color:var(--critical);font-weight:600;z-index:2}
.cam-tile-rec::before{content:'';width:7px;height:7px;background:var(--critical);border-radius:50%;animation:pulse-dot 1s infinite}
.cam-tile-time{position:absolute;top:8px;right:10px;font-family:var(--font-mono);font-size:10px;color:rgba(255,255,255,.7);z-index:2}
.cam-tile-meta{position:absolute;bottom:0;left:0;right:0;padding:22px 12px 10px;background:linear-gradient(180deg,transparent,rgba(0,0,0,.85));z-index:2}
.cam-tile-name{font-size:12px;font-weight:500;color:var(--text-hi);margin-bottom:2px}
.cam-tile-loc{font-size:11px;color:rgba(255,255,255,.65);font-family:var(--font-mono)}
.cam-tile-agents{position:absolute;bottom:10px;right:10px;display:flex;gap:4px;z-index:3}
.cam-tile-agent{width:22px;height:22px;background:rgba(7,9,26,.7);border:1px solid var(--brand-gold);border-radius:4px;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:9px;color:var(--brand-gold-bright);font-weight:600;backdrop-filter:blur(6px)}
.cam-tile-bbox{position:absolute;border:1.5px solid var(--brand-gold);z-index:1}
.cam-tile-bbox.alert{border-color:var(--critical)}
.cam-tile-bbox-label{position:absolute;top:-16px;left:-1px;background:var(--brand-gold);color:#1a1304;font-family:var(--font-mono);font-size:8px;font-weight:600;padding:2px 4px;border-radius:2px 2px 0 0}
.cam-tile-bbox.alert .cam-tile-bbox-label{background:var(--critical);color:#fff}

.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:18px;padding:12px;background:var(--bg-elev-1);border:1px solid var(--border-subtle);border-radius:var(--r-md);flex-wrap:wrap}
.toolbar-section{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.toolbar-divider{width:1px;height:20px;background:var(--border-default)}
.toolbar-label{font-size:12px;color:var(--text-lo)}
.filter-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;font-size:12px;background:var(--bg-elev-2);border:1px solid var(--border-default);border-radius:999px;color:var(--text-mid);transition:all .12s;cursor:pointer}
.filter-chip:hover{color:var(--text-hi);border-color:var(--border-strong)}
.filter-chip.is-active{background:rgba(70,101,255,.12);border-color:var(--brand-blue-bright);color:var(--text-hi)}
.filter-chip svg{width:12px;height:12px}

.tbl-wrap{background:var(--bg-elev-1);border:1px solid var(--border-subtle);border-radius:var(--r-lg);overflow:hidden;overflow-x:auto}
.tbl{width:100%;border-collapse:collapse;min-width:800px}
.tbl thead th{text-align:left;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-lo);font-weight:500;padding:12px 16px;border-bottom:1px solid var(--border-subtle);background:var(--bg-canvas);position:sticky;top:0}
.tbl tbody td{padding:14px 16px;border-bottom:1px solid var(--border-subtle);font-size:13px;vertical-align:middle}
.tbl tbody tr:last-child td{border-bottom:0}
.tbl tbody tr{transition:background .12s;cursor:pointer}
.tbl tbody tr:hover{background:var(--bg-elev-2)}
.tbl-mono{font-family:var(--font-mono);color:var(--text-mid);font-size:12px}

.agent-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.agent-card{background:var(--bg-elev-1);border:1px solid var(--border-subtle);border-radius:var(--r-lg);padding:18px;transition:all .16s;position:relative;overflow:hidden;cursor:pointer}
.agent-card:hover{border-color:var(--brand-gold);transform:translateY(-2px);box-shadow:var(--shadow-pop)}
.agent-card-icon{width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,var(--brand-blue-bright),var(--brand-blue-deep));display:flex;align-items:center;justify-content:center;margin-bottom:14px;border:1px solid var(--brand-gold);position:relative}
.agent-card-icon svg{width:22px;color:var(--brand-gold-bright)}
.agent-card-icon.gold{background:linear-gradient(135deg,var(--brand-gold),var(--brand-gold-soft));border-color:var(--brand-gold-bright)}
.agent-card-icon.gold svg{color:var(--brand-blue-deep)}
.agent-card-name{font-size:15px;font-weight:600;margin-bottom:4px}
.agent-card-vendor{font-size:11px;color:var(--text-lo);font-family:var(--font-mono);margin-bottom:10px}
.agent-card-desc{font-size:13px;color:var(--text-mid);line-height:1.5;margin-bottom:14px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.agent-card-foot{display:flex;justify-content:space-between;align-items:center;padding-top:14px;border-top:1px solid var(--border-subtle)}
.agent-card-rating{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-mid);font-family:var(--font-mono)}
.agent-card-rating svg{color:var(--brand-gold);width:12px;height:12px}
.agent-card-price{font-family:var(--font-mono);font-size:13px;color:var(--brand-gold-bright);font-weight:500}
.agent-installed{position:absolute;top:14px;right:14px;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--success);background:var(--success-bg);border:1px solid rgba(62,224,138,.25);padding:2px 6px;border-radius:3px;font-family:var(--font-mono);font-weight:600}

.subhead{display:flex;justify-content:space-between;align-items:baseline;margin:28px 0 14px}
.subhead-title{font-size:16px;font-weight:600;letter-spacing:-.01em}
.subhead-link{font-size:12px;color:var(--brand-gold)}
.subhead-link:hover{color:var(--brand-gold-bright)}

.settings-shell{display:grid;grid-template-columns:220px 1fr;gap:32px}
.settings-nav{position:sticky;top:80px;align-self:start}
.settings-nav-link{display:block;padding:8px 12px;font-size:13px;color:var(--text-mid);border-radius:6px;margin-bottom:2px;cursor:pointer}
.settings-nav-link:hover{background:var(--bg-elev-1);color:var(--text-hi)}
.settings-nav-link.is-active{background:var(--bg-elev-1);color:var(--text-hi);border-left:2px solid var(--brand-gold)}
.settings-section{margin-bottom:32px}
.settings-section-title{font-size:18px;font-weight:600;margin-bottom:4px}
.settings-section-sub{color:var(--text-mid);font-size:13px;margin-bottom:18px}

.toggle{display:inline-flex;align-items:center;gap:8px;cursor:pointer}
.toggle-track{width:36px;height:20px;background:var(--bg-elev-3);border-radius:999px;position:relative;border:1px solid var(--border-default);transition:all .16s;display:inline-block}
.toggle-track::after{content:'';position:absolute;top:2px;left:2px;width:14px;height:14px;background:var(--text-mid);border-radius:50%;transition:all .16s}
.toggle-input{display:none}
.toggle-input:checked+.toggle-track{background:var(--brand-blue);border-color:var(--brand-blue-bright)}
.toggle-input:checked+.toggle-track::after{left:18px;background:#fff}

.tabs{display:flex;border-bottom:1px solid var(--border-subtle);margin-bottom:22px;gap:4px;overflow-x:auto}
.tab-link{padding:10px 16px;font-size:13px;color:var(--text-mid);border-bottom:2px solid transparent;position:relative;margin-bottom:-1px;white-space:nowrap}
.tab-link:hover{color:var(--text-hi)}
.tab-link.is-active{color:var(--text-hi);border-bottom-color:var(--brand-gold)}
.tab-link-count{font-family:var(--font-mono);font-size:11px;color:var(--text-lo);margin-left:4px}

.empty{text-align:center;padding:60px 20px;color:var(--text-mid)}
.empty-icon{width:56px;height:56px;background:var(--bg-elev-2);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;border:1px solid var(--border-default)}
.empty-icon svg{width:22px;color:var(--text-lo)}
.empty-title{font-size:16px;color:var(--text-hi);margin-bottom:4px;font-weight:500}
.empty-sub{font-size:13px}

.chart-area{display:flex;align-items:flex-end;gap:4px;height:160px;padding:12px 0}
.chart-bar{flex:1;background:linear-gradient(180deg,var(--brand-blue-bright),var(--brand-blue-deep));border-radius:2px 2px 0 0;min-height:4px;position:relative;cursor:pointer;transition:opacity .12s}
.chart-bar:hover{opacity:.7}
.chart-bar.gold{background:linear-gradient(180deg,var(--brand-gold-bright),var(--brand-gold-soft))}

.onboard-shell{max-width:720px;margin:0 auto;padding:40px 0}
.onboard-hero{text-align:center;margin-bottom:36px}
.onboard-hero-title{font-family:var(--font-display);font-size:44px;letter-spacing:-.02em;margin-bottom:8px;font-weight:400}
.onboard-hero-title em{color:var(--brand-gold)}
.onboard-hero-sub{color:var(--text-mid);font-size:15px}

.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:80;display:none;backdrop-filter:blur(4px)}
.drawer-overlay.is-open{display:block}
.drawer{position:fixed;top:0;right:0;bottom:0;width:480px;max-width:100vw;background:var(--bg-canvas);border-left:1px solid var(--border-strong);z-index:90;transform:translateX(100%);transition:transform .28s cubic-bezier(.32,.72,.21,1);display:flex;flex-direction:column;overflow:hidden}
.drawer.is-open{transform:translateX(0)}
.drawer-head{padding:20px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.drawer-body{flex:1;overflow-y:auto;padding:20px}
.drawer-foot{padding:16px 20px;border-top:1px solid var(--border-subtle);display:flex;gap:8px;justify-content:flex-end}
.drawer-preview{aspect-ratio:16/9;background:linear-gradient(135deg,#060912,#0d1428);border-radius:var(--r-md);position:relative;overflow:hidden;margin-bottom:16px;border:1px solid var(--border-default)}
.drawer-meta-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:14px 0;border-bottom:1px solid var(--border-subtle)}
.drawer-meta-label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-lo);margin-bottom:4px}
.drawer-meta-val{font-size:13px}

.integ-card{background:var(--bg-elev-1);border:1px solid var(--border-subtle);border-radius:var(--r-md);padding:16px;display:flex;align-items:center;gap:14px}
.integ-icon{width:44px;height:44px;background:var(--bg-elev-3);border:1px solid var(--border-default);border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:20px;color:var(--brand-gold);flex-shrink:0}
.integ-info{flex:1;min-width:0}
.integ-name{font-weight:500;font-size:14px}
.integ-desc{font-size:12px;color:var(--text-lo);margin-top:2px}

.box-card{background:var(--bg-elev-1);border:1px solid var(--border-subtle);border-radius:var(--r-lg);padding:18px;position:relative}
.box-card-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.box-card-id{width:38px;height:38px;background:var(--bg-elev-3);border:1px solid var(--brand-gold);border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:13px;color:var(--brand-gold-bright);font-weight:600}
.box-card-info{flex:1}
.box-card-name{font-weight:500}
.box-card-loc{font-size:11px;font-family:var(--font-mono);color:var(--text-lo);margin-top:2px}
.metric-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:12px 0;border-top:1px solid var(--border-subtle);margin-top:12px}
.metric-cell{text-align:left}
.metric-label{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-lo);margin-bottom:4px}
.metric-val{font-family:var(--font-mono);font-size:14px;color:var(--text-hi)}

.tree-node{padding:8px 12px;display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer;border-radius:6px;transition:background .1s}
.tree-node:hover{background:var(--bg-elev-2)}
.tree-node svg{width:14px;color:var(--text-lo)}
.tree-node.depth-1{padding-left:28px}
.tree-node.depth-2{padding-left:48px}
.tree-node.depth-3{padding-left:68px}
.tree-count{margin-left:auto;font-family:var(--font-mono);font-size:11px;color:var(--text-lo)}

.toast-wrap{position:fixed;bottom:28px;right:28px;z-index:100;display:flex;flex-direction:column;gap:8px}
.toast{background:var(--bg-elev-2);border:1px solid var(--border-strong);border-left:3px solid var(--brand-gold);border-radius:var(--r-md);padding:12px 16px;font-size:13px;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-pop);max-width:360px;animation:toastin .24s ease}
@keyframes toastin{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}

.flex{display:flex}
.items-center{align-items:center}
.justify-between{justify-content:space-between}
.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}
.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-4{margin-bottom:16px}
.text-mid{color:var(--text-mid)}.text-lo{color:var(--text-lo)}
.text-mono{font-family:var(--font-mono)}
.grid{display:grid}.col-2{grid-template-columns:1fr 1fr}.col-3{grid-template-columns:repeat(3,1fr)}.col-4{grid-template-columns:repeat(4,1fr)}

/* ============================================================
   LOOP HERO — From footage to outcomes
   ============================================================ */
.loop-hero{position:relative;background:linear-gradient(180deg,rgba(70,101,255,.05),rgba(7,9,26,0) 60%),var(--bg-elev-1);border:1px solid var(--border-subtle);border-radius:var(--r-lg);padding:24px 24px 28px;margin-bottom:18px;overflow:hidden;box-shadow:var(--shadow-card)}
.loop-hero::before,.loop-hero::after{content:'';position:absolute;width:18px;height:18px;border:1px solid var(--brand-gold);opacity:.55;pointer-events:none}
.loop-hero::before{top:-1px;left:-1px;border-right:0;border-bottom:0}
.loop-hero::after{bottom:-1px;right:-1px;border-left:0;border-top:0}
.loop-hero-glow{position:absolute;top:-160px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(201,163,104,.18),transparent 70%);pointer-events:none;filter:blur(40px)}
.loop-hero-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:22px;position:relative;z-index:1}
.loop-hero-title-block .card-title-eyebrow{font-size:10px;letter-spacing:.16em;color:var(--brand-gold);font-weight:500;text-transform:uppercase;display:flex;align-items:center;gap:8px;margin-bottom:6px}
.loop-hero-title-block .card-title-eyebrow::before{content:'';width:14px;height:1px;background:var(--brand-gold);opacity:.6}
.loop-hero-title{font-family:var(--font-display);font-size:26px;letter-spacing:-.02em;line-height:1.1;font-weight:400;color:var(--text-hi)}
.loop-hero-title em{font-style:italic;color:var(--brand-gold)}
.loop-hero-sub{color:var(--text-mid);font-size:13px;margin-top:4px;max-width:520px}
.loop-hero-pulse{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11px;color:var(--text-mid);padding:6px 10px;border:1px solid var(--border-default);border-radius:6px;background:var(--bg-elev-1)}
.loop-hero-pulse::before{content:'';width:6px;height:6px;background:var(--success);border-radius:50%;box-shadow:0 0 8px var(--success);animation:pulse-dot 1.4s infinite}

.loop-grid{display:grid;grid-template-columns:1fr 28px 1fr 28px 1fr 28px 1fr 28px 1fr;align-items:stretch;gap:0;position:relative;z-index:1}
.loop-stage{background:var(--bg-elev-2);border:1px solid var(--border-default);border-radius:var(--r-md);padding:14px 14px 16px;cursor:pointer;transition:all .18s ease;position:relative;display:flex;flex-direction:column;min-height:172px}
.loop-stage:hover{border-color:var(--border-strong);background:var(--bg-elev-3);transform:translateY(-2px)}
.loop-stage.is-active{border-color:var(--ls-color,var(--brand-blue-bright));background:linear-gradient(180deg,rgba(70,101,255,.08),var(--bg-elev-2));box-shadow:0 0 0 1px var(--ls-color,var(--brand-blue-bright)),0 12px 32px -16px var(--ls-color,rgba(70,101,255,.5))}
.loop-stage.is-active::before{content:'';position:absolute;top:0;left:14px;right:14px;height:1px;background:linear-gradient(90deg,transparent,var(--ls-color,var(--brand-blue-bright)),transparent);opacity:.9}
.ls-num{position:absolute;top:10px;right:10px;width:20px;height:20px;border-radius:50%;background:var(--bg-base);border:1px solid var(--border-default);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:10px;font-weight:600;color:var(--text-lo)}
.loop-stage.is-active .ls-num{background:var(--ls-color);color:var(--bg-base);border-color:var(--ls-color);box-shadow:0 0 12px var(--ls-color)}
.ls-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--ls-color,var(--brand-blue-bright));background:color-mix(in srgb,var(--ls-color,#4665FF) 12%,transparent);border:1px solid color-mix(in srgb,var(--ls-color,#4665FF) 20%,transparent);margin-bottom:10px}
.ls-icon svg{width:18px;height:18px}
.ls-title{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-lo);font-weight:500;margin-bottom:4px}
.ls-stage-name{font-size:14px;font-weight:500;color:var(--text-hi);margin-bottom:10px}
.ls-metric{font-family:var(--font-display);font-size:30px;line-height:1;letter-spacing:-.02em;color:var(--text-hi);margin-bottom:4px;font-weight:400}
.ls-metric.mono{font-family:var(--font-mono);font-size:22px;font-weight:500}
.ls-metric .unit{font-size:14px;color:var(--text-lo);margin-left:2px;font-family:var(--font-ui)}
.ls-meta{font-size:11px;color:var(--text-mid);font-family:var(--font-mono);margin-top:auto}
.ls-meta .delta{padding:1px 5px;border-radius:3px;background:var(--success-bg);color:var(--success);margin-right:4px}
.ls-meta .delta.warn{background:var(--warning-bg);color:var(--warning)}
.ls-meta .delta.crit{background:var(--critical-bg);color:var(--critical)}
.ls-spark{position:absolute;bottom:0;left:0;right:0;height:24px;opacity:.4;pointer-events:none}
.loop-stage.is-active .ls-spark{opacity:.75}

.loop-arrow{display:flex;align-items:center;justify-content:center;position:relative;align-self:center;height:36px}
.loop-arrow svg{width:28px;height:14px;color:var(--border-strong)}
.loop-arrow::before{content:'';position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);height:1px;background:linear-gradient(90deg,transparent,var(--brand-blue-bright),var(--brand-gold),transparent);opacity:.35}
.loop-arrow .arrow-pulse{position:absolute;top:50%;left:0;width:5px;height:5px;border-radius:50%;background:var(--brand-blue-bright);box-shadow:0 0 8px var(--brand-blue-bright);transform:translateY(-50%);animation:flow 2.4s linear infinite}
.loop-arrow:nth-of-type(2) .arrow-pulse{animation-delay:.6s;background:var(--brand-gold);box-shadow:0 0 8px var(--brand-gold)}
.loop-arrow:nth-of-type(3) .arrow-pulse{animation-delay:1.2s;background:var(--info);box-shadow:0 0 8px var(--info)}
.loop-arrow:nth-of-type(4) .arrow-pulse{animation-delay:1.8s;background:var(--success);box-shadow:0 0 8px var(--success)}
@keyframes flow{0%{left:-4px;opacity:0}10%{opacity:1}90%{opacity:1}100%{left:calc(100% + 4px);opacity:0}}

.loop-close{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:18px;padding-top:18px;border-top:1px dashed var(--border-default);font-family:var(--font-mono);font-size:11px;color:var(--text-lo);position:relative;z-index:1}
.loop-close svg{width:14px;height:14px;color:var(--brand-gold);animation:spin-slow 8s linear infinite}
@keyframes spin-slow{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.loop-close strong{color:var(--text-mid);font-weight:500}

/* Stage detail panel */
.stage-panel{background:var(--bg-elev-1);border:1px solid var(--border-subtle);border-radius:var(--r-lg);padding:0;margin-bottom:22px;box-shadow:var(--shadow-card);overflow:hidden}
.stage-panel-head{display:flex;align-items:center;gap:0;padding:0 18px;border-bottom:1px solid var(--border-subtle);background:linear-gradient(180deg,var(--bg-elev-1),var(--bg-elev-2))}
.stage-tab{padding:14px 16px 12px;font-size:12px;color:var(--text-lo);font-weight:500;letter-spacing:.04em;cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;display:flex;align-items:center;gap:8px;white-space:nowrap}
.stage-tab:hover{color:var(--text-mid)}
.stage-tab .tab-num{width:18px;height:18px;border-radius:50%;background:var(--bg-elev-3);border:1px solid var(--border-default);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:9px;color:var(--text-lo);font-weight:600}
.stage-tab.is-active{color:var(--text-hi);border-bottom-color:var(--st-color,var(--brand-blue-bright))}
.stage-tab.is-active .tab-num{background:var(--st-color);border-color:var(--st-color);color:var(--bg-base)}
.stage-tab-spacer{flex:1}
.stage-tab-action{padding:14px 0;font-size:12px;color:var(--text-lo);cursor:pointer}
.stage-tab-action:hover{color:var(--brand-gold)}
.stage-body{padding:6px 10px 10px;display:none}
.stage-body.is-active{display:block;animation:fadein .25s ease}

/* Evidence pack cards */
.pack-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;padding:8px}
.pack-card{background:var(--bg-elev-2);border:1px solid var(--border-default);border-radius:var(--r-md);overflow:hidden;cursor:pointer;transition:all .15s}
.pack-card:hover{border-color:var(--border-strong);transform:translateY(-2px);box-shadow:var(--shadow-pop)}
.pack-thumb{aspect-ratio:16/9;position:relative;background:linear-gradient(135deg,#0a0e1a,#1a2447);overflow:hidden}
.pack-thumb::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:10px 10px}
.pack-thumb-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:space-between;padding:8px}
.pack-bbox{position:absolute;border:1.5px solid var(--brand-gold);border-radius:2px;animation:pulse-box 2s infinite}
@keyframes pulse-box{0%,100%{box-shadow:0 0 0 0 rgba(201,163,104,.5)}50%{box-shadow:0 0 0 4px rgba(201,163,104,0)}}
.pack-tag{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-mono);font-size:9px;padding:2px 6px;border-radius:3px;background:rgba(0,0,0,.6);color:#fff;font-weight:500;align-self:flex-start}
.pack-time-stamp{font-family:var(--font-mono);font-size:9px;color:rgba(255,255,255,.7);background:rgba(0,0,0,.5);padding:2px 6px;border-radius:3px;align-self:flex-end}
.pack-info{padding:10px 12px}
.pack-info-title{font-size:13px;font-weight:500;color:var(--text-hi);margin-bottom:4px;display:flex;align-items:center;gap:6px}
.pack-info-meta{font-size:11px;color:var(--text-lo);font-family:var(--font-mono);margin-bottom:8px}
.pack-contents{display:flex;gap:6px;flex-wrap:wrap;font-size:10px}
.pack-chip{display:inline-flex;align-items:center;gap:3px;padding:2px 6px;background:var(--bg-base);border:1px solid var(--border-default);border-radius:3px;color:var(--text-mid);font-family:var(--font-mono)}
.pack-chip svg{width:9px;height:9px}

/* Route rows */
.route-table{display:flex;flex-direction:column;padding:6px 8px}
.route-row{display:grid;grid-template-columns:1fr 200px 160px 120px 90px;gap:14px;padding:12px 12px;border-radius:var(--r-md);align-items:center;transition:background .14s;border:1px solid transparent}
.route-row:hover{background:var(--bg-elev-2);border-color:var(--border-default)}
.route-row+.route-row{border-top:1px solid var(--border-subtle);border-radius:0}
.route-incident{font-size:13px;color:var(--text-hi);font-weight:500;display:flex;align-items:center;gap:8px}
.route-incident-meta{font-size:11px;color:var(--text-lo);font-family:var(--font-mono);margin-top:2px}
.route-assignee{display:flex;align-items:center;gap:8px}
.route-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--brand-blue),var(--brand-blue-deep));color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;font-family:var(--font-mono);flex-shrink:0;border:1px solid var(--border-default)}
.route-avatar.gold{background:linear-gradient(135deg,var(--brand-gold-bright),var(--brand-gold))}
.route-avatar.green{background:linear-gradient(135deg,var(--success),#22a466)}
.route-name{font-size:12px;color:var(--text-hi);font-weight:500;line-height:1.2}
.route-role{font-size:10px;color:var(--text-lo);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em}
.route-channels{display:flex;gap:6px}
.route-channel{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:4px;font-size:10px;font-family:var(--font-mono);background:var(--bg-elev-2);border:1px solid var(--border-default);color:var(--text-mid)}
.route-channel.is-acked{background:var(--success-bg);border-color:rgba(62,224,138,.25);color:var(--success)}
.route-channel svg{width:11px;height:11px}
.route-status{font-size:11px;font-family:var(--font-mono);text-align:right}
.route-time{font-family:var(--font-mono);font-size:11px;color:var(--text-mid);text-align:right}
.route-time-ago{color:var(--text-lo);font-size:10px}

/* SLA / Closure tracking */
.sla-list{display:flex;flex-direction:column;padding:6px 8px}
.sla-row{padding:14px 12px;border-radius:var(--r-md);transition:background .14s;border:1px solid transparent}
.sla-row:hover{background:var(--bg-elev-2);border-color:var(--border-default)}
.sla-row+.sla-row{border-top:1px solid var(--border-subtle);border-radius:0}
.sla-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.sla-incident{font-size:13px;color:var(--text-hi);font-weight:500;display:flex;align-items:center;gap:8px}
.sla-incident-id{font-family:var(--font-mono);font-size:11px;color:var(--text-lo);background:var(--bg-elev-2);padding:1px 6px;border-radius:3px;border:1px solid var(--border-default)}
.sla-timer{font-family:var(--font-mono);font-size:12px;color:var(--text-hi)}
.sla-timer .lbl{color:var(--text-lo);font-size:10px;text-transform:uppercase;letter-spacing:.06em;margin-right:6px}
.sla-track{display:grid;grid-template-columns:60px 1fr 60px 1fr 60px;gap:8px;align-items:center}
.sla-step{display:flex;flex-direction:column;align-items:center;gap:4px}
.sla-step-dot{width:18px;height:18px;border-radius:50%;background:var(--bg-elev-3);border:1px solid var(--border-default);display:flex;align-items:center;justify-content:center;color:var(--text-lo)}
.sla-step.done .sla-step-dot{background:var(--success);border-color:var(--success);color:var(--bg-base)}
.sla-step.active .sla-step-dot{background:var(--brand-blue-bright);border-color:var(--brand-blue-bright);color:var(--bg-base);box-shadow:0 0 12px var(--brand-blue-bright);animation:pulse-dot 1.5s infinite}
.sla-step.breach .sla-step-dot{background:var(--critical);border-color:var(--critical);color:var(--bg-base);box-shadow:0 0 12px var(--critical)}
.sla-step-dot svg{width:10px;height:10px}
.sla-step-lbl{font-size:9px;color:var(--text-lo);text-transform:uppercase;letter-spacing:.04em;font-family:var(--font-mono);text-align:center}
.sla-step.done .sla-step-lbl{color:var(--success)}
.sla-step.active .sla-step-lbl{color:var(--brand-blue-bright)}
.sla-step.breach .sla-step-lbl{color:var(--critical)}
.sla-line{height:2px;background:var(--bg-elev-3);position:relative;border-radius:1px}
.sla-line.filled{background:var(--success)}
.sla-line.partial::after{content:'';position:absolute;top:0;left:0;height:100%;width:60%;background:var(--brand-blue-bright);border-radius:1px}
.sla-line.breach{background:linear-gradient(90deg,var(--success) 50%,var(--critical) 50%)}

/* Weekly outcome card */
.outcome-card{background:linear-gradient(135deg,rgba(201,163,104,.08),rgba(70,101,255,.05) 60%,rgba(7,9,26,0));border:1px solid var(--border-gold);border-radius:var(--r-lg);padding:24px;margin-bottom:22px;position:relative;overflow:hidden}
.outcome-card::before{content:'';position:absolute;top:-100px;right:-50px;width:300px;height:300px;background:radial-gradient(circle,rgba(201,163,104,.18),transparent 70%);pointer-events:none;filter:blur(40px)}
.outcome-card::after{content:'';position:absolute;width:14px;height:14px;border:1px solid var(--brand-gold);bottom:-1px;right:-1px;border-left:0;border-top:0;opacity:.6}
.outcome-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:20px;flex-wrap:wrap;position:relative;z-index:1}
.outcome-eyebrow{font-size:10px;letter-spacing:.16em;color:var(--brand-gold);text-transform:uppercase;font-weight:500;margin-bottom:6px;display:flex;align-items:center;gap:8px}
.outcome-eyebrow::before{content:'';width:14px;height:1px;background:var(--brand-gold)}
.outcome-title{font-family:var(--font-display);font-size:24px;letter-spacing:-.02em;line-height:1.1;font-weight:400}
.outcome-title em{font-style:italic;color:var(--brand-gold-bright)}
.outcome-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:18px;position:relative;z-index:1}
.outcome-roi{background:rgba(7,9,26,.4);border:1px solid var(--border-gold);border-radius:var(--r-md);padding:18px;display:flex;flex-direction:column;justify-content:space-between;gap:14px;position:relative;overflow:hidden}
.outcome-roi::after{content:'₹';position:absolute;font-family:var(--font-display);font-size:200px;color:var(--brand-gold);opacity:.06;right:-20px;bottom:-80px;line-height:1}
.outcome-roi-lbl{font-size:11px;letter-spacing:.12em;color:var(--brand-gold);text-transform:uppercase;font-weight:500;display:flex;align-items:center;gap:6px;position:relative;z-index:1}
.outcome-roi-val{font-family:var(--font-display);font-size:48px;line-height:1;letter-spacing:-.02em;color:var(--text-hi);font-weight:400;position:relative;z-index:1}
.outcome-roi-val em{font-style:italic;color:var(--brand-gold-bright)}
.outcome-roi-val .unit{font-size:18px;color:var(--text-lo);margin-left:4px;font-family:var(--font-ui)}
.outcome-roi-meta{font-size:12px;color:var(--text-mid);position:relative;z-index:1}
.outcome-tile{background:var(--bg-elev-1);border:1px solid var(--border-subtle);border-radius:var(--r-md);padding:16px;display:flex;flex-direction:column;gap:8px}
.outcome-tile-lbl{font-size:11px;letter-spacing:.1em;color:var(--text-lo);text-transform:uppercase;font-weight:500;display:flex;align-items:center;gap:6px}
.outcome-tile-lbl svg{width:13px;height:13px}
.outcome-tile-val{font-family:var(--font-display);font-size:30px;line-height:1;letter-spacing:-.02em;color:var(--text-hi);font-weight:400}
.outcome-tile-val.mono{font-family:var(--font-mono);font-size:22px;font-weight:500}
.outcome-tile-meta{font-size:11px;color:var(--text-mid);font-family:var(--font-mono);margin-top:auto}
.outcome-tile-bar{height:3px;background:var(--bg-elev-3);border-radius:2px;overflow:hidden;margin-top:6px}
.outcome-tile-bar-fill{height:100%;background:linear-gradient(90deg,var(--brand-blue-bright),var(--brand-gold));border-radius:2px}
.hotspot-list{display:flex;flex-direction:column;gap:6px;margin-top:6px}
.hotspot-row{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-mid);font-family:var(--font-mono)}
.hotspot-row .rank{color:var(--brand-gold);width:14px;font-weight:600}
.hotspot-row .name{flex:1;color:var(--text-hi);font-family:var(--font-ui)}
.hotspot-row .count{color:var(--critical)}

@media (max-width:1280px){.kpi-grid{grid-template-columns:repeat(3,1fr)}
  .loop-grid{grid-template-columns:1fr 1fr 1fr;grid-template-rows:auto 20px auto 20px auto;}
  .loop-grid .loop-arrow{display:none}
  .outcome-grid{grid-template-columns:1fr 1fr}
}

/* ============================================================
   LIGHT-THEME OVERRIDE — Dashboard page only
   Sidebar + topbar + other pages stay dark.
   ============================================================ */
.page[data-page="dashboard"]{
  --bg-base:#F5F6FA;
  --bg-canvas:#FFFFFF;
  --bg-elev-1:#FFFFFF;
  --bg-elev-2:#F5F6FA;
  --bg-elev-3:#EAEDF5;
  --bg-overlay:rgba(255,255,255,.92);
  --border-subtle:rgba(15,20,41,.06);
  --border-default:rgba(15,20,41,.10);
  --border-strong:rgba(15,20,41,.18);
  --border-brand:rgba(43,62,240,.30);
  --border-gold:rgba(201,163,104,.45);
  --text-hi:#0F1429;
  --text-mid:#4A5167;
  --text-lo:#6E7693;
  --text-dim:#9097A8;
  --shadow-card:0 1px 2px rgba(15,20,41,.04),0 4px 12px rgba(15,20,41,.05);
  --shadow-pop:0 16px 40px rgba(15,20,41,.14);
  background:#F5F6FA;
  margin:-24px -28px -48px;
  padding:24px 28px 48px;
  min-height:calc(100vh - var(--topbar-h));
  position:relative;
}
.page[data-page="dashboard"]::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(15,20,41,.022) 1px,transparent 1px),linear-gradient(90deg,rgba(15,20,41,.022) 1px,transparent 1px);background-size:32px 32px;pointer-events:none;z-index:0}
.page[data-page="dashboard"] > *{position:relative;z-index:1}
.page[data-page="dashboard"] .page-title em{color:var(--brand-blue)}
.page[data-page="dashboard"] .page-eyebrow{color:#8B6F3F}
.page[data-page="dashboard"] .page-eyebrow::before{background:#C9A368}
.page[data-page="dashboard"] .page-sub{color:#4A5167}

/* Buttons */
.page[data-page="dashboard"] .btn-secondary{background:#FFFFFF;border-color:rgba(15,20,41,.12);color:#0F1429}
.page[data-page="dashboard"] .btn-secondary:hover{background:#F5F6FA;border-color:rgba(15,20,41,.20)}
.page[data-page="dashboard"] .btn-ghost{color:#4A5167}
.page[data-page="dashboard"] .btn-ghost:hover{background:#F5F6FA;color:#0F1429}
.page[data-page="dashboard"] .btn-gold{color:#1a1304}
.page[data-page="dashboard"] .filter-chip{background:#FFFFFF;border-color:rgba(15,20,41,.10);color:#4A5167;box-shadow:0 1px 2px rgba(15,20,41,.04)}
.page[data-page="dashboard"] .filter-chip:hover{background:#F5F6FA;border-color:rgba(15,20,41,.18);color:#0F1429}

/* Loop hero */
.page[data-page="dashboard"] .loop-hero{background:linear-gradient(180deg,rgba(43,62,240,.04),#FFFFFF 60%);border-color:rgba(15,20,41,.08);box-shadow:0 1px 2px rgba(15,20,41,.04),0 8px 24px rgba(15,20,41,.05)}
.page[data-page="dashboard"] .loop-hero-glow{background:radial-gradient(circle,rgba(201,163,104,.16),transparent 70%)}
.page[data-page="dashboard"] .loop-hero-title em{color:#8B6F3F}
.page[data-page="dashboard"] .loop-hero-pulse{background:#FFFFFF;border-color:rgba(15,20,41,.10);color:#4A5167}
.page[data-page="dashboard"] .loop-close{border-top-color:rgba(15,20,41,.12)}
.page[data-page="dashboard"] .loop-close strong{color:#0F1429}

/* Loop stage cards */
.page[data-page="dashboard"] .loop-stage{background:#FFFFFF;border-color:rgba(15,20,41,.10);box-shadow:0 1px 3px rgba(15,20,41,.05)}
.page[data-page="dashboard"] .loop-stage:hover{background:#FAFBFE;border-color:rgba(15,20,41,.18);box-shadow:0 8px 20px rgba(15,20,41,.08)}
.page[data-page="dashboard"] .loop-stage.is-active{background:linear-gradient(180deg,rgba(43,62,240,.04),#FFFFFF);box-shadow:0 0 0 1.5px var(--ls-color),0 12px 24px -10px color-mix(in srgb,var(--ls-color) 35%,transparent)}
.page[data-page="dashboard"] .ls-num{background:#F5F6FA;color:#6E7693;border-color:rgba(15,20,41,.12)}
.page[data-page="dashboard"] .loop-stage.is-active .ls-num{color:#FFFFFF}
.page[data-page="dashboard"] .ls-spark{opacity:.5}
.page[data-page="dashboard"] .loop-stage.is-active .ls-spark{opacity:.85}
.page[data-page="dashboard"] .ls-meta .delta{background:rgba(62,224,138,.16)}
.page[data-page="dashboard"] .ls-meta .delta.warn{background:rgba(244,168,71,.18)}
.page[data-page="dashboard"] .ls-meta .delta.crit{background:rgba(255,77,106,.12)}

/* Loop arrow line color */
.page[data-page="dashboard"] .loop-arrow svg{color:rgba(15,20,41,.18)}
.page[data-page="dashboard"] .loop-arrow::before{background:linear-gradient(90deg,transparent,#2B3EF0,#C9A368,transparent);opacity:.45}

/* Stage detail panel */
.page[data-page="dashboard"] .stage-panel{background:#FFFFFF;border-color:rgba(15,20,41,.06);box-shadow:0 1px 2px rgba(15,20,41,.04),0 4px 12px rgba(15,20,41,.04)}
.page[data-page="dashboard"] .stage-panel-head{background:linear-gradient(180deg,#FAFBFE,#F5F6FA);border-bottom-color:rgba(15,20,41,.06)}
.page[data-page="dashboard"] .stage-tab .tab-num{background:#EAEDF5;border-color:rgba(15,20,41,.10);color:#6E7693}
.page[data-page="dashboard"] .stage-tab.is-active .tab-num{color:#FFFFFF}
.page[data-page="dashboard"] .stage-tab-action:hover{color:#8B6F3F}

/* Event rows */
.page[data-page="dashboard"] .event-row{border-color:transparent}
.page[data-page="dashboard"] .event-row:hover{background:#F5F6FA;border-color:rgba(15,20,41,.10)}
.page[data-page="dashboard"] .event-row+.event-row{border-top-color:rgba(15,20,41,.06)}
.page[data-page="dashboard"] .event-loc{color:#6E7693}
.page[data-page="dashboard"] .event-time{color:#4A5167}
.page[data-page="dashboard"] .event-time-ago{color:#9097A8}

/* Pack cards (thumbs stay dark — they're CCTV) */
.page[data-page="dashboard"] .pack-card{background:#FFFFFF;border-color:rgba(15,20,41,.10);box-shadow:0 1px 2px rgba(15,20,41,.04)}
.page[data-page="dashboard"] .pack-card:hover{border-color:rgba(15,20,41,.20);box-shadow:0 8px 20px rgba(15,20,41,.10)}
.page[data-page="dashboard"] .pack-info-meta{color:#6E7693}
.page[data-page="dashboard"] .pack-chip{background:#F5F6FA;border-color:rgba(15,20,41,.10);color:#4A5167}

/* Route rows */
.page[data-page="dashboard"] .route-row{border-color:transparent}
.page[data-page="dashboard"] .route-row:hover{background:#F5F6FA;border-color:rgba(15,20,41,.10)}
.page[data-page="dashboard"] .route-row+.route-row{border-top-color:rgba(15,20,41,.06)}
.page[data-page="dashboard"] .route-incident-meta{color:#6E7693}
.page[data-page="dashboard"] .route-channel{background:#F5F6FA;border-color:rgba(15,20,41,.10);color:#4A5167}
.page[data-page="dashboard"] .route-channel.is-acked{background:rgba(62,224,138,.14);border-color:rgba(62,224,138,.30);color:#1a8048}
.page[data-page="dashboard"] .route-time{color:#4A5167}
.page[data-page="dashboard"] .route-time-ago{color:#9097A8}
.page[data-page="dashboard"] .route-role{color:#6E7693}
.page[data-page="dashboard"] .route-avatar{border-color:rgba(15,20,41,.06)}

/* SLA tracking */
.page[data-page="dashboard"] .sla-row{border-color:transparent}
.page[data-page="dashboard"] .sla-row:hover{background:#F5F6FA;border-color:rgba(15,20,41,.10)}
.page[data-page="dashboard"] .sla-row+.sla-row{border-top-color:rgba(15,20,41,.06)}
.page[data-page="dashboard"] .sla-step-dot{background:#EAEDF5;border-color:rgba(15,20,41,.18);color:#9097A8}
.page[data-page="dashboard"] .sla-step.done .sla-step-dot{color:#FFFFFF}
.page[data-page="dashboard"] .sla-step.active .sla-step-dot{color:#FFFFFF}
.page[data-page="dashboard"] .sla-step.breach .sla-step-dot{color:#FFFFFF}
.page[data-page="dashboard"] .sla-line{background:#EAEDF5}
.page[data-page="dashboard"] .sla-incident-id{background:#F5F6FA;border-color:rgba(15,20,41,.10);color:#6E7693}
.page[data-page="dashboard"] .sla-timer .lbl{color:#9097A8}

/* KPI cards */
.page[data-page="dashboard"] .kpi{background:#FFFFFF;border-color:rgba(15,20,41,.06);box-shadow:0 1px 2px rgba(15,20,41,.04),0 4px 10px rgba(15,20,41,.04)}
.page[data-page="dashboard"] .kpi-label{color:#6E7693}
.page[data-page="dashboard"] .kpi-delta.up{background:rgba(62,224,138,.16);color:#1a8048}
.page[data-page="dashboard"] .kpi-delta.down{background:rgba(255,77,106,.12);color:#c92a47}

/* Generic cards */
.page[data-page="dashboard"] .card{background:#FFFFFF;border-color:rgba(15,20,41,.06);box-shadow:0 1px 2px rgba(15,20,41,.04),0 4px 10px rgba(15,20,41,.04)}
.page[data-page="dashboard"] .card-title-eyebrow{color:#6E7693}
.page[data-page="dashboard"] .card-action{color:#6E7693}
.page[data-page="dashboard"] .card-action:hover{color:#0F1429;background:#F5F6FA}

/* Brackets accent — slightly more visible on white */
.page[data-page="dashboard"] .brackets::before,
.page[data-page="dashboard"] .brackets::after,
.page[data-page="dashboard"] .loop-hero::before,
.page[data-page="dashboard"] .loop-hero::after{border-color:#C9A368;opacity:.7}

/* Site map */
.page[data-page="dashboard"] .site-map{background:#F5F6FA;border-color:rgba(15,20,41,.08)}
.page[data-page="dashboard"] .site-map::before{background:radial-gradient(circle at 30% 40%,rgba(43,62,240,.10),transparent 30%),radial-gradient(circle at 70% 60%,rgba(201,163,104,.10),transparent 25%)}
.page[data-page="dashboard"] .site-map::after{background-image:linear-gradient(rgba(15,20,41,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(15,20,41,.04) 1px,transparent 1px)}
.page[data-page="dashboard"] .site-pin{border-color:#FFFFFF;box-shadow:0 0 8px var(--brand-blue-bright),0 1px 4px rgba(15,20,41,.25)}
.page[data-page="dashboard"] .site-pin.is-alert{box-shadow:0 0 8px var(--critical),0 1px 4px rgba(15,20,41,.25)}
.page[data-page="dashboard"] .site-tag{background:#FFFFFF;border-color:rgba(15,20,41,.10);color:#4A5167;box-shadow:0 1px 3px rgba(15,20,41,.08)}

/* Fleet donut & legend */
.page[data-page="dashboard"] .donut-center{color:#0F1429}
.page[data-page="dashboard"] .donut-center-sub{color:#6E7693}
.page[data-page="dashboard"] .legend-val{color:#4A5167}
.page[data-page="dashboard"] .legend-item[style*="border-top"]{border-top-color:rgba(15,20,41,.10) !important}

/* Bars */
.page[data-page="dashboard"] .bar-track{background:#EAEDF5}
.page[data-page="dashboard"] .bar-item-val{color:#4A5167}

/* Heatmap */
.page[data-page="dashboard"] .heatmap-cell{background:#EAEDF5}
.page[data-page="dashboard"] .heatmap-cell.l1{background:rgba(43,62,240,.18)}
.page[data-page="dashboard"] .heatmap-cell.l2{background:rgba(43,62,240,.40)}
.page[data-page="dashboard"] .heatmap-cell.l3{background:rgba(43,62,240,.65)}
.page[data-page="dashboard"] .heatmap-cell.l4{background:rgba(201,163,104,.75)}
.page[data-page="dashboard"] .heatmap-day{color:#6E7693}
.page[data-page="dashboard"] .heatmap-hr{color:#9097A8}

/* Outcome card — premium gold-themed hero */
.page[data-page="dashboard"] .outcome-card{background:linear-gradient(135deg,rgba(201,163,104,.14),rgba(43,62,240,.05) 60%,#FFFFFF);border-color:rgba(201,163,104,.55);box-shadow:0 1px 2px rgba(15,20,41,.04),0 12px 32px rgba(201,163,104,.12)}
.page[data-page="dashboard"] .outcome-card::before{background:radial-gradient(circle,rgba(201,163,104,.22),transparent 70%)}
.page[data-page="dashboard"] .outcome-card::after{border-color:#C9A368;opacity:.8}
.page[data-page="dashboard"] .outcome-eyebrow{color:#8B6F3F}
.page[data-page="dashboard"] .outcome-eyebrow::before{background:#C9A368}
.page[data-page="dashboard"] .outcome-title em{color:#8B6F3F}
.page[data-page="dashboard"] .outcome-roi{background:#FFFFFF;border-color:rgba(201,163,104,.50);box-shadow:0 1px 3px rgba(15,20,41,.04)}
.page[data-page="dashboard"] .outcome-roi::after{color:#C9A368;opacity:.10}
.page[data-page="dashboard"] .outcome-roi-lbl{color:#8B6F3F}
.page[data-page="dashboard"] .outcome-roi-val em{color:#8B6F3F}
.page[data-page="dashboard"] .outcome-roi-meta{color:#4A5167}
.page[data-page="dashboard"] .outcome-roi-meta div[style*="border-bottom"]{border-bottom-color:rgba(15,20,41,.08) !important}
.page[data-page="dashboard"] .outcome-roi-meta span[style*="brand-gold"]{color:#8B6F3F !important}
.page[data-page="dashboard"] .outcome-tile{background:#FFFFFF;border-color:rgba(15,20,41,.06);box-shadow:0 1px 2px rgba(15,20,41,.04)}
.page[data-page="dashboard"] .outcome-tile-lbl{color:#6E7693}
.page[data-page="dashboard"] .outcome-tile-bar{background:#EAEDF5}
.page[data-page="dashboard"] .hotspot-row .rank{color:#8B6F3F}

/* Subhead */
.page[data-page="dashboard"] .subhead-link{color:#8B6F3F}
.page[data-page="dashboard"] .subhead-link:hover{color:#C9A368}

/* Stage 5 inline summary card overrides */
.page[data-page="dashboard"] [data-body="report"] > div > div[style*="rgba(201,163,104"]{background:rgba(201,163,104,.06) !important;border-color:rgba(201,163,104,.45) !important}
.page[data-page="dashboard"] [data-body="report"] > div > div > div div[style*="font-size:13px"]{color:#0F1429 !important}
.page[data-page="dashboard"] [data-body="report"] > div > div > div div[style*="font-size:12px"]{color:#4A5167 !important}
.page[data-page="dashboard"] [data-body="report"] [style*="background:var(--bg-elev-2)"]{background:#F5F6FA !important;border-color:rgba(15,20,41,.10) !important}
.page[data-page="dashboard"] [data-body="report"] [style*="font-family:var(--font-display)"]{color:#0F1429}
.page[data-page="dashboard"] [data-body="report"] span[style*="color:var(--text-lo)"]{color:#6E7693 !important}

/* Inline overrides on outcome card sub-text */
.page[data-page="dashboard"] .outcome-head p[style*="color:var(--text-mid)"]{color:#4A5167 !important}
.page[data-page="dashboard"] .ls-meta span[style*="color:var(--text-lo)"]{color:#9097A8 !important}
.page[data-page="dashboard"] .ls-metric .unit{color:#9097A8}

/* Mobile breakpoint for light dashboard */
@media (max-width:960px){
  .page[data-page="dashboard"]{margin:-16px;padding:16px}
}
@media (max-width:960px){
  .auth-shell{grid-template-columns:1fr}.auth-brand-side{display:none}
  .app-shell{grid-template-columns:0 1fr}.sidebar{display:none}
  .kpi-grid{grid-template-columns:1fr 1fr}.cam-grid{grid-template-columns:1fr 1fr}
  .canvas{padding:16px}.page-title{font-size:28px}.settings-shell{grid-template-columns:1fr}
  .grid[style*='2fr 1fr']{grid-template-columns:1fr !important}
  .col-3,.col-4{grid-template-columns:1fr 1fr}
  .drawer{width:100vw}
}

/* =========================================================================
   ENTERPRISE-WHITE THEME OVERRIDE  (v0504)
   Approved enterprise design language: white surfaces, blue+gold accents,
   colored top-border KPI cards, subtle box shadows. Applies app-wide.
   ========================================================================= */
:root{
  /* surfaces */
  --bg-base:#F5F6FA;
  --bg-canvas:#FFFFFF;
  --bg-elev-1:#FFFFFF;
  --bg-elev-2:#F5F6FA;
  --bg-elev-3:#EAEDF5;
  --bg-overlay:rgba(15,20,41,.45);

  /* text */
  --text-hi:#0F1429;
  --text-mid:#4A5167;
  --text-lo:#6E7693;
  --text-dim:#9097A8;

  /* borders */
  --border-subtle:rgba(15,20,41,.06);
  --border-default:rgba(15,20,41,.10);
  --border-strong:rgba(15,20,41,.16);
  --border-brand:rgba(43,62,240,.30);
  --border-gold:rgba(201,163,104,.40);

  /* brand */
  --brand-blue:#2B3EF0;
  --brand-blue-bright:#4665FF;
  --brand-blue-deep:#1A36B5;
  --brand-blue-shadow:#0F1E5C;
  --brand-blue-soft:rgba(43,62,240,.08);

  /* status (slightly deeper for legibility on white) */
  --critical:#E11D48;
  --critical-bg:rgba(225,29,72,.08);
  --warning:#D97706;
  --warning-bg:rgba(217,119,6,.10);
  --success:#059669;
  --success-bg:rgba(5,150,105,.10);
  --info:#2563EB;
  --info-bg:rgba(37,99,235,.08);

  /* shadows */
  --shadow-card:0 1px 2px rgba(15,20,41,.04),0 1px 3px rgba(15,20,41,.06);
  --shadow-pop:0 12px 32px -8px rgba(15,20,41,.18),0 4px 12px rgba(15,20,41,.06);

  /* radii */
  --r-sm:6px;--r-md:10px;--r-lg:14px;
}

/* base body — light surface, gold + blue ambient glow */
body{background:var(--bg-base);color:var(--text-hi)}
body::before{background-image:linear-gradient(rgba(43,62,240,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(43,62,240,.025) 1px,transparent 1px);opacity:.6}
body::after{background:radial-gradient(circle,rgba(43,62,240,.08),transparent 70%);filter:blur(80px)}

/* scrollbar */
::-webkit-scrollbar-thumb{background:rgba(15,20,41,.16);background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:rgba(15,20,41,.28);background-clip:padding-box}

/* ---- SIDEBAR ---- */
.sidebar{background:#FFFFFF;border-right:1px solid var(--border-subtle);box-shadow:1px 0 0 rgba(15,20,41,.02)}
.sidebar-brand{border-bottom:1px solid var(--border-subtle)}
.sidebar-brand::after{background:linear-gradient(90deg,#C9A368,transparent);opacity:.5}
.sidebar-brand svg text:first-of-type,.sidebar-brand svg text{fill:var(--text-hi)}
.sidebar-org{background:#F5F6FA;border:1px solid var(--border-default)}
.sidebar-org:hover{border-color:var(--border-strong);background:#EAEDF5}
.sidebar-org-icon{background:linear-gradient(135deg,var(--brand-blue-bright),var(--brand-blue-deep));border:1px solid #C9A368;color:#FFFFFF}
.sidebar-org-name{color:var(--text-hi)}
.sidebar-org-plan{color:var(--text-lo)}
.nav-section-label{color:var(--text-dim)}
.nav-link{color:var(--text-mid)}
.nav-link:hover{background:#F5F6FA;color:var(--text-hi)}
.nav-link.is-active{background:linear-gradient(90deg,rgba(43,62,240,.10),transparent);color:var(--brand-blue-deep);font-weight:500}
.nav-link.is-active::before{background:#C9A368;box-shadow:0 0 8px rgba(201,163,104,.5)}
.nav-link-badge{background:var(--critical);color:#FFFFFF}
.nav-link-badge.is-info{background:var(--brand-blue);color:#FFFFFF}
.sidebar-foot{border-top:1px solid var(--border-subtle);background:#FFFFFF}
.user-avatar{background:linear-gradient(135deg,#C9A368,#8B6F3F);color:#FFFFFF;border:1px solid #E8C988}
.user-name{color:var(--text-hi)}
.user-role{color:var(--text-lo)}

/* ---- TOPBAR ---- */
.topbar{background:#FFFFFF;border-bottom:1px solid var(--border-subtle);backdrop-filter:none}
.topbar-search-input{background:#F5F6FA;border:1px solid var(--border-default);color:var(--text-hi)}
.topbar-search-input::placeholder{color:var(--text-dim)}
.topbar-search-input:focus{background:#FFFFFF;border-color:var(--brand-blue-bright);box-shadow:0 0 0 3px rgba(43,62,240,.10)}
.topbar-search svg{color:var(--text-lo)}
.topbar-search-shortcut{background:#FFFFFF;border:1px solid var(--border-default);color:var(--text-lo)}
.topbar-status{color:var(--text-mid)}
.status-dot{background:var(--success);box-shadow:0 0 8px rgba(5,150,105,.5)}
.tb-btn{color:var(--text-mid)}
.tb-btn:hover{background:#F5F6FA;color:var(--text-hi)}
.tb-btn-dot{border-color:#FFFFFF}

/* ---- CANVAS / PAGES ---- */
.canvas{background:var(--bg-base)}
.page-eyebrow{color:#8B6F3F;font-weight:500;letter-spacing:.18em;text-transform:uppercase;font-size:11px}
.page-title{color:var(--text-hi)}
.page-title em{color:#8B6F3F;font-style:italic}
.page-sub{color:var(--text-mid)}

/* ---- CARDS ---- */
.card{background:#FFFFFF;border:1px solid var(--border-default);box-shadow:var(--shadow-card)}
.card.brackets::before,.card.brackets::after{border-color:#C9A368;opacity:.6}

/* ---- KPI cards: colored top border accent ---- */
.kpi-label{color:var(--text-lo);font-size:11px;letter-spacing:.10em;text-transform:uppercase;font-weight:500}
.kpi-label svg{color:var(--brand-blue)}
.kpi-value{color:var(--text-hi)}
.kpi-meta{color:var(--text-lo)}
.grid.col-4>.card.brackets{border-top:3px solid var(--brand-blue);position:relative}
.grid.col-4>.card.brackets:nth-child(2){border-top-color:var(--success)}
.grid.col-4>.card.brackets:nth-child(3){border-top-color:var(--warning)}
.grid.col-4>.card.brackets:nth-child(4){border-top-color:var(--critical)}

/* ---- BUTTONS ---- */
.btn-primary{background:linear-gradient(180deg,var(--brand-blue-bright),var(--brand-blue));color:#FFFFFF;box-shadow:0 1px 0 rgba(255,255,255,.20) inset,0 4px 12px -4px rgba(43,62,240,.40)}
.btn-primary:hover{box-shadow:0 1px 0 rgba(255,255,255,.25) inset,0 8px 20px -4px rgba(43,62,240,.55)}
.btn-secondary{background:#FFFFFF;border-color:var(--border-default);color:var(--text-hi)}
.btn-secondary:hover{background:#F5F6FA;border-color:var(--border-strong)}
.btn-ghost{background:transparent;color:var(--text-mid)}
.btn-ghost:hover{background:#F5F6FA;color:var(--text-hi)}
.btn-gold{background:linear-gradient(180deg,#E8C988,#C9A368);color:#1a1304;font-weight:600}
.btn-danger{background:var(--critical-bg);color:var(--critical);border-color:rgba(225,29,72,.30)}
/* NEW — distinct Acknowledge button (green/teal success) */
.btn-acknowledge{background:linear-gradient(180deg,#10B981,#059669);color:#FFFFFF;box-shadow:0 1px 0 rgba(255,255,255,.20) inset,0 4px 12px -4px rgba(5,150,105,.40);border:1px solid #047857}
.btn-acknowledge:hover{transform:translateY(-1px);box-shadow:0 1px 0 rgba(255,255,255,.25) inset,0 8px 20px -4px rgba(5,150,105,.55)}
.btn-acknowledge svg{stroke:#FFFFFF}
/* False positive / negative feedback buttons */
.btn-feedback-fp{background:#FFFFFF;border:1px solid rgba(225,29,72,.35);color:#BE123C}
.btn-feedback-fp:hover{background:rgba(225,29,72,.06);border-color:rgba(225,29,72,.55)}
.btn-feedback-fn{background:#FFFFFF;border:1px solid rgba(217,119,6,.35);color:#B45309}
.btn-feedback-fn:hover{background:rgba(217,119,6,.06);border-color:rgba(217,119,6,.55)}

/* ---- FILTER CHIPS / TABS / TOOLBARS ---- */
.toolbar{background:#FFFFFF;border:1px solid var(--border-default);border-radius:var(--r-md);box-shadow:var(--shadow-card)}
.toolbar-label,.toolbar-divider{color:var(--text-lo)}
.toolbar-divider{background:var(--border-default)}
.filter-chip{background:#FFFFFF;border:1px solid var(--border-default);color:var(--text-mid)}
.filter-chip:hover{background:#F5F6FA;border-color:var(--border-strong);color:var(--text-hi)}
.filter-chip.is-active{background:var(--brand-blue-soft);border-color:var(--brand-blue);color:var(--brand-blue-deep);font-weight:500}
.filter-chip svg{color:currentColor}
.filter-chip .text-mono{color:var(--text-lo)}
.filter-chip.is-active .text-mono{color:var(--brand-blue)}
.tabs{border-bottom:1px solid var(--border-default)}
.tab-link{color:var(--text-mid);border-bottom:2px solid transparent;background:transparent}
.tab-link:hover{color:var(--text-hi);background:transparent}
.tab-link.is-active{color:var(--brand-blue-deep);border-bottom-color:#C9A368;background:transparent;font-weight:500}
.tab-link-count{background:#F5F6FA;color:var(--text-lo);border:1px solid var(--border-default)}
.tab-link.is-active .tab-link-count{background:var(--brand-blue-soft);color:var(--brand-blue-deep);border-color:var(--brand-blue)}

/* ---- TABLES ---- */
.tbl-wrap{background:#FFFFFF;border:1px solid var(--border-default);border-radius:var(--r-md);box-shadow:var(--shadow-card);overflow:visible}
.tbl thead{background:#F5F6FA}
.tbl th{color:var(--text-lo);font-weight:500;letter-spacing:.06em;text-transform:uppercase;font-size:11px;border-bottom:1px solid var(--border-default)}
.tbl td{border-bottom:1px solid var(--border-subtle);color:var(--text-hi)}
.tbl tr:hover td{background:#F5F6FA}
.tbl tr:last-child td{border-bottom:none}
.tbl-mono{color:var(--text-mid);font-family:var(--font-mono);font-size:12px}

/* ---- CHIPS ---- */
.chip{font-weight:500}
.chip-success{background:var(--success-bg);color:#047857;border:1px solid rgba(5,150,105,.30)}
.chip-warning{background:var(--warning-bg);color:#B45309;border:1px solid rgba(217,119,6,.30)}
.chip-critical{background:var(--critical-bg);color:#BE123C;border:1px solid rgba(225,29,72,.30)}
.chip-info{background:var(--info-bg);color:#1D4ED8;border:1px solid rgba(37,99,235,.30)}
.chip-gold{background:rgba(201,163,104,.12);color:#8B6F3F;border:1px solid rgba(201,163,104,.35)}
.chip-neutral{background:#F5F6FA;color:var(--text-mid);border:1px solid var(--border-default)}
.severity-dot.critical{background:var(--critical);box-shadow:0 0 6px rgba(225,29,72,.5)}
.severity-dot.warning{background:var(--warning);box-shadow:0 0 6px rgba(217,119,6,.5)}
.severity-dot.info{background:var(--info)}

/* ---- FORM FIELDS ---- */
.field-label{color:var(--text-mid)}
.field-input,.field-select,.field-textarea{background:#FFFFFF;border:1px solid var(--border-default);color:var(--text-hi)}
.field-input:focus,.field-select:focus,.field-textarea:focus{background:#FFFFFF;border-color:var(--brand-blue-bright);box-shadow:0 0 0 3px rgba(43,62,240,.10)}
.field-input::placeholder{color:var(--text-dim)}

/* ---- LIVE VIEW — camera tiles need to stay dark for contrast ---- */
.cam-tile{background:#0F1429;border:1px solid var(--border-default);box-shadow:var(--shadow-card)}
.cam-tile-meta{color:rgba(255,255,255,.95)}
.cam-tile-loc{color:rgba(255,255,255,.65)}
.cam-tile-name{color:#FFFFFF}

/* ---- DASHBOARD-specific: keep its dedicated overrides (already light) ---- */
/* Page-level event row, pack card, etc — make light */
.event-row{background:#FFFFFF;border:1px solid var(--border-default)}
.event-row:hover{background:#F5F6FA;border-color:var(--border-strong)}
.event-type{color:var(--text-hi)}
.event-loc{color:var(--text-lo)}
.event-time{color:var(--text-mid)}
.event-time-ago{color:var(--text-dim)}
.event-thumb{background:linear-gradient(135deg,#1f2950,#0a0f25)}

.pack-card{background:#FFFFFF;border:1px solid var(--border-default);box-shadow:var(--shadow-card)}
.pack-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-pop)}
.pack-info-title{color:var(--text-hi)}
.pack-info-meta{color:var(--text-lo)}
.pack-chip{background:#F5F6FA;color:var(--text-mid);border:1px solid var(--border-default)}

/* ---- LOOP HERO (dashboard) ---- */
.loop-hero{background:#FFFFFF;border:1px solid var(--border-default);box-shadow:var(--shadow-card)}
.loop-hero-glow{background:radial-gradient(ellipse at top right,rgba(43,62,240,.06),transparent 60%)}
.loop-hero-title{color:var(--text-hi)}
.loop-hero-title em{color:#8B6F3F}
.loop-hero-sub{color:var(--text-mid)}
.loop-hero-pulse{background:var(--success-bg);color:#047857;border:1px solid rgba(5,150,105,.30)}
.loop-stage{background:#FFFFFF;border:1px solid var(--border-default)}
.loop-stage:hover{border-color:var(--border-strong)}
.loop-stage.is-active{box-shadow:0 0 0 1px var(--ls-color),0 8px 20px -8px rgba(15,20,41,.15)}
.ls-num{color:var(--text-dim)}
.ls-title{color:var(--text-lo)}
.ls-stage-name{color:var(--text-hi)}
.ls-metric{color:var(--text-hi)}
.ls-meta{color:var(--text-lo)}
.delta{color:var(--success)}
.loop-arrow{color:var(--text-dim)}
.loop-close{background:#F5F6FA;border:1px solid var(--border-default);color:var(--text-mid)}
.loop-close strong{color:var(--text-hi)}

.stage-panel{background:#FFFFFF;border:1px solid var(--border-default);box-shadow:var(--shadow-card)}
.stage-panel-head{background:#F5F6FA;border-bottom:1px solid var(--border-default)}
.stage-tab{color:var(--text-mid)}
.stage-tab:hover{color:var(--text-hi)}
.stage-tab.is-active{color:var(--text-hi);border-bottom:2px solid var(--st-color);font-weight:500}
.stage-tab .tab-num{background:#F5F6FA;color:var(--text-lo);border:1px solid var(--border-default)}
.stage-tab.is-active .tab-num{background:var(--st-color);color:#FFFFFF;border-color:var(--st-color)}
.stage-tab-action{color:var(--brand-blue)}

/* ---- AGENT CARDS ---- */
.agent-card{background:#FFFFFF;border:1px solid var(--border-default);box-shadow:var(--shadow-card);transition:all .16s ease}
.agent-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-pop);transform:translateY(-1px)}
.agent-card-icon{background:var(--brand-blue-soft);color:var(--brand-blue)}
.agent-card-icon.gold{background:rgba(201,163,104,.12);color:#8B6F3F}
.agent-card-name{color:var(--text-hi)}
.agent-card-vendor{color:var(--text-lo)}
.agent-card-desc{color:var(--text-mid)}
.agent-card-rating{color:var(--text-lo)}
.agent-card-rating svg{color:#C9A368}
.agent-card-price{color:var(--brand-blue);font-weight:600}

/* ---- BOX CARDS (Edge Boxes) ---- */
.box-card{background:#FFFFFF;border:1px solid var(--border-default);box-shadow:var(--shadow-card)}
.box-card-id{background:linear-gradient(135deg,var(--brand-blue-bright),var(--brand-blue-deep));color:#FFFFFF}
.box-card-name{color:var(--text-hi)}
.box-card-loc{color:var(--text-lo)}
.metric-cell{background:#F5F6FA;border:1px solid var(--border-default)}
.metric-row{gap:8px}
.metric-label{color:var(--text-lo)}
.metric-val{color:var(--text-hi)}

/* ---- SETTINGS ---- */
.settings-shell{background:transparent}
.settings-nav{background:#FFFFFF;border:1px solid var(--border-default);box-shadow:var(--shadow-card);border-radius:var(--r-md);padding:8px}
.settings-nav-link{color:var(--text-mid);padding:9px 12px;border-radius:6px;cursor:pointer;display:block;transition:all .12s}
.settings-nav-link:hover{background:#F5F6FA;color:var(--text-hi)}
.settings-nav-link.is-active{background:var(--brand-blue-soft);color:var(--brand-blue-deep);font-weight:500;border-left:2px solid #C9A368;padding-left:10px}
.settings-section-title{color:var(--text-hi)}
.settings-section-sub{color:var(--text-lo)}
.settings-pane{display:none}
.settings-pane.is-active{display:block;animation:fadein .25s ease}

/* ---- DRAWER ---- */
.drawer{background:#FFFFFF;border-left:1px solid var(--border-default);box-shadow:-12px 0 32px -8px rgba(15,20,41,.12)}
.drawer-overlay{background:rgba(15,20,41,.45)}
.drawer-head{background:#FFFFFF;border-bottom:1px solid var(--border-default)}
.drawer-title{color:var(--text-hi)}
.drawer-foot{background:#FFFFFF;border-top:1px solid var(--border-default)}

/* ---- PAGE-WIDE: tabs/subhead ---- */
.subhead-title{color:var(--text-hi)}
.subhead-link{color:var(--brand-blue);cursor:pointer}
.subhead-link:hover{text-decoration:underline}

/* Tabbed content panels (NEW) */
.tab-pane{display:none}
.tab-pane.is-active{display:block;animation:fadein .25s ease}

/* ---- KEBAB DROPDOWN MENU (NEW) ---- */
.kebab-wrap{position:relative;display:inline-block}
.kebab-menu{position:absolute;top:calc(100% + 4px);right:0;min-width:200px;background:#FFFFFF;border:1px solid var(--border-default);border-radius:var(--r-md);box-shadow:var(--shadow-pop);padding:6px;z-index:30;display:none}
.kebab-menu.is-open{display:block;animation:fadein .12s ease}
.kebab-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border-radius:6px;font-size:13px;color:var(--text-hi);cursor:pointer;text-align:left;background:transparent;border:none;transition:background .1s}
.kebab-item:hover{background:#F5F6FA}
.kebab-item svg{width:14px;height:14px;color:var(--text-mid)}
.kebab-item.is-danger{color:var(--critical)}
.kebab-item.is-danger:hover{background:rgba(225,29,72,.06)}
.kebab-item.is-danger svg{color:var(--critical)}
.kebab-divider{height:1px;background:var(--border-subtle);margin:4px 0}
.kebab-section-label{font-size:10px;letter-spacing:.10em;text-transform:uppercase;color:var(--text-dim);padding:8px 10px 4px;font-weight:500}

/* ---- TOAST ---- */
.toast{background:#FFFFFF;border:1px solid var(--border-default);color:var(--text-hi);box-shadow:var(--shadow-pop)}
.toast::before{background:var(--brand-blue)}

/* ---- HEATMAP / BARS ---- */
.bar-track{background:#EAEDF5}
.bar-fill{background:linear-gradient(90deg,var(--brand-blue),var(--brand-blue-bright))}
.bar-item-val{color:var(--text-mid)}
.bar-item-label{color:var(--text-mid)}
.heatmap-cell{background:#EAEDF5}
.heatmap-cell.l1{background:rgba(43,62,240,.18)}
.heatmap-cell.l2{background:rgba(43,62,240,.40)}
.heatmap-cell.l3{background:rgba(43,62,240,.65)}
.heatmap-cell.l4{background:rgba(201,163,104,.75)}
.heatmap-cell.l5{background:#C9A368}

/* ---- ANALYTICS / SITE / etc fallbacks ---- */
.metric-bar{background:#EAEDF5}

/* feedback hint banner inside drawer */
.feedback-hint{background:#F5F6FA;border:1px dashed var(--border-default);border-radius:var(--r-md);padding:10px 12px;font-size:12px;color:var(--text-mid);margin:0 0 10px}
.feedback-hint strong{color:var(--text-hi)}

/* Toggle switches keep light look */
.toggle-track{background:#EAEDF5}
.toggle-input:checked+.toggle-track{background:var(--brand-blue)}

/* Settings textarea: ensure readable */
.field-textarea{background:#FFFFFF}

/* Auth shell — keep its own decorative gradient on the brand side, but
   make form side white */
.auth-form-side{background:#FFFFFF}
.auth-title{color:var(--text-hi)}
.auth-subtitle{color:var(--text-mid)}
.field-input{background:#FFFFFF}
.sso-btn{background:#FFFFFF;border:1px solid var(--border-default);color:var(--text-hi)}
.sso-btn:hover{background:#F5F6FA}
.auth-foot{color:var(--text-mid)}
.auth-divider{color:var(--text-lo)}
.auth-divider::before,.auth-divider::after{background:var(--border-default)}
.signup-step{background:#EAEDF5}
.industry-tile,.plan-tile{background:#FFFFFF;border:1px solid var(--border-default)}
.industry-tile:hover,.plan-tile:hover{border-color:var(--border-strong)}
.industry-tile.is-selected{background:var(--brand-blue-soft);border-color:var(--brand-blue);box-shadow:0 0 0 1px var(--brand-blue),0 4px 16px -4px rgba(43,62,240,.30)}
.plan-tile.is-selected{background:rgba(201,163,104,.06);border-color:#C9A368}
.industry-name{color:var(--text-hi)}
.industry-desc{color:var(--text-lo)}
.plan-name{color:var(--text-hi)}
.plan-features{color:var(--text-lo)}
.plan-price{color:#8B6F3F}

/* Click outside support for kebab */
body.has-kebab-open{cursor:default}

/* Make sure the row's last cell positions kebab nicely */
.tbl td:last-child{position:relative;text-align:right}
