/* labs.mist.com — UI shell. Design language adapted from the Mist console,
   relabeled to labs.mist.com branding. */

/* Self-hosted Open Sans (Apache-2.0), with Mist's exact weight->file remapping:
   CSS weight 200=Light, 300=Regular, 400=Semibold, 500-700=Bold.
   Use these same numeric weights on elements to match the Mist console 1:1. */
@font-face { font-family: "OpenSans"; font-weight: 200; font-style: normal; font-display: swap; src: url("fonts/OpenSans-Light-webfont.woff?v=1") format("woff"); }
@font-face { font-family: "OpenSans"; font-weight: 300; font-style: normal; font-display: swap; src: url("fonts/OpenSans-Regular-webfont.woff?v=1") format("woff"); }
@font-face { font-family: "OpenSans"; font-weight: 400; font-style: normal; font-display: swap; src: url("fonts/OpenSans-Semibold-webfont.woff?v=1") format("woff"); }
@font-face { font-family: "OpenSans"; font-weight: 500 700; font-style: normal; font-display: swap; src: url("fonts/OpenSans-Bold-webfont.woff?v=1") format("woff"); }

:root {
  --sidebar:        #1e3d2f;   /* NetPilot dark enterprise green */
  --sidebar-hover:  #2a513e;
  --sidebar-active: #2f5944;
  --brand-green:    #01A982;   /* HPE green accent */
  --brand-green-dk: #006c52;
  --accent:         #01A982;   /* HPE green */
  --accent-dark:    #006c52;
  --green:          #5cb85c;
  --green-dark:     #4ca34c;
  --wired-blue:     #a9c7e8;
  --banner:         #fdf3c8;
  --banner-border:  #f0e0a0;
  --beta:           #f5d63d;
  --text:           #2c3e50;
  --muted:          #5b6672;   /* AA: 5.8:1 on white */
  --link:           #006c52;   /* HPE green; AA 6.4:1 on white (normal text) */
  --bg:             #f4f5f7;
  --card:           #ffffff;
  --border:         #e2e5e9;
  --tab-bg:         #eef0f2;

  --title-green:    #008c69;   /* page-title green; AA large-text on page bg (3.8:1) */
  --sidebar-w: 130px;   /* matches Mist console */
  --font: "OpenSans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

* { box-sizing: border-box; }

/* ── Accessibility: skip link + focus indicators ─────────── */
.skip-link {
  position: absolute;
  left: 8px;
  top: -48px;
  z-index: 100;
  background: #fff;
  color: var(--link);
  border: 2px solid var(--link);
  padding: 8px 14px;
  border-radius: 6px;
  font-weight: 600;
  text-decoration: none;
  transition: top .15s ease;
}
.skip-link:focus { top: 8px; }

/* Visible focus ring (WCAG 2.4.7). Blue on light surfaces. */
a:focus-visible,
button:focus-visible,
[tabindex]:focus-visible {
  outline: 2px solid var(--link);
  outline-offset: 2px;
  border-radius: 4px;
}
/* White ring on the dark green rail (3:1+ against #1e3d2f). */
.nav a:focus-visible { outline: 2px solid #fff; outline-offset: -3px; }
/* Inset ring inside the clipped segmented control. */
.segment button:focus-visible { outline: 2px solid var(--link); outline-offset: -2px; }

html, body {
  margin: 0;
  height: 100%;
  font-family: var(--font);
  font-weight: 300;          /* Mist base text is light (300) */
  color: var(--text);
  background: var(--bg);
  font-size: 14px;
}

.app { display: flex; flex-direction: column; min-height: 100vh; }
.body { display: flex; flex: 1; }

/* ── Top header bar ──────────────────────────────────────── */
.topbar {
  display: flex;
  height: 46px;
  position: sticky;
  top: 0;
  z-index: 20;
  background: #fff;
  border-bottom: 1px solid var(--border);
  box-shadow: 0 1px 3px rgba(0,0,0,.05);
}
.brand-block {
  width: var(--sidebar-w);
  flex: 0 0 var(--sidebar-w);
  background: var(--sidebar);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  padding: 0 8px;
}
.brand-block .hpe-logo { height: 19px; width: auto; display: block; }
.brand-block .labs {
  font-size: 11px; line-height: 1; letter-spacing: .6px;
  color: #fff; white-space: nowrap; text-transform: uppercase;
}
.brand-block .labs b { font-weight: 700; }
.brand-block .labs span { font-weight: 700; color: var(--brand-green); }

.topbar-main { flex: 1; display: flex; align-items: center; gap: 14px; padding: 0 16px; min-width: 0; }
.org { display: flex; align-items: center; gap: 10px; font-weight: 400; font-size: 16px; color: #0d1b16; letter-spacing: .2px; }
.org-avatar {
  width: 34px; height: 34px; border-radius: 8px; background: #1e3d2f;
  display: flex; align-items: center; justify-content: center; flex: 0 0 34px;
}
.org-avatar { color: #fff; }
.org-avatar svg { width: 22px; height: 22px; }   /* verbatim Marvis icon carries its own fill/stroke */
.tb-spacer { flex: 1; }
.lang {
  display: inline-flex; align-items: center; gap: 10px;
  border: 1px solid var(--border); background: #f6f7f8; border-radius: 5px;
  padding: 6px 12px; font-size: 13px; color: var(--text); cursor: pointer; white-space: nowrap;
  font-family: var(--font);
}
.lang .caret { color: var(--muted); }
.tb-time { font-size: 12px; color: var(--muted); letter-spacing: .5px; white-space: nowrap; }
.tb-icons { display: inline-flex; align-items: center; gap: 10px; color: #57636f; }
/* Icon-only buttons: reset chrome, give a >=24px hit target (2.2 AA target size). */
.icon-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 30px; height: 30px; padding: 0;
  border: 0; background: transparent; color: inherit; cursor: pointer; border-radius: 6px;
}
.icon-btn:hover { background: rgba(0,0,0,.06); }
.tb-icons .icon-btn { color: #57636f; }
.tb-icons svg { width: 20px; height: 20px; stroke: currentColor; fill: none; stroke-width: 1.6; }

/* ── Sidebar ─────────────────────────────────────────────── */
.sidebar {
  width: var(--sidebar-w);
  flex: 0 0 var(--sidebar-w);
  background: var(--sidebar);
  color: #c7d0e0;
  display: flex;
  flex-direction: column;
  position: sticky;
  top: 46px;
  height: calc(100vh - 46px);
  z-index: 10;
}

.brand {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 5px;
  padding: 13px 9px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.brand .hpe-logo { height: 17px; width: auto; display: block; }
.brand .word { font-size: 11px; color: #fff; letter-spacing: .1px; white-space: nowrap; }
.brand .word b { font-weight: 700; }
.brand .word span { font-weight: 300; opacity: .85; }

.nav { padding: 8px 0; overflow: visible; }

/* ── Hover/focus flyout submenus (recreated from Mist nav) ── */
.nav-item { position: relative; }
.nav .flyout {
  position: absolute;
  left: 100%;
  top: 0;
  min-width: 178px;
  background: var(--sidebar);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 6px 18px rgba(0,0,0,.35);
  padding: 4px 0;
  display: none;
  z-index: 40;
}
.nav-item:hover > .flyout,
.nav-item:focus-within > .flyout { display: block; }
.nav .flyout a {
  display: block;
  min-height: 0;
  padding: 9px 16px;
  font-size: 12px;
  font-weight: 300;
  color: rgba(255,255,255,.9);
  white-space: nowrap;
}
.nav .flyout a:hover { background: var(--sidebar-hover); color: #fff; }
.nav .flyout a.active { color: #fff; font-weight: 600; background: #15291f; box-shadow: inset 3px 0 0 var(--brand-green); }
.nav a {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 9px;
  min-height: 47px;
  color: #fff;
  text-decoration: none;
  font-size: 12px;
  font-weight: 300;
}
.nav a:hover { background: var(--sidebar-hover); }
.nav a.active {
  background: #15291f;   /* darker green band, matches Mist active state */
}
/* Each icon SVG carries its own fill/stroke (currentColor) verbatim from Mist. */
.nav a svg { width: 20px; height: 20px; flex: 0 0 20px; }
.nav .sup { font-size: 7px; vertical-align: super; opacity: .85; }

/* ── Main ────────────────────────────────────────────────── */
.main { flex: 1; min-width: 0; display: flex; flex-direction: column; }

.banner {
  background: var(--banner);
  border-bottom: 1px solid var(--banner-border);
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 22px;
  font-size: 13px;
}
.banner .warn { color: #b8860b; }
.banner .b-title { font-weight: 700; line-height: 1.25; }
.banner .b-sub { color: var(--muted); font-size: 12px; }
.banner .spacer { flex: 1; }
.banner .b-link { color: var(--text); text-decoration: none; padding: 0 12px; }
.banner .b-link:hover { color: var(--accent); }
.banner .b-sep { color: #c9bd86; }
.banner .b-close { color: var(--muted); cursor: pointer; }

.content { padding: 18px 22px 40px; }

.page-head { display: flex; align-items: center; margin-bottom: 14px; }
.page-title { font-size: 28px; font-weight: 200; color: var(--title-green); margin: 0; letter-spacing: normal; }
.page-head .tools { margin-left: auto; display: flex; gap: 8px; color: var(--muted); }
.page-head .tools svg { width: 18px; height: 18px; stroke: currentColor; fill: none; stroke-width: 1.6; }

/* sub-nav / tabs */
.subnav { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; flex-wrap: wrap; }
.segment { display: inline-flex; border: 1px solid var(--border); border-radius: 4px; overflow: hidden; background: var(--tab-bg); }
.segment button {
  border: 0; background: transparent; padding: 8px 16px; font-size: 13px;
  color: var(--text); cursor: pointer; border-right: 1px solid var(--border);
  font-family: var(--font);
}
.segment button:last-child { border-right: 0; }
.segment button:hover { background: #e3e6ea; }
.segment button.active { background: var(--link); color: #fff; }

.select {
  display: inline-flex; align-items: center; gap: 8px;
  border: 1px solid var(--border); border-radius: 4px; background: #fff;
  padding: 7px 12px; font-size: 13px; cursor: pointer; color: var(--text);
  font-family: var(--font);
}
.select .lbl { color: var(--muted); }
.select .caret { margin-left: 6px; color: var(--muted); }

.badge-beta {
  background: var(--beta); color: #5a4d00; font-weight: 700; font-size: 10px;
  letter-spacing: .5px; padding: 3px 7px; border-radius: 3px;
}
.link { color: var(--link); text-decoration: none; font-weight: 600; font-size: 13px; }
.link:hover { text-decoration: underline; }

/* ── KPI cards ───────────────────────────────────────────── */
.kpi-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 5px;
}

/* Reflow (WCAG 1.4.10): no two-axis scroll when zoomed/narrow. */
@media (max-width: 720px) {
  .kpi-row { grid-template-columns: repeat(2, 1fr); }
  .kpi:nth-child(2) { border-right: 0; }
}
@media (max-width: 460px) {
  .kpi-row { grid-template-columns: 1fr; }
  .kpi { border-right: 0; border-bottom: 1px solid var(--border); }
  .kpi:last-child { border-bottom: 0; }
}
.kpi {
  padding: 20px 22px;
  border-right: 1px solid var(--border);
}
.kpi:last-child { border-right: 0; }
.kpi .head { display: flex; align-items: baseline; gap: 10px; }
.kpi .num { font-size: 34px; font-weight: 400; line-height: 1; }
.kpi .lbl { font-size: 14px; color: var(--text); }
.kpi .bar { margin-top: 14px; height: 6px; border-radius: 3px; background: #eceef1; position: relative; }
.kpi .bar > i { display: block; height: 100%; border-radius: 3px; background: var(--green-dark); }
.kpi .bar-foot { text-align: right; font-size: 12px; color: var(--muted); margin-top: 4px; }
.kpi .lbl-sub { display: block; font-size: 14px; color: var(--text); margin-top: 6px; }

/* ── Placeholder panels ──────────────────────────────────── */
.panel {
  background: var(--card); border: 1px solid var(--border); border-radius: 5px;
  margin-top: 16px; padding: 18px 20px;
}
.panel h2 { font-size: 20px; font-weight: 400; margin: 0 0 14px; }
.placeholder {
  height: 180px; border: 1px dashed var(--border); border-radius: 4px;
  display: flex; align-items: center; justify-content: center; color: var(--muted);
  font-size: 13px; background: repeating-linear-gradient(45deg,#fafbfc,#fafbfc 10px,#f4f5f7 10px,#f4f5f7 20px);
}

/* ── Org/site selector (NetPilot methodology) ────────────── */
.orgsite { position: relative; display: flex; align-items: center; gap: 10px; }
.orgsite-info { display: flex; align-items: center; gap: 10px; }
.org-name { font-weight: 400; font-size: 16px; color: #0d1b16; letter-spacing: .2px; }
.site-trigger {
  display: inline-flex; align-items: center; gap: 7px;
  border: 1px solid var(--border); background: #f6f7f8; border-radius: 5px;
  padding: 5px 11px; font: inherit; font-size: 13px; color: var(--text); cursor: pointer;
}
.site-trigger .lbl { color: var(--muted); }
.site-trigger .caret { color: var(--muted); }
.site-pop {
  position: absolute; top: calc(100% + 6px); left: 44px; width: 250px;
  background: #fff; border: 1px solid var(--border); border-radius: 8px;
  box-shadow: 0 8px 24px rgba(13,27,22,.18); padding: 8px; z-index: 50;
}
.site-search {
  width: 100%; box-sizing: border-box; border: 1px solid var(--border);
  border-radius: 6px; padding: 7px 10px; font: inherit; font-size: 13px; margin-bottom: 6px;
}
.site-search:focus-visible { outline: 2px solid var(--link); outline-offset: 1px; }
.site-list { max-height: 260px; overflow-y: auto; display: flex; flex-direction: column; }
.site-opt {
  text-align: left; border: 0; background: transparent; padding: 8px 10px;
  font: inherit; font-size: 13px; color: var(--text); cursor: pointer; border-radius: 6px; white-space: nowrap;
}
.site-opt:hover { background: #eef4f1; }
.site-opt.active { background: #eef4f1; color: var(--brand-green-dk); font-weight: 600; }
.site-opt.all { font-style: italic; color: var(--muted); border-bottom: 1px solid var(--border); border-radius: 0; margin-bottom: 4px; padding-bottom: 9px; }
.site-empty { padding: 10px; font-size: 13px; color: var(--muted); }

/* ── User menu (the avatar / "little man") ───────────────── */
.user-menu-wrap { position: relative; display: inline-flex; }
.user-menu {
  position: absolute; top: calc(100% + 8px); right: 0; width: 224px;
  background: #fff; border: 1px solid var(--border); border-radius: 8px;
  box-shadow: 0 8px 24px rgba(13,27,22,.18); padding: 6px; z-index: 50;
}
.user-head { padding: 8px 10px 10px; border-bottom: 1px solid var(--border); margin-bottom: 4px; }
.user-name { font-weight: 600; font-size: 13px; color: var(--text); }
.user-email { font-size: 12px; color: var(--muted); }
.user-menu a { display: block; padding: 8px 10px; font-size: 13px; color: var(--text); text-decoration: none; border-radius: 6px; }
.user-menu a:hover { background: #eef4f1; color: var(--brand-green-dk); }
.user-menu a.danger { color: #b3261e; }
.user-menu a.danger:hover { background: #fdeceb; color: #9b1c15; }

/* ── Settings page ───────────────────────────────────────── */
.settings { max-width: 660px; }
.field { margin-bottom: 20px; }
.field > label { display: block; font-size: 11px; text-transform: uppercase; letter-spacing: .6px; color: var(--muted); font-weight: 600; margin-bottom: 7px; }
.field input[type="text"], .field input[type="password"], .field select {
  width: 100%; box-sizing: border-box; border: 1px solid var(--border); border-radius: 6px;
  padding: 10px 12px; font: inherit; font-size: 14px; background: #fff; color: var(--text);
}
.field input:focus-visible, .field select:focus-visible { outline: 2px solid var(--link); outline-offset: 1px; }
.field .hint { font-size: 12px; color: var(--muted); margin-top: 6px; }
.with-eye { position: relative; }
.with-eye input { padding-right: 42px; }
.eye-btn { position: absolute; right: 6px; top: 50%; transform: translateY(-50%); border: 0; background: transparent; cursor: pointer; color: var(--muted); padding: 6px; border-radius: 6px; }
.eye-btn:hover { background: rgba(0,0,0,.06); }
.toggle-row { display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.toggle-row .toggle-text strong { display: block; font-size: 14px; color: var(--text); font-weight: 600; }
.toggle-row .toggle-text span { font-size: 12px; color: var(--muted); }
.switch { position: relative; display: inline-block; width: 42px; height: 24px; flex: 0 0 42px; }
.switch input { opacity: 0; width: 0; height: 0; }
.switch .track { position: absolute; inset: 0; background: #cdd4d0; border-radius: 999px; transition: background .15s; }
.switch .track::before { content: ""; position: absolute; left: 3px; top: 3px; width: 18px; height: 18px; background: #fff; border-radius: 50%; transition: transform .15s; }
.switch input:checked + .track { background: var(--brand-green); }
.switch input:checked + .track::before { transform: translateX(18px); }
.switch input:focus-visible + .track { outline: 2px solid var(--link); outline-offset: 2px; }
.settings-actions { margin-top: 26px; display: flex; gap: 12px; align-items: center; }
.btn-primary { background: var(--brand-green); color: #fff; border: 0; border-radius: 6px; padding: 10px 20px; font: inherit; font-weight: 600; font-size: 14px; cursor: pointer; }
.btn-primary:hover { background: var(--brand-green-dk); }
.btn-ghost { background: transparent; border: 1px solid var(--border); color: var(--text); border-radius: 6px; padding: 10px 18px; font: inherit; font-size: 14px; cursor: pointer; }
.btn-ghost:hover { background: #eef4f1; }

/* ── Reusable feature components (Change Intel / Anomaly / PoE / Orchestrator) ── */
.data-table { width: 100%; border-collapse: collapse; }
.data-table th { text-align: left; font-size: 11px; font-weight: 600; color: var(--muted); text-transform: uppercase; letter-spacing: .4px; padding: 8px 10px; border-bottom: 1px solid var(--border); }
.data-table td { font-size: 13px; padding: 11px 10px; border-bottom: 1px solid var(--border); vertical-align: middle; color: var(--text); }
.data-table tr:last-child td { border-bottom: 0; }
.data-table tbody tr:hover { background: #f6f8f7; }
.data-table .mono { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 12px; color: #475569; }
.muted-cell { color: var(--muted); }

.sev { display: inline-flex; align-items: center; gap: 6px; font-size: 11px; font-weight: 600; padding: 3px 9px; border-radius: 999px; white-space: nowrap; }
.sev::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: currentColor; }
.sev-critical { color: #c0362c; background: #fdecea; }
.sev-warning  { color: #9a6b00; background: #fbf2d9; }
.sev-info     { color: #1f6fb2; background: #e7f1fb; }
.sev-ok       { color: var(--brand-green-dk); background: #e9f7f0; }
.sev-high     { color: #c0362c; background: #fdecea; }
.sev-medium   { color: #9a6b00; background: #fbf2d9; }
.sev-low      { color: var(--brand-green-dk); background: #e9f7f0; }

.hero { display: flex; align-items: center; gap: 16px; padding: 18px 20px; border: 1px solid var(--border); border-left: 4px solid var(--border); border-radius: 8px; background: var(--card); }
.hero.active { border-left-color: var(--brand-green); }
.hero .hdot { width: 12px; height: 12px; border-radius: 50%; background: #c2cbd3; flex: 0 0 12px; }
.hero.active .hdot { background: var(--brand-green); box-shadow: 0 0 0 4px rgba(1,169,130,.18); }
.hero .htitle { font-size: 18px; font-weight: 600; color: var(--text); }
.hero .hsub { font-size: 13px; color: var(--muted); margin-top: 2px; }
.hero .hmetrics { margin-left: auto; display: flex; gap: 26px; text-align: right; }
.hero .hm .v { font-size: 22px; font-weight: 400; color: var(--text); }
.hero .hm .l { font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: .4px; }
.countdown { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-variant-numeric: tabular-nums; font-weight: 600; }

.btn-sm { font: inherit; font-size: 12px; padding: 5px 11px; border-radius: 6px; border: 1px solid var(--border); background: #fff; color: var(--text); cursor: pointer; }
.btn-sm:hover { background: #eef4f1; border-color: var(--brand-green); color: var(--brand-green-dk); }
.btn-sm.danger { color: #c0362c; } .btn-sm.danger:hover { background: #fdecea; border-color: #e0a59f; color: #9b1c15; }

.timeline { position: relative; padding-left: 22px; }
.timeline::before { content: ""; position: absolute; left: 6px; top: 4px; bottom: 4px; width: 2px; background: var(--border); }
.tl-row { position: relative; padding: 0 0 18px 0; }
.tl-row::before { content: ""; position: absolute; left: -19px; top: 4px; width: 10px; height: 10px; border-radius: 50%; background: #fff; border: 2px solid var(--brand-green); }
.tl-row.bad::before { border-color: #c0362c; } .tl-row.warn::before { border-color: #9a6b00; }
.tl-time { font-size: 11px; color: var(--muted); }
.tl-title { font-size: 13px; font-weight: 600; color: var(--text); margin: 1px 0; }
.tl-desc { font-size: 12px; color: var(--muted); }

.intent-box { display: flex; gap: 10px; }
.intent-box textarea { flex: 1; min-height: 56px; resize: vertical; border: 1px solid var(--border); border-radius: 8px; padding: 12px 14px; font: inherit; font-size: 14px; color: var(--text); }
.intent-box textarea:focus-visible { outline: 2px solid var(--link); outline-offset: 1px; }
.intent-examples { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 10px; }
.op-row { display: flex; gap: 12px; align-items: flex-start; padding: 12px 0; border-bottom: 1px solid var(--border); }
.op-row:last-child { border-bottom: 0; }
.op-num { width: 24px; height: 24px; flex: 0 0 24px; border-radius: 50%; background: #eef4f1; color: var(--brand-green-dk); font-size: 12px; font-weight: 600; display: flex; align-items: center; justify-content: center; }
.op-body .op-title { font-size: 13px; font-weight: 600; color: var(--text); }
.op-body .op-detail { font-size: 12px; color: var(--muted); margin-top: 2px; }
.step-row { display: flex; align-items: center; gap: 10px; padding: 8px 0; font-size: 13px; color: var(--text); }
.step-row .sdot { width: 16px; height: 16px; border-radius: 50%; border: 2px solid var(--border); flex: 0 0 16px; }
.step-row.done .sdot { background: var(--brand-green); border-color: var(--brand-green); }
.step-row.active .sdot { border-color: var(--brand-green); border-right-color: transparent; animation: spin .8s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

.scatter { width: 100%; height: 260px; display: block; }
.scatter .axis { stroke: var(--border); stroke-width: 1; }

/* ── Dark mode (toggled via data-theme="dark" on <html>) ─────────────────── */
[data-theme="dark"] {
  --bg: #0e1713;
  --card: #17241e;
  --border: #2b3a33;
  --text: #e7eeea;
  --muted: #9aaaa2;            /* ~5:1 on --bg */
  --tab-bg: #1d2b24;
  --link: #2ec39a;            /* lighter HPE green for dark surfaces */
  --title-green: #2ec39a;
  --brand-green-dk: #34c79e;  /* accent text on dark surfaces */
}
[data-theme="dark"] .topbar { background: var(--card); border-bottom-color: var(--border); box-shadow: 0 1px 3px rgba(0,0,0,.4); }
[data-theme="dark"] .org-name { color: var(--text); }
[data-theme="dark"] .lang,
[data-theme="dark"] .select,
[data-theme="dark"] .site-trigger { background: #1d2b24; color: var(--text); border-color: var(--border); }
[data-theme="dark"] .site-pop,
[data-theme="dark"] .user-menu,
[data-theme="dark"] .cf-panel,
[data-theme="dark"] .cf-panel-head { background: var(--card); }
[data-theme="dark"] .site-search,
[data-theme="dark"] .cf-search input,
[data-theme="dark"] .field input,
[data-theme="dark"] .field select,
[data-theme="dark"] .intent-box textarea { background: #11201a; color: var(--text); border-color: var(--border); }
[data-theme="dark"] code,
[data-theme="dark"] .cf-hint code,
[data-theme="dark"] .cf-tag { background: #23332b; color: var(--muted); }
[data-theme="dark"] .kpi .bar,
[data-theme="dark"] .risk-bar,
[data-theme="dark"] .recept,
[data-theme="dark"] .wt-bar,
[data-theme="dark"] .rssi-track { background: #23332b; }
[data-theme="dark"] .segment button:hover,
[data-theme="dark"] .data-table tbody tr:hover { background: #1d2b24; }
[data-theme="dark"] .icon-btn:hover,
[data-theme="dark"] .eye-btn:hover { background: rgba(255,255,255,.08); }
[data-theme="dark"] .site-opt:hover,
[data-theme="dark"] .site-opt.active,
[data-theme="dark"] .user-menu a:hover,
[data-theme="dark"] .btn-sm:hover,
[data-theme="dark"] .btn-ghost:hover { background: #233a30; }
[data-theme="dark"] .cf-card .mono,
[data-theme="dark"] .data-table .mono,
[data-theme="dark"] .dp-field span.mono { color: #a9bcb3; }
[data-theme="dark"] .cf-card .ic,
[data-theme="dark"] .cf-panel-head .ic,
[data-theme="dark"] .op-num { background: #233a30; }
[data-theme="dark"] .dp-banner.off { background: #1d2b24; color: var(--muted); }
[data-theme="dark"] .skip-link { background: var(--card); }
[data-theme="dark"] .placeholder {
  border-color: var(--border); color: var(--muted);
  background: repeating-linear-gradient(45deg,#16231d,#16231d 10px,#13201a 10px,#13201a 20px);
}
[data-theme="dark"] .cf-card:hover { box-shadow: 0 2px 10px rgba(0,0,0,.4); }
