:root {
  --ob-bg-dark: #080d13;
  --ob-bg-light: #f4f7fb;
  --ob-panel-dark: rgba(17, 27, 38, 0.96);
  --ob-panel-light: rgba(255, 255, 255, 0.96);
  --ob-panel-2-dark: rgba(21, 34, 47, 0.96);
  --ob-panel-2-light: #eef4f8;
  --ob-text-dark: #e5edf4;
  --ob-text-light: #17212f;
  --ob-muted-dark: #94a3b8;
  --ob-muted-light: #5f6f82;
  --ob-line-dark: rgba(148, 163, 184, 0.22);
  --ob-line-light: rgba(33, 54, 74, 0.14);
  --ob-blue: #2f8fd8;
  --ob-teal: #1aa7a1;
  --ob-green: #2f9f63;
  --ob-amber: #bd7b16;
  --ob-red: #cf3f3f;
}

:root[data-theme="dark"] {
  --bg: var(--ob-bg-dark);
  --surface: #111821;
  --surface-2: #15202b;
  --surface-3: #1b2a36;
  --panel: var(--ob-panel-dark);
  --ink: var(--ob-text-dark);
  --text: var(--ob-text-dark);
  --muted: var(--ob-muted-dark);
  --subtle: #64748b;
  --line: var(--ob-line-dark);
  --line-strong: rgba(148, 163, 184, 0.34);
  --blue: #5ab7ff;
  --teal: #4fd1c5;
  --green: #8bd17c;
  --amber: #f6c667;
  --red: #f87171;
}

:root[data-theme="light"] {
  --bg: var(--ob-bg-light);
  --surface: #ffffff;
  --surface-2: #eef4f8;
  --surface-3: #e3edf3;
  --panel: var(--ob-panel-light);
  --ink: var(--ob-text-light);
  --text: var(--ob-text-light);
  --muted: var(--ob-muted-light);
  --subtle: #7b899a;
  --line: var(--ob-line-light);
  --line-strong: rgba(33, 54, 74, 0.24);
  --blue: var(--ob-blue);
  --teal: var(--ob-teal);
  --green: var(--ob-green);
  --amber: var(--ob-amber);
  --red: var(--ob-red);
}

.theme-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  border-radius: 8px;
  border: 1px solid var(--line-strong, rgba(148, 163, 184, 0.34));
  background: color-mix(in srgb, var(--surface-2, #15202b) 84%, transparent);
  color: var(--text, #e5edf4);
  padding: 7px 12px;
  font: inherit;
  font-size: 0.84rem;
  line-height: 1;
  cursor: pointer;
}

.theme-toggle:hover {
  border-color: color-mix(in srgb, var(--teal, #4fd1c5) 58%, transparent);
  background: color-mix(in srgb, var(--teal, #4fd1c5) 14%, transparent);
}

.top-nav,
.graph-nav,
.topbar,
header nav,
.nav {
  display: flex;
  align-items: center;
  gap: 8px !important;
  flex-wrap: wrap;
}

.top-nav a,
.graph-nav a,
.topbar a,
header nav a,
.nav a {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  border-radius: 8px;
  border: 1px solid var(--line-strong, rgba(148, 163, 184, 0.34));
  background: color-mix(in srgb, var(--surface-2, #15202b) 84%, transparent);
  color: var(--text, #e5edf4) !important;
  padding: 7px 11px;
  font-size: 0.84rem;
  line-height: 1;
  text-decoration: none !important;
}

.top-nav a:hover,
.graph-nav a:hover,
.topbar a:hover,
header nav a:hover,
.nav a:hover,
.top-nav a.active-nav,
.graph-nav a.active-nav,
.topbar a.active-nav,
header nav a.active-nav,
.nav a.active-nav {
  border-color: color-mix(in srgb, var(--teal, #4fd1c5) 58%, transparent);
  background: color-mix(in srgb, var(--teal, #4fd1c5) 14%, transparent);
  color: var(--text, #e5edf4) !important;
}

.app-shell,
.tab-content,
.chart-row,
.chart-row > *,
.chart-box {
  min-width: 0;
  max-width: 100%;
}

.app-shell {
  width: min(1440px, calc(100vw - 24px)) !important;
}

main {
  padding-top: 16px !important;
  padding-bottom: 30px !important;
}

header,
#header,
.header {
  padding-block: 12px !important;
}

.tabs {
  margin-bottom: 14px !important;
  padding: 6px !important;
}

.tab {
  min-height: 30px !important;
  padding: 7px 10px !important;
}

.grid,
.summary,
.loop-grid,
.model-cards,
.email-accounts,
.chart-row {
  gap: 10px !important;
  margin-bottom: 14px !important;
  align-items: start !important;
}

h2 {
  margin-top: 16px !important;
  margin-bottom: 8px !important;
}

.card,
.stat,
.item,
.source,
.loop-card,
.email-card,
.model-card,
.timeline-item,
.journal-entry,
.journal-empty,
.past-journal,
.autonomy-level,
.filter-bar,
.chart-box {
  padding: 12px !important;
}

.card,
.stat {
  min-height: 86px !important;
}

th,
td {
  padding: 7px 8px !important;
}

.empty {
  padding: 24px !important;
}

.source {
  gap: 12px !important;
}

.source .toggles,
.toggles {
  gap: 6px !important;
}

.chart-box {
  position: relative;
  overflow: hidden;
  min-height: 0 !important;
}

.chart-box canvas {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  height: 220px !important;
  max-height: 240px !important;
}

.chart-single {
  width: min(720px, 100%) !important;
}

.chart-single canvas {
  height: 250px !important;
  max-height: 270px !important;
}

.overview-memory-row {
  grid-template-columns: minmax(520px, 1.7fr) minmax(360px, 0.9fr) !important;
}

.overview-memory-row .chart-box {
  align-self: start !important;
}

.overview-memory-row .chart-box canvas {
  height: 190px !important;
  max-height: 210px !important;
}

.overview-memory-row table {
  margin-bottom: 8px !important;
}

@media (max-width: 700px) {
  body:not(.obds-app) .app-shell,
  body:not(.obds-app) main {
    width: min(100vw - 16px, 760px) !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .chart-box canvas {
    height: 190px !important;
    max-height: 210px !important;
  }
  .chart-single canvas {
    height: 210px !important;
    max-height: 230px !important;
  }
  .overview-memory-row {
    grid-template-columns: 1fr !important;
  }
  .overview-memory-row .chart-box canvas {
    height: 180px !important;
    max-height: 200px !important;
  }
}

:root[data-theme="dark"] button,
:root[data-theme="dark"] select,
:root[data-theme="dark"] input,
:root[data-theme="dark"] textarea {
  background: #101b26 !important;
  color: var(--text) !important;
  border-color: var(--line-strong) !important;
}

:root[data-theme="dark"] select {
  color-scheme: dark;
  accent-color: var(--teal);
}

:root[data-theme="dark"] select option {
  background: #101b26;
  color: var(--text);
}

:root[data-theme="dark"] select:disabled,
:root[data-theme="dark"] input:disabled,
:root[data-theme="dark"] textarea:disabled,
:root[data-theme="dark"] button:disabled {
  background: rgba(16, 27, 38, 0.58) !important;
  color: rgba(229, 237, 244, 0.62) !important;
  border-color: rgba(148, 163, 184, 0.18) !important;
}

:root[data-theme="dark"] select:focus,
:root[data-theme="dark"] input:focus,
:root[data-theme="dark"] textarea:focus {
  outline: 2px solid color-mix(in srgb, var(--blue) 72%, transparent);
  outline-offset: 1px;
}

:root[data-theme="light"] body {
  background:
    linear-gradient(180deg, rgba(223, 237, 245, 0.96) 0, rgba(244, 247, 251, 0.98) 340px),
    var(--bg) !important;
  color: var(--text) !important;
}

:root[data-theme="light"] header,
:root[data-theme="light"] #header,
:root[data-theme="light"] .header {
  background: rgba(255, 255, 255, 0.86) !important;
  color: var(--text) !important;
  border-color: var(--line) !important;
}

:root[data-theme="light"] h1,
:root[data-theme="light"] h2,
:root[data-theme="light"] h3,
:root[data-theme="light"] .title,
:root[data-theme="light"] .name,
:root[data-theme="light"] .value,
:root[data-theme="light"] .card-value {
  color: var(--text) !important;
}

:root[data-theme="light"] a {
  color: var(--blue) !important;
}

:root[data-theme="light"] .card,
:root[data-theme="light"] .stat,
:root[data-theme="light"] .item,
:root[data-theme="light"] .smartbar,
:root[data-theme="light"] .source,
:root[data-theme="light"] .chart-box,
:root[data-theme="light"] table,
:root[data-theme="light"] .loop-card,
:root[data-theme="light"] .email-card,
:root[data-theme="light"] .model-card,
:root[data-theme="light"] .timeline-item,
:root[data-theme="light"] .journal-entry,
:root[data-theme="light"] .journal-empty,
:root[data-theme="light"] .past-journal,
:root[data-theme="light"] .autonomy-level,
:root[data-theme="light"] .info-panel,
:root[data-theme="light"] .legend,
:root[data-theme="light"] #activity-feed,
:root[data-theme="light"] #tooltip,
:root[data-theme="light"] #loading-overlay,
:root[data-theme="light"] .result,
:root[data-theme="light"] .content,
:root[data-theme="light"] .empty {
  background: var(--panel) !important;
  color: var(--text) !important;
  border-color: var(--line) !important;
  box-shadow: 0 14px 34px rgba(23, 33, 47, 0.08) !important;
}

:root[data-theme="light"] thead,
:root[data-theme="light"] tbody,
:root[data-theme="light"] tr {
  background: transparent !important;
}

:root[data-theme="light"] tr:hover td {
  background: rgba(33, 54, 74, 0.045) !important;
}

:root[data-theme="light"] .tabs,
:root[data-theme="light"] .filter-bar,
:root[data-theme="light"] #controls,
:root[data-theme="light"] #breadcrumb {
  background: rgba(255, 255, 255, 0.82) !important;
  border-color: var(--line) !important;
}

:root[data-theme="light"] .tab,
:root[data-theme="light"] .meta,
:root[data-theme="light"] .sub,
:root[data-theme="light"] .label,
:root[data-theme="light"] .card-label,
:root[data-theme="light"] .desc,
:root[data-theme="light"] .metrics,
:root[data-theme="light"] .status,
:root[data-theme="light"] #stats-label {
  color: var(--muted) !important;
}

:root[data-theme="light"] .tab.active,
:root[data-theme="light"] button.primary,
:root[data-theme="light"] .primary,
:root[data-theme="light"] #controls button.active,
:root[data-theme="light"] .top-nav a.primary-link,
:root[data-theme="light"] #header a.primary-link {
  background: linear-gradient(135deg, #1aa7a1, #2f8fd8) !important;
  border-color: transparent !important;
  color: #ffffff !important;
}

:root[data-theme="light"] button.success,
:root[data-theme="dark"] button.success {
  background: linear-gradient(135deg, #15803d, #22c55e) !important;
  border-color: transparent !important;
  color: #ffffff !important;
}

:root[data-theme="light"] button,
:root[data-theme="light"] select,
:root[data-theme="light"] input,
:root[data-theme="light"] textarea,
:root[data-theme="light"] .top-nav a,
:root[data-theme="light"] #header a,
:root[data-theme="light"] nav a {
  background: rgba(255, 255, 255, 0.9) !important;
  color: var(--text) !important;
  border-color: var(--line-strong) !important;
}

:root[data-theme="light"] th {
  background: #edf4f8 !important;
  color: #405164 !important;
  border-color: var(--line) !important;
}

:root[data-theme="light"] td {
  color: var(--text) !important;
  border-color: rgba(33, 54, 74, 0.1) !important;
}

:root[data-theme="light"] td[style*="color:#555"],
:root[data-theme="light"] td[style*="color:#666"],
:root[data-theme="light"] td[style*="color:#888"],
:root[data-theme="light"] div[style*="color:#555"],
:root[data-theme="light"] div[style*="color:#666"],
:root[data-theme="light"] div[style*="color:#888"],
:root[data-theme="light"] span[style*="color:#555"],
:root[data-theme="light"] span[style*="color:#666"],
:root[data-theme="light"] span[style*="color:#888"],
:root[data-theme="light"] label[style*="color:#888"] {
  color: var(--muted) !important;
}

:root[data-theme="light"] .action-task_started,
:root[data-theme="light"] .action-insight_generated {
  color: #1d78b3 !important;
}

:root[data-theme="light"] .action-task_completed,
:root[data-theme="light"] .action-memories_archived {
  color: #187348 !important;
}

:root[data-theme="light"] .action-task_failed {
  color: #a92d2d !important;
}

:root[data-theme="light"] .action-subtasks_created,
:root[data-theme="light"] .action-scheduled_job_triggered,
:root[data-theme="light"] .action-self_improvement {
  color: #8a530b !important;
}

:root[data-theme="light"] .action-weekly_critique {
  color: #7c3ea3 !important;
}

:root[data-theme="light"] .pill {
  background: #e8f0f6 !important;
  color: #405164 !important;
}

:root[data-theme="light"] .status-completed,
:root[data-theme="light"] .status-success,
:root[data-theme="light"] .status-approved,
:root[data-theme="light"] .status-active {
  background: rgba(47, 159, 99, 0.13) !important;
  color: #187348 !important;
}

:root[data-theme="light"] .status-pending,
:root[data-theme="light"] .status-training {
  background: rgba(189, 123, 22, 0.13) !important;
  color: #8a530b !important;
}

:root[data-theme="light"] .status-failed,
:root[data-theme="light"] .status-rejected {
  background: rgba(207, 63, 63, 0.13) !important;
  color: #a92d2d !important;
}

:root[data-theme="light"] .status-in_progress,
:root[data-theme="light"] .status-validating {
  background: rgba(47, 143, 216, 0.13) !important;
  color: #1d78b3 !important;
}

:root[data-theme="light"] .status-cancelled,
:root[data-theme="light"] .status-retired,
:root[data-theme="light"] .status-expired {
  background: rgba(95, 111, 130, 0.14) !important;
  color: #405164 !important;
}

:root[data-theme="light"] .ok,
:root[data-theme="light"] .pill.ok,
:root[data-theme="light"] .direct {
  background: rgba(47, 159, 99, 0.12) !important;
  color: #187348 !important;
}

:root[data-theme="light"] .warn,
:root[data-theme="light"] .pill.warn,
:root[data-theme="light"] .warn-pill,
:root[data-theme="light"] .inbox {
  background: rgba(189, 123, 22, 0.13) !important;
  color: #8a530b !important;
}

:root[data-theme="light"] .bad,
:root[data-theme="light"] .pill.bad,
:root[data-theme="light"] .danger,
:root[data-theme="light"] .off {
  background: rgba(207, 63, 63, 0.12) !important;
  color: #a92d2d !important;
}

:root[data-theme="light"] #graph-container canvas {
  filter: saturate(0.9) contrast(0.96);
}

body.ob-shell-mounted {
  margin: 0 !important;
}

.ob-app-shell,
.ob-app-shell * {
  box-sizing: border-box;
}

.ob-app-shell {
  position: sticky !important;
  top: 0;
  z-index: 1000;
  display: grid !important;
  gap: 10px;
  width: 100%;
  padding: 14px clamp(16px, 3vw, 30px) 12px !important;
  border-bottom: 1px solid var(--line, rgba(148, 163, 184, 0.22)) !important;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--surface, #111821) 94%, transparent), color-mix(in srgb, var(--surface-2, #15202b) 90%, transparent)) !important;
  color: var(--text, #e5edf4) !important;
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.22) !important;
  backdrop-filter: blur(18px);
}

.ob-shell-top {
  display: grid;
  grid-template-columns: minmax(190px, 0.7fr) minmax(260px, 1.1fr) auto;
  gap: 16px;
  align-items: center;
}

.ob-brand {
  display: inline-grid !important;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 11px;
  align-items: center;
  color: var(--text, #e5edf4) !important;
  text-decoration: none !important;
  min-width: 0;
}

.ob-brand-mark {
  width: 42px;
  height: 42px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, var(--teal, #4fd1c5), var(--blue, #5ab7ff));
  color: #061019;
  font-weight: 900;
  letter-spacing: 0;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.22);
}

.ob-brand-copy,
.ob-page-title {
  min-width: 0;
}

.ob-brand-name {
  display: block;
  color: var(--text, #e5edf4);
  font-size: 1rem;
  font-weight: 850;
  line-height: 1.1;
}

.ob-brand-sub {
  display: block;
  margin-top: 3px;
  color: var(--muted, #94a3b8);
  font-size: 0.78rem;
  line-height: 1.2;
}

.ob-breadcrumb {
  display: flex;
  gap: 7px;
  align-items: center;
  color: var(--muted, #94a3b8);
  font-size: 0.74rem;
  line-height: 1;
  margin-bottom: 5px;
}

.ob-breadcrumb a {
  color: var(--teal, #4fd1c5) !important;
  text-decoration: none !important;
}

.ob-page-title h1 {
  margin: 0 !important;
  color: var(--text, #e5edf4) !important;
  font-size: clamp(1.28rem, 2vw, 1.8rem) !important;
  line-height: 1.08 !important;
  letter-spacing: 0 !important;
}

.ob-page-title p {
  margin: 5px 0 0 !important;
  color: var(--muted, #94a3b8) !important;
  font-size: 0.84rem !important;
  line-height: 1.35 !important;
}

.ob-shell-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  min-width: 0;
}

.ob-shell-status {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  max-width: min(420px, 42vw);
  padding: 7px 10px;
  border: 1px solid var(--line, rgba(148, 163, 184, 0.22));
  border-radius: 8px;
  background: color-mix(in srgb, var(--surface-2, #15202b) 72%, transparent);
  color: var(--muted, #94a3b8) !important;
  font-size: 0.78rem !important;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ob-primary-nav {
  display: flex !important;
  align-items: center;
  gap: 7px !important;
  flex-wrap: wrap;
}

.ob-primary-nav .ob-nav-link {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  border-radius: 8px;
  border: 1px solid transparent !important;
  background: transparent !important;
  color: var(--muted, #94a3b8) !important;
  padding: 7px 10px;
  font-size: 0.84rem;
  font-weight: 650;
  line-height: 1;
  text-decoration: none !important;
}

.ob-primary-nav .ob-nav-link:hover,
.ob-primary-nav .ob-nav-link.active {
  border-color: color-mix(in srgb, var(--teal, #4fd1c5) 52%, transparent) !important;
  background: color-mix(in srgb, var(--teal, #4fd1c5) 12%, transparent) !important;
  color: var(--text, #e5edf4) !important;
}

.ob-theme-toggle {
  white-space: nowrap;
}

.ob-install-button[hidden] {
  display: none !important;
}

.ob-install-button {
  border-color: color-mix(in srgb, var(--teal, #4fd1c5) 45%, var(--line-strong, rgba(148, 163, 184, 0.34))) !important;
}

.ob-legacy-page-header {
  display: none !important;
}

body.ob-shell-mounted > main,
body.ob-shell-mounted > .app-shell,
body.ob-shell-mounted > .shell {
  margin-top: 0 !important;
}

body.ob-page-audit {
  padding: 0 !important;
}

body.ob-page-audit > .summary,
body.ob-page-audit > .filters,
body.ob-page-audit > .timeline,
body.ob-page-audit > .load-more,
body.ob-page-audit > .empty {
  width: min(1320px, calc(100% - 44px));
  margin-left: auto;
  margin-right: auto;
}

body.ob-page-audit > .summary,
body.ob-page-audit > .filters {
  margin-top: 18px;
}

body.ob-page-graph #graph-container {
  height: calc(100vh - 132px) !important;
}

body.ob-page-graph #controls {
  top: auto !important;
}

body.ob-page-graph #graph-insights,
body.ob-page-graph .info-panel,
body.ob-page-graph #activity-feed {
  top: 236px !important;
}

body.ob-page-audit .summary {
  align-items: stretch !important;
}

body.ob-page-audit .summary-box {
  position: relative;
  min-height: 88px;
  display: grid;
  align-content: center;
  gap: 5px;
  overflow: hidden;
  border: 1px solid var(--line, rgba(148, 163, 184, 0.22));
  border-radius: 8px !important;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--surface-2, #15202b) 92%, transparent), color-mix(in srgb, var(--surface, #111821) 96%, transparent)) !important;
  color: var(--text, #e5edf4) !important;
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.16);
}

body.ob-page-audit .summary-box::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 5px;
  background: var(--audit-accent, var(--teal, #4fd1c5));
}

body.ob-page-audit .summary-box:nth-child(1) { --audit-accent: var(--blue, #5ab7ff); }
body.ob-page-audit .summary-box:nth-child(2) { --audit-accent: var(--teal, #4fd1c5); }
body.ob-page-audit .summary-box:nth-child(3) { --audit-accent: var(--green, #8bd17c); }
body.ob-page-audit .summary-box:nth-child(4) { --audit-accent: var(--amber, #f6c667); }

body.ob-page-audit .summary-value {
  color: var(--text, #e5edf4) !important;
  font-size: clamp(1.35rem, 2vw, 1.85rem) !important;
  line-height: 1 !important;
}

body.ob-page-audit .summary-label {
  color: var(--muted, #94a3b8) !important;
  font-weight: 750;
  letter-spacing: 0.08em;
}

body.ob-page-audit .filters {
  align-items: end !important;
  padding: 12px;
  border: 1px solid var(--line, rgba(148, 163, 184, 0.22));
  border-radius: 8px;
  background: color-mix(in srgb, var(--panel, rgba(17, 27, 38, 0.96)) 82%, transparent);
}

body.ob-page-device main > section.grid {
  align-items: stretch !important;
}

body.ob-page-device main > section.grid > .panel {
  height: 100%;
  display: flex;
  flex-direction: column;
}

body.ob-page-device main > section.grid > .panel .code {
  margin-top: auto;
}

body.ob-page-device .panel {
  position: relative;
  overflow: hidden;
}

body.ob-page-device .panel::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 3px;
  background: linear-gradient(90deg, var(--teal, #4fd1c5), var(--blue, #5ab7ff));
  opacity: 0.72;
}

body.ob-page-device .deploy-grid {
  align-items: stretch !important;
}

body.ob-page-device .deploy-grid > article {
  min-height: 238px;
  padding: 12px;
  border: 1px solid var(--line, rgba(148, 163, 184, 0.22));
  border-radius: 8px;
  background: color-mix(in srgb, var(--surface-2, #15202b) 72%, transparent);
}

body.ob-page-device ol,
body.ob-page-device ul {
  color: var(--muted, #94a3b8) !important;
}

body.ob-page-device li {
  margin-bottom: 4px;
}

:root[data-theme="light"] body.ob-page-audit .summary-box {
  background:
    linear-gradient(135deg, #ffffff, #f5f9fc) !important;
  border-color: var(--line, rgba(33, 54, 74, 0.14)) !important;
  box-shadow: 0 14px 34px rgba(23, 33, 47, 0.08) !important;
}

:root[data-theme="light"] body.ob-page-audit .summary-value {
  color: var(--text, #17212f) !important;
}

:root[data-theme="light"] body.ob-page-audit .summary-label {
  color: #52657b !important;
}

:root[data-theme="light"] body.ob-page-audit .filters {
  background: rgba(255, 255, 255, 0.78) !important;
}

:root[data-theme="light"] body.ob-page-device .deploy-grid > article {
  background: #f8fbfd !important;
  border-color: var(--line, rgba(33, 54, 74, 0.14)) !important;
}

:root[data-theme="light"] body.ob-page-device ol,
:root[data-theme="light"] body.ob-page-device ul {
  color: #4d5f74 !important;
}

:root[data-theme="light"] body.ob-page-device li::marker {
  color: #8190a3;
}

:root[data-theme="light"] .ob-app-shell {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(241, 247, 251, 0.94)) !important;
  color: var(--text) !important;
  box-shadow: 0 16px 38px rgba(23, 33, 47, 0.10) !important;
}

:root[data-theme="light"] .ob-brand,
:root[data-theme="light"] .ob-brand-name,
:root[data-theme="light"] .ob-page-title h1 {
  color: var(--text) !important;
}

@media (max-width: 980px) {
  .ob-app-shell {
    position: relative !important;
  }

  .ob-shell-top {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .ob-shell-actions {
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  .ob-shell-status {
    max-width: 100%;
  }

  .ob-primary-nav .ob-nav-link {
    flex: 1 1 calc(50% - 8px);
  }

  body.ob-page-graph #graph-container {
    height: calc(100vh - 230px) !important;
    min-height: 520px;
  }

  body.ob-page-graph #graph-insights,
  body.ob-page-graph .info-panel,
  body.ob-page-graph #activity-feed {
    top: auto !important;
  }
}

@media (max-width: 760px) {
  html {
    -webkit-text-size-adjust: 100%;
  }

  body.ob-shell-mounted {
    min-width: 0 !important;
    overflow-x: hidden;
  }

  .ob-app-shell {
    position: sticky !important;
    top: 0;
    gap: 8px;
    padding:
      calc(env(safe-area-inset-top, 0px) + 10px)
      max(10px, env(safe-area-inset-right, 0px))
      9px
      max(10px, env(safe-area-inset-left, 0px)) !important;
  }

  .ob-shell-top {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 9px;
  }

  .ob-brand {
    grid-template-columns: 36px minmax(0, 1fr);
    gap: 9px;
  }

  .ob-brand-mark {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    font-size: 0.78rem;
  }

  .ob-brand-name {
    font-size: 0.92rem;
  }

  .ob-brand-sub,
  .ob-breadcrumb,
  .ob-page-title p {
    display: none !important;
  }

  .ob-page-title {
    grid-column: 1 / -1;
    order: 3;
  }

  .ob-page-title h1 {
    font-size: 1.18rem !important;
    line-height: 1.1 !important;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .ob-shell-actions {
    align-self: start;
    gap: 6px;
    justify-content: flex-end;
  }

  .theme-toggle,
  .ob-theme-toggle,
  .ob-install-button {
    min-height: 32px;
    padding: 7px 9px;
    font-size: 0.78rem;
  }

  .ob-primary-nav {
    flex-wrap: nowrap !important;
    gap: 6px !important;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 1px 0 3px;
    scroll-snap-type: x proximity;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }

  .ob-primary-nav::-webkit-scrollbar {
    display: none;
  }

  .ob-primary-nav .ob-nav-link {
    flex: 0 0 auto;
    min-height: 32px;
    min-width: max-content;
    padding: 7px 10px;
    font-size: 0.78rem;
    scroll-snap-align: start;
  }

  /*
   * Legacy responsive clamp — applies ONLY to pages still using the old
   * shell (body.ob-shell-mounted via theme.js or pages without obds-app).
   * The bare `main`/`.app-shell`/`.shell` selectors used to be unqualified
   * and were squeezing the new design-system canvas (<main class="obds-canvas-body">)
   * down to 760px wide on narrow viewports — see fix 2026-05-04.
   */
  body.ob-shell-mounted > main,
  body.ob-shell-mounted > .app-shell,
  body.ob-shell-mounted > .shell,
  body:not(.obds-app) main,
  body:not(.obds-app) .app-shell,
  body:not(.obds-app) .shell {
    width: min(100vw - 20px, 760px) !important;
    max-width: calc(100vw - 20px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .grid,
  .summary,
  .loop-grid,
  .model-cards,
  .email-accounts,
  .chart-row,
  .cards,
  .deploy-grid {
    grid-template-columns: 1fr !important;
  }

  .card,
  .stat,
  .item,
  .source,
  .loop-card,
  .email-card,
  .model-card,
  .timeline-item,
  .journal-entry,
  .journal-empty,
  .past-journal,
  .autonomy-level,
  .filter-bar,
  .chart-box,
  .panel {
    border-radius: 8px !important;
    padding: 11px !important;
  }

  table {
    display: block;
    max-width: 100%;
    overflow-x: auto;
    white-space: nowrap;
  }

  input,
  select,
  textarea,
  button {
    max-width: 100%;
  }

  textarea {
    min-height: 96px;
  }

  body.ob-page-graph #graph-container {
    height: calc(100vh - 178px) !important;
    min-height: 460px;
  }
}

@media (display-mode: standalone) {
  .ob-app-shell {
    padding-top: calc(env(safe-area-inset-top, 0px) + 12px) !important;
  }

  .ob-install-button {
    display: none !important;
  }
}
