:root {
  color-scheme: light;
  --bg: #f6f8fb;
  --surface: #ffffff;
  --surface-soft: #f8fafc;
  --surface-strong: #eef2f6;
  --glass: rgba(255, 255, 255, 0.72);
  --glass-strong: rgba(255, 255, 255, 0.9);
  --glass-soft: rgba(255, 255, 255, 0.58);
  --text: #0f172a;
  --muted: #64748b;
  --line: rgba(148, 163, 184, 0.28);
  --line-strong: rgba(100, 116, 139, 0.34);
  --teal: #0f8b8d;
  --teal-strong: #0f766e;
  --blue: #2563eb;
  --amber: #b7791f;
  --coral: #d15b4f;
  --slate: #64748b;
  --violet: #7c3aed;
  --success: #0f766e;
  --warning: #b7791f;
  --ink: #111827;
  --blur: 24px;
  --radius-lg: 28px;
  --radius-md: 20px;
  --radius-sm: 14px;
  --shadow-sm: 0 10px 30px rgba(25, 39, 62, 0.08);
  --shadow-md: 0 24px 64px rgba(25, 39, 62, 0.13);
  --shadow-lg: 0 36px 110px rgba(25, 39, 62, 0.17);
}

:root[data-theme="dark"] {
  color-scheme: dark;
  --bg: #0d1117;
  --surface: #151b23;
  --surface-soft: #1b2430;
  --surface-strong: #233041;
  --glass: rgba(21, 27, 35, 0.68);
  --glass-strong: rgba(23, 31, 42, 0.84);
  --glass-soft: rgba(27, 36, 48, 0.52);
  --text: #eef3f8;
  --muted: #a5b2c0;
  --line: rgba(146, 166, 190, 0.22);
  --line-strong: rgba(159, 178, 201, 0.34);
  --teal: #5cc8bb;
  --teal-strong: #8ee6dc;
  --blue: #8cbdf0;
  --amber: #e2b75f;
  --coral: #ee927d;
  --slate: #c5d0de;
  --violet: #b8a9ff;
  --success: #5cc8bb;
  --warning: #e2b75f;
  --ink: #f7fbff;
  --blur: 26px;
  --radius-lg: 28px;
  --radius-md: 20px;
  --radius-sm: 14px;
  --shadow-sm: 0 10px 26px rgba(0, 0, 0, 0.26);
  --shadow-md: 0 22px 60px rgba(0, 0, 0, 0.34);
  --shadow-lg: 0 34px 100px rgba(0, 0, 0, 0.42);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 112px;
  overflow-x: hidden;
}

body {
  margin: 0;
  min-height: 100vh;
  max-width: 100%;
  overflow-x: hidden;
  background:
    linear-gradient(180deg, #f8fafc 0%, #f2f5f9 46%, #eef3f7 100%),
    var(--bg);
  background-attachment: fixed;
  color: var(--text);
  font-family:
    Inter, "Segoe UI", "Microsoft YaHei", "PingFang SC", Arial, sans-serif;
  line-height: 1.5;
}

body::before {
  position: fixed;
  inset: 0;
  pointer-events: none;
  content: "";
  background-image:
    linear-gradient(rgba(17, 24, 39, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(17, 24, 39, 0.04) 1px, transparent 1px);
  background-size: 32px 32px;
  mask-image: linear-gradient(to bottom, black, transparent 78%);
}

:root[data-theme="dark"] body::before {
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.035) 1px, transparent 1px);
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input {
  font: inherit;
}

button {
  cursor: pointer;
}

button:disabled {
  cursor: not-allowed;
}

:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--teal) 45%, transparent);
  outline-offset: 3px;
}

.app-shell {
  position: relative;
  width: min(100% - 32px, 1540px);
  max-width: 100%;
  min-width: 0;
  margin: 16px auto;
  display: grid;
  grid-template-columns: 284px minmax(0, 1fr);
  min-height: calc(100vh - 32px);
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--line-strong) 74%, transparent);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--glass-strong) 92%, transparent), color-mix(in srgb, var(--glass-soft) 72%, transparent)),
    var(--surface);
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(var(--blur));
}

.desktop-chrome {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 6;
  height: 48px;
  border-bottom: 1px solid var(--line);
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
  padding: 0 18px;
  background: color-mix(in srgb, var(--glass-strong) 84%, transparent);
  -webkit-backdrop-filter: blur(var(--blur)) saturate(150%);
  backdrop-filter: blur(var(--blur));
}

.desktop-chrome strong {
  min-width: 0;
  font-size: 13px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.desktop-chrome em {
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
}

.desktop-chrome .window-dots {
  width: 52px;
  justify-content: flex-start;
}

.sidebar {
  position: sticky;
  top: 16px;
  min-width: 0;
  height: calc(100vh - 32px);
  padding: 72px 20px 22px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--glass-strong) 88%, transparent), color-mix(in srgb, var(--glass-soft) 72%, transparent)),
    var(--glass);
  border-right: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  gap: 24px;
  box-shadow: 12px 0 38px rgba(17, 24, 39, 0.06);
  -webkit-backdrop-filter: blur(var(--blur)) saturate(145%);
  backdrop-filter: blur(var(--blur));
  z-index: 4;
}

.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.brand-mark {
  position: relative;
  width: 48px;
  height: 48px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  background:
    linear-gradient(135deg, var(--ink), color-mix(in srgb, var(--ink) 72%, var(--teal))),
    var(--ink);
  color: #ffffff;
  font-weight: 900;
  box-shadow: var(--shadow-sm);
}

.brand-mark::after {
  position: absolute;
  right: -3px;
  bottom: -3px;
  width: 13px;
  height: 13px;
  border: 2px solid var(--surface);
  border-radius: 50%;
  background: var(--success);
  content: "";
}

.brand strong,
.brand small {
  display: block;
  overflow-wrap: anywhere;
}

.brand strong {
  font-size: 17px;
}

.brand small {
  margin-top: 2px;
  color: var(--muted);
}

.side-nav {
  display: grid;
  gap: 16px;
}

.nav-group {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.nav-group-external {
  border-top: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  padding-top: 14px;
}

.side-nav a {
  min-width: 0;
  min-height: 44px;
  border-radius: 16px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 12px;
  color: var(--muted);
  border: 1px solid transparent;
  line-height: 1.1;
  transition:
    background 160ms ease,
    border-color 160ms ease,
    color 160ms ease,
    transform 160ms ease;
}

.nav-label {
  min-width: 0;
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.nav-label-short {
  display: none;
}

.nav-status-dot {
  flex: 0 0 auto;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--muted);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--muted) 12%, transparent);
}

.nav-status-dot.online,
.nav-status-dot.protected {
  background: var(--teal);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--teal) 15%, transparent);
}

.nav-status-dot.degraded,
.nav-status-dot.planned {
  background: var(--amber);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--amber) 15%, transparent);
}

.nav-status-dot.down {
  background: var(--coral);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--coral) 15%, transparent);
}

.nav-badge {
  flex: 0 0 auto;
  min-width: 34px;
  min-height: 20px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 7px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-soft) 88%, transparent);
  border: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
}

.nav-badge.protected {
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 11%, var(--surface));
  border-color: color-mix(in srgb, var(--teal) 22%, var(--line));
}

.nav-count-badge {
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 10%, var(--surface));
  border-color: color-mix(in srgb, var(--teal) 22%, var(--line));
}

.side-nav a:hover,
.side-nav a.active {
  color: var(--text);
  background: color-mix(in srgb, var(--surface) 78%, transparent);
  border-color: color-mix(in srgb, var(--line) 72%, transparent);
  transform: translateX(2px);
  box-shadow: var(--shadow-sm);
}

.side-nav a.active {
  box-shadow:
    inset 3px 0 0 var(--teal),
    var(--shadow-sm);
}

.toolbox-sidebar {
  gap: 18px;
}

.toolbox-sidebar .brand {
  align-items: flex-start;
}

.sidebar-home {
  min-height: 66px;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  color: var(--text);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 94%, transparent), color-mix(in srgb, var(--surface-soft) 72%, transparent)),
    var(--surface);
  box-shadow: var(--shadow-sm);
  transition:
    transform 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease;
}

.sidebar-home:hover {
  transform: translateY(-1px);
  border-color: var(--teal);
  box-shadow: var(--shadow-md);
}

.sidebar-home svg {
  width: 34px;
  height: 34px;
  border-radius: 8px;
  padding: 8px;
  color: var(--teal);
  background: color-mix(in srgb, var(--teal) 13%, transparent);
  flex: 0 0 auto;
}

.sidebar-home strong,
.sidebar-home small {
  display: block;
}

.sidebar-home small {
  margin-top: 2px;
  color: var(--muted);
  font-size: 12px;
}

.nav-section-label {
  margin: 0 8px -2px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.toolbox-sidebar .side-nav {
  border-left: 1px solid var(--line);
  padding-left: 10px;
}

.toolbox-sidebar .side-nav a {
  position: relative;
  min-height: 40px;
  padding: 0 10px;
}

.toolbox-sidebar .side-nav a::before {
  position: absolute;
  left: -14px;
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: var(--line-strong);
  content: "";
}

.toolbox-sidebar .side-nav a.active::before,
.toolbox-sidebar .side-nav a:hover::before {
  background: var(--teal);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--teal) 13%, transparent);
}

.toolbox-sidebar .side-nav a.active {
  box-shadow: none;
}

.toolbox-sidebar .domain-box {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 14px;
  background: color-mix(in srgb, var(--surface-soft) 70%, transparent);
}

.sidebar-note {
  margin: 10px 0 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.55;
}

.domain-box {
  margin-top: auto;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: 14px;
  background: color-mix(in srgb, var(--surface) 68%, transparent);
  box-shadow: var(--shadow-sm);
}

.rail-status {
  min-height: 34px;
  margin-top: 10px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 0 10px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-soft) 82%, transparent);
  font-size: 13px;
}

.pulse-dot {
  position: relative;
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: var(--success);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--success) 14%, transparent);
}

.copy-line {
  width: 100%;
  min-width: 0;
  margin-top: 8px;
  min-height: 44px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 88%, transparent);
  color: var(--text);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 0 12px;
  transition:
    border-color 160ms ease,
    box-shadow 160ms ease,
    transform 160ms ease;
}

.copy-line span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.copy-line:hover {
  border-color: var(--teal);
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
}

.workspace {
  position: relative;
  width: min(100%, 1256px);
  min-width: 0;
  margin: 0 auto;
  padding: 78px 30px 30px;
}

.topbar,
.section-heading,
.hero-actions,
.hero-status-row,
.top-actions,
.control-strip,
.segments,
.status-list div {
  display: flex;
  align-items: center;
}

.topbar {
  position: sticky;
  top: 48px;
  z-index: 3;
  justify-content: space-between;
  gap: 20px;
  margin: -78px -30px 24px;
  padding: 64px 30px 16px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--glass-strong) 92%, transparent), color-mix(in srgb, var(--glass) 62%, transparent));
  -webkit-backdrop-filter: blur(var(--blur)) saturate(150%);
  backdrop-filter: blur(var(--blur));
  border-bottom: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
}

.topbar h1,
.section-heading h2,
.hero-copy h2,
.note-panel h2 {
  margin: 0;
  line-height: 1.15;
  letter-spacing: 0;
}

.topbar h1 {
  font-size: 30px;
  white-space: nowrap;
}

.top-actions {
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.global-search {
  position: relative;
  width: min(440px, 36vw);
  min-width: 280px;
  height: 44px;
  border: 1px solid var(--line);
  border-radius: 16px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 12px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface) 82%, transparent);
  -webkit-backdrop-filter: blur(18px) saturate(145%);
  backdrop-filter: blur(18px) saturate(145%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.34);
}

.global-search:focus-within {
  border-color: color-mix(in srgb, var(--teal) 56%, var(--line));
  box-shadow:
    0 12px 30px color-mix(in srgb, var(--teal) 12%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.34);
}

.global-search input {
  width: 100%;
  min-width: 0;
  border: 0;
  outline: 0;
  color: var(--text);
  background: transparent;
}

.global-search kbd {
  flex: 0 0 auto;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 3px 6px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-soft) 82%, transparent);
  font-family: inherit;
  font-size: 11px;
}

.global-search-results {
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  right: 0;
  z-index: 12;
  max-height: min(520px, calc(100vh - 160px));
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 8px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--glass-strong) 96%, transparent), color-mix(in srgb, var(--glass) 90%, transparent)),
    var(--surface);
  box-shadow: var(--shadow-lg);
  -webkit-backdrop-filter: blur(22px) saturate(150%);
  backdrop-filter: blur(22px) saturate(150%);
  overflow: auto;
}

.global-search-results[hidden] {
  display: none;
}

.global-search-result {
  width: 100%;
  min-height: 58px;
  border: 1px solid transparent;
  border-radius: 13px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 9px 10px;
  color: var(--text);
  background: transparent;
  text-align: left;
}

.global-search-result:hover,
.global-search-result:focus-visible,
.global-search-result.is-active {
  border-color: color-mix(in srgb, var(--teal) 32%, var(--line));
  background: color-mix(in srgb, var(--teal) 8%, transparent);
}

.global-search-result svg {
  color: var(--teal);
}

.global-search-result strong,
.global-search-result small {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.global-search-result small {
  margin-top: 3px;
  color: var(--muted);
  font-size: 12px;
}

.global-search-result em {
  border-radius: 999px;
  padding: 4px 7px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-soft) 86%, transparent);
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
  white-space: nowrap;
}

.global-search-result.is-active em {
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 14%, var(--surface));
}

.global-search-empty {
  padding: 16px;
  color: var(--muted);
  text-align: center;
}

.icon-button,
.primary-action,
.secondary-action {
  min-height: 42px;
  border-radius: 14px;
  border: 1px solid var(--line);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 0 14px;
  color: var(--text);
  background: color-mix(in srgb, var(--surface) 82%, transparent);
  -webkit-backdrop-filter: blur(16px) saturate(145%);
  backdrop-filter: blur(16px);
  transition:
    transform 160ms ease,
    box-shadow 160ms ease,
    border-color 160ms ease,
    background 160ms ease;
}

.icon-button {
  width: 42px;
  padding: 0;
}

.primary-action {
  border-color: var(--teal);
  background:
    linear-gradient(135deg, var(--teal), color-mix(in srgb, var(--blue) 34%, var(--teal))),
    var(--teal);
  color: #ffffff;
  font-weight: 800;
  box-shadow: 0 12px 24px color-mix(in srgb, var(--teal) 24%, transparent);
}

.secondary-action:hover,
.icon-button:hover,
.copy-line:hover,
.primary-action:hover {
  transform: translateY(-1px);
}

.secondary-action:hover,
.icon-button:hover {
  border-color: var(--teal);
  box-shadow: var(--shadow-sm);
}

.secondary-action.compact {
  min-height: 38px;
}

.hero-panel {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
  gap: 28px;
  align-items: stretch;
  margin-bottom: 16px;
  padding: 30px;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--teal) 16%, transparent), transparent 38%),
    linear-gradient(220deg, color-mix(in srgb, var(--blue) 13%, transparent), transparent 46%),
    linear-gradient(0deg, color-mix(in srgb, var(--amber) 9%, transparent), transparent 62%),
    color-mix(in srgb, var(--glass-strong) 84%, transparent);
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(var(--blur));
  overflow: hidden;
}

.hero-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
}

.hero-copy h2 {
  max-width: 820px;
  font-size: clamp(38px, 4.2vw, 60px);
  line-height: 1.15;
  letter-spacing: 0;
}

.hero-copy p {
  max-width: 680px;
  margin: 16px 0 0;
  color: var(--muted);
  font-size: 17px;
}

.console-overview {
  grid-template-columns: minmax(0, 1.08fr) minmax(340px, 0.92fr);
  gap: 20px;
  padding: 24px;
}

.console-main {
  justify-content: flex-start;
}

.console-main h2 {
  max-width: 760px;
  font-size: clamp(34px, 3.4vw, 48px);
}

.console-main > p {
  max-width: 780px;
}

.console-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: 24px;
}

.console-summary-card {
  --tone: var(--teal);
  min-height: 104px;
  border: 1px solid color-mix(in srgb, var(--tone) 28%, var(--line));
  border-radius: 18px;
  padding: 14px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--tone) 10%, transparent), transparent 68%),
    color-mix(in srgb, var(--surface) 82%, transparent);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.32);
}

.console-summary-card.tone-teal {
  --tone: var(--teal);
}

.console-summary-card.tone-blue {
  --tone: var(--blue);
}

.console-summary-card.tone-coral {
  --tone: var(--coral);
}

.console-summary-card.tone-amber {
  --tone: var(--amber);
}

.console-summary-card span,
.console-summary-card strong,
.console-summary-card small {
  display: block;
  overflow-wrap: anywhere;
}

.console-summary-card span {
  color: var(--muted);
  font-size: 13px;
}

.console-summary-card strong {
  margin-top: 8px;
  font-size: 24px;
  line-height: 1.1;
}

.console-summary-card small {
  margin-top: 6px;
  color: var(--muted);
  font-size: 12px;
}

.console-rail {
  min-width: 0;
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  gap: 14px;
}

.console-map {
  min-height: 0;
}

.console-map .hero-map {
  min-height: 210px;
  padding: 14px;
}

.console-card {
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 16px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--glass-strong) 84%, transparent), color-mix(in srgb, var(--glass) 72%, transparent)),
    var(--surface);
  box-shadow:
    var(--shadow-sm),
    inset 0 1px 0 rgba(255, 255, 255, 0.32);
  -webkit-backdrop-filter: blur(18px) saturate(145%);
  backdrop-filter: blur(18px) saturate(145%);
}

.console-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}

.console-card h3 {
  margin: 0;
  font-size: 18px;
  line-height: 1.2;
}

.console-checklist {
  display: grid;
  gap: 9px;
  margin-top: 14px;
}

.console-checklist span {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 10px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface) 72%, transparent);
  font-size: 13px;
  overflow-wrap: anywhere;
}

.console-checklist svg {
  flex: 0 0 auto;
  color: var(--teal);
}

.page-hero {
  min-height: 196px;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 24px 30px;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--teal) 12%, transparent), transparent 42%),
    linear-gradient(220deg, color-mix(in srgb, var(--blue) 10%, transparent), transparent 52%),
    color-mix(in srgb, var(--glass-strong) 84%, transparent);
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(var(--blur));
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.page-hero h2 {
  max-width: 820px;
  margin: 0;
  font-size: clamp(30px, 3vw, 44px);
  line-height: 1.14;
  letter-spacing: 0;
}

.page-hero p {
  max-width: 760px;
  margin: 14px 0 0;
  color: var(--muted);
  font-size: 16px;
}

.page-hero-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 0 0 auto;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.hero-status-row {
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 18px;
}

.hero-status-row span {
  min-height: 32px;
  border: 1px solid var(--line);
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 0 10px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface) 68%, transparent);
  backdrop-filter: blur(12px);
  font-size: 13px;
}

.hero-status-row svg {
  color: var(--teal);
}

.hero-actions {
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 24px;
}

.hero-kpis {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 26px;
}

.hero-kpis article {
  min-height: 86px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: 13px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 88%, transparent), color-mix(in srgb, var(--surface-soft) 88%, transparent)),
    var(--surface-soft);
}

.hero-kpis strong,
.hero-kpis span {
  display: block;
  overflow-wrap: anywhere;
}

.hero-kpis strong {
  font-size: 24px;
  line-height: 1.1;
}

.hero-kpis span {
  margin-top: 6px;
  color: var(--muted);
  font-size: 13px;
}

.hero-visual {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  overflow: hidden;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--slate) 11%, transparent), transparent 45%),
    color-mix(in srgb, var(--surface-soft) 82%, transparent);
  box-shadow: var(--shadow-md);
  display: grid;
  grid-template-rows: auto minmax(260px, 1fr) auto;
}

.visual-top,
.visual-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 14px;
  color: var(--muted);
  font-size: 13px;
}

.visual-top {
  border-bottom: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 70%, transparent);
}

.window-dots {
  display: inline-flex;
  gap: 6px;
}

.window-dots i {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: var(--line-strong);
}

.window-dots i:nth-child(1) {
  background: var(--coral);
}

.window-dots i:nth-child(2) {
  background: var(--amber);
}

.window-dots i:nth-child(3) {
  background: var(--teal);
}

.hero-map {
  width: 100%;
  height: 100%;
  min-height: 300px;
  object-fit: contain;
  padding: 18px;
}

.visual-bottom {
  flex-wrap: wrap;
  border-top: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 70%, transparent);
}

.visual-bottom span {
  min-height: 28px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 0 9px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-soft) 78%, transparent);
}

.eyebrow {
  display: block;
  margin: 0 0 6px;
  color: var(--teal-strong);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0;
}

.status-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 26px;
}

.metric-card {
  position: relative;
  min-height: 92px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px;
  color: var(--text);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 96%, transparent), color-mix(in srgb, var(--surface-soft) 82%, transparent)),
    color-mix(in srgb, var(--glass-strong) 82%, transparent);
  box-shadow: var(--shadow-sm);
  backdrop-filter: blur(18px);
  text-align: left;
  overflow: hidden;
  transition:
    transform 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease;
}

.metric-card:hover {
  transform: translateY(-2px);
  border-color: var(--teal);
  box-shadow: var(--shadow-md);
}

.metric-card::after {
  position: absolute;
  inset: auto 14px 0;
  height: 3px;
  border-radius: 999px 999px 0 0;
  background: linear-gradient(90deg, var(--teal), var(--blue));
  content: "";
  opacity: 0.72;
}

.metric-icon {
  width: 44px;
  height: 44px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  color: #ffffff;
  background:
    linear-gradient(135deg, var(--teal), color-mix(in srgb, var(--blue) 42%, var(--teal))),
    var(--teal);
  flex: 0 0 auto;
}

.metric-card strong,
.metric-card small {
  display: block;
  overflow-wrap: anywhere;
}

.metric-card small {
  color: var(--muted);
  margin-top: 2px;
}

.control-strip {
  justify-content: space-between;
  gap: 14px;
  margin: 34px 0 24px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: 12px;
  background: color-mix(in srgb, var(--glass-strong) 82%, transparent);
  box-shadow: var(--shadow-sm);
  backdrop-filter: blur(18px);
}

.search-box {
  flex: 1;
  min-width: 220px;
  height: 48px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: color-mix(in srgb, var(--surface) 84%, transparent);
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 14px;
  box-shadow: none;
}

.search-box input {
  width: 100%;
  min-width: 0;
  border: 0;
  outline: 0;
  background: transparent;
  color: var(--text);
}

.search-box input::placeholder {
  color: color-mix(in srgb, var(--muted) 78%, transparent);
}

.segments {
  gap: 6px;
  padding: 5px;
  border-radius: 16px;
  background: color-mix(in srgb, var(--surface-soft) 82%, transparent);
  border: 1px solid var(--line);
  box-shadow: none;
}

.segment {
  height: 36px;
  border: 0;
  border-radius: 12px;
  padding: 0 13px;
  color: var(--muted);
  background: transparent;
  transition:
    background 160ms ease,
    color 160ms ease;
}

.segment.active {
  color: #ffffff;
  background: var(--ink);
}

.section-block {
  margin-top: 32px;
  scroll-margin-top: 104px;
}

.view-panel {
  display: none;
}

.view-panel.active {
  display: block;
}

.view-panel[hidden] {
  display: none !important;
}

.section-heading {
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
}

.section-heading h2,
.note-panel h2 {
  font-size: 22px;
}

.dashboard-shell,
.settings-shell {
  display: grid;
  gap: 16px;
}

.dashboard-head,
.settings-head,
.dashboard-panel,
.settings-list {
  border: 1px solid var(--line);
  border-radius: 18px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--glass-strong) 86%, transparent), color-mix(in srgb, var(--glass) 72%, transparent)),
    var(--surface);
  box-shadow:
    var(--shadow-sm),
    inset 0 1px 0 rgba(255, 255, 255, 0.34);
  -webkit-backdrop-filter: blur(18px) saturate(145%);
  backdrop-filter: blur(18px) saturate(145%);
}

.dashboard-head,
.settings-head {
  min-height: 120px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 22px;
}

.dashboard-head h2,
.settings-head h2 {
  margin: 0;
  font-size: clamp(28px, 3vw, 38px);
  line-height: 1.1;
}

.dashboard-head p,
.settings-head p {
  max-width: 760px;
  margin: 8px 0 0;
  color: var(--muted);
}

.dashboard-head-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

.system-head {
  min-height: 94px;
  padding: 16px 18px;
}

.system-head h2 {
  font-size: 24px;
}

.system-head p {
  max-width: 640px;
  margin-top: 6px;
  font-size: 13px;
  line-height: 1.45;
}

.system-head-copy {
  min-width: 0;
}

.system-head-meta {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.system-head-actions {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.dashboard-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.console-overview-grid {
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr) minmax(280px, 0.78fr);
  grid-template-areas:
    "runtime runtime quick"
    "todo updates assets";
  align-items: start;
}

.dashboard-panel {
  min-width: 0;
  min-height: 236px;
  padding: 16px;
}

.runtime-panel {
  grid-area: runtime;
}

.quick-panel {
  grid-area: quick;
}

.todo-panel {
  grid-area: todo;
}

.updates-panel {
  grid-area: updates;
}

.asset-panel {
  grid-area: assets;
}

.dashboard-panel.panel-wide {
  grid-column: span 2;
}

.topology-panel {
  grid-column: span 2;
}

.dashboard-panel-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.dashboard-panel h3 {
  margin: 0;
  font-size: 20px;
  line-height: 1.2;
}

.health-grid,
.task-list,
.timeline-list,
.settings-list,
.modal-rule-list {
  display: grid;
  gap: 10px;
}

.live-kpi-grid,
.group-health-list {
  display: grid;
  gap: 10px;
}

.live-kpi-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-bottom: 12px;
}

.health-item,
.task-row,
.setting-row,
.timeline-list div,
.asset-table div,
.live-kpi-grid div,
.group-health-item,
.modal-rule-list span {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: color-mix(in srgb, var(--surface) 74%, transparent);
}

.health-grid {
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.compact-health-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.health-item {
  min-height: 68px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  padding: 12px;
}

.health-icon,
.setting-icon {
  --tone: var(--teal);
  width: 40px;
  height: 40px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  color: var(--tone);
  background: color-mix(in srgb, var(--tone) 13%, transparent);
  flex: 0 0 auto;
}

.tone-teal {
  --tone: var(--teal);
}

.tone-blue {
  --tone: var(--blue);
}

.tone-coral {
  --tone: var(--coral);
}

.tone-amber {
  --tone: var(--amber);
}

.tone-slate {
  --tone: var(--slate);
}

.health-item strong,
.health-item small,
.task-row strong,
.task-row small,
.live-kpi-grid strong,
.live-kpi-grid span,
.group-health-item strong,
.group-health-item span,
.group-health-item small,
.asset-table strong,
.asset-table span,
.asset-table em {
  display: block;
  overflow-wrap: anywhere;
}

.health-item strong,
.live-kpi-grid strong,
.quick-entry-grid span,
.status-pill {
  overflow-wrap: normal;
  word-break: keep-all;
}

.quick-entry-grid span,
.status-pill {
  white-space: nowrap;
}

.health-item small,
.task-row small,
.live-kpi-grid span,
.group-health-item span,
.group-health-item small,
.asset-table em {
  color: var(--muted);
  font-style: normal;
  font-size: 13px;
}

.live-kpi-grid div {
  padding: 12px;
}

.live-kpi-grid strong {
  font-size: 24px;
  line-height: 1.1;
  white-space: nowrap;
}

.live-kpi-grid span {
  margin-top: 6px;
}

.monitor-strip {
  margin-top: 12px;
  border-top: 1px solid var(--line);
  padding-top: 12px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

.compact-kpis {
  margin: 0;
}

.compact-groups {
  max-height: 124px;
  overflow: auto;
}

.group-health-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--success) 10%, transparent), transparent),
    color-mix(in srgb, var(--surface) 74%, transparent);
}

.group-health-item.degraded {
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--warning) 13%, transparent), transparent),
    color-mix(in srgb, var(--surface) 74%, transparent);
}

.group-health-item.down {
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--coral) 13%, transparent), transparent),
    color-mix(in srgb, var(--surface) 74%, transparent);
}

.group-health-item small {
  text-align: right;
}

.empty-text {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
}

.quick-entry-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.system-quick-grid {
  grid-template-columns: 1fr;
}

.quick-entry-grid a {
  min-height: 54px;
  border: 1px solid var(--line);
  border-radius: 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 12px;
  background: color-mix(in srgb, var(--surface) 74%, transparent);
  color: var(--text);
  font-weight: 800;
  transition:
    transform 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease;
}

.quick-entry-grid a:hover {
  transform: translateY(-1px);
  border-color: var(--teal);
  box-shadow: var(--shadow-sm);
}

.quick-entry-grid svg {
  color: var(--teal);
}

.system-quick-grid a {
  min-height: 52px;
  justify-content: space-between;
  padding: 0 14px;
}

.system-quick-grid a svg {
  order: 2;
}

.task-row {
  position: relative;
  min-height: 70px;
  padding: 12px 12px 12px 30px;
}

.task-dot {
  --tone: var(--teal);
  position: absolute;
  left: 12px;
  top: 18px;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--tone);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--tone) 14%, transparent);
}

.timeline-list div {
  min-height: 54px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
}

.timeline-list time {
  border-radius: 999px;
  padding: 4px 8px;
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 12%, transparent);
  font-size: 12px;
  font-weight: 900;
}

.asset-table {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.console-asset-table {
  display: flex;
  flex-direction: column;
  height: auto;
}

.asset-table div {
  padding: 12px;
}

.asset-panel .asset-table div {
  padding: 9px 10px;
}

.asset-table span {
  margin-top: 5px;
  color: var(--text);
  font-weight: 800;
}

.topology-map {
  width: 100%;
  min-height: 214px;
  max-height: 260px;
  object-fit: contain;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 12px;
  background: color-mix(in srgb, var(--surface) 72%, transparent);
}

.settings-list {
  padding: 10px;
}

.setting-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
  min-height: 84px;
  padding: 14px;
}

.setting-row h3 {
  margin: 0;
  font-size: 17px;
}

.setting-row p {
  margin: 5px 0 0;
  color: var(--muted);
  font-size: 14px;
}

.switch-control {
  min-width: 104px;
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 0 6px 0 13px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface) 82%, transparent);
}

.switch-control i {
  position: relative;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: var(--line-strong);
  transition:
    background 160ms ease,
    transform 160ms ease;
}

.switch-control[aria-pressed="true"] {
  color: var(--text);
  border-color: color-mix(in srgb, var(--teal) 50%, var(--line));
  background: color-mix(in srgb, var(--teal) 12%, transparent);
}

.switch-control[aria-pressed="true"] i {
  background: var(--teal);
  transform: translateX(2px);
}

.modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 40;
  display: grid;
  place-items: center;
  padding: 18px;
  background: rgba(11, 18, 32, 0.36);
  -webkit-backdrop-filter: blur(18px);
  backdrop-filter: blur(18px);
}

body.modal-open {
  overflow: hidden;
}

.modal-backdrop[hidden] {
  display: none;
}

.system-modal {
  width: min(100%, 560px);
  max-height: calc(100vh - 36px);
  border: 1px solid var(--line);
  border-radius: 22px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--glass-strong) 94%, transparent), color-mix(in srgb, var(--glass) 88%, transparent)),
    var(--surface);
  box-shadow: var(--shadow-lg);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.modal-head,
.modal-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 18px;
}

.modal-head {
  border-bottom: 1px solid var(--line);
  flex: 0 0 auto;
}

.modal-head h2 {
  margin: 0;
  font-size: 24px;
}

.modal-body {
  padding: 18px;
  overflow: auto;
}

.modal-body p {
  margin: 0 0 14px;
  color: var(--muted);
}

.modal-rule-list span {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  color: var(--muted);
}

.modal-rule-list svg {
  color: var(--teal);
  flex: 0 0 auto;
}

.modal-actions {
  border-top: 1px solid var(--line);
  justify-content: flex-end;
  flex: 0 0 auto;
}

.service-detail-modal {
  width: min(100%, 720px);
}

.service-modal-title {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 12px;
}

.service-modal-icon {
  --tone: var(--teal);
  width: 48px;
  height: 48px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  color: var(--tone);
  background: color-mix(in srgb, var(--tone) 13%, transparent);
  flex: 0 0 auto;
}

.service-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 14px 0;
}

.service-detail-grid div {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 11px 12px;
  background: color-mix(in srgb, var(--surface) 78%, transparent);
}

.service-detail-grid span,
.service-detail-grid strong {
  display: block;
  overflow-wrap: anywhere;
}

.service-detail-grid span {
  color: var(--muted);
  font-size: 12px;
}

.service-detail-grid strong {
  margin-top: 5px;
  font-size: 14px;
}

.service-maintenance-grid {
  border: 1px solid color-mix(in srgb, var(--line) 86%, transparent);
  border-radius: 14px;
  margin: 12px 0 14px;
  padding: 12px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 94%, transparent), color-mix(in srgb, var(--surface-soft) 64%, transparent)),
    var(--surface);
}

.service-maintenance-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 9px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
}

.service-maintenance-head strong {
  color: var(--text);
  font-size: 15px;
}

.service-maintenance-head span {
  color: var(--muted);
  font-size: 12px;
}

.service-maintenance-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: 10px;
}

.service-maintenance-list div {
  min-width: 0;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: 10px;
  padding: 9px 10px;
  background: color-mix(in srgb, var(--surface) 78%, transparent);
}

.service-maintenance-list span,
.service-maintenance-list strong {
  display: block;
  overflow-wrap: anywhere;
}

.service-maintenance-list span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.service-maintenance-list strong {
  margin-top: 4px;
  color: var(--text);
  font-size: 13px;
  line-height: 1.35;
}

.service-modal-notes {
  margin-top: 10px;
}

.service-modal-section {
  margin-top: 16px;
}

.service-modal-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.service-modal-section-head h3 {
  margin: 0;
  font-size: 17px;
}

.service-modal-section-head span {
  color: var(--muted);
  font-size: 12px;
}

.service-action-grid,
.service-related-grid {
  display: grid;
  gap: 10px;
}

.service-action-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.service-action-button,
.service-related-link {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 14px;
  color: var(--text);
  background: color-mix(in srgb, var(--surface) 78%, transparent);
  transition:
    transform 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease;
}

.service-action-button:hover,
.service-related-link:hover {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--teal) 42%, var(--line));
  box-shadow: var(--shadow-sm);
}

.service-action-button {
  min-height: 76px;
  display: grid;
  place-items: center;
  gap: 7px;
  padding: 10px;
  text-align: center;
  font-weight: 900;
}

.service-action-button svg,
.service-related-link svg {
  color: var(--teal);
}

.service-related-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.service-related-link {
  min-height: 72px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  padding: 12px;
}

.service-related-link strong,
.service-related-link small {
  display: block;
  overflow-wrap: anywhere;
}

.service-related-link small {
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
}

.service-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
}

.service-card {
  --tone: var(--teal);
  position: relative;
  min-height: 198px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 98%, transparent), color-mix(in srgb, var(--surface-soft) 52%, transparent)),
    color-mix(in srgb, var(--glass-strong) 82%, transparent);
  display: flex;
  flex-direction: column;
  gap: 16px;
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition:
    transform 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease;
}

.service-card::before {
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: linear-gradient(180deg, var(--tone), color-mix(in srgb, var(--tone) 42%, transparent));
  content: "";
}

.service-card:hover {
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--tone) 56%, var(--line));
  box-shadow: var(--shadow-md);
}

.service-card.tone-teal {
  --tone: var(--teal);
}

.service-card.tone-blue {
  --tone: var(--blue);
}

.service-card.tone-amber {
  --tone: var(--amber);
}

.service-card.tone-coral {
  --tone: var(--coral);
}

.service-card.tone-slate {
  --tone: var(--slate);
}

.card-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.card-icon {
  width: 48px;
  height: 48px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  color: var(--tone);
  background: color-mix(in srgb, var(--tone) 13%, transparent);
  flex: 0 0 auto;
}

.service-card h3 {
  margin: 0;
  font-size: 17px;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.service-card p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  overflow-wrap: anywhere;
}

.status-pill {
  flex: 0 0 auto;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 9px;
  font-size: 12px;
  font-weight: 800;
  color: var(--success);
  background: color-mix(in srgb, var(--success) 13%, transparent);
}

.status-pill.planned {
  color: var(--warning);
  background: color-mix(in srgb, var(--warning) 15%, transparent);
}

.status-pill.protected {
  color: var(--coral);
  background: color-mix(in srgb, var(--coral) 14%, transparent);
}

.status-pill.degraded {
  color: var(--warning);
  background: color-mix(in srgb, var(--warning) 15%, transparent);
}

.status-pill.down {
  color: var(--coral);
  background: color-mix(in srgb, var(--coral) 14%, transparent);
}

.card-bottom {
  margin-top: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

.service-meta-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.tag {
  color: var(--muted);
  font-size: 13px;
}

.service-domain {
  max-width: 100%;
  min-height: 24px;
  border: 1px solid var(--line);
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  padding: 0 8px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-soft) 82%, transparent);
  font-size: 12px;
  overflow-wrap: anywhere;
}

.module-badge {
  min-height: 24px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  padding: 0 8px;
  color: var(--teal-strong);
  border: 1px solid color-mix(in srgb, var(--teal) 22%, var(--line));
  background: color-mix(in srgb, var(--teal) 10%, var(--surface));
  font-size: 12px;
  font-weight: 900;
}

.module-badge.subsite,
.module-badge.external {
  color: var(--muted);
  border-color: color-mix(in srgb, var(--line) 82%, transparent);
  background: color-mix(in srgb, var(--surface-soft) 88%, transparent);
}

.module-badge.protected {
  color: var(--coral);
  border-color: color-mix(in srgb, var(--coral) 22%, var(--line));
  background: color-mix(in srgb, var(--coral) 10%, var(--surface));
}

.module-badge.planned {
  color: var(--warning);
  border-color: color-mix(in srgb, var(--warning) 22%, var(--line));
  background: color-mix(in srgb, var(--warning) 10%, var(--surface));
}

.open-link,
.ghost-link,
.ghost-button {
  min-height: 36px;
  border-radius: 14px;
  border: 1px solid var(--line);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 0 10px;
  white-space: nowrap;
  background: transparent;
}

.ghost-button {
  width: 36px;
  padding: 0;
  color: var(--muted);
}

.copy-service-button span {
  display: none;
}

.ghost-button:hover {
  border-color: var(--teal);
  color: var(--text);
}

.service-actions {
  justify-content: flex-end;
}

.service-actions .open-link,
.service-actions .secondary-action {
  min-height: 36px;
}

.open-link {
  color: #ffffff;
  background:
    linear-gradient(135deg, var(--ink), color-mix(in srgb, var(--ink) 74%, var(--slate))),
    var(--ink);
  border-color: color-mix(in srgb, var(--ink) 88%, transparent);
  transition:
    transform 160ms ease,
    background 160ms ease;
}

.open-link:hover {
  transform: translateY(-1px);
  background: color-mix(in srgb, var(--ink) 88%, var(--teal));
}

.ghost-link {
  color: var(--muted);
}

.domain-table,
.download-list,
.update-grid {
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: hidden;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 96%, transparent), color-mix(in srgb, var(--surface-soft) 60%, transparent)),
    var(--surface);
  box-shadow: var(--shadow-sm);
}

.home-resource-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.resource-panel {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 97%, transparent), color-mix(in srgb, var(--surface-soft) 58%, transparent)),
    var(--surface);
  box-shadow: var(--shadow-sm);
}

.resource-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.resource-panel h3 {
  margin: 4px 0 0;
  font-size: 20px;
}

.home-resource-grid .domain-table,
.home-resource-grid .download-list {
  box-shadow: none;
}

.command-pack-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.command-pack {
  --tone: var(--teal);
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--tone) 9%, transparent), transparent 54%),
    color-mix(in srgb, var(--surface) 96%, transparent);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: 13px;
}

.command-pack-head,
.command-pack-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.command-pack-icon {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  color: var(--tone);
  background: color-mix(in srgb, var(--tone) 13%, transparent);
}

.command-pack h3 {
  margin: 0;
  font-size: 18px;
}

.command-pack p {
  margin: 7px 0 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.65;
}

.command-pack pre {
  min-height: 168px;
  max-height: 220px;
  margin: 0;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: 8px;
  padding: 12px;
  color: var(--text);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--ink) 8%, transparent), transparent),
    color-mix(in srgb, var(--surface-soft) 84%, transparent);
  overflow: auto;
}

.command-pack code {
  font-family: Consolas, "Cascadia Code", monospace;
  font-size: 12px;
  line-height: 1.65;
  white-space: pre;
}

.command-pack-actions {
  margin-top: auto;
}

.command-pack-actions .secondary-action,
.command-pack-actions .open-link {
  min-height: 36px;
}

.update-chip {
  min-height: 34px;
  border: 1px solid var(--line);
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 0 12px;
  color: var(--muted);
  background: var(--surface);
  box-shadow: var(--shadow-sm);
  white-space: nowrap;
}

.update-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  box-shadow: var(--shadow-sm);
}

.update-card {
  --tone: var(--teal);
  min-height: 188px;
  padding: 18px;
  border-left: 1px solid var(--line);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--tone) 8%, transparent), transparent 58%),
    var(--surface);
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.update-card:first-child {
  border-left: 0;
}

.update-card.tone-teal {
  --tone: var(--teal);
}

.update-card.tone-blue {
  --tone: var(--blue);
}

.update-card.tone-coral {
  --tone: var(--coral);
}

.update-card.tone-amber {
  --tone: var(--amber);
}

.update-card.tone-slate {
  --tone: var(--slate);
}

.update-card time {
  width: max-content;
  border-radius: 999px;
  padding: 4px 9px;
  color: var(--tone);
  background: color-mix(in srgb, var(--tone) 12%, transparent);
  font-size: 12px;
  font-weight: 800;
}

.update-card h3 {
  margin: 0;
  font-size: 16px;
  line-height: 1.28;
  overflow-wrap: anywhere;
}

.update-card p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  overflow-wrap: anywhere;
}

.ops-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.ops-card {
  --tone: var(--teal);
  position: relative;
  min-height: 158px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 97%, transparent), color-mix(in srgb, var(--surface-soft) 58%, transparent)),
    var(--surface);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 16px;
  overflow: hidden;
  transition:
    transform 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease;
}

.ops-card::after {
  position: absolute;
  right: 14px;
  top: 14px;
  width: 42px;
  height: 3px;
  border-radius: 999px;
  background: var(--tone);
  content: "";
  opacity: 0.62;
}

.ops-card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--tone) 52%, var(--line));
  box-shadow: var(--shadow-md);
}

.ops-card.tone-teal {
  --tone: var(--teal);
}

.ops-card.tone-blue {
  --tone: var(--blue);
}

.ops-card.tone-amber {
  --tone: var(--amber);
}

.ops-card.tone-coral {
  --tone: var(--coral);
}

.ops-icon {
  width: 46px;
  height: 46px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  color: var(--tone);
  background: color-mix(in srgb, var(--tone) 13%, transparent);
}

.ops-title,
.ops-card strong,
.ops-card small {
  display: block;
  overflow-wrap: anywhere;
}

.ops-title {
  color: var(--muted);
  font-size: 13px;
}

.ops-card strong {
  margin-top: 3px;
  font-size: 20px;
}

.ops-card small {
  margin-top: 5px;
  color: var(--muted);
}

.access-panel {
  margin-top: 14px;
  min-height: 166px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 20px;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--coral) 10%, transparent), transparent 46%),
    linear-gradient(220deg, color-mix(in srgb, var(--violet) 10%, transparent), transparent 48%),
    var(--surface);
  box-shadow: var(--shadow-md);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.access-panel h3 {
  margin: 0;
  font-size: 24px;
  line-height: 1.2;
}

.access-panel p {
  max-width: 760px;
  margin: 8px 0 0;
  color: var(--muted);
}

.access-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 0 0 auto;
}

.workbench-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.workbench-card {
  --tone: var(--teal);
  min-height: 236px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 18px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--tone) 9%, transparent), transparent 62%),
    var(--surface);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.workbench-card.tone-teal {
  --tone: var(--teal);
}

.workbench-card.tone-blue {
  --tone: var(--blue);
}

.workbench-card.tone-amber {
  --tone: var(--amber);
}

.workbench-card.tone-coral {
  --tone: var(--coral);
}

.workbench-icon {
  width: 46px;
  height: 46px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  color: var(--tone);
  background: color-mix(in srgb, var(--tone) 13%, transparent);
}

.workbench-card h3 {
  margin: 0;
  font-size: 18px;
  overflow-wrap: anywhere;
}

.workbench-card p {
  margin: 8px 0 0;
  color: var(--muted);
  font-size: 14px;
  overflow-wrap: anywhere;
}

.workbench-card a {
  min-height: 38px;
  border: 1px solid color-mix(in srgb, var(--tone) 36%, var(--line));
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: auto;
  padding: 0 12px;
  color: var(--tone);
  font-weight: 900;
  background: color-mix(in srgb, var(--tone) 8%, transparent);
}

.roadmap-board {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.roadmap-card {
  --tone: var(--teal);
  min-height: 270px;
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 20px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--tone) 10%, transparent), transparent 58%),
    var(--surface);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.roadmap-card.tone-teal {
  --tone: var(--teal);
}

.roadmap-card.tone-blue {
  --tone: var(--blue);
}

.roadmap-card.tone-coral {
  --tone: var(--coral);
}

.roadmap-step {
  width: 46px;
  height: 46px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  color: var(--tone);
  background: color-mix(in srgb, var(--tone) 13%, transparent);
  font-weight: 900;
}

.roadmap-card h3 {
  margin: 0;
  font-size: 22px;
  line-height: 1.2;
}

.roadmap-card p {
  margin: 0;
  color: var(--muted);
}

.roadmap-card ul {
  display: grid;
  gap: 8px;
  margin: auto 0 0;
  padding-left: 20px;
  color: var(--muted);
}

.route-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.route-card {
  --tone: var(--teal);
  min-height: 148px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 18px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--tone) 9%, transparent), transparent 64%),
    var(--surface);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition:
    transform 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease;
}

.route-card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--tone) 52%, var(--line));
  box-shadow: var(--shadow-md);
}

.route-card.tone-teal {
  --tone: var(--teal);
}

.route-card.tone-blue {
  --tone: var(--blue);
}

.route-card.tone-amber {
  --tone: var(--amber);
}

.route-card.tone-coral {
  --tone: var(--coral);
}

.route-card svg {
  color: var(--tone);
}

.route-card strong {
  font-size: 18px;
}

.route-card span {
  color: var(--muted);
  overflow-wrap: anywhere;
}

.domain-row,
.download-row {
  display: grid;
  grid-template-columns: 230px minmax(0, 1fr) 130px;
  gap: 16px;
  align-items: center;
  min-height: 68px;
  padding: 14px 16px;
  border-top: 1px solid var(--line);
  transition: background 160ms ease;
}

.home-resource-grid .domain-row,
.home-resource-grid .download-row {
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 6px 12px;
  align-items: start;
}

.home-resource-grid .domain-purpose,
.home-resource-grid .download-desc {
  grid-column: 1 / -1;
  font-size: 14px;
}

.home-resource-grid .domain-state {
  align-self: start;
}

.domain-row:hover,
.download-row:hover {
  background: var(--surface-soft);
}

.domain-row:first-child,
.download-row:first-child {
  border-top: 0;
}

.domain-row .copy-line {
  margin-top: 0;
  box-shadow: none;
}

.domain-name,
.download-name {
  font-weight: 800;
  overflow-wrap: anywhere;
}

.domain-purpose,
.download-desc {
  color: var(--muted);
  overflow-wrap: anywhere;
}

.domain-state {
  justify-self: end;
  border-radius: 999px;
  padding: 5px 10px;
  font-size: 12px;
  font-weight: 800;
  color: var(--muted);
  background: var(--surface-soft);
}

.domain-state.online {
  color: var(--success);
  background: color-mix(in srgb, var(--success) 13%, transparent);
}

.domain-state.planned {
  color: var(--warning);
  background: color-mix(in srgb, var(--warning) 15%, transparent);
}

.two-column {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 28px;
}

.note-panel {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 20px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 96%, transparent), color-mix(in srgb, var(--surface-soft) 56%, transparent)),
    var(--surface);
  box-shadow: var(--shadow-sm);
}

.note-panel ul {
  margin: 12px 0 0;
  padding-left: 20px;
  color: var(--muted);
}

.note-panel li + li {
  margin-top: 8px;
}

.note-panel code {
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 1px 5px;
  color: var(--text);
  background: color-mix(in srgb, var(--teal) 8%, transparent);
  font-family: Consolas, "Cascadia Code", monospace;
  font-size: 0.92em;
  overflow-wrap: anywhere;
}

.status-list {
  display: grid;
  gap: 10px;
  margin: 14px 0 0;
}

.status-list div {
  justify-content: space-between;
  gap: 12px;
  min-height: 36px;
  border-bottom: 1px solid var(--line);
}

.status-list dt {
  font-weight: 800;
}

.status-list dd {
  margin: 0;
  color: var(--muted);
  text-align: right;
}

.download-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.82fr);
  gap: 24px;
  align-items: stretch;
  margin-bottom: 16px;
  padding: 30px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--teal) 13%, transparent), transparent 38%),
    linear-gradient(220deg, color-mix(in srgb, var(--violet) 12%, transparent), transparent 48%),
    var(--surface);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}

.download-hero-copy {
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.download-hero h2 {
  max-width: 780px;
  margin: 0;
  font-size: clamp(38px, 5vw, 66px);
  line-height: 1.12;
  letter-spacing: 0;
}

.download-hero p {
  max-width: 740px;
  margin: 16px 0 0;
  color: var(--muted);
  font-size: 17px;
}

.download-terminal {
  min-width: 0;
  max-width: 100%;
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: hidden;
  background: #0f172a;
  color: #dbeafe;
  box-shadow: var(--shadow-md);
}

.download-terminal .visual-top {
  border-bottom-color: rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.06);
  color: #cbd5e1;
}

.download-terminal pre {
  margin: 0;
  padding: 22px;
  overflow-x: auto;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  font-family: Consolas, "Cascadia Code", monospace;
  font-size: 14px;
  line-height: 1.7;
}

.script-summary,
.resource-grid,
.playbook-grid,
.recipe-grid,
.recovery-board,
.script-grid {
  display: grid;
  gap: 14px;
}

.script-summary {
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  margin-bottom: 24px;
}

.script-summary article {
  min-height: 132px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 97%, transparent), color-mix(in srgb, var(--surface-soft) 58%, transparent)),
    var(--surface);
  box-shadow: var(--shadow-sm);
}

.script-summary svg {
  width: 42px;
  height: 42px;
  border-radius: 8px;
  padding: 10px;
  color: var(--teal);
  background: color-mix(in srgb, var(--teal) 13%, transparent);
}

.script-summary strong,
.script-summary span {
  display: block;
  overflow-wrap: anywhere;
}

.script-summary strong {
  margin-top: 14px;
  font-size: 22px;
}

.script-summary span {
  margin-top: 4px;
  color: var(--muted);
  font-size: 13px;
}

.resource-grid {
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.playbook-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.recipe-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.section-hint {
  max-width: 460px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.5;
}

.playbook-card {
  --tone: var(--teal);
  min-width: 0;
  min-height: 360px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 18px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--tone) 10%, transparent), transparent 56%),
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 96%, transparent), color-mix(in srgb, var(--surface-soft) 58%, transparent)),
    var(--surface);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: 14px;
  overflow: hidden;
  transition:
    transform 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease;
}

.playbook-card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--tone) 52%, var(--line));
  box-shadow: var(--shadow-md);
}

.playbook-card.tone-teal {
  --tone: var(--teal);
}

.playbook-card.tone-blue {
  --tone: var(--blue);
}

.playbook-card.tone-amber {
  --tone: var(--amber);
}

.playbook-card.tone-coral {
  --tone: var(--coral);
}

.playbook-card.tone-slate {
  --tone: var(--slate);
}

.playbook-head,
.playbook-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.playbook-icon {
  width: 44px;
  height: 44px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  color: var(--tone);
  background: color-mix(in srgb, var(--tone) 14%, transparent);
  flex: 0 0 auto;
}

.playbook-card h3 {
  margin: 0;
  font-size: 20px;
  line-height: 1.22;
}

.playbook-card p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
}

.playbook-steps {
  display: grid;
  gap: 8px;
  margin: 0;
  padding-left: 20px;
  color: var(--muted);
  font-size: 14px;
}

.playbook-command-list {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: auto;
}

.playbook-command-list span {
  max-width: 100%;
  min-height: 28px;
  border: 1px solid color-mix(in srgb, var(--tone) 24%, var(--line));
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  padding: 0 9px;
  color: var(--muted);
  background: color-mix(in srgb, var(--tone) 7%, transparent);
  font-size: 12px;
  overflow-wrap: anywhere;
}

.playbook-actions {
  justify-content: flex-end;
  flex-wrap: wrap;
  margin-top: 2px;
}

.recovery-board {
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.recipe-card {
  --tone: var(--teal);
  min-height: 260px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 18px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--tone) 9%, transparent), transparent 58%),
    var(--surface);
  box-shadow: var(--shadow-sm);
}

.recipe-card.tone-teal {
  --tone: var(--teal);
}

.recipe-card.tone-blue {
  --tone: var(--blue);
}

.recipe-card.tone-amber {
  --tone: var(--amber);
}

.recipe-card.tone-coral {
  --tone: var(--coral);
}

.recipe-card h3 {
  margin: 14px 0 8px;
  font-size: 19px;
}

.recipe-card p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
}

.recipe-card ol {
  display: grid;
  gap: 8px;
  margin: 14px 0 0;
  padding-left: 20px;
  color: var(--muted);
  font-size: 14px;
}

.recovery-card {
  --tone: var(--teal);
  min-width: 0;
  min-height: 292px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 18px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--tone) 10%, transparent), transparent 64%),
    var(--surface);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: 14px;
  overflow: hidden;
  transition:
    transform 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease;
}

.recovery-card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--tone) 52%, var(--line));
  box-shadow: var(--shadow-md);
}

.recovery-card.tone-teal {
  --tone: var(--teal);
}

.recovery-card.tone-blue {
  --tone: var(--blue);
}

.recovery-card.tone-amber {
  --tone: var(--amber);
}

.recovery-card.tone-coral {
  --tone: var(--coral);
}

.recovery-card.tone-slate {
  --tone: var(--slate);
}

.recovery-phase {
  display: flex;
  align-items: center;
  gap: 11px;
}

.recovery-phase span {
  width: 42px;
  height: 42px;
  border-radius: 13px;
  display: grid;
  place-items: center;
  color: var(--tone);
  background: color-mix(in srgb, var(--tone) 13%, transparent);
  font-weight: 900;
  flex: 0 0 auto;
}

.recovery-phase strong {
  min-width: 0;
  font-size: 17px;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.recovery-card p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
}

.recovery-card ul {
  display: grid;
  gap: 8px;
  margin: 0;
  padding-left: 20px;
  color: var(--muted);
  font-size: 14px;
}

.recovery-copy {
  width: 100%;
  margin-top: auto;
}

.recovery-copy span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.resource-card {
  --tone: var(--teal);
  position: relative;
  min-height: 206px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 98%, transparent), color-mix(in srgb, var(--surface-soft) 52%, transparent)),
    var(--surface);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: 16px;
  overflow: hidden;
  transition:
    transform 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease;
}

.resource-card::before {
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: linear-gradient(180deg, var(--tone), color-mix(in srgb, var(--tone) 42%, transparent));
  content: "";
}

.resource-card:hover,
.script-card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--tone, var(--teal)) 52%, var(--line));
  box-shadow: var(--shadow-md);
}

.resource-card.tone-teal,
.service-card.tone-teal {
  --tone: var(--teal);
}

.resource-card.tone-blue,
.service-card.tone-blue {
  --tone: var(--blue);
}

.resource-card.tone-amber,
.service-card.tone-amber {
  --tone: var(--amber);
}

.resource-card.tone-coral,
.service-card.tone-coral {
  --tone: var(--coral);
}

.resource-card.tone-slate,
.service-card.tone-slate {
  --tone: var(--slate);
}

.resource-card.tone-green,
.service-card.tone-green {
  --tone: var(--teal);
}

.resource-card h3 {
  margin: 0;
  font-size: 18px;
  line-height: 1.25;
}

.resource-card p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
}

.ghost-copy {
  min-height: 36px;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 0 10px;
  color: var(--muted);
  background: transparent;
}

.ghost-copy:hover {
  border-color: var(--teal);
  color: var(--text);
}

.script-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.script-card {
  --tone: var(--teal);
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 97%, transparent), color-mix(in srgb, var(--surface-soft) 52%, transparent)),
    var(--surface);
  box-shadow: var(--shadow-sm);
  transition:
    transform 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease;
}

.script-meta h3 {
  margin: 12px 0 0;
  font-size: 19px;
  line-height: 1.25;
}

.script-meta p {
  margin: 8px 0 0;
  color: var(--muted);
}

.script-code {
  margin: 14px 0 0;
  max-width: 100%;
  min-height: 148px;
  max-height: 300px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 14px;
  color: var(--text);
  background: var(--surface-soft);
  overflow: auto;
  font-family: Consolas, "Cascadia Code", monospace;
  font-size: 13px;
  line-height: 1.55;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
}

.script-actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 14px;
}

.toast {
  position: fixed;
  left: 50%;
  bottom: 24px;
  transform: translate(-50%, 16px);
  opacity: 0;
  pointer-events: none;
  min-width: 180px;
  max-width: min(420px, calc(100vw - 32px));
  border-radius: 8px;
  background: var(--ink);
  color: var(--bg);
  padding: 12px 16px;
  text-align: center;
  box-shadow: var(--shadow-md);
  transition:
    opacity 160ms ease,
    transform 160ms ease;
  z-index: 20;
}

.toast.show {
  opacity: 1;
  transform: translate(-50%, 0);
}

.entry-pet {
  --entry-pet-body: #111827;
  --entry-pet-body-soft: #1f2937;
  --entry-pet-border: color-mix(in srgb, var(--teal) 38%, #111827);
  --entry-pet-ear: #111827;
  --entry-pet-ear-inner: color-mix(in srgb, var(--coral) 44%, #111827);
  --entry-pet-eye: #f8fafc;
  --entry-pet-nose: color-mix(in srgb, var(--coral) 78%, #f8fafc);
  --entry-pet-cheek: color-mix(in srgb, var(--coral) 30%, transparent);
  --entry-pet-tail: #111827;
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 19;
  pointer-events: none;
}

.entry-pet[data-pet-skin="white-cat"] {
  --entry-pet-body: #f8fafc;
  --entry-pet-body-soft: #e2e8f0;
  --entry-pet-border: color-mix(in srgb, var(--teal) 24%, var(--line));
  --entry-pet-ear: #f8fafc;
  --entry-pet-ear-inner: color-mix(in srgb, var(--coral) 26%, #f8fafc);
  --entry-pet-eye: #111827;
  --entry-pet-nose: color-mix(in srgb, var(--coral) 86%, var(--ink));
  --entry-pet-cheek: color-mix(in srgb, var(--coral) 22%, transparent);
  --entry-pet-tail: #f8fafc;
}

.entry-pet[data-pet-skin="puppy"] {
  --entry-pet-body: #b7791f;
  --entry-pet-body-soft: #e2b75f;
  --entry-pet-border: color-mix(in srgb, var(--amber) 42%, var(--line));
  --entry-pet-ear: #8a5a24;
  --entry-pet-ear-inner: color-mix(in srgb, var(--amber) 40%, #8a5a24);
  --entry-pet-eye: #111827;
  --entry-pet-nose: #111827;
  --entry-pet-cheek: color-mix(in srgb, var(--amber) 28%, transparent);
  --entry-pet-tail: #8a5a24;
}

.entry-pet[data-pet-skin="dumpling"] {
  --entry-pet-body: #f1f5f9;
  --entry-pet-body-soft: #dbeafe;
  --entry-pet-border: color-mix(in srgb, var(--blue) 24%, var(--line));
  --entry-pet-ear: #f1f5f9;
  --entry-pet-ear-inner: color-mix(in srgb, var(--blue) 16%, #f1f5f9);
  --entry-pet-eye: #111827;
  --entry-pet-nose: color-mix(in srgb, var(--teal) 72%, var(--ink));
  --entry-pet-cheek: color-mix(in srgb, var(--coral) 20%, transparent);
  --entry-pet-tail: #dbeafe;
}

.entry-pet.is-hidden {
  display: none;
}

.entry-pet-toggle {
  position: relative;
  width: 74px;
  height: 74px;
  border: 0;
  border-radius: 24px;
  background: transparent;
  cursor: pointer;
  pointer-events: auto;
}

.entry-pet-toggle:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--teal) 42%, transparent);
  outline-offset: 4px;
}

.entry-pet-bubble {
  position: absolute;
  right: 50px;
  bottom: 48px;
  min-width: 68px;
  border: 1px solid color-mix(in srgb, var(--line) 76%, transparent);
  border-radius: 999px;
  padding: 6px 10px;
  color: var(--text);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow: var(--shadow-sm);
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
  transform-origin: right bottom;
  opacity: 0;
  transform: translateY(6px) scale(0.96);
  transition:
    opacity 160ms ease,
    transform 160ms ease;
}

.entry-pet-toggle:hover .entry-pet-bubble,
.entry-pet-toggle:focus-visible .entry-pet-bubble {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.entry-pet.is-open .entry-pet-bubble {
  opacity: 0;
  transform: translateY(4px) scale(0.94);
}

.entry-pet-character {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  animation: entryPetFloat 3.8s ease-in-out infinite;
}

.entry-pet.is-playing .entry-pet-character {
  animation: entryPetPlay 620ms ease;
}

.entry-pet-shadow {
  position: absolute;
  left: 15px;
  right: 15px;
  bottom: 6px;
  height: 12px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--ink) 12%, transparent);
  filter: blur(4px);
  transform: scaleX(0.88);
}

.entry-pet-body {
  position: relative;
  width: 54px;
  height: 54px;
  border: 2px solid var(--entry-pet-border);
  border-radius: 20px 20px 24px 24px;
  background:
    radial-gradient(circle at 32% 36%, rgba(255, 255, 255, 0.8), transparent 12%),
    linear-gradient(145deg, var(--entry-pet-body-soft), var(--entry-pet-body));
  box-shadow:
    0 16px 32px color-mix(in srgb, var(--entry-pet-body) 18%, transparent),
    inset 0 -8px 18px color-mix(in srgb, var(--entry-pet-border) 18%, transparent);
}

.entry-pet-body::before,
.entry-pet-body::after {
  content: "";
  position: absolute;
  top: 35px;
  display: none;
  width: 13px;
  height: 1px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--entry-pet-eye) 70%, transparent);
  box-shadow: 0 4px 0 color-mix(in srgb, var(--entry-pet-eye) 55%, transparent);
  opacity: 0.68;
}

.entry-pet[data-pet-skin="black-cat"] .entry-pet-body::before,
.entry-pet[data-pet-skin="black-cat"] .entry-pet-body::after,
.entry-pet[data-pet-skin="white-cat"] .entry-pet-body::before,
.entry-pet[data-pet-skin="white-cat"] .entry-pet-body::after {
  display: block;
}

.entry-pet-body::before {
  left: 2px;
  transform: rotate(10deg);
}

.entry-pet-body::after {
  right: 2px;
  transform: rotate(-10deg);
}

.entry-pet-ear {
  position: absolute;
  top: -10px;
  width: 18px;
  height: 18px;
  border: 2px solid var(--entry-pet-border);
  border-bottom: 0;
  background: var(--entry-pet-ear);
}

.entry-pet-ear::after {
  content: "";
  position: absolute;
  inset: 5px;
  border-radius: inherit;
  background: var(--entry-pet-ear-inner);
}

.entry-pet-ear.ear-left {
  left: 7px;
  border-radius: 14px 8px 0 8px;
  transform: rotate(-16deg);
}

.entry-pet-ear.ear-right {
  right: 7px;
  border-radius: 8px 14px 8px 0;
  transform: rotate(16deg);
}

.entry-pet-eye {
  position: absolute;
  top: 23px;
  width: 7px;
  height: 9px;
  border-radius: 999px;
  background: var(--entry-pet-eye);
  animation: entryPetBlink 5.8s infinite;
}

.entry-pet-eye.eye-left {
  left: 17px;
}

.entry-pet-eye.eye-right {
  right: 17px;
}

.entry-pet-nose {
  position: absolute;
  left: 50%;
  top: 32px;
  width: 7px;
  height: 5px;
  border-radius: 999px;
  background: var(--entry-pet-nose);
  transform: translateX(-50%);
}

.entry-pet-cheek {
  position: absolute;
  top: 34px;
  width: 8px;
  height: 5px;
  border-radius: 999px;
  background: var(--entry-pet-cheek);
}

.entry-pet-cheek.cheek-left {
  left: 9px;
}

.entry-pet-cheek.cheek-right {
  right: 9px;
}

.entry-pet-tail {
  position: absolute;
  right: 3px;
  bottom: 18px;
  width: 25px;
  height: 22px;
  border: 6px solid var(--entry-pet-tail);
  border-left: 0;
  border-bottom: 0;
  border-radius: 0 22px 0 0;
  transform-origin: left bottom;
  animation: entryPetTail 4.6s ease-in-out infinite;
}

.entry-pet[data-pet-skin="puppy"] .entry-pet-body {
  border-radius: 22px 22px 20px 20px;
}

.entry-pet[data-pet-skin="puppy"] .entry-pet-ear {
  top: 4px;
  width: 16px;
  height: 25px;
  border: 0;
  border-radius: 12px 12px 16px 16px;
}

.entry-pet[data-pet-skin="puppy"] .entry-pet-ear::after {
  display: none;
}

.entry-pet[data-pet-skin="puppy"] .entry-pet-ear.ear-left {
  left: 2px;
  transform: rotate(18deg);
}

.entry-pet[data-pet-skin="puppy"] .entry-pet-ear.ear-right {
  right: 2px;
  transform: rotate(-18deg);
}

.entry-pet[data-pet-skin="puppy"] .entry-pet-nose {
  top: 31px;
  width: 9px;
  height: 7px;
}

.entry-pet[data-pet-skin="dumpling"] .entry-pet-body {
  border-radius: 50%;
}

.entry-pet[data-pet-skin="dumpling"] .entry-pet-ear,
.entry-pet[data-pet-skin="dumpling"] .entry-pet-tail {
  display: none;
}

.entry-pet[data-pet-skin="dumpling"] .entry-pet-eye {
  top: 22px;
}

.entry-pet-panel {
  position: absolute;
  right: 0;
  bottom: 84px;
  width: min(248px, calc(100vw - 32px));
  border: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  border-radius: 18px;
  padding: 12px;
  background: color-mix(in srgb, var(--surface) 94%, transparent);
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(18px) saturate(145%);
  pointer-events: auto;
}

.entry-pet-panel[hidden] {
  display: none;
}

.entry-pet-panel::after {
  content: "";
  position: absolute;
  right: 24px;
  bottom: -8px;
  width: 14px;
  height: 14px;
  border-right: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  border-bottom: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  background: inherit;
  transform: rotate(45deg);
}

.entry-pet-panel-head {
  margin-bottom: 10px;
}

.entry-pet-panel-head strong {
  display: block;
  color: var(--text);
  font-size: 14px;
  line-height: 1.2;
}

.entry-pet-panel-head span {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.entry-pet-actions {
  display: grid;
  gap: 7px;
}

.entry-pet-actions a,
.entry-pet-actions button,
.entry-pet-hide {
  width: 100%;
  min-height: 40px;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: 12px;
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 0 11px;
  color: var(--text);
  background: color-mix(in srgb, var(--surface-soft) 76%, transparent);
  font: inherit;
  font-size: 13px;
  font-weight: 900;
  text-decoration: none;
  cursor: pointer;
}

.entry-pet-actions a:hover,
.entry-pet-actions a:focus-visible,
.entry-pet-actions button:hover,
.entry-pet-actions button:focus-visible,
.entry-pet-hide:hover,
.entry-pet-hide:focus-visible {
  border-color: color-mix(in srgb, var(--teal) 36%, var(--line));
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 8%, var(--surface));
}

.entry-pet-actions svg,
.entry-pet-hide svg {
  width: 16px;
  height: 16px;
  flex: 0 0 auto;
}

.entry-pet-hide {
  margin-top: 8px;
  justify-content: center;
  color: var(--muted);
  background: transparent;
}

.entry-pet-skins {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid color-mix(in srgb, var(--line) 76%, transparent);
}

.entry-pet-skins > span {
  display: block;
  margin-bottom: 7px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.entry-pet-skin-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 7px;
}

.entry-pet-skin-grid button {
  min-width: 0;
  min-height: 34px;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: 11px;
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 0 8px;
  color: var(--text);
  background: color-mix(in srgb, var(--surface-soft) 72%, transparent);
  font: inherit;
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
}

.entry-pet-skin-grid button.active,
.entry-pet-skin-grid button[aria-pressed="true"],
.entry-pet-skin-grid button:hover,
.entry-pet-skin-grid button:focus-visible {
  border-color: color-mix(in srgb, var(--teal) 38%, var(--line));
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 8%, var(--surface));
}

.skin-dot {
  width: 14px;
  height: 14px;
  border: 1px solid color-mix(in srgb, var(--line) 76%, transparent);
  border-radius: 999px;
  flex: 0 0 auto;
}

.skin-black {
  background: #111827;
}

.skin-white {
  background: #f8fafc;
}

.skin-puppy {
  background: #b7791f;
}

.skin-dumpling {
  background: #dbeafe;
}

@keyframes entryPetFloat {
  0%,
  100% {
    transform: translateY(0) scale(1);
  }
  50% {
    transform: translateY(-4px) scale(1.015);
  }
}

@keyframes entryPetTail {
  0%,
  100% {
    transform: rotate(0deg);
  }
  50% {
    transform: rotate(8deg);
  }
}

@keyframes entryPetPlay {
  0%,
  100% {
    transform: translateY(0) rotate(0deg) scale(1);
  }
  28% {
    transform: translateY(-9px) rotate(-5deg) scale(1.04);
  }
  58% {
    transform: translateY(0) rotate(4deg) scale(0.99);
  }
}

@keyframes entryPetBlink {
  0%,
  92%,
  100% {
    transform: scaleY(1);
  }
  95% {
    transform: scaleY(0.15);
  }
}

@media (max-width: 760px) {
  .entry-pet {
    right: 12px;
    bottom: 14px;
  }

  .entry-pet-toggle {
    width: 62px;
    height: 62px;
  }

  .entry-pet-character {
    transform: scale(0.86);
  }

  .entry-pet-bubble {
    display: none;
  }

  .entry-pet-panel {
    right: 0;
    bottom: 70px;
    width: min(236px, calc(100vw - 24px));
  }
}

@media (prefers-reduced-motion: reduce) {
  .entry-pet-bubble,
  .entry-pet-character,
  .entry-pet-eye,
  .entry-pet-tail,
  .entry-pet.is-playing .entry-pet-character {
    animation: none;
  }
}

svg {
  width: 18px;
  height: 18px;
  stroke-width: 2;
}

/* Restrained system color layer */
:root[data-theme="dark"] body,
body {
  background:
    linear-gradient(180deg, var(--bg) 0%, color-mix(in srgb, var(--bg) 84%, var(--surface-strong)) 100%);
  background-attachment: fixed;
}

.brand-mark {
  background:
    linear-gradient(145deg, #111827, color-mix(in srgb, #111827 84%, var(--teal))),
    #111827;
}

.app-shell,
.dashboard-head,
.settings-head,
.dashboard-panel,
.settings-list,
.page-hero,
.hero-panel,
.access-panel,
.resource-panel,
.service-card,
.workbench-card,
.route-card,
.roadmap-card,
.note-panel,
.script-card,
.resource-card,
.download-hero,
.download-terminal {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 88%, transparent), color-mix(in srgb, var(--surface-soft) 74%, transparent)),
    var(--surface);
}

.dashboard-head,
.settings-head {
  box-shadow:
    0 16px 42px rgba(15, 23, 42, 0.055),
    inset 0 1px 0 rgba(255, 255, 255, 0.44);
}

.primary-action {
  border-color: color-mix(in srgb, var(--teal) 76%, transparent);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--teal) 94%, #ffffff), var(--teal)),
    var(--teal);
  box-shadow:
    0 12px 26px color-mix(in srgb, var(--teal) 20%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.22);
}

.metric-card::after,
.service-card::before {
  background: var(--tone, var(--teal));
}

.quick-entry-grid a,
.health-item,
.task-row,
.setting-row,
.timeline-list div,
.asset-table div,
.modal-rule-list span {
  background: color-mix(in srgb, var(--surface) 84%, transparent);
}

.console-summary-card,
.ops-card,
.workbench-card,
.roadmap-card,
.update-card {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--tone, var(--teal)) 5%, transparent), transparent 64%),
    color-mix(in srgb, var(--surface) 88%, transparent);
}

.status-pill,
.update-chip {
  background: color-mix(in srgb, var(--success) 11%, var(--surface));
}

.status-pill.protected {
  color: var(--blue);
  background: color-mix(in srgb, var(--blue) 10%, var(--surface));
}

/* Modern translucent workspace layer */
:root[data-theme="dark"] body {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--bg) 92%, #ffffff), var(--bg)),
    var(--bg);
}

.app-shell {
  grid-template-columns: 302px minmax(0, 1fr);
}

.sidebar {
  height: calc(100vh - 32px);
  margin: 0;
  border: 0;
  border-right: 1px solid var(--line);
  border-radius: 0;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--glass-strong) 88%, transparent), color-mix(in srgb, var(--glass) 72%, transparent)),
    color-mix(in srgb, var(--surface) 76%, transparent);
  box-shadow:
    inset -1px 0 0 color-mix(in srgb, #ffffff 34%, transparent),
    10px 0 34px rgba(25, 39, 62, 0.04);
  -webkit-backdrop-filter: blur(var(--blur)) saturate(150%);
  backdrop-filter: blur(var(--blur)) saturate(150%);
}

:root[data-theme="dark"] .sidebar {
  box-shadow:
    inset -1px 0 0 rgba(255, 255, 255, 0.06),
    10px 0 34px rgba(0, 0, 0, 0.12);
}

.brand-mark {
  border-radius: 14px;
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--ink) 92%, var(--teal)), color-mix(in srgb, var(--ink) 72%, var(--blue))),
    var(--ink);
}

:root[data-theme="dark"] .brand-mark {
  background:
    linear-gradient(145deg, #172033, color-mix(in srgb, #172033 58%, var(--teal))),
    #172033;
  color: #ffffff;
}

.side-nav a {
  border-radius: 13px;
  background: transparent;
}

.side-nav a:hover,
.side-nav a.active {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 72%, transparent), color-mix(in srgb, var(--surface-soft) 54%, transparent));
  border-color: color-mix(in srgb, var(--line-strong) 78%, transparent);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.36),
    0 8px 18px rgba(25, 39, 62, 0.055);
}

.side-nav a.active {
  color: var(--text);
  box-shadow:
    inset 3px 0 0 var(--teal),
    inset 0 1px 0 rgba(255, 255, 255, 0.38),
    0 8px 18px rgba(25, 39, 62, 0.065);
}

.domain-box {
  border-top-color: color-mix(in srgb, var(--line) 72%, transparent);
}

.rail-status,
.copy-line,
.global-search,
.search-box,
.segments,
.update-chip,
.sidebar-home {
  background: var(--glass-soft);
  -webkit-backdrop-filter: blur(18px) saturate(150%);
  backdrop-filter: blur(18px) saturate(150%);
}

.workspace {
  padding: 78px 34px 36px;
}

.topbar {
  margin: -78px -34px 24px;
  padding: 64px 34px 16px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--glass-strong) 88%, transparent), color-mix(in srgb, var(--glass) 62%, transparent));
  -webkit-backdrop-filter: blur(22px) saturate(150%);
  backdrop-filter: blur(22px) saturate(150%);
}

.icon-button,
.primary-action,
.secondary-action,
.open-link,
.ghost-link,
.ghost-copy,
.workbench-card a {
  border-radius: 11px;
}

.primary-action {
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--teal) 88%, #ffffff), color-mix(in srgb, var(--blue) 48%, var(--teal))),
    var(--teal);
  box-shadow:
    0 14px 30px color-mix(in srgb, var(--teal) 24%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.26);
}

.secondary-action,
.icon-button,
.copy-line,
.global-search,
.search-box,
.segments {
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.34);
}

.hero-panel,
.page-hero,
.access-panel,
.download-hero {
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--teal) 12%, transparent), transparent 42%),
    linear-gradient(225deg, color-mix(in srgb, var(--blue) 11%, transparent), transparent 52%),
    linear-gradient(0deg, color-mix(in srgb, var(--amber) 7%, transparent), transparent 70%),
    var(--glass-strong);
  -webkit-backdrop-filter: blur(var(--blur)) saturate(150%);
  backdrop-filter: blur(var(--blur)) saturate(150%);
  box-shadow:
    var(--shadow-lg),
    inset 0 1px 0 rgba(255, 255, 255, 0.38);
}

.hero-visual,
.metric-card,
.service-card,
.ops-card,
.workbench-card,
.route-card,
.resource-panel,
.note-panel,
.script-summary article,
.playbook-card,
.recipe-card,
.recovery-card,
.resource-card,
.script-card,
.domain-table,
.download-list,
.update-grid {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--glass-strong) 86%, transparent), color-mix(in srgb, var(--glass) 82%, transparent)),
    var(--surface);
  -webkit-backdrop-filter: blur(18px) saturate(145%);
  backdrop-filter: blur(18px) saturate(145%);
  box-shadow:
    var(--shadow-sm),
    inset 0 1px 0 rgba(255, 255, 255, 0.34);
}

:root[data-theme="dark"] .hero-panel,
:root[data-theme="dark"] .page-hero,
:root[data-theme="dark"] .access-panel,
:root[data-theme="dark"] .download-hero,
:root[data-theme="dark"] .hero-visual,
:root[data-theme="dark"] .metric-card,
:root[data-theme="dark"] .service-card,
:root[data-theme="dark"] .ops-card,
:root[data-theme="dark"] .workbench-card,
:root[data-theme="dark"] .route-card,
:root[data-theme="dark"] .resource-panel,
:root[data-theme="dark"] .note-panel,
:root[data-theme="dark"] .script-summary article,
:root[data-theme="dark"] .playbook-card,
:root[data-theme="dark"] .recipe-card,
:root[data-theme="dark"] .recovery-card,
:root[data-theme="dark"] .resource-card,
:root[data-theme="dark"] .script-card,
:root[data-theme="dark"] .domain-table,
:root[data-theme="dark"] .download-list,
:root[data-theme="dark"] .update-grid {
  box-shadow:
    var(--shadow-sm),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.hero-kpis article,
.hero-status-row span,
.visual-top,
.visual-bottom,
.visual-bottom span,
.control-strip,
.download-terminal .visual-top,
.script-code {
  background: var(--glass-soft);
  -webkit-backdrop-filter: blur(16px) saturate(145%);
  backdrop-filter: blur(16px) saturate(145%);
}

.metric-card::after {
  inset: auto 18px 0;
  height: 2px;
}

.metric-icon,
.card-icon,
.ops-icon,
.workbench-icon,
.playbook-icon,
.script-summary svg {
  border-radius: 12px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.segment {
  border-radius: 9px;
}

.segment.active {
  background:
    linear-gradient(135deg, var(--ink), color-mix(in srgb, var(--ink) 72%, var(--teal)));
  box-shadow:
    0 8px 18px rgba(17, 24, 39, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.16);
}

:root[data-theme="dark"] .open-link {
  color: #0b1220;
  background:
    linear-gradient(135deg, var(--teal-strong), color-mix(in srgb, var(--blue) 54%, var(--teal-strong))),
    var(--teal-strong);
  border-color: color-mix(in srgb, var(--teal-strong) 74%, transparent);
}

:root[data-theme="dark"] .open-link:hover {
  background:
    linear-gradient(135deg, var(--teal), color-mix(in srgb, var(--blue) 52%, var(--teal))),
    var(--teal);
}

:root[data-theme="dark"] .segment.active {
  color: #071217;
  background:
    linear-gradient(135deg, var(--teal-strong), color-mix(in srgb, var(--blue) 45%, var(--teal-strong)));
}

.toast {
  border: 1px solid var(--line);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--ink) 92%, transparent), color-mix(in srgb, var(--ink) 78%, transparent));
  color: #ffffff;
  -webkit-backdrop-filter: blur(22px) saturate(150%);
  backdrop-filter: blur(22px) saturate(150%);
}

:root[data-theme="dark"] .toast {
  color: #0b1220;
  background:
    linear-gradient(180deg, rgba(247, 251, 255, 0.94), rgba(226, 239, 244, 0.86));
}

/* Rounder system controls for the macOS-style workspace */
.sidebar {
  border-radius: 0;
}

.hero-panel,
.page-hero,
.access-panel,
.download-hero {
  border-radius: 22px;
}

.hero-visual,
.metric-card,
.service-card,
.ops-card,
.workbench-card,
.route-card,
.resource-panel,
.note-panel,
.script-summary article,
.recipe-card,
.recovery-card,
.resource-card,
.script-card,
.domain-table,
.download-list,
.update-grid,
.download-terminal,
.control-strip {
  border-radius: 18px;
}

.copy-line,
.search-box,
.segments,
.sidebar-home,
.topbar .secondary-action,
.topbar .primary-action,
.icon-button,
.primary-action,
.secondary-action,
.open-link,
.ghost-link,
.ghost-button,
.ghost-copy,
.workbench-card a {
  border-radius: 14px;
}

.side-nav a {
  border-radius: 16px;
}

.brand-mark,
.metric-icon,
.card-icon,
.ops-icon,
.workbench-icon,
.script-summary svg {
  border-radius: 16px;
}

.hero-kpis article,
.script-code {
  border-radius: 16px;
}

.segment {
  border-radius: 12px;
}

.toast {
  border-radius: 18px;
}

/* Final color polish: neutral surfaces first, semantic color second */
body {
  background:
    linear-gradient(180deg, #f8fafc 0%, #f4f7fa 48%, #eef3f7 100%),
    var(--bg);
}

:root[data-theme="dark"] body {
  background:
    linear-gradient(180deg, #0d1117 0%, #101720 100%),
    var(--bg);
}

.app-shell,
.dashboard-head,
.settings-head,
.dashboard-panel,
.settings-list,
.page-hero,
.hero-panel,
.access-panel,
.resource-panel,
.service-card,
.workbench-card,
.route-card,
.roadmap-card,
.note-panel,
.script-card,
.resource-card,
.download-hero,
.download-terminal,
.domain-table,
.download-list,
.update-grid {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 88%, transparent), color-mix(in srgb, var(--surface-soft) 76%, transparent)),
    var(--surface);
}

.dashboard-head,
.settings-head,
.dashboard-panel,
.settings-list {
  box-shadow:
    0 16px 42px rgba(15, 23, 42, 0.055),
    inset 0 1px 0 rgba(255, 255, 255, 0.42);
}

:root[data-theme="dark"] .dashboard-head,
:root[data-theme="dark"] .settings-head,
:root[data-theme="dark"] .dashboard-panel,
:root[data-theme="dark"] .settings-list {
  box-shadow:
    0 18px 54px rgba(0, 0, 0, 0.26),
    inset 0 1px 0 rgba(255, 255, 255, 0.07);
}

.primary-action {
  border-color: color-mix(in srgb, var(--teal) 78%, transparent);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--teal) 94%, #ffffff), var(--teal)),
    var(--teal);
  box-shadow:
    0 12px 26px color-mix(in srgb, var(--teal) 20%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.22);
}

.health-item,
.task-row,
.setting-row,
.timeline-list div,
.asset-table div,
.quick-entry-grid a,
.modal-rule-list span {
  background: color-mix(in srgb, var(--surface) 84%, transparent);
}

.metric-card::after,
.service-card::before {
  background: var(--tone, var(--teal));
}

.console-summary-card,
.ops-card,
.workbench-card,
.roadmap-card,
.update-card {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--tone, var(--teal)) 5%, transparent), transparent 64%),
    color-mix(in srgb, var(--surface) 88%, transparent);
}

.status-pill {
  background: color-mix(in srgb, var(--success) 11%, var(--surface));
}

.status-pill.protected {
  color: var(--blue);
  background: color-mix(in srgb, var(--blue) 10%, var(--surface));
}

.status-pill.planned {
  background: color-mix(in srgb, var(--warning) 12%, var(--surface));
}

.visual-top,
.visual-bottom,
.control-strip,
.search-box,
.segments {
  background: color-mix(in srgb, var(--surface) 80%, transparent);
}

/* System console polish */
.dashboard-shell,
.settings-shell {
  gap: 18px;
}

.dashboard-head,
.settings-head,
.dashboard-panel,
.settings-list {
  border-color: color-mix(in srgb, var(--line-strong) 78%, transparent);
}

.system-head {
  min-height: 106px;
  align-items: flex-start;
  padding: 18px 20px;
}

.system-head h2 {
  margin-top: 1px;
  font-size: 26px;
}

.system-head-meta {
  padding-top: 4px;
}

.dashboard-panel {
  position: relative;
  padding: 18px;
  overflow: hidden;
}

.dashboard-panel::before,
.settings-list::before {
  position: absolute;
  inset: 0 0 auto;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.68), transparent);
  content: "";
}

.dashboard-panel-head {
  min-height: 44px;
  align-items: center;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
}

.dashboard-panel h3 {
  font-size: 19px;
}

.health-item,
.task-row,
.timeline-list div,
.asset-table div,
.live-kpi-grid div,
.quick-entry-grid a,
.setting-row,
.group-health-item {
  border-color: color-mix(in srgb, var(--line) 82%, transparent);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 92%, transparent), color-mix(in srgb, var(--surface-soft) 72%, transparent)),
    var(--surface);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.36);
  transition:
    transform 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease,
    background 160ms ease;
}

.health-item:hover,
.task-row:hover,
.timeline-list div:hover,
.asset-table div:hover,
.quick-entry-grid a:hover,
.setting-row:hover,
.group-health-item:hover {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--teal) 34%, var(--line));
  box-shadow:
    0 10px 24px rgba(15, 23, 42, 0.055),
    inset 0 1px 0 rgba(255, 255, 255, 0.42);
}

.status-pill {
  min-height: 28px;
  border: 1px solid color-mix(in srgb, currentColor 16%, transparent);
  padding: 0 10px;
  font-size: 12px;
  line-height: 1;
}

.status-pill svg {
  width: 16px;
  height: 16px;
}

.quick-entry-grid a {
  min-height: 56px;
  border-radius: 16px;
}

.system-quick-grid a {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 34px;
  padding: 0 12px 0 16px;
}

.system-quick-grid a svg {
  width: 34px;
  height: 34px;
  border-radius: 12px;
  padding: 8px;
  background: color-mix(in srgb, var(--teal) 12%, transparent);
}

.service-card {
  min-height: 214px;
  padding: 18px 18px 16px;
  border-radius: 18px;
}

.service-card::before {
  width: 3px;
}

.service-meta-row {
  min-height: 28px;
}

.card-bottom {
  padding-top: 12px;
  border-top: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
}

.service-actions .ghost-button,
.service-actions .secondary-action,
.service-actions .open-link {
  min-height: 38px;
}

.command-pack {
  border-radius: 18px;
  padding: 18px;
  box-shadow:
    var(--shadow-sm),
    inset 0 1px 0 rgba(255, 255, 255, 0.34);
}

.command-pack pre {
  border-radius: 14px;
}

.command-pack-actions {
  display: grid;
  grid-template-columns: 1fr;
  padding-top: 12px;
  border-top: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
}

.settings-list {
  position: relative;
  padding: 12px;
  overflow: hidden;
}

.setting-row {
  min-height: 88px;
  border-radius: 16px;
}

.switch-control {
  min-height: 40px;
  border-radius: 14px;
}

/* Interaction polish: search, modals, command cards */
.global-search-results {
  padding: 10px;
  border-color: color-mix(in srgb, var(--line-strong) 74%, transparent);
}

.global-search-result {
  position: relative;
  min-height: 64px;
  border-radius: 15px;
  padding: 10px 12px;
}

.global-search-result::before {
  width: 34px;
  height: 34px;
  border-radius: 12px;
  grid-row: 1;
  grid-column: 1;
  background: color-mix(in srgb, var(--teal) 10%, transparent);
  content: "";
}

.global-search-result svg {
  position: relative;
  z-index: 1;
  justify-self: center;
  grid-column: 1;
  grid-row: 1;
}

.global-search-result:hover,
.global-search-result:focus-visible,
.global-search-result.is-active {
  box-shadow:
    0 10px 24px rgba(15, 23, 42, 0.07),
    inset 3px 0 0 var(--teal);
}

.global-search-result em {
  min-height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid color-mix(in srgb, var(--line) 76%, transparent);
}

.system-modal {
  border-radius: 24px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--glass-strong) 96%, transparent), color-mix(in srgb, var(--glass) 90%, transparent)),
    var(--surface);
  -webkit-backdrop-filter: blur(24px) saturate(150%);
  backdrop-filter: blur(24px) saturate(150%);
}

.modal-head {
  padding: 20px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 88%, transparent), transparent);
}

.modal-body {
  padding: 20px 20px 24px;
}

.modal-actions {
  padding: 16px 20px;
  background: color-mix(in srgb, var(--surface-soft) 64%, transparent);
  box-shadow: 0 -12px 28px color-mix(in srgb, var(--surface) 72%, transparent);
}

.service-detail-modal {
  width: min(100%, 780px);
}

.service-modal-icon {
  width: 52px;
  height: 52px;
  border-radius: 17px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.34);
}

.service-detail-grid div,
.service-action-button,
.service-related-link,
.modal-rule-list span {
  border-color: color-mix(in srgb, var(--line) 82%, transparent);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 92%, transparent), color-mix(in srgb, var(--surface-soft) 72%, transparent)),
    var(--surface);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.34);
}

.service-detail-grid div {
  min-height: 72px;
  padding: 12px 14px;
}

.service-detail-grid strong {
  font-size: 15px;
}

.service-modal-section {
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
}

.service-detail-modal .modal-body {
  padding-bottom: 30px;
}

.service-modal-section-head {
  align-items: flex-end;
}

.service-action-button {
  min-height: 82px;
  border-radius: 16px;
}

.service-action-button svg,
.service-related-link svg {
  width: 22px;
  height: 22px;
}

.service-related-link {
  min-height: 78px;
  border-radius: 16px;
}

.command-pack {
  position: relative;
  overflow: hidden;
}

.command-pack::before {
  position: absolute;
  inset: 0 auto 0 0;
  width: 3px;
  background: var(--tone, var(--teal));
  content: "";
}

.command-pack-head {
  min-height: 44px;
}

.command-pack pre {
  position: relative;
  min-height: 180px;
  padding: 34px 14px 14px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--ink) 9%, transparent), transparent 62%),
    color-mix(in srgb, var(--surface-soft) 88%, transparent);
}

.command-pack pre::before {
  position: absolute;
  top: 10px;
  left: 13px;
  width: 35px;
  height: 8px;
  border-radius: 999px;
  background:
    radial-gradient(circle at 4px 4px, var(--coral) 0 3px, transparent 3.5px),
    radial-gradient(circle at 17px 4px, var(--amber) 0 3px, transparent 3.5px),
    radial-gradient(circle at 30px 4px, var(--teal) 0 3px, transparent 3.5px);
  content: "";
}

.command-pack code {
  display: block;
  min-width: max-content;
}

.command-pack-actions .secondary-action,
.command-pack-actions .open-link {
  width: 100%;
  min-width: 0;
}

.command-pack-actions svg {
  flex: 0 0 auto;
}

.command-pack-actions span {
  flex: 0 0 auto;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Overview final layout polish */
.console-overview-grid {
  gap: 12px;
  align-items: stretch;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.95fr) minmax(260px, 0.72fr);
}

.system-head {
  min-height: 88px;
  padding: 15px 18px;
}

.system-head h2 {
  font-size: 25px;
}

.system-head p {
  max-width: 720px;
}

.dashboard-panel {
  min-height: 218px;
}

.runtime-panel .compact-health-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.runtime-panel .health-item {
  min-height: 64px;
  gap: 10px;
  padding: 10px;
}

.runtime-panel .health-icon {
  width: 36px;
  height: 36px;
  border-radius: 12px;
}

.health-item {
  border-left: 3px solid color-mix(in srgb, var(--tone, var(--teal)) 42%, var(--line));
}

.health-item[data-health-state="online"],
.health-item[data-health-state="protected"] {
  border-color: color-mix(in srgb, var(--success) 34%, var(--line));
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--success) 8%, transparent), transparent 42%),
    color-mix(in srgb, var(--surface) 90%, transparent);
}

.health-item[data-health-state="degraded"],
.health-item[data-health-state="planned"] {
  border-color: color-mix(in srgb, var(--warning) 34%, var(--line));
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--warning) 8%, transparent), transparent 42%),
    color-mix(in srgb, var(--surface) 90%, transparent);
}

.health-item[data-health-state="down"] {
  border-color: color-mix(in srgb, var(--coral) 38%, var(--line));
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--coral) 9%, transparent), transparent 42%),
    color-mix(in srgb, var(--surface) 90%, transparent);
}

.monitor-strip {
  margin-top: 10px;
  padding-top: 10px;
}

.live-kpi-grid div {
  min-height: 66px;
  padding: 10px 12px;
}

.live-kpi-grid strong {
  font-size: 22px;
}

.quick-panel,
.todo-panel,
.updates-panel,
.asset-panel {
  display: flex;
  flex-direction: column;
}

.quick-entry-grid,
.task-list,
.timeline-list,
.console-asset-table {
  flex: 1;
}

.quick-entry-group {
  min-width: 0;
  display: grid;
  gap: 8px;
}

.quick-entry-group + .quick-entry-group {
  padding-top: 10px;
  border-top: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
}

.quick-entry-group-label {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.quick-entry-group-grid {
  min-width: 0;
  display: grid;
  gap: 8px;
}

.quick-panel .quick-entry-grid {
  flex: 0 0 auto;
  align-content: start;
}

.quick-panel .quick-entry-group-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.system-quick-grid {
  gap: 10px;
}

.system-quick-grid a {
  min-height: 44px;
  gap: 8px;
  padding: 0 10px;
  border-radius: 13px;
  font-size: 13px;
}

.todo-panel,
.updates-panel,
.asset-panel {
  min-height: 270px;
}

.task-row,
.timeline-list div,
.asset-panel .asset-table div {
  min-height: 58px;
}

.asset-panel .asset-table div {
  padding: 10px 11px;
}

@media (min-width: 1280px) {
  .runtime-panel .compact-health-grid {
    grid-template-columns: repeat(auto-fit, minmax(158px, 1fr));
  }

  .runtime-panel .health-item {
    min-height: 86px;
    grid-template-columns: 30px minmax(0, 1fr);
    align-content: center;
    align-items: center;
    gap: 6px 8px;
    padding: 9px;
  }

  .runtime-panel .health-icon {
    width: 30px;
    height: 30px;
    border-radius: 10px;
  }

  .runtime-panel .health-item > div {
    min-width: 0;
  }

  .runtime-panel .health-item strong {
    font-size: 13px;
    line-height: 1.25;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .runtime-panel .health-item .status-pill {
    grid-column: 1 / -1;
    justify-self: start;
    min-height: 24px;
    gap: 4px;
    padding: 0 8px;
    font-size: 11px;
  }

  .runtime-panel .health-item small {
    min-height: 0;
    margin-top: 2px;
    font-size: 11px;
    line-height: 1.35;
    display: -webkit-box;
    overflow: hidden;
    overflow-wrap: normal;
    word-break: normal;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
  }

  .runtime-panel .health-item .status-pill svg {
    width: 13px;
    height: 13px;
  }
}

/* Admin UI direction: lightweight system console inspired by mature dashboards */
:root {
  --teal: #0d9488;
  --teal-strong: #0f766e;
  --blue: #2563eb;
  --amber: #d97706;
  --coral: #dc5f57;
  --line: rgba(148, 163, 184, 0.24);
  --line-strong: rgba(100, 116, 139, 0.32);
  --radius-lg: 22px;
  --radius-md: 14px;
  --radius-sm: 10px;
  --shadow-sm: 0 8px 22px rgba(15, 23, 42, 0.055);
  --shadow-md: 0 18px 46px rgba(15, 23, 42, 0.095);
  --shadow-lg: 0 26px 80px rgba(15, 23, 42, 0.13);
}

:root[data-theme="dark"] {
  --line: rgba(148, 163, 184, 0.18);
  --line-strong: rgba(159, 178, 201, 0.28);
  --shadow-sm: 0 10px 24px rgba(0, 0, 0, 0.24);
  --shadow-md: 0 18px 50px rgba(0, 0, 0, 0.32);
  --shadow-lg: 0 28px 84px rgba(0, 0, 0, 0.42);
}

body {
  background:
    linear-gradient(180deg, #f8fafc 0%, #f5f8fb 52%, #eef3f7 100%),
    var(--bg);
}

body::before {
  opacity: 0.72;
  background-size: 28px 28px;
}

.app-shell {
  grid-template-columns: 272px minmax(0, 1fr);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 96%, transparent), color-mix(in srgb, var(--surface-soft) 78%, transparent)),
    var(--surface);
}

.desktop-chrome {
  height: 46px;
  background: color-mix(in srgb, var(--surface) 90%, transparent);
}

.sidebar {
  gap: 18px;
  padding: 68px 16px 18px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 94%, transparent), color-mix(in srgb, var(--surface-soft) 78%, transparent)),
    var(--surface);
  box-shadow: none;
}

.brand {
  gap: 11px;
  padding: 0 2px;
}

.brand-mark {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background:
    linear-gradient(135deg, #102033, color-mix(in srgb, #102033 76%, var(--teal))),
    #102033;
}

.brand strong {
  font-size: 16px;
}

.brand small {
  font-size: 12px;
}

.side-nav {
  gap: 14px;
}

.nav-group {
  gap: 5px;
}

.nav-section-label {
  margin: 0 8px 4px;
  color: color-mix(in srgb, var(--muted) 82%, var(--text));
  font-size: 10px;
}

.side-nav a {
  position: relative;
  min-height: 38px;
  border-radius: 10px;
  gap: 9px;
  padding: 0 10px;
  color: color-mix(in srgb, var(--muted) 88%, var(--text));
  box-shadow: none;
  transform: none;
}

.side-nav a svg {
  width: 18px;
  height: 18px;
}

.side-nav a:hover,
.side-nav a.active {
  border-color: color-mix(in srgb, var(--teal) 24%, var(--line));
  background: color-mix(in srgb, var(--teal) 8%, var(--surface));
  color: var(--text);
  box-shadow: none;
  transform: none;
}

.side-nav a.active {
  box-shadow: inset 3px 0 0 var(--teal);
}

.nav-badge {
  min-width: 30px;
  min-height: 18px;
  padding: 0 6px;
  font-size: 10px;
}

.domain-box {
  border-radius: 12px;
  padding: 12px;
  box-shadow: none;
}

.copy-line {
  min-height: 38px;
  border-radius: 10px;
}

.rail-status {
  min-height: 30px;
  border-radius: 10px;
}

.workspace {
  padding: 74px 28px 28px;
}

.topbar {
  gap: 14px;
  margin: -74px -28px 48px;
  padding: 58px 28px 12px;
  background: color-mix(in srgb, var(--surface) 86%, transparent);
}

.topbar h1 {
  font-size: 27px;
}

.global-search {
  width: min(380px, 30vw);
  min-width: 260px;
  height: 40px;
  border-radius: 11px;
  background: color-mix(in srgb, var(--surface) 92%, transparent);
}

.global-search-results {
  border-radius: 12px;
}

.global-search-result {
  min-height: 52px;
  border-radius: 9px;
}

.top-actions {
  gap: 8px;
}

.icon-button,
.primary-action,
.secondary-action,
.open-link,
.ghost-link,
.ghost-button,
.ghost-copy,
.workbench-card a {
  min-height: 38px;
  border-radius: 10px;
}

.icon-button {
  width: 38px;
}

.primary-action,
.secondary-action {
  padding: 0 12px;
  font-size: 14px;
}

.primary-action {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--teal) 94%, #ffffff), var(--teal-strong)),
    var(--teal);
}

.dashboard-shell,
.settings-shell {
  gap: 12px;
}

.dashboard-head,
.settings-head,
.dashboard-panel,
.settings-list,
.page-hero,
.hero-panel,
.access-panel,
.resource-panel,
.service-card,
.workbench-card,
.route-card,
.roadmap-card,
.note-panel,
.script-card,
.resource-card,
.download-hero,
.download-terminal,
.domain-table,
.download-list,
.update-grid {
  border-radius: 12px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 96%, transparent), color-mix(in srgb, var(--surface-soft) 74%, transparent)),
    var(--surface);
  box-shadow:
    0 10px 26px rgba(15, 23, 42, 0.045),
    inset 0 1px 0 rgba(255, 255, 255, 0.38);
}

.dashboard-head,
.settings-head {
  min-height: 86px;
  padding: 16px;
}

.system-head {
  min-height: 78px;
  padding: 14px 16px;
}

.system-head h2 {
  font-size: 23px;
}

.system-head p {
  max-width: 760px;
  margin-top: 4px;
  font-size: 12px;
}

.system-head-meta {
  gap: 6px;
}

.console-overview-grid .dashboard-panel {
  padding: 14px;
}

.dashboard-panel-head {
  min-height: 36px;
  margin-bottom: 12px;
  padding-bottom: 10px;
}

.dashboard-panel h3 {
  font-size: 18px;
}

.eyebrow {
  margin-bottom: 4px;
  font-size: 11px;
}

.status-pill {
  min-height: 24px;
  border-radius: 999px;
  gap: 5px;
  padding: 0 8px;
  font-size: 11px;
}

.status-pill svg {
  width: 14px;
  height: 14px;
}

.health-item,
.task-row,
.timeline-list div,
.asset-table div,
.live-kpi-grid div,
.quick-entry-grid a,
.setting-row,
.group-health-item,
.modal-rule-list span {
  border-radius: 10px;
  box-shadow: none;
}

.health-item:hover,
.task-row:hover,
.timeline-list div:hover,
.asset-table div:hover,
.quick-entry-grid a:hover,
.setting-row:hover,
.group-health-item:hover {
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.05);
}

.runtime-panel .health-item {
  border-left-width: 3px;
}

.health-icon,
.setting-icon,
.card-icon,
.metric-icon,
.ops-icon,
.workbench-icon,
.script-summary svg {
  border-radius: 10px;
}

.live-kpi-grid {
  gap: 8px;
}

.live-kpi-grid div {
  min-height: 58px;
  padding: 9px 10px;
}

.live-kpi-grid strong {
  font-size: 20px;
}

.monitor-strip {
  margin-top: 9px;
  padding-top: 9px;
}

.quick-entry-group {
  gap: 7px;
}

.quick-entry-group + .quick-entry-group {
  padding-top: 9px;
}

.quick-entry-group-label {
  font-size: 10px;
}

.quick-entry-group-grid {
  gap: 7px;
}

.system-quick-grid a {
  min-height: 40px;
  border-radius: 10px;
  padding: 0 8px 0 11px;
}

.system-quick-grid a svg {
  width: 30px;
  height: 30px;
  border-radius: 9px;
  padding: 7px;
}

.task-row {
  min-height: 62px;
  padding: 10px 11px 10px 28px;
}

.task-dot {
  left: 11px;
  top: 17px;
}

.timeline-list div {
  min-height: 50px;
  padding: 9px 10px;
}

.asset-panel .asset-table div {
  padding: 9px 10px;
}

.todo-panel,
.updates-panel,
.asset-panel {
  min-height: 250px;
}

.todo-panel .task-list,
.updates-panel .timeline-list,
.asset-panel .console-asset-table {
  flex: 0 0 auto;
  align-content: start;
}

.page-hero {
  min-height: 160px;
  padding: 20px 22px;
}

.page-hero h2 {
  font-size: clamp(26px, 2.5vw, 36px);
}

.page-hero p {
  margin-top: 10px;
  font-size: 14px;
}

@media (min-width: 761px) {
  .app-shell {
    width: 100%;
    min-height: 100vh;
    margin: 0;
    border-width: 0 0 1px;
    border-radius: 0;
    box-shadow: none;
  }

  .desktop-chrome {
    display: none;
  }

  .sidebar {
    top: 0;
    height: 100vh;
    padding: 22px 16px 18px;
  }

  .workspace {
    width: 100%;
    max-width: none;
    padding: 0 28px 28px;
  }

  .topbar {
    top: 0;
    min-height: 72px;
    margin: 0 -28px 16px;
    padding: 16px 28px 14px;
    border-bottom: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
    background:
      linear-gradient(180deg, color-mix(in srgb, var(--surface) 94%, transparent), color-mix(in srgb, var(--surface) 84%, transparent)),
      var(--surface);
  }

  .topbar h1 {
    font-size: 26px;
  }

  .system-head {
    min-height: 76px;
  }

  .console-overview-grid {
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.95fr) minmax(270px, 0.55fr);
    grid-template-areas:
      "runtime runtime quick"
      "todo updates assets";
  }

  .runtime-panel .compact-health-grid {
    grid-template-columns: repeat(auto-fit, minmax(158px, 1fr));
  }

  .todo-panel,
  .updates-panel,
  .asset-panel {
    min-height: 250px;
  }
}

@media (min-width: 1280px) {
  .runtime-panel .health-item {
    min-height: 78px;
  }
}

/* Unified backend pages: services, server, resources, settings */
.view-panel:not([data-view="overview"]) {
  min-width: 0;
}

.view-panel:not([data-view="overview"]) .page-hero,
.settings-head {
  min-height: auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  border-radius: 12px;
  box-shadow: none;
}

.view-panel:not([data-view="overview"]) .page-hero h2,
.settings-head h2 {
  font-size: 23px;
  line-height: 1.15;
}

.view-panel:not([data-view="overview"]) .page-hero p,
.settings-head p {
  max-width: 760px;
  margin-top: 5px;
  font-size: 13px;
  line-height: 1.45;
}

.page-hero-actions,
.dashboard-head-actions {
  gap: 8px;
}

.section-block {
  margin-top: 14px;
}

.section-heading {
  min-height: 40px;
  margin-bottom: 10px;
}

.section-heading h2 {
  font-size: 20px;
}

.control-strip {
  min-height: 56px;
  margin-top: 12px;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 8px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 96%, transparent), color-mix(in srgb, var(--surface-soft) 70%, transparent)),
    var(--surface);
  box-shadow: none;
}

#serviceControlStrip {
  position: sticky;
  top: 86px;
  z-index: 2;
  margin-bottom: 18px;
  -webkit-backdrop-filter: blur(18px) saturate(145%);
  backdrop-filter: blur(18px) saturate(145%);
}

.search-box {
  height: 40px;
  border-radius: 10px;
}

.segments {
  min-height: 40px;
  border-radius: 10px;
  padding: 3px;
  flex-wrap: wrap;
}

.service-result-summary {
  min-height: 40px;
  border: 1px solid color-mix(in srgb, var(--line) 90%, transparent);
  border-radius: 10px;
  padding: 0 12px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.service-result-summary strong {
  color: var(--teal-strong);
  font-size: 18px;
  line-height: 1;
}

.service-result-summary em {
  color: var(--muted);
  font-style: normal;
}

.service-view-toggle,
.service-search-chips {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.service-view-toggle {
  min-height: 40px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 3px;
  background: color-mix(in srgb, var(--surface-soft) 78%, transparent);
}

.service-view-toggle button,
.service-search-chips button {
  border: 0;
  border-radius: 8px;
  min-height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 0 10px;
  color: var(--muted);
  background: transparent;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.service-view-toggle button.active,
.service-search-chips button.active {
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 10%, var(--surface));
}

.service-view-toggle svg {
  width: 15px;
  height: 15px;
}

.service-search-chips {
  flex: 1 1 100%;
  flex-wrap: wrap;
}

.service-search-chips button {
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  background: color-mix(in srgb, var(--surface) 82%, transparent);
}

.segment {
  min-height: 32px;
  border-radius: 8px;
  gap: 7px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
}

.segment em {
  min-width: 20px;
  border-radius: 999px;
  padding: 2px 6px;
  color: inherit;
  background: color-mix(in srgb, var(--surface-soft) 82%, transparent);
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
  line-height: 1.25;
  text-align: center;
}

.service-overview-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: 12px;
}

[data-page-hero="services"] {
  min-height: 112px;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

[data-page-hero="services"] h2 {
  font-size: clamp(24px, 3vw, 34px);
}

[data-page-hero="services"] p:not(.eyebrow) {
  max-width: 640px;
}

.service-stat-card {
  min-width: 0;
  min-height: 68px;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  border-radius: 12px;
  padding: 12px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 98%, transparent), color-mix(in srgb, var(--surface-soft) 58%, transparent)),
    var(--surface);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.service-stat-card > span {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 9%, var(--surface-soft));
}

.service-stat-card strong,
.service-stat-card small,
.service-stat-card em {
  display: block;
}

.service-stat-card strong {
  font-size: 20px;
  line-height: 1;
}

.service-stat-card small {
  margin-top: 4px;
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}

.service-stat-card em {
  margin-top: 2px;
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
  overflow-wrap: anywhere;
}

.service-grid {
  grid-template-columns: 1fr;
  gap: 10px;
  min-height: 260px;
  align-content: start;
  scroll-margin-top: 112px;
}

.service-launchpad {
  margin-top: 12px;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  border-radius: 12px;
  padding: 12px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 98%, transparent), color-mix(in srgb, var(--surface-soft) 62%, transparent)),
    var(--surface);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.service-launchpad-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.service-launchpad-head h2 {
  margin: 0;
  color: var(--text);
  font-size: 18px;
}

.service-launchpad-head p:not(.eyebrow) {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 13px;
}

.service-launchpad-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 8px;
}

.service-launch-card {
  --tone: var(--teal);
  min-width: 0;
  min-height: 98px;
  border: 1px solid color-mix(in srgb, var(--tone) 14%, var(--line));
  border-radius: 12px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  grid-template-rows: auto auto auto;
  align-items: start;
  gap: 5px 11px;
  padding: 13px;
  color: var(--text);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--tone) 5%, transparent), transparent 68%),
    color-mix(in srgb, var(--surface) 88%, transparent);
  text-decoration: none;
  transition:
    transform 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease;
}

.service-launch-card:hover {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--tone) 34%, var(--line));
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.055);
}

.service-launch-card.tone-blue {
  --tone: var(--blue);
}

.service-launch-card.tone-amber {
  --tone: var(--amber);
}

.service-launch-card.tone-coral {
  --tone: var(--coral);
}

.service-launch-card.tone-slate {
  --tone: var(--slate);
}

.service-launch-card > span {
  grid-row: 1 / span 3;
  width: 40px;
  height: 40px;
  border-radius: 11px;
  display: grid;
  place-items: center;
  color: var(--tone);
  background: color-mix(in srgb, var(--tone) 10%, var(--surface-soft));
}

.service-launch-card svg {
  width: 18px;
  height: 18px;
}

.service-launch-card strong,
.service-launch-card small,
.service-launch-card em {
  min-width: 0;
}

.service-launch-card strong {
  font-size: 14px;
  line-height: 1.2;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.service-launch-card small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.35;
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.service-launch-card em {
  width: fit-content;
  max-width: 100%;
  min-height: 22px;
  border: 1px solid color-mix(in srgb, var(--tone) 18%, var(--line));
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  padding: 0 8px;
  color: var(--tone);
  background: color-mix(in srgb, var(--tone) 8%, var(--surface));
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.service-directory-group {
  --tone: var(--teal);
  min-width: 0;
  min-height: 400px;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  border-radius: 12px;
  padding: 12px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--tone) 3%, transparent), transparent 58%),
    var(--surface);
}

.service-directory-group.tone-blue {
  --tone: var(--blue);
}

.service-directory-group.tone-amber {
  --tone: var(--amber);
}

.service-directory-group.tone-coral {
  --tone: var(--coral);
}

.service-directory-group.tone-slate {
  --tone: var(--slate);
}

.service-directory-head {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  margin-bottom: 10px;
  padding: 0 2px 10px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
}

.service-directory-head > span {
  width: 36px;
  height: 36px;
  border: 1px solid color-mix(in srgb, var(--tone) 15%, var(--line));
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: var(--tone);
  background: color-mix(in srgb, var(--tone) 9%, var(--surface-soft));
}

.service-directory-head h3 {
  margin: 0;
  color: var(--text);
  font-size: 16px;
}

.service-directory-head p {
  margin: 3px 0 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.service-directory-head em {
  min-height: 28px;
  border: 1px solid color-mix(in srgb, var(--tone) 18%, var(--line));
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  padding: 0 10px;
  color: var(--tone);
  background: color-mix(in srgb, var(--tone) 8%, var(--surface));
  font-size: 12px;
  font-style: normal;
  font-weight: 900;
  white-space: nowrap;
}

.service-list {
  display: grid;
  gap: 8px;
  align-content: start;
}

.service-card-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(238px, 1fr));
  gap: 10px;
  align-content: start;
}

.service-app-card {
  --tone: var(--teal);
  min-width: 0;
  min-height: 156px;
  border: 1px solid color-mix(in srgb, var(--tone) 16%, var(--line));
  border-radius: 12px;
  display: grid;
  gap: 10px;
  padding: 12px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--tone) 4%, transparent), transparent 70%),
    color-mix(in srgb, var(--surface) 90%, transparent);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.28);
  transition:
    transform 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease;
}

.service-app-card:hover {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--tone) 30%, var(--line));
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.052);
}

.service-app-card.tone-blue {
  --tone: var(--blue);
}

.service-app-card.tone-amber {
  --tone: var(--amber);
}

.service-app-card.tone-coral {
  --tone: var(--coral);
}

.service-app-card.tone-slate {
  --tone: var(--slate);
}

.service-app-head {
  min-width: 0;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  align-items: start;
}

.service-app-head h3 {
  margin: 0;
  color: var(--text);
  font-size: 15px;
  line-height: 1.25;
}

.service-app-head p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.42;
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.service-app-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  align-self: end;
}

.service-app-actions .primary-action,
.service-app-actions .secondary-action,
.service-app-actions .ghost-link {
  min-height: 34px;
  border-radius: 9px;
  justify-content: center;
}

.service-row {
  --tone: var(--teal);
  min-width: 0;
  min-height: 72px;
  border: 1px solid color-mix(in srgb, var(--line) 86%, transparent);
  border-radius: 10px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 11px;
  align-items: center;
  padding: 10px;
  background: color-mix(in srgb, var(--surface) 88%, transparent);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.28);
  transition:
    transform 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease;
}

.service-row:hover {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--tone) 28%, var(--line));
  box-shadow:
    0 10px 22px rgba(15, 23, 42, 0.052),
    inset 0 1px 0 rgba(255, 255, 255, 0.34);
}

.service-row.tone-blue {
  --tone: var(--blue);
}

.service-row.tone-amber {
  --tone: var(--amber);
}

.service-row.tone-coral {
  --tone: var(--coral);
}

.service-row.tone-slate {
  --tone: var(--slate);
}

.service-row-icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: var(--tone);
  background: color-mix(in srgb, var(--tone) 10%, var(--surface-soft));
}

.service-row-main {
  min-width: 0;
}

.service-row-title,
.service-row-meta,
.service-row-actions {
  display: flex;
  align-items: center;
}

.service-row-title {
  gap: 8px;
  flex-wrap: wrap;
}

.service-row-title h3 {
  margin: 0;
  color: var(--text);
  font-size: 15px;
}

.service-row-main p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
}

.service-row-meta {
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 7px;
}

.service-row-meta span {
  min-height: 23px;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 0 8px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-soft) 78%, transparent);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
}

.service-row-meta .visibility-chip {
  border-color: color-mix(in srgb, var(--teal) 22%, var(--line));
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 8%, var(--surface));
}

.visibility-chip.visibility-private {
  border-color: color-mix(in srgb, var(--blue) 20%, var(--line));
  color: var(--blue);
  background: color-mix(in srgb, var(--blue) 8%, var(--surface));
}

.visibility-chip.visibility-ops {
  border-color: color-mix(in srgb, var(--amber) 24%, var(--line));
  color: var(--amber);
  background: color-mix(in srgb, var(--amber) 10%, var(--surface));
}

.service-row-meta svg {
  width: 13px;
  height: 13px;
  color: var(--tone);
}

.service-row-actions {
  justify-content: flex-end;
  gap: 8px;
}

.service-row-actions .primary-action,
.service-row-actions .secondary-action,
.service-row-actions .ghost-link {
  min-height: 34px;
  border-radius: 9px;
  white-space: nowrap;
}

.service-empty-state {
  min-height: 400px;
  border: 1px dashed color-mix(in srgb, var(--line-strong) 72%, transparent);
  border-radius: 12px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 8px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface) 80%, transparent);
  text-align: center;
}

.service-empty-state h3 {
  margin: 0;
  color: var(--text);
}

.service-empty-state p {
  margin: 0;
}

@media (max-width: 1180px) {
  .service-launchpad-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .service-row {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .service-row-actions {
    grid-column: 1 / -1;
    justify-content: flex-start;
  }
}

@media (max-width: 760px) {
  #serviceControlStrip {
    position: static;
    top: auto;
    margin-bottom: 14px;
  }

  .service-grid {
    min-height: 320px;
    scroll-margin-top: 18px;
  }

  .service-view-toggle,
  .service-search-chips {
    width: 100%;
  }

  .service-view-toggle button {
    flex: 1;
  }

  .service-directory-group {
    min-height: 320px;
  }

  .service-empty-state {
    min-height: 320px;
  }

  .service-launchpad-head,
  .service-directory-head {
    align-items: flex-start;
  }

  .service-launchpad-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    overflow: visible;
    padding-bottom: 0;
    scroll-snap-type: none;
  }

  .service-launch-card {
    grid-template-columns: 1fr;
    min-height: 128px;
    gap: 7px;
    padding: 12px;
    scroll-snap-align: none;
  }

  .service-launch-card > span {
    grid-row: auto;
    width: 36px;
    height: 36px;
  }

  .service-launch-card strong {
    white-space: normal;
  }

  .service-launch-card em {
    width: 100%;
    justify-content: center;
  }

  .service-card-list {
    grid-template-columns: 1fr;
  }

  .service-row {
    grid-template-columns: 42px minmax(0, 1fr);
    align-items: center;
  }

  .service-row-icon {
    width: 42px;
    height: 42px;
  }

  .service-row-actions {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .service-row-actions .primary-action,
  .service-row-actions .secondary-action,
  .service-row-actions .ghost-link {
    width: 100%;
    justify-content: center;
  }
}

@media (max-width: 430px) {
  .service-launchpad-grid {
    grid-template-columns: 1fr;
  }

  .service-overview-strip {
    grid-template-columns: 1fr 1fr;
  }

  .service-launch-card {
    min-height: 108px;
    grid-template-columns: auto minmax(0, 1fr);
  }

  .service-launch-card > span {
    grid-row: 1 / span 3;
  }

  .service-launch-card em {
    width: fit-content;
    justify-content: flex-start;
  }
}

.service-card {
  min-height: auto;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  grid-template-areas:
    "top main meta"
    "top foot actions";
  align-items: center;
  gap: 10px 12px;
  padding: 12px;
  border-radius: 12px;
}

.service-card::before {
  width: 3px;
}

.service-card:hover,
.workbench-card:hover,
.command-pack:hover,
.resource-panel:hover,
.setting-row:hover {
  transform: translateY(-1px);
}

.service-card .card-top {
  grid-area: top;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 7px;
}

.service-card .card-icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
}

.service-card-main {
  grid-area: main;
  min-width: 0;
}

.service-card h3 {
  font-size: 16px;
}

.service-card p {
  margin-top: 5px;
  font-size: 13px;
  line-height: 1.5;
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.service-meta-row {
  grid-area: meta;
  justify-content: flex-end;
  gap: 6px;
}

.service-domain {
  max-width: 180px;
}

.service-footnote {
  grid-area: foot;
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  color: var(--muted);
  font-size: 12px;
}

.service-footnote span {
  min-width: 0;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  overflow-wrap: anywhere;
}

.service-footnote svg {
  width: 14px;
  height: 14px;
  color: var(--teal-strong);
}

.service-card .card-bottom {
  grid-area: actions;
  justify-content: flex-end;
  padding-top: 0;
  border-top: 0;
}

.workbench-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.workbench-card {
  min-height: 118px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  padding: 13px;
  border-radius: 12px;
}

.workbench-icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
}

.workbench-card h3 {
  font-size: 16px;
}

.workbench-card p {
  margin-top: 5px;
  font-size: 13px;
  line-height: 1.5;
}

.workbench-card a {
  min-width: 86px;
  min-height: 34px;
  border-radius: 9px;
  white-space: nowrap;
}

.server-security-summary {
  min-height: 68px;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: 12px;
  margin-bottom: 10px;
  padding: 12px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--teal) 8%, transparent), transparent 52%),
    color-mix(in srgb, var(--surface) 94%, transparent);
}

.server-security-summary.tone-degraded {
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--amber) 10%, transparent), transparent 54%),
    color-mix(in srgb, var(--surface) 94%, transparent);
}

.server-security-summary .summary-icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 11%, var(--surface-soft));
}

.server-security-summary.tone-degraded .summary-icon {
  color: var(--amber-strong);
  background: color-mix(in srgb, var(--amber) 13%, var(--surface-soft));
}

.server-security-summary strong,
.server-security-summary p {
  display: block;
}

.server-security-summary strong {
  font-size: 15px;
}

.server-security-summary p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.server-summary-chips {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
}

.server-summary-chips span {
  min-height: 26px;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  padding: 0 9px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-soft) 78%, transparent);
  font-size: 12px;
  font-weight: 800;
  white-space: nowrap;
}

.server-today-strip {
  --tone: var(--teal);
  min-width: 0;
  min-height: 58px;
  border: 1px solid color-mix(in srgb, var(--tone) 20%, var(--line));
  border-radius: 12px;
  display: grid;
  grid-template-columns: auto minmax(180px, 1fr) repeat(4, minmax(90px, 0.32fr));
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
  padding: 10px 12px;
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--tone) 8%, transparent), transparent 54%),
    color-mix(in srgb, var(--surface) 94%, transparent);
  box-shadow:
    0 8px 22px rgba(15, 23, 42, 0.04),
    inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.server-today-strip.tone-degraded {
  --tone: var(--amber);
}

.server-today-strip.tone-planned {
  --tone: var(--slate);
}

.server-today-icon {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: var(--tone);
  background: color-mix(in srgb, var(--tone) 10%, var(--surface-soft));
}

.server-today-strip span,
.server-today-strip strong {
  display: block;
  min-width: 0;
}

.server-today-strip div:not(.server-today-main) span,
.server-today-main span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
}

.server-today-strip strong {
  margin-top: 2px;
  color: var(--text);
  font-size: 13px;
  line-height: 1.25;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.server-today-main strong {
  color: var(--tone);
  font-size: 16px;
}

.server-overview-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 10px;
}

.server-entry-groups,
.server-entry-group,
.server-group-grid {
  min-width: 0;
}

#serverCardGrid {
  display: block;
}

.server-entry-group {
  display: grid;
  gap: 8px;
}

.server-entry-group + .server-entry-group {
  margin-top: 12px;
}

.server-entry-group-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  color: var(--muted);
}

.server-entry-group-head strong {
  color: var(--text);
  font-size: 14px;
}

.server-entry-group-head span {
  font-size: 12px;
  overflow-wrap: anywhere;
}

.server-group-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.server-entry-card {
  --entry-tone: var(--teal);
  min-width: 0;
  min-height: 92px;
  border: 1px solid color-mix(in srgb, var(--entry-tone) 18%, var(--line));
  border-radius: 12px;
  padding: 12px;
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--entry-tone) 7%, transparent), transparent 58%),
    var(--surface);
  box-shadow: var(--shadow-sm);
}

.server-entry-card.tone-blue {
  --entry-tone: var(--blue);
}

.server-entry-card.tone-amber {
  --entry-tone: var(--amber);
}

.server-entry-card.tone-coral {
  --entry-tone: var(--coral);
}

.server-entry-icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: var(--entry-tone);
  background: color-mix(in srgb, var(--entry-tone) 10%, var(--surface-soft));
}

.server-entry-icon svg {
  width: 19px;
  height: 19px;
}

.server-entry-main {
  min-width: 0;
}

.server-entry-main h3 {
  margin: 0;
  font-size: 16px;
  line-height: 1.2;
}

.server-entry-main p,
.server-entry-main small {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.server-entry-main p {
  margin: 6px 0 0;
  color: var(--text);
  font-size: 12px;
  font-weight: 850;
}

.server-entry-main small {
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.server-entry-meta {
  margin-top: 7px;
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.server-entry-action {
  min-height: 36px;
  border: 1px solid color-mix(in srgb, var(--entry-tone) 22%, var(--line));
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 0 12px;
  color: var(--entry-tone);
  background: color-mix(in srgb, var(--entry-tone) 8%, var(--surface));
  font-size: 13px;
  font-weight: 900;
  white-space: nowrap;
}

.server-entry-action svg {
  width: 15px;
  height: 15px;
}

.server-entry-action:hover,
.server-entry-action:focus-visible {
  border-color: color-mix(in srgb, var(--entry-tone) 38%, var(--line));
  background: color-mix(in srgb, var(--entry-tone) 12%, var(--surface));
  transform: translateY(-1px);
}

.server-stat-card {
  min-width: 0;
  min-height: 64px;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  border-radius: 12px;
  padding: 10px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 98%, transparent), color-mix(in srgb, var(--surface-soft) 58%, transparent)),
    var(--surface);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.server-stat-card > span {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 9%, var(--surface-soft));
}

.server-stat-card strong,
.server-stat-card small,
.server-stat-card em {
  display: block;
}

.server-stat-card strong {
  font-size: 18px;
  line-height: 1;
}

.server-stat-card small {
  margin-top: 3px;
  color: var(--text);
  font-size: 12px;
  font-weight: 800;
}

.server-stat-card em {
  margin-top: 1px;
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  overflow-wrap: anywhere;
}

.server-card-meta {
  margin-top: 8px;
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.server-domain {
  max-width: 190px;
  min-height: 24px;
  border: 1px solid var(--line);
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  padding: 0 8px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-soft) 82%, transparent);
  font-size: 12px;
  overflow-wrap: anywhere;
}

.server-risk-pill {
  min-height: 24px;
  border: 1px solid color-mix(in srgb, var(--amber) 22%, var(--line));
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  padding: 0 8px;
  color: var(--amber-strong);
  background: color-mix(in srgb, var(--amber) 10%, var(--surface));
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.server-risk-pill.tone-coral {
  border-color: color-mix(in srgb, var(--coral) 28%, var(--line));
  color: var(--coral);
  background: color-mix(in srgb, var(--coral) 9%, var(--surface));
}

.server-risk-pill.tone-blue {
  border-color: color-mix(in srgb, var(--blue) 24%, var(--line));
  color: var(--blue);
  background: color-mix(in srgb, var(--blue) 8%, var(--surface));
}

.server-risk-pill.tone-amber {
  border-color: color-mix(in srgb, var(--amber) 26%, var(--line));
  color: var(--amber);
  background: color-mix(in srgb, var(--amber) 10%, var(--surface));
}

.server-risk-pill.tone-teal {
  border-color: color-mix(in srgb, var(--teal) 26%, var(--line));
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 9%, var(--surface));
}

.workbench-card small {
  display: block;
  margin-top: 7px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.server-admin-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  gap: 10px;
}

.server-flow-panel,
.server-safety-panel,
.server-trouble-panel,
.server-status-panel {
  min-width: 0;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  border-radius: 12px;
  padding: 13px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 98%, transparent), color-mix(in srgb, var(--surface-soft) 64%, transparent)),
    var(--surface);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.server-status-panel {
  grid-column: 1 / -1;
}

.server-flow-head {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  padding-bottom: 10px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
}

.server-flow-head > span {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 9%, var(--surface-soft));
}

.server-flow-head h3 {
  margin: 0;
  font-size: 16px;
}

.server-flow-head p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
}

.server-flow-steps,
.server-check-list,
.server-trouble-list,
.server-status-list {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.server-flow-steps div,
.server-check-list div,
.server-trouble-list div,
.server-status-list div {
  min-height: 54px;
  border: 1px solid color-mix(in srgb, var(--line) 86%, transparent);
  border-radius: 10px;
  padding: 10px 11px;
  display: grid;
  gap: 3px;
  background: color-mix(in srgb, var(--surface) 88%, transparent);
}

.server-flow-steps strong {
  color: var(--text);
  font-size: 14px;
}

.server-flow-steps {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.server-flow-steps .server-flow-step {
  position: relative;
  min-height: 98px;
  padding: 12px;
  align-content: start;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--teal) 8%, transparent), transparent 60%),
    color-mix(in srgb, var(--surface) 90%, transparent);
}

.server-flow-step::after {
  content: "";
  position: absolute;
  top: 50%;
  right: -10px;
  width: 18px;
  height: 18px;
  border-top: 2px solid color-mix(in srgb, var(--teal) 30%, var(--line));
  border-right: 2px solid color-mix(in srgb, var(--teal) 30%, var(--line));
  background: var(--surface);
  transform: translateY(-50%) rotate(45deg);
  z-index: 1;
}

.server-flow-step:last-child::after {
  display: none;
}

.server-flow-step em {
  width: 26px;
  height: 26px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  color: #fff;
  background: var(--teal);
  font-size: 12px;
  font-style: normal;
  font-weight: 900;
}

.server-flow-steps span {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.server-check-list .server-check-row {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 4px 10px;
}

.server-check-row .server-check-label {
  color: var(--text);
  font-size: 13px;
  font-weight: 900;
}

.server-check-row small {
  grid-column: 1 / -1;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.server-trouble-list {
  grid-template-columns: 1fr;
}

.server-trouble-row {
  grid-template-columns: auto minmax(0, 1fr);
  align-items: start;
  gap: 10px;
}

.server-trouble-row > span {
  width: 30px;
  height: 30px;
  border-radius: 9px;
  display: grid;
  place-items: center;
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 9%, var(--surface-soft));
}

.server-trouble-row.tone-blue > span {
  color: var(--blue);
  background: color-mix(in srgb, var(--blue) 9%, var(--surface));
}

.server-trouble-row.tone-amber > span {
  color: var(--amber);
  background: color-mix(in srgb, var(--amber) 10%, var(--surface));
}

.server-trouble-row.tone-coral > span {
  color: var(--coral);
  background: color-mix(in srgb, var(--coral) 9%, var(--surface));
}

.server-trouble-row strong,
.server-trouble-row small {
  display: block;
}

.server-trouble-row small {
  margin-top: 3px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.server-status-list {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.server-status-list.is-compact {
  grid-template-columns: 1fr;
}

.server-status-list.is-compact .server-status-item {
  min-height: 62px;
}

.server-status-item {
  position: relative;
}

.server-status-item::before {
  content: "";
  position: absolute;
  top: 13px;
  right: 13px;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--muted);
}

.server-status-item.online::before {
  background: var(--teal);
}

.server-status-item.degraded,
.server-status-item.down {
  border-color: color-mix(in srgb, var(--coral) 26%, var(--line));
}

.server-status-item.degraded::before,
.server-status-item.down::before {
  background: var(--coral);
}

.server-status-item.planned::before {
  background: var(--amber);
}

.server-status-list strong {
  color: var(--text);
  font-size: 14px;
}

.server-status-list span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.server-backup-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.server-backup-item {
  min-width: 0;
  min-height: 126px;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  border-radius: 12px;
  padding: 13px;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 9px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 98%, transparent), color-mix(in srgb, var(--surface-soft) 62%, transparent)),
    var(--surface);
}

.server-backup-item > span {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 9%, var(--surface-soft));
}

.server-backup-item.tone-amber > span {
  color: var(--amber-strong);
  background: color-mix(in srgb, var(--amber) 11%, var(--surface-soft));
}

.server-backup-item.tone-blue > span {
  color: var(--blue-strong);
  background: color-mix(in srgb, var(--blue) 10%, var(--surface-soft));
}

.server-backup-item.tone-coral > span {
  color: var(--coral-strong);
  background: color-mix(in srgb, var(--coral) 10%, var(--surface-soft));
}

.server-backup-item h3 {
  margin: 0;
  font-size: 15px;
}

.server-backup-item p {
  margin: 5px 0 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.server-backup-item em {
  width: fit-content;
  min-height: 24px;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  padding: 0 8px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-soft) 80%, transparent);
  font-size: 12px;
  font-style: normal;
  font-weight: 900;
}

.server-backup-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.server-backup-meta small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
}

.server-backup-grid.server-backup-checklist {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.server-backup-check {
  min-height: 86px;
  grid-template-columns: 24px 38px minmax(0, 1fr) auto;
  grid-template-rows: auto;
  align-items: center;
  gap: 10px;
}

.server-backup-check .server-backup-index {
  width: 24px;
  height: 24px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-soft) 82%, transparent);
  font-size: 12px;
  font-weight: 900;
}

.server-backup-check .server-backup-icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 9%, var(--surface-soft));
}

.server-backup-check.tone-amber .server-backup-icon {
  color: var(--amber-strong);
  background: color-mix(in srgb, var(--amber) 11%, var(--surface-soft));
}

.server-backup-check.tone-blue .server-backup-icon {
  color: var(--blue-strong);
  background: color-mix(in srgb, var(--blue) 10%, var(--surface-soft));
}

.server-backup-check.tone-coral .server-backup-icon {
  color: var(--coral-strong);
  background: color-mix(in srgb, var(--coral) 10%, var(--surface-soft));
}

.server-backup-check .server-backup-main {
  min-width: 0;
}

.server-backup-check .server-backup-main p {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.server-backup-check .server-backup-meta {
  justify-content: flex-end;
  max-width: 150px;
}

.server-workspace {
  position: relative;
  margin-top: 28px;
  margin-right: -12px;
  margin-left: -12px;
  padding: 16px 12px 18px;
  border-top: 1px solid color-mix(in srgb, var(--teal) 18%, var(--line));
  border-bottom: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--teal) 7%, transparent), transparent 180px),
    color-mix(in srgb, var(--surface-soft) 38%, transparent);
  scroll-margin-top: 110px;
}

.server-workspace::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 12px;
  width: 118px;
  height: 3px;
  border-radius: 999px;
  background: var(--teal);
}

.server-workspace .section-heading {
  margin-bottom: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 76%, transparent);
}

.server-tabs {
  width: 100%;
  max-width: 100%;
  min-height: 46px;
  margin-bottom: 14px;
  padding: 5px;
  border-color: color-mix(in srgb, var(--teal) 15%, var(--line));
  background: color-mix(in srgb, var(--surface) 88%, transparent);
  overflow-x: auto;
  scrollbar-width: thin;
}

.server-tabs .segment {
  flex: 1 1 0;
  min-height: 36px;
  border: 1px solid transparent;
  color: var(--muted);
  font-weight: 900;
}

.server-tabs .segment svg {
  width: 16px;
  height: 16px;
}

.server-tabs .segment.active {
  border-color: color-mix(in srgb, var(--teal) 22%, var(--line));
  color: var(--teal-strong);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--monitor-green-bg) 74%, var(--surface)), color-mix(in srgb, var(--surface) 92%, transparent));
  box-shadow:
    0 8px 18px color-mix(in srgb, var(--teal) 8%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.32);
}

.server-tabs .segment.active em {
  background: color-mix(in srgb, var(--teal) 12%, var(--surface));
}

.server-tab-panels {
  min-width: 0;
  padding-top: 2px;
}

.server-tab-panel {
  min-width: 0;
  padding: 14px;
  border: 1px solid color-mix(in srgb, var(--line) 84%, transparent);
  border-radius: 12px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 96%, transparent), color-mix(in srgb, var(--surface-soft) 50%, transparent)),
    var(--surface);
}

.server-tab-panel[hidden] {
  display: none !important;
}

.server-tab-panel.active {
  display: block;
}

.server-panel-head {
  min-height: 42px;
  margin: -2px 0 12px;
  padding-bottom: 11px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 74%, transparent);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  color: var(--muted);
}

.server-panel-head strong,
.server-panel-head span {
  display: block;
}

.server-panel-head strong {
  color: var(--text);
  font-size: 17px;
}

.server-panel-head span {
  margin-top: 3px;
  font-size: 12px;
  line-height: 1.45;
}

.server-workspace .server-entry-group-head {
  min-height: 38px;
  margin-bottom: 8px;
  padding: 8px 10px;
  border: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  border-radius: 10px;
  background: color-mix(in srgb, var(--surface-soft) 68%, transparent);
}

.server-workspace .server-entry-group-head strong {
  font-size: 15px;
}

.server-security-grid {
  align-items: start;
}

.server-tab-panel .server-status-panel {
  grid-column: auto;
}

.home-resource-grid {
  gap: 10px;
  align-items: start;
}

.resource-panel {
  border-radius: 12px;
  padding: 13px;
  transition:
    transform 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease;
}

.resource-panel-head {
  min-height: 38px;
  margin-bottom: 10px;
  padding-bottom: 9px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
}

.resource-panel h3 {
  font-size: 18px;
}

.domain-table,
.download-list {
  border-radius: 10px;
  box-shadow: none;
}

.domain-row,
.download-row {
  min-height: 56px;
  padding: 10px 12px;
}

.home-resource-grid .domain-row,
.home-resource-grid .download-row {
  gap: 4px 10px;
}

.command-pack-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.command-pack-controls {
  margin: 0 0 12px;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  border-radius: 12px;
  padding: 10px;
  display: grid;
  grid-template-columns: minmax(260px, 0.72fr) minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 98%, transparent), color-mix(in srgb, var(--surface-soft) 62%, transparent)),
    var(--surface);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.command-pack-search {
  min-width: 0;
  min-height: 40px;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  border-radius: 10px;
  padding: 0 12px;
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
}

.command-pack-search input {
  width: 100%;
  min-width: 0;
  border: 0;
  outline: 0;
  color: var(--text);
  background: transparent;
  font: inherit;
}

.command-pack-segments {
  min-width: 0;
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.command-pack-segment {
  min-height: 34px;
  border: 1px solid color-mix(in srgb, var(--line) 86%, transparent);
  border-radius: 10px;
  padding: 0 9px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface) 88%, transparent);
  font: inherit;
  font-size: 13px;
  font-weight: 800;
  cursor: pointer;
  transition:
    color 160ms ease,
    border-color 160ms ease,
    background 160ms ease;
}

.command-pack-segment em {
  min-width: 20px;
  border-radius: 999px;
  padding: 2px 6px;
  color: inherit;
  background: color-mix(in srgb, var(--surface-soft) 80%, transparent);
  font-size: 11px;
  font-style: normal;
  text-align: center;
}

.command-pack-segment:hover,
.command-pack-segment.active {
  color: var(--teal-strong);
  border-color: color-mix(in srgb, var(--teal) 22%, var(--line));
  background: color-mix(in srgb, var(--teal) 7%, var(--surface));
}

.command-pack {
  min-height: auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 0.95fr);
  grid-template-areas:
    "head code"
    "body code"
    "actions code";
  gap: 10px 12px;
  padding: 13px;
  border-radius: 12px;
}

.command-pack-head {
  grid-area: head;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  justify-content: stretch;
}

.command-pack-body {
  grid-area: body;
}

.command-pack pre {
  grid-area: code;
  min-height: 168px;
  max-height: 190px;
  border-radius: 10px;
  padding: 11px;
}

.command-pack-actions {
  grid-area: actions;
  align-self: end;
  margin-top: 0;
}

.command-pack-icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
}

.command-pack h3 {
  font-size: 16px;
}

.command-pack p {
  margin-top: 5px;
  font-size: 13px;
  line-height: 1.55;
}

.command-exec-panel {
  min-height: 56px;
  margin-top: 10px;
  border: 1px solid color-mix(in srgb, var(--teal) 18%, var(--line));
  border-radius: 10px;
  padding: 9px 10px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 9px;
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--teal) 8%, transparent), transparent 70%),
    color-mix(in srgb, var(--surface) 86%, transparent);
}

.command-exec-panel > span {
  width: 34px;
  height: 34px;
  border-radius: 9px;
  display: grid;
  place-items: center;
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 9%, var(--surface-soft));
}

.command-exec-panel small,
.command-exec-panel strong {
  display: block;
}

.command-exec-panel small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
}

.command-exec-panel strong {
  margin-top: 2px;
  color: var(--text);
  font-size: 13px;
}

.command-exec-panel em {
  grid-column: 2;
  justify-self: start;
  min-height: 24px;
  border-radius: 999px;
  padding: 4px 8px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-soft) 75%, transparent);
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
  white-space: normal;
}

.command-exec-panel.tone-blue {
  border-color: color-mix(in srgb, var(--blue) 18%, var(--line));
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--blue) 7%, transparent), transparent 70%),
    color-mix(in srgb, var(--surface) 86%, transparent);
}

.command-exec-panel.tone-blue > span {
  color: var(--blue);
  background: color-mix(in srgb, var(--blue) 9%, var(--surface-soft));
}

.command-exec-panel.tone-amber {
  border-color: color-mix(in srgb, var(--amber) 20%, var(--line));
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--amber) 8%, transparent), transparent 70%),
    color-mix(in srgb, var(--surface) 86%, transparent);
}

.command-exec-panel.tone-amber > span {
  color: var(--amber-strong);
  background: color-mix(in srgb, var(--amber) 10%, var(--surface-soft));
}

.command-exec-panel.tone-coral {
  border-color: color-mix(in srgb, var(--coral) 20%, var(--line));
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--coral) 7%, transparent), transparent 70%),
    color-mix(in srgb, var(--surface) 86%, transparent);
}

.command-exec-panel.tone-coral > span {
  color: var(--coral-strong);
  background: color-mix(in srgb, var(--coral) 9%, var(--surface-soft));
}

.command-code-block {
  grid-area: code;
  min-width: 0;
}

.command-pack-badges {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.command-risk-badge,
.command-runtime-badge {
  min-height: 24px;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 0 8px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-soft) 80%, transparent);
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.command-risk-badge.tone-teal {
  color: var(--teal-strong);
  border-color: color-mix(in srgb, var(--teal) 22%, var(--line));
  background: color-mix(in srgb, var(--teal) 8%, var(--surface));
}

.command-risk-badge.tone-blue {
  color: var(--blue);
  border-color: color-mix(in srgb, var(--blue) 22%, var(--line));
  background: color-mix(in srgb, var(--blue) 8%, var(--surface));
}

.command-risk-badge.tone-amber {
  color: var(--amber-strong);
  border-color: color-mix(in srgb, var(--amber) 24%, var(--line));
  background: color-mix(in srgb, var(--amber) 10%, var(--surface));
}

.command-risk-badge.tone-coral {
  color: var(--coral-strong);
  border-color: color-mix(in srgb, var(--coral) 24%, var(--line));
  background: color-mix(in srgb, var(--coral) 9%, var(--surface));
}

.command-runtime-badge svg {
  width: 14px;
  height: 14px;
}

.command-pin-button {
  flex: 0 0 auto;
  width: 34px;
  height: 34px;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface) 86%, transparent);
  cursor: pointer;
}

.command-pin-button.active {
  color: var(--amber-strong);
  border-color: color-mix(in srgb, var(--amber) 24%, var(--line));
  background: color-mix(in srgb, var(--amber) 10%, var(--surface));
}

.command-preflight {
  margin-top: 10px;
  display: grid;
  gap: 6px;
}

.command-preflight span {
  min-height: 28px;
  border: 1px solid color-mix(in srgb, var(--line) 80%, transparent);
  border-radius: 8px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 6px;
  padding: 5px 8px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface) 82%, transparent);
  font-size: 12px;
  line-height: 1.35;
}

.command-preflight svg {
  width: 14px;
  height: 14px;
  color: var(--teal-strong);
}

.command-related-tools {
  margin-top: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.command-related-tools span {
  min-height: 22px;
  border: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  padding: 0 7px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-soft) 72%, transparent);
  font-size: 11px;
  font-weight: 900;
}

.command-code-block summary {
  min-height: 38px;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  border-radius: 10px;
  padding: 0 10px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 8px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-soft) 74%, transparent);
  cursor: pointer;
  list-style: none;
  user-select: none;
}

.command-code-block summary::-webkit-details-marker {
  display: none;
}

.command-code-block summary span {
  color: var(--text);
  font-weight: 800;
}

.command-code-block summary em {
  border-radius: 999px;
  padding: 3px 8px;
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 8%, var(--surface));
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
}

.command-code-block summary svg {
  transition: transform 160ms ease;
}

.command-code-block[open] summary svg {
  transform: rotate(180deg);
}

.command-code-block pre {
  margin-top: 8px;
}

.command-line-list {
  display: grid;
  gap: 6px;
  margin-top: 8px;
}

.command-line-copy {
  min-width: 0;
  min-height: 34px;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: 8px;
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr) 18px;
  align-items: center;
  gap: 7px;
  padding: 6px 8px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface) 86%, transparent);
  cursor: pointer;
  text-align: left;
}

.command-line-copy span {
  width: 22px;
  height: 22px;
  border-radius: 7px;
  display: grid;
  place-items: center;
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 8%, var(--surface));
  font-size: 11px;
  font-weight: 900;
}

.command-line-copy code {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--text);
}

.command-line-copy svg {
  width: 16px;
  height: 16px;
}

.command-pack-empty {
  grid-column: 1 / -1;
  min-height: 180px;
  border: 1px dashed color-mix(in srgb, var(--line-strong) 72%, transparent);
  border-radius: 12px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 8px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface) 80%, transparent);
  text-align: center;
}

.command-pack-empty svg {
  color: var(--teal-strong);
}

.command-pack-empty strong {
  color: var(--text);
}

.settings-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  padding: 10px;
  box-shadow: none;
}

.settings-overview-strip,
.maintenance-overview-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.settings-stat-card,
.maintenance-stat-card {
  min-width: 0;
  min-height: 78px;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  border-radius: 12px;
  padding: 12px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 98%, transparent), color-mix(in srgb, var(--surface-soft) 58%, transparent)),
    var(--surface);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.settings-stat-card > span,
.maintenance-stat-card > span {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 9%, var(--surface-soft));
}

.settings-stat-card strong,
.settings-stat-card small,
.settings-stat-card em,
.maintenance-stat-card strong,
.maintenance-stat-card small,
.maintenance-stat-card em {
  display: block;
}

.settings-stat-card strong,
.maintenance-stat-card strong {
  font-size: 21px;
  line-height: 1;
}

.settings-stat-card small,
.maintenance-stat-card small {
  margin-top: 4px;
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}

.settings-stat-card em,
.maintenance-stat-card em {
  margin-top: 2px;
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
  overflow-wrap: anywhere;
}

.setting-row {
  min-height: 76px;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 11px;
  padding: 12px;
  border-radius: 10px;
}

.setting-row-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 8px;
}

.setting-icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
}

.setting-row h3 {
  font-size: 16px;
}

.setting-row p {
  font-size: 13px;
  line-height: 1.45;
}

.switch-control {
  min-height: 34px;
  border-radius: 10px;
}

.settings-list {
  grid-template-columns: 1fr;
  gap: 14px;
}

.settings-group,
.settings-panel {
  min-width: 0;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  border-radius: 12px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 96%, transparent), color-mix(in srgb, var(--surface-soft) 62%, transparent)),
    var(--surface);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.3);
}

.settings-group {
  padding: 12px;
}

.settings-group-head,
.settings-panel-head {
  display: flex;
  align-items: center;
  gap: 12px;
}

.settings-group-head {
  justify-content: flex-start;
  margin-bottom: 10px;
  padding: 0 2px 10px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
}

.settings-panel-head {
  justify-content: space-between;
}

.settings-group-head > div,
.settings-panel-head > div {
  min-width: 0;
}

.settings-group-head > span {
  width: 36px;
  height: 36px;
  border: 1px solid color-mix(in srgb, var(--teal) 16%, var(--line));
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 8%, var(--surface-soft));
}

.settings-group-head h3,
.settings-panel-head h3 {
  margin: 0;
  color: var(--text);
  font-size: 16px;
}

.settings-group-head p,
.settings-panel-head p {
  margin: 3px 0 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.settings-section-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.settings-group.is-single .settings-section-grid {
  grid-template-columns: 1fr;
}

.setting-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 8px;
}

.setting-source-badge {
  min-height: 24px;
  border: 1px solid color-mix(in srgb, var(--line) 86%, transparent);
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 0 9px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-soft) 78%, transparent);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
}

.setting-source-badge svg {
  width: 13px;
  height: 13px;
}

.setting-source-badge.tone-protected {
  color: var(--blue);
  background: color-mix(in srgb, var(--blue) 9%, var(--surface));
}

.setting-source-badge.tone-online,
.setting-source-badge.tone-local {
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 9%, var(--surface));
}

.setting-source-badge.tone-public {
  color: var(--slate);
}

.setting-detail-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}

.setting-detail-pills span {
  min-height: 24px;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  padding: 0 8px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface) 82%, transparent);
  font-size: 12px;
  font-weight: 800;
}

.settings-panel {
  padding: 14px;
}

.settings-panel-head {
  margin-bottom: 12px;
}

.settings-panel-chip {
  min-height: 30px;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 0 10px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-soft) 76%, transparent);
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.settings-panel-chip svg {
  width: 15px;
  height: 15px;
  color: var(--teal-strong);
}

.settings-matrix {
  display: grid;
  gap: 6px;
}

.settings-matrix-head,
.settings-matrix-row {
  display: grid;
  grid-template-columns: 1.1fr 1fr 1fr 1.15fr;
  gap: 8px;
  align-items: center;
}

.settings-matrix-head {
  padding: 0 10px 4px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.settings-matrix-row {
  min-height: 44px;
  border: 1px solid color-mix(in srgb, var(--line) 86%, transparent);
  border-radius: 10px;
  padding: 10px;
  background: color-mix(in srgb, var(--surface) 86%, transparent);
}

.settings-matrix-row strong {
  color: var(--text);
  font-size: 13px;
}

.settings-matrix-row span,
.settings-matrix-row em {
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
}

.settings-matrix-row.tone-protected {
  border-color: color-mix(in srgb, var(--blue) 18%, var(--line));
}

.settings-matrix-row.tone-online {
  border-color: color-mix(in srgb, var(--teal) 18%, var(--line));
}

.settings-matrix-row.tone-planned {
  border-color: color-mix(in srgb, var(--amber) 20%, var(--line));
}

.settings-chip-grid,
.settings-channel-grid,
.settings-preference-grid,
.settings-system-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.settings-chip-item,
.settings-channel-item,
.settings-preference-grid div,
.settings-system-grid div {
  min-height: 58px;
  border: 1px solid color-mix(in srgb, var(--line) 86%, transparent);
  border-radius: 10px;
  display: grid;
  gap: 6px;
  align-content: center;
  padding: 10px;
  background: color-mix(in srgb, var(--surface) 86%, transparent);
}

.settings-chip-item strong,
.settings-channel-item span,
.settings-preference-grid span,
.settings-system-grid span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.settings-channel-item strong,
.settings-preference-grid strong,
.settings-system-grid strong {
  color: var(--text);
  font-size: 14px;
  overflow-wrap: anywhere;
}

.settings-channel-item.tone-protected strong {
  color: var(--blue);
}

.settings-channel-item.tone-online strong {
  color: var(--teal-strong);
}

.settings-channel-item.tone-planned strong {
  color: var(--amber);
}

.settings-tabs {
  justify-content: flex-start;
  gap: 8px;
  padding: 8px;
  overflow-x: auto;
  border: 1px solid color-mix(in srgb, var(--line) 84%, transparent);
  border-radius: 12px;
  background: color-mix(in srgb, var(--surface-soft) 58%, transparent);
}

.settings-tab {
  white-space: nowrap;
}

.settings-tab em {
  min-width: 22px;
  min-height: 22px;
  border-radius: 999px;
  display: inline-grid;
  place-items: center;
  padding: 0 6px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface) 86%, transparent);
  font-size: 12px;
  font-style: normal;
  font-weight: 900;
}

.settings-tab.active em {
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 12%, var(--surface));
}

.settings-active-group .settings-group-head {
  justify-content: flex-start;
}

.settings-group-head > em {
  margin-left: auto;
  min-height: 28px;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  padding: 0 10px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-soft) 76%, transparent);
  font-size: 12px;
  font-style: normal;
  font-weight: 900;
  white-space: nowrap;
}

.settings-panel-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 8px;
}

.settings-export-actions {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 8px;
}

.setting-accent-picker {
  justify-self: end;
  max-width: 310px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.setting-accent-picker .accent-choice {
  min-width: 42px;
}

.settings-safety-grid,
.settings-structure-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.settings-safety-item {
  min-width: 0;
  min-height: 86px;
  border: 1px solid color-mix(in srgb, var(--line) 86%, transparent);
  border-radius: 10px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 10px;
  align-items: start;
  padding: 12px;
  background: color-mix(in srgb, var(--surface) 86%, transparent);
}

.settings-safety-item > span {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 9%, var(--surface-soft));
}

.settings-safety-item strong,
.settings-structure-item strong {
  display: block;
  color: var(--text);
  font-size: 14px;
}

.settings-safety-item p,
.settings-structure-item p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.settings-safety-item em {
  min-height: 24px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  padding: 0 8px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-soft) 82%, transparent);
  font-size: 12px;
  font-style: normal;
  font-weight: 900;
  white-space: nowrap;
}

.settings-safety-item.tone-protected {
  border-color: color-mix(in srgb, var(--blue) 18%, var(--line));
}

.settings-safety-item.tone-protected > span,
.settings-safety-item.tone-protected em {
  color: var(--blue);
  background: color-mix(in srgb, var(--blue) 9%, var(--surface));
}

.settings-safety-item.tone-online {
  border-color: color-mix(in srgb, var(--teal) 18%, var(--line));
}

.settings-safety-item.tone-planned {
  border-color: color-mix(in srgb, var(--amber) 20%, var(--line));
}

.settings-safety-item.tone-planned > span,
.settings-safety-item.tone-planned em {
  color: var(--amber);
  background: color-mix(in srgb, var(--amber) 10%, var(--surface));
}

.settings-structure-item {
  min-height: 82px;
  border: 1px solid color-mix(in srgb, var(--line) 86%, transparent);
  border-radius: 10px;
  display: grid;
  align-content: start;
  gap: 4px;
  padding: 12px;
  background: color-mix(in srgb, var(--surface) 86%, transparent);
}

.settings-structure-item span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.settings-system-grid {
  margin-top: 10px;
}

.settings-local-scope {
  margin-top: 10px;
}

.copy-fallback-modal {
  max-width: min(720px, calc(100vw - 32px));
}

.copy-fallback-textarea {
  width: 100%;
  min-height: 220px;
  border: 1px solid color-mix(in srgb, var(--line) 86%, transparent);
  border-radius: 12px;
  padding: 12px;
  color: var(--text);
  background: color-mix(in srgb, var(--surface-soft) 78%, transparent);
  font: 13px/1.55 ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", monospace;
  resize: vertical;
}

.module-badge.experience,
.module-badge.local,
.module-badge.security,
.module-badge.backup,
.module-badge.automation,
.module-badge.structure {
  color: var(--slate);
  background: color-mix(in srgb, var(--surface-soft) 88%, transparent);
}

.module-badge.security {
  color: var(--blue);
  background: color-mix(in srgb, var(--blue) 8%, var(--surface));
}

.module-badge.local {
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 8%, var(--surface));
}

.module-badge.backup {
  color: var(--coral);
  background: color-mix(in srgb, var(--coral) 9%, var(--surface));
}

.module-badge.automation {
  color: var(--amber);
  background: color-mix(in srgb, var(--amber) 10%, var(--surface));
}

@media (max-width: 1180px) {
  .service-grid,
  .service-overview-strip,
  .server-overview-strip,
  .settings-overview-strip,
  .maintenance-overview-strip,
  .server-admin-grid,
  .workbench-grid,
  .command-pack-grid,
  .command-pack-controls,
  .settings-list,
  .home-resource-grid {
    grid-template-columns: 1fr;
  }

  .service-card,
  .command-pack {
    display: flex;
    flex-direction: column;
    align-items: stretch;
  }

  .service-card .card-top,
  .service-meta-row,
  .service-footnote,
  .service-card .card-bottom {
    flex-direction: row;
    justify-content: space-between;
  }

  .command-pack pre {
    min-height: 132px;
  }

  .command-pack-segments {
    justify-content: flex-start;
  }

  .settings-section-grid,
  .settings-chip-grid,
  .settings-channel-grid,
  .settings-preference-grid,
  .settings-system-grid,
  .settings-safety-grid,
  .settings-structure-grid {
    grid-template-columns: 1fr;
  }

  .settings-tabs {
    padding-bottom: 10px;
  }

  .settings-safety-item {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .settings-safety-item em {
    grid-column: 2;
    justify-self: start;
  }

  .settings-group-head > em,
  .settings-panel-actions,
  .settings-export-actions {
    width: 100%;
    justify-content: center;
  }

  .settings-matrix-head {
    display: none;
  }

  .settings-matrix-row {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .settings-panel-head {
    align-items: stretch;
    flex-direction: column;
  }

  .settings-panel-head .secondary-action {
    width: 100%;
    justify-content: center;
  }

  .setting-accent-picker {
    justify-self: stretch;
    max-width: none;
    justify-content: flex-start;
  }
}

/* Color discipline: neutral surfaces first, semantic color only where it helps */
:root {
  --teal: #0d9488;
  --teal-strong: #0f766e;
  --blue: #2563eb;
  --amber: #c77700;
  --coral: #d95f54;
  --line: rgba(148, 163, 184, 0.22);
  --line-strong: rgba(100, 116, 139, 0.3);
}

:root[data-theme="dark"] {
  --line: rgba(148, 163, 184, 0.18);
  --line-strong: rgba(159, 178, 201, 0.27);
}

body {
  background:
    linear-gradient(180deg, #f8fafc 0%, #f5f7fa 48%, #eef3f7 100%),
    var(--bg);
}

body::before {
  opacity: 0.46;
}

:root[data-theme="dark"] body::before {
  opacity: 0.32;
}

.sidebar,
.topbar,
.dashboard-head,
.settings-head,
.dashboard-panel,
.settings-list,
.page-hero,
.hero-panel,
.access-panel,
.resource-panel,
.service-card,
.workbench-card,
.route-card,
.roadmap-card,
.note-panel,
.script-card,
.resource-card,
.download-hero,
.download-terminal,
.domain-table,
.download-list,
.update-grid,
.service-stat-card,
.server-stat-card,
.settings-stat-card,
.maintenance-stat-card,
.server-flow-panel,
.server-safety-panel,
.command-pack-controls,
.command-pack,
.control-strip {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 98%, transparent), color-mix(in srgb, var(--surface-soft) 64%, transparent)),
    var(--surface);
}

.service-card,
.workbench-card,
.command-pack,
.service-stat-card,
.server-stat-card,
.settings-stat-card,
.maintenance-stat-card,
.server-flow-panel,
.server-safety-panel,
.resource-panel,
.setting-row,
.health-item,
.task-row,
.timeline-list div,
.asset-table div,
.live-kpi-grid div,
.quick-entry-grid a,
.domain-row,
.download-row {
  border-color: color-mix(in srgb, var(--line) 88%, transparent);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.service-card:hover,
.workbench-card:hover,
.command-pack:hover,
.resource-panel:hover,
.server-flow-panel:hover,
.server-safety-panel:hover,
.setting-row:hover,
.health-item:hover,
.task-row:hover,
.timeline-list div:hover,
.asset-table div:hover,
.quick-entry-grid a:hover {
  border-color: color-mix(in srgb, var(--teal) 26%, var(--line));
  box-shadow:
    0 8px 22px rgba(15, 23, 42, 0.045),
    inset 0 1px 0 rgba(255, 255, 255, 0.32);
}

.primary-action {
  border-color: color-mix(in srgb, var(--teal-strong) 76%, transparent);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--teal) 94%, #ffffff), var(--teal-strong)),
    var(--teal);
  box-shadow:
    0 10px 22px color-mix(in srgb, var(--teal) 15%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.22);
}

.secondary-action,
.icon-button,
.global-search,
.search-box,
.segments,
.copy-line,
.rail-status {
  background: color-mix(in srgb, var(--surface) 92%, transparent);
}

.side-nav a:hover,
.side-nav a.active {
  border-color: color-mix(in srgb, var(--teal) 18%, var(--line));
  background: color-mix(in srgb, var(--teal) 6%, var(--surface));
}

.eyebrow {
  color: color-mix(in srgb, var(--teal-strong) 88%, var(--text));
}

.brand-mark {
  background:
    linear-gradient(145deg, #0f172a, color-mix(in srgb, #0f172a 84%, var(--teal))),
    #0f172a;
}

.health-icon,
.setting-icon,
.card-icon,
.metric-icon,
.ops-icon,
.workbench-icon,
.command-pack-icon,
.script-summary svg,
.system-quick-grid a svg,
.global-search-result::before {
  background: color-mix(in srgb, var(--tone, var(--teal)) 9%, var(--surface-soft));
}

.service-card::before,
.resource-card::before,
.metric-card::after {
  opacity: 0.74;
}

.service-card,
.workbench-card,
.command-pack,
.resource-card,
.ops-card,
.update-card,
.console-summary-card {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--tone, var(--teal)) 3%, transparent), transparent 62%),
    var(--surface);
}

.health-item[data-health-state="online"] {
  border-color: color-mix(in srgb, var(--teal) 22%, var(--line));
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--teal) 4%, transparent), transparent 34%),
    var(--surface);
}

.health-item[data-health-state="protected"] {
  border-color: color-mix(in srgb, var(--blue) 22%, var(--line));
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--blue) 4%, transparent), transparent 34%),
    var(--surface);
}

.health-item[data-health-state="degraded"],
.health-item[data-health-state="planned"] {
  border-color: color-mix(in srgb, var(--amber) 24%, var(--line));
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--amber) 4%, transparent), transparent 34%),
    var(--surface);
}

.health-item[data-health-state="down"] {
  border-color: color-mix(in srgb, var(--coral) 26%, var(--line));
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--coral) 4%, transparent), transparent 34%),
    var(--surface);
}

.status-pill,
.status-pill.online {
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 10%, var(--surface));
  border-color: color-mix(in srgb, var(--teal) 20%, transparent);
}

.status-pill.protected {
  color: var(--blue);
  background: color-mix(in srgb, var(--blue) 9%, var(--surface));
  border-color: color-mix(in srgb, var(--blue) 18%, transparent);
}

.status-pill.planned,
.status-pill.degraded {
  color: var(--amber);
  background: color-mix(in srgb, var(--amber) 10%, var(--surface));
  border-color: color-mix(in srgb, var(--amber) 18%, transparent);
}

.status-pill.down {
  color: var(--coral);
  background: color-mix(in srgb, var(--coral) 9%, var(--surface));
  border-color: color-mix(in srgb, var(--coral) 18%, transparent);
}

.module-badge {
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 8%, var(--surface));
  border-color: color-mix(in srgb, var(--teal) 16%, var(--line));
}

.module-badge.protected {
  color: var(--blue);
  background: color-mix(in srgb, var(--blue) 8%, var(--surface));
  border-color: color-mix(in srgb, var(--blue) 16%, var(--line));
}

.module-badge.planned {
  color: var(--amber);
  background: color-mix(in srgb, var(--amber) 9%, var(--surface));
  border-color: color-mix(in srgb, var(--amber) 16%, var(--line));
}

.open-link {
  color: var(--teal-strong);
  border-color: color-mix(in srgb, var(--teal) 18%, var(--line));
  background: color-mix(in srgb, var(--teal) 7%, var(--surface));
  box-shadow: none;
}

.open-link:hover {
  color: var(--teal-strong);
  border-color: color-mix(in srgb, var(--teal) 32%, var(--line));
  background: color-mix(in srgb, var(--teal) 11%, var(--surface));
}

.resource-overview-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 12px;
}

.resource-stat-card {
  min-width: 0;
  min-height: 78px;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  border-radius: 12px;
  padding: 12px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 98%, transparent), color-mix(in srgb, var(--surface-soft) 58%, transparent)),
    var(--surface);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.resource-stat-card > span {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 9%, var(--surface-soft));
}

.resource-stat-card strong,
.resource-stat-card small,
.resource-stat-card em {
  display: block;
}

.resource-stat-card strong {
  font-size: 21px;
  line-height: 1;
}

.resource-stat-card small {
  margin-top: 4px;
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}

.resource-stat-card em {
  margin-top: 2px;
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
  overflow-wrap: anywhere;
}

.resource-launchpad {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin: 0 0 14px;
}

.resource-launch-card {
  min-width: 0;
  min-height: 176px;
  border: 1px solid color-mix(in srgb, var(--line) 84%, transparent);
  border-radius: 12px;
  padding: 12px;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 10px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 98%, transparent), color-mix(in srgb, var(--surface-soft) 58%, transparent)),
    var(--surface);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.resource-launch-card > span {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 9%, var(--surface-soft));
}

.resource-launch-card.tone-blue > span {
  color: var(--blue);
  background: color-mix(in srgb, var(--blue) 9%, var(--surface-soft));
}

.resource-launch-card.tone-amber > span {
  color: var(--amber-strong);
  background: color-mix(in srgb, var(--amber) 10%, var(--surface-soft));
}

.resource-launch-card.tone-coral > span {
  color: var(--coral-strong);
  background: color-mix(in srgb, var(--coral) 9%, var(--surface-soft));
}

.resource-launch-card small,
.resource-launch-card strong,
.resource-launch-card em {
  display: block;
}

.resource-launch-card small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
}

.resource-launch-card strong {
  margin-top: 4px;
  color: var(--text);
  font-size: 16px;
}

.resource-launch-card em {
  margin-top: 5px;
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
  line-height: 1.45;
}

.resource-launch-meta {
  margin-top: 8px;
  display: flex;
  align-items: center;
  gap: 5px;
  flex-wrap: wrap;
}

.resource-launch-meta b:not(.command-risk-badge) {
  min-height: 24px;
  border: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  padding: 0 8px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-soft) 72%, transparent);
  font-size: 11px;
  font-weight: 900;
}

.resource-launch-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.resource-workspace {
  position: relative;
  margin-top: 12px;
  padding: 14px;
  border: 1px solid color-mix(in srgb, var(--teal) 14%, var(--line));
  border-radius: 14px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--teal) 6%, transparent), transparent 190px),
    color-mix(in srgb, var(--surface-soft) 38%, transparent);
}

.resource-tabs {
  width: 100%;
  min-height: 46px;
  margin-bottom: 14px;
  padding: 5px;
  border-color: color-mix(in srgb, var(--teal) 15%, var(--line));
  background: color-mix(in srgb, var(--surface) 88%, transparent);
  overflow-x: auto;
  scrollbar-width: thin;
}

.resource-tabs .segment {
  flex: 1 1 0;
  min-height: 36px;
  border: 1px solid transparent;
  color: var(--muted);
  font-weight: 900;
}

.resource-tabs .segment svg {
  width: 16px;
  height: 16px;
}

.resource-tabs .segment.active {
  border-color: color-mix(in srgb, var(--teal) 22%, var(--line));
  color: var(--teal-strong);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--monitor-green-bg) 72%, var(--surface)), color-mix(in srgb, var(--surface) 92%, transparent));
  box-shadow:
    0 8px 18px color-mix(in srgb, var(--teal) 8%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.32);
}

.resource-tab-panel[hidden] {
  display: none !important;
}

.resource-tab-panel {
  min-width: 0;
}

.resource-command-head {
  min-height: 48px;
  margin-bottom: 12px;
  padding-bottom: 11px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 74%, transparent);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.resource-command-head h3 {
  margin: 0;
  font-size: 18px;
}

.resource-command-head span {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.download-main {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.download-kind {
  justify-self: start;
  min-width: 46px;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: 999px;
  padding: 3px 8px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-soft) 72%, transparent);
  font-size: 12px;
  font-weight: 800;
  text-align: center;
}

.download-kind.internal {
  color: var(--teal-strong);
  border-color: color-mix(in srgb, var(--teal) 18%, var(--line));
  background: color-mix(in srgb, var(--teal) 8%, var(--surface));
}

.download-kind.external {
  color: var(--blue);
  border-color: color-mix(in srgb, var(--blue) 16%, var(--line));
  background: color-mix(in srgb, var(--blue) 7%, var(--surface));
}

.download-related {
  width: fit-content;
  min-height: 24px;
  margin-top: 4px;
  border: 1px solid color-mix(in srgb, var(--teal) 18%, var(--line));
  border-radius: 999px;
  padding: 0 8px;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 7%, var(--surface));
  font: inherit;
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
}

.download-related strong {
  color: var(--text);
  font-size: 12px;
}

.download-related svg {
  width: 14px;
  height: 14px;
}

.home-resource-grid .download-row {
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
}

.home-resource-grid .download-desc {
  grid-column: auto;
}

.home-resource-grid .download-row .open-link {
  min-width: 72px;
}

:root[data-theme="dark"] .global-search-result:hover,
:root[data-theme="dark"] .global-search-result:focus-visible,
:root[data-theme="dark"] .global-search-result.is-active {
  box-shadow:
    0 12px 28px rgba(0, 0, 0, 0.24),
    inset 3px 0 0 var(--teal-strong);
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
  }
}

@media (max-width: 1120px) {
  body::after,
  .desktop-chrome {
    display: none;
  }

  .app-shell {
    width: 100%;
    min-height: 100vh;
    margin: 0;
    border: 0;
    border-radius: 0;
  }

  .app-shell {
    grid-template-columns: 1fr;
  }

  .sidebar {
    position: static;
    height: auto;
    margin: 16px;
    border: 1px solid var(--line);
    border-radius: 22px;
    flex-direction: row;
    align-items: center;
    flex-wrap: wrap;
    padding: 16px;
    box-shadow: var(--shadow-sm);
  }

  .side-nav {
    width: 100%;
    grid-auto-flow: initial;
    grid-auto-columns: initial;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    overflow-x: visible;
  }

  .nav-group {
    display: contents;
  }

  .nav-section-label {
    grid-column: 1 / -1;
    margin-top: 4px;
  }

  .nav-badge {
    display: none;
  }

  .side-nav a[data-nav-id="services"] .nav-badge,
  .side-nav a[data-nav-id="server"] .nav-badge {
    display: inline-flex;
  }

  .side-nav a:hover,
  .side-nav a.active {
    transform: none;
  }

  .toolbox-sidebar .side-nav {
    border-left: 0;
    padding-left: 0;
  }

  .toolbox-sidebar .side-nav a::before {
    display: none;
  }

  .domain-box {
    margin: 0 0 0 auto;
    border-top: 0;
    padding-top: 0;
    min-width: 190px;
  }

  .hero-panel {
    grid-template-columns: 1fr;
  }

  .console-rail {
    grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
    grid-template-rows: auto;
  }

  .download-hero {
    grid-template-columns: 1fr;
  }

  .page-hero {
    align-items: stretch;
    flex-direction: column;
  }

  .page-hero-actions {
    justify-content: flex-start;
  }

  .hero-visual {
    grid-template-rows: auto 300px auto;
  }

  .hero-map {
    min-height: 0;
  }

  .status-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .workbench-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .route-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .roadmap-board {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .update-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .update-card {
    border-left: 0;
    border-top: 1px solid var(--line);
  }

  .update-card:nth-child(-n + 2) {
    border-top: 0;
  }

  .ops-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dashboard-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .console-overview-grid {
    grid-template-areas:
      "runtime runtime"
      "quick todo"
      "assets updates";
  }

  .dashboard-panel.panel-wide,
  .topology-panel {
    grid-column: span 2;
  }

  .script-summary,
  .playbook-grid,
  .recipe-grid,
  .recovery-board,
  .command-pack-grid,
  .home-resource-grid,
  .script-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .access-panel {
    align-items: stretch;
    flex-direction: column;
  }

  .access-actions {
    flex-wrap: wrap;
  }

  .resource-overview-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .service-overview-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .server-overview-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .server-security-summary {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .server-summary-chips {
    grid-column: 1 / -1;
    justify-content: flex-start;
  }

  .server-status-list,
  .server-backup-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .settings-overview-strip,
  .maintenance-overview-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .app-shell {
    width: 100%;
    max-width: 100%;
    margin: 0;
    border-radius: 0;
  }

  .workspace {
    width: 100%;
    max-width: 100%;
    padding: 0 14px 18px;
  }

  .topbar {
    position: static;
    margin: 0 0 20px;
    padding: 0;
    background: transparent;
    border-bottom: 0;
    backdrop-filter: none;
  }

  .topbar,
  .control-strip,
  .section-heading {
    align-items: stretch;
    flex-direction: column;
  }

  .resource-overview-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .service-overview-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .server-overview-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .server-security-summary,
  .server-group-grid,
  .server-status-list,
  .server-backup-grid {
    grid-template-columns: 1fr;
  }

  .server-entry-group-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .settings-overview-strip,
  .maintenance-overview-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .server-admin-grid {
    grid-template-columns: 1fr;
  }

  .resource-stat-card,
  .service-stat-card,
  .server-stat-card,
  .settings-stat-card,
  .maintenance-stat-card {
    min-height: 74px;
    padding: 10px;
    gap: 8px;
  }

  .resource-stat-card > span,
  .service-stat-card > span,
  .server-stat-card > span,
  .settings-stat-card > span,
  .maintenance-stat-card > span {
    width: 34px;
    height: 34px;
    border-radius: 9px;
  }

  .resource-stat-card strong,
  .service-stat-card strong,
  .server-stat-card strong,
  .settings-stat-card strong,
  .maintenance-stat-card strong {
    font-size: 19px;
  }

  .resource-stat-card em,
  .service-stat-card em,
  .server-stat-card em,
  .settings-stat-card em,
  .maintenance-stat-card em {
    font-size: 11px;
    line-height: 1.35;
  }

  .global-search {
    width: 100%;
    min-width: 0;
  }

  .global-search-results {
    max-height: min(420px, calc(100vh - 180px));
  }

  .top-actions,
  .hero-actions {
    width: 100%;
  }

  .top-actions {
    justify-content: stretch;
    display: grid;
    grid-template-columns: 46px minmax(0, 1fr);
    gap: 10px;
  }

  .top-actions .secondary-action {
    grid-column: 1 / -1;
    width: 100%;
  }

  .top-actions .icon-button {
    width: 46px;
    padding: 0;
  }

  .top-actions .primary-action {
    grid-column: 2;
    width: 100%;
  }

  .primary-action,
  .secondary-action {
    min-width: 0;
    flex: 1;
  }

  .top-actions .primary-action span,
  .top-actions .secondary-action span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .hero-panel {
    padding: 18px;
  }

  .console-summary-grid,
  .console-rail {
    grid-template-columns: 1fr;
  }

  .console-summary-card {
    min-height: 88px;
  }

  .download-hero {
    max-width: 100%;
    padding: 18px;
    gap: 16px;
  }

  .page-hero {
    padding: 18px;
  }

  .hero-copy h2 {
    font-size: 34px;
  }

  .download-hero h2 {
    font-size: 30px;
    line-height: 1.18;
    overflow-wrap: anywhere;
    word-break: break-all;
  }

  .page-hero h2 {
    font-size: 31px;
  }

  .hero-copy p {
    font-size: 15px;
  }

  .download-hero p {
    font-size: 15px;
  }

  .hero-kpis {
    grid-template-columns: 1fr;
  }

  .hero-visual {
    grid-template-rows: auto 240px auto;
  }

  .status-strip {
    grid-template-columns: 1fr;
  }

  .segments {
    width: 100%;
    overflow-x: auto;
  }

  .segment {
    flex: 1;
    min-width: 76px;
  }

  .service-result-summary {
    width: 100%;
    justify-content: space-between;
  }

  .service-grid,
  .dashboard-grid,
  .console-overview-grid,
  .health-grid,
  .live-kpi-grid,
  .asset-table,
  .service-detail-grid,
  .service-action-grid,
  .service-related-grid,
  .workbench-grid,
  .route-grid,
  .roadmap-board,
  .update-grid,
  .ops-grid,
  .home-resource-grid,
  .command-pack-grid,
  .script-summary,
  .playbook-grid,
  .recipe-grid,
  .recovery-board,
  .script-grid,
  .two-column {
    grid-template-columns: 1fr;
  }

  .console-overview-grid {
    grid-template-areas:
      "runtime"
      "quick"
      "todo"
      "updates"
      "assets";
  }

  .monitor-strip,
  .console-asset-table {
    grid-template-columns: 1fr;
  }

  .dashboard-head,
  .settings-head,
  .dashboard-panel-head,
  .group-health-item,
  .setting-row {
    align-items: stretch;
    grid-template-columns: 1fr;
    flex-direction: column;
  }

  .dashboard-panel.panel-wide,
  .topology-panel {
    grid-column: span 1;
  }

  .dashboard-head-actions,
  .system-head-meta,
  .command-pack-actions,
  .service-actions,
  .modal-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .dashboard-head-actions .secondary-action,
  .command-pack-actions .secondary-action,
  .command-pack-actions .open-link,
  .service-actions .secondary-action,
  .service-actions .open-link,
  .service-actions .ghost-button,
  .modal-actions .secondary-action,
  .modal-actions .primary-action,
  .switch-control {
    width: 100%;
  }

  .setting-row > .status-pill {
    width: max-content;
    max-width: 100%;
    justify-self: start;
  }

  .copy-service-button span {
    display: inline;
  }

  .resource-panel-head {
    align-items: stretch;
    flex-direction: column;
  }

  .update-card,
  .update-card:nth-child(-n + 2) {
    border-left: 0;
    border-top: 1px solid var(--line);
  }

  .update-card:first-child {
    border-top: 0;
  }

  .domain-row,
  .download-row {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .domain-state {
    justify-self: start;
  }

  .sidebar {
    width: auto;
    max-width: 100%;
    margin: 10px;
    gap: 14px;
    display: grid;
    grid-template-columns: 1fr;
    align-items: stretch;
    padding: 14px;
    overflow: hidden;
  }

  .side-nav {
    width: 100%;
    grid-auto-flow: initial;
    grid-auto-columns: initial;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    overflow-x: visible;
  }

  .side-nav a {
    min-height: 42px;
    justify-content: center;
    gap: 7px;
    padding: 0 8px;
    font-size: 13px;
  }

  .side-nav a span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .domain-box {
    width: 100%;
    max-width: 100%;
    margin-left: 0;
  }

  .download-terminal pre,
  .script-code {
    font-size: 12px;
  }
}

@media (max-width: 760px) {
  .sidebar {
    position: sticky;
    top: 0;
    z-index: 24;
    margin: 0 0 12px;
    padding: 10px 12px 12px;
    border-width: 0 0 1px;
    border-radius: 0 0 20px 20px;
    gap: 10px;
  }

  .brand {
    gap: 10px;
  }

  .brand-mark {
    width: 42px;
    height: 42px;
    border-radius: 14px;
  }

  .brand strong {
    font-size: 16px;
  }

  .brand small {
    font-size: 12px;
  }

  .nav-section-label,
  .domain-box {
    display: none;
  }

  .side-nav {
    display: flex;
    grid-template-columns: none;
    gap: 8px;
    margin: 0 -2px;
    padding: 0 2px 3px;
    overflow-x: auto;
    scrollbar-width: none;
    scroll-snap-type: x proximity;
  }

  .side-nav::-webkit-scrollbar {
    display: none;
  }

  .side-nav a {
    flex: 0 0 auto;
    min-width: max-content;
    min-height: 38px;
    border-radius: 14px;
    justify-content: center;
    padding: 0 12px;
    scroll-snap-align: start;
  }

  .side-nav a[data-nav-id="services"] .nav-badge {
    display: inline-flex;
  }

  .nav-label-full {
    display: none;
  }

  .nav-label-short {
    display: inline;
  }

  .topbar {
    gap: 12px;
    margin-bottom: 14px;
  }

  .topbar h1 {
    font-size: 27px;
  }

  .dashboard-shell {
    gap: 12px;
  }

  .system-head {
    min-height: auto;
    padding: 14px;
  }

  .system-head h2 {
    font-size: 24px;
  }

  .system-head p {
    font-size: 12px;
  }

  .system-head-meta {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
    padding-top: 0;
  }

  .system-head-meta .status-pill,
  .system-head-actions .secondary-action {
    width: 100%;
    justify-content: center;
  }

  .dashboard-panel {
    min-height: auto;
    padding: 14px;
  }

  .console-overview-grid .dashboard-panel-head {
    min-height: 40px;
    align-items: center;
    flex-direction: row;
    margin-bottom: 12px;
    padding-bottom: 10px;
  }

  .runtime-panel .compact-health-grid {
    grid-template-columns: 1fr;
  }

  .runtime-panel .health-item {
    min-height: 58px;
  }

  .live-kpi-grid div {
    min-height: 58px;
  }

  .quick-panel .quick-entry-group-grid,
  .quick-entry-group-grid {
    grid-template-columns: 1fr;
  }

  .todo-panel,
  .updates-panel,
  .asset-panel {
    min-height: auto;
  }
}

@media (max-width: 760px) {
  .view-panel:not([data-view="overview"]) .page-hero,
  .settings-head {
    display: grid;
    grid-template-columns: 1fr;
    align-items: stretch;
    gap: 12px;
    min-height: auto;
    padding: 14px;
  }

  .view-panel:not([data-view="overview"]) .page-hero h2,
  .settings-head h2 {
    font-size: 23px;
    line-height: 1.16;
    word-break: keep-all;
  }

  .view-panel:not([data-view="overview"]) .page-hero p,
  .settings-head p {
    max-width: none;
    font-size: 12px;
    line-height: 1.45;
  }

  .page-hero-actions,
  .dashboard-head-actions {
    width: 100%;
    justify-content: stretch;
  }

  .page-hero-actions .primary-action,
  .page-hero-actions .secondary-action,
  .dashboard-head-actions .primary-action,
  .dashboard-head-actions .secondary-action {
    min-width: 0;
    flex: 1;
  }

  .service-card p {
    -webkit-line-clamp: 3;
  }
}

/* Final console monitor direction: public-safe rings, trends, and selectable accents */
:root[data-accent="bluegray"] {
  --teal: #2563eb;
  --teal-strong: #1d4ed8;
  --success: #2563eb;
  --line: rgba(100, 116, 139, 0.22);
  --line-strong: rgba(37, 99, 235, 0.28);
}

:root[data-accent="indigo"] {
  --teal: #4f46e5;
  --teal-strong: #3730a3;
  --success: #4f46e5;
  --line: rgba(99, 102, 241, 0.18);
  --line-strong: rgba(79, 70, 229, 0.28);
}

:root[data-accent="violet"] {
  --teal: #7c3aed;
  --teal-strong: #6d28d9;
  --success: #7c3aed;
  --line: rgba(124, 58, 237, 0.16);
  --line-strong: rgba(124, 58, 237, 0.28);
}

:root[data-theme="dark"][data-accent="bluegray"] {
  --teal: #60a5fa;
  --teal-strong: #93c5fd;
  --success: #60a5fa;
}

:root[data-theme="dark"][data-accent="indigo"] {
  --teal: #818cf8;
  --teal-strong: #c4b5fd;
  --success: #818cf8;
}

:root[data-theme="dark"][data-accent="violet"] {
  --teal: #a78bfa;
  --teal-strong: #ddd6fe;
  --success: #a78bfa;
}

:root[data-accent="bluegray"] body {
  background:
    linear-gradient(180deg, #f8fafc 0%, #f4f7fb 48%, #edf3fb 100%),
    var(--bg);
}

:root[data-accent="indigo"] body {
  background:
    linear-gradient(180deg, #f8fafc 0%, #f6f6fb 48%, #f0f1fb 100%),
    var(--bg);
}

:root[data-accent="violet"] body {
  background:
    linear-gradient(180deg, #faf8fc 0%, #f8f5fb 48%, #f3effb 100%),
    var(--bg);
}

:root[data-theme="dark"][data-accent] body {
  background:
    linear-gradient(180deg, #0d1117 0%, #101720 100%),
    var(--bg);
}

.accent-picker {
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  border-radius: 10px;
  padding: 3px;
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.24);
}

.accent-choice {
  min-width: 54px;
  min-height: 30px;
  border: 1px solid transparent;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 0 8px;
  color: var(--muted);
  background: transparent;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.accent-choice.active {
  color: var(--teal-strong);
  border-color: color-mix(in srgb, var(--teal) 18%, var(--line));
  background: color-mix(in srgb, var(--teal) 9%, var(--surface));
}

.accent-swatch {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #0d9488;
  box-shadow: 0 0 0 3px color-mix(in srgb, #0d9488 12%, transparent);
}

.accent-swatch.bluegray {
  background: #2563eb;
  box-shadow: 0 0 0 3px color-mix(in srgb, #2563eb 12%, transparent);
}

.accent-swatch.indigo {
  background: #4f46e5;
  box-shadow: 0 0 0 3px color-mix(in srgb, #4f46e5 12%, transparent);
}

.accent-swatch.violet {
  background: #7c3aed;
  box-shadow: 0 0 0 3px color-mix(in srgb, #7c3aed 12%, transparent);
}

.overview-monitor-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
}

.monitor-card {
  --tone: var(--teal);
  min-width: 0;
  min-height: 132px;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  border-radius: 12px;
  display: grid;
  grid-template-columns: 94px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  padding: 14px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--tone) 4%, transparent), transparent 66%),
    var(--surface);
  box-shadow:
    0 10px 26px rgba(15, 23, 42, 0.045),
    inset 0 1px 0 rgba(255, 255, 255, 0.32);
}

.monitor-card.tone-blue {
  --tone: var(--blue);
}

.monitor-card.tone-amber {
  --tone: var(--amber);
}

.monitor-card.tone-coral {
  --tone: var(--coral);
}

.monitor-ring {
  width: 92px;
  aspect-ratio: 1;
  border-radius: 50%;
  display: grid;
  place-items: center;
  color: var(--tone);
  background:
    radial-gradient(circle, var(--surface) 0 55%, transparent 56%),
    conic-gradient(var(--tone) var(--progress, 0%), color-mix(in srgb, var(--line) 56%, transparent) 0);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--line) 70%, transparent);
}

.monitor-ring strong {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 2px;
  font-size: 26px;
  line-height: 1;
}

.monitor-card[data-monitor-card="online"] .monitor-ring strong {
  font-size: 22px;
}

.monitor-ring small {
  font-size: 12px;
}

.monitor-card span,
.monitor-card b {
  display: block;
}

.monitor-card span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 900;
}

.monitor-card b {
  margin-top: 8px;
  color: var(--text);
  font-size: 18px;
  line-height: 1.15;
}

.trend-panel {
  grid-area: trend;
  min-height: 300px;
}

.trend-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(250px, 0.65fr);
  gap: 12px;
  align-items: stretch;
}

.trend-chart-card,
.live-event-list {
  min-width: 0;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  border-radius: 12px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 98%, transparent), color-mix(in srgb, var(--surface-soft) 58%, transparent)),
    var(--surface);
}

.trend-chart-card {
  position: relative;
  overflow: hidden;
  padding: 12px 14px 10px;
  color: var(--teal);
}

.trend-chart-card::after {
  position: absolute;
  inset: 0 0 auto;
  height: 1px;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--teal) 32%, transparent), transparent);
  content: "";
  animation: trend-scan 2.6s linear infinite;
}

@keyframes trend-scan {
  from {
    transform: translateY(0);
    opacity: 0;
  }

  35%,
  70% {
    opacity: 1;
  }

  to {
    transform: translateY(170px);
    opacity: 0;
  }
}

.trend-chart-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.trend-chart-head strong {
  color: var(--teal-strong);
  font-size: 20px;
}

.trend-chart {
  width: 100%;
  height: 168px;
  overflow: visible;
}

.trend-grid-line {
  stroke: color-mix(in srgb, var(--line) 80%, transparent);
  stroke-width: 1;
  stroke-dasharray: 4 5;
}

.trend-area {
  fill: url("#trendFill");
  color: var(--teal);
}

.trend-line {
  fill: none;
  stroke: var(--teal);
  stroke-width: 3;
  stroke-linecap: round;
  stroke-linejoin: round;
  filter: drop-shadow(0 8px 12px color-mix(in srgb, var(--teal) 22%, transparent));
}

.trend-dot {
  fill: var(--surface);
  stroke: var(--teal);
  stroke-width: 2;
}

.trend-dot.active {
  fill: var(--teal);
}

.live-event-list {
  display: grid;
  gap: 8px;
  align-content: start;
  padding: 10px;
}

.live-event-row {
  position: relative;
  min-width: 0;
  min-height: 58px;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  border-radius: 10px;
  display: grid;
  grid-template-columns: 12px minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  padding: 10px;
  background: var(--surface);
}

.live-event-row .pulse-dot {
  width: 8px;
  height: 8px;
}

.live-event-row strong,
.live-event-row small,
.live-event-row time {
  display: block;
}

.live-event-row strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 13px;
}

.live-event-row small {
  grid-column: 2;
  color: var(--muted);
  font-size: 12px;
  overflow-wrap: anywhere;
}

.live-event-row time {
  grid-row: 1 / span 2;
  grid-column: 3;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
}

.live-event-row.tone-amber .pulse-dot {
  background: var(--amber);
}

.live-event-row.tone-coral .pulse-dot {
  background: var(--coral);
}

.console-overview-grid {
  grid-template-areas:
    "runtime runtime quick"
    "trend trend quick"
    "todo updates assets";
}

.service-stat-card.console-stat-card,
.server-stat-card.console-stat-card,
.resource-stat-card.console-stat-card,
.settings-stat-card.console-stat-card,
.maintenance-stat-card.console-stat-card {
  --tone: var(--teal);
  min-height: 124px;
  border-color: color-mix(in srgb, var(--line) 88%, transparent);
  border-radius: 12px;
  grid-template-columns: 48px minmax(0, 1fr);
  align-items: start;
  gap: 12px;
  padding: 18px 16px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--tone) 3%, transparent), transparent 68%),
    var(--surface);
  box-shadow:
    0 10px 26px rgba(15, 23, 42, 0.045),
    inset 0 1px 0 rgba(255, 255, 255, 0.32);
}

.console-stat-card.is-ring {
  min-height: 132px;
  grid-template-columns: 94px minmax(0, 1fr);
}

.console-stat-card.tone-blue {
  --tone: var(--blue);
}

.console-stat-card.tone-amber {
  --tone: var(--amber);
}

.console-stat-card.tone-coral {
  --tone: var(--coral);
}

.console-stat-card.tone-slate {
  --tone: var(--slate);
}

.console-stat-card .stat-number-icon {
  width: 44px;
  height: 44px;
  margin-top: 26px;
  border: 1px solid color-mix(in srgb, var(--tone) 14%, var(--line));
  border-radius: 12px;
  display: grid;
  place-items: center;
  color: var(--tone);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--tone) 10%, transparent), transparent),
    color-mix(in srgb, var(--surface-soft) 76%, var(--surface));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.console-stat-card .stat-number-icon svg {
  width: 20px;
  height: 20px;
  stroke-width: 2.3;
}

.console-stat-card .stat-ring-wrap {
  position: relative;
  width: 92px;
  display: grid;
  place-items: center;
}

.console-stat-card .stat-card-icon {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 30px;
  height: 30px;
  border: 1px solid color-mix(in srgb, var(--tone) 18%, var(--line));
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: var(--tone);
  background: color-mix(in srgb, var(--surface) 94%, white);
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.08);
}

.console-stat-card .stat-card-icon svg {
  width: 16px;
  height: 16px;
  stroke-width: 2.4;
}

.console-stat-card .monitor-ring.is-compact strong {
  font-size: 20px;
  letter-spacing: 0;
}

.console-stat-card .console-stat-copy {
  min-width: 0;
  min-height: 88px;
  display: grid;
  grid-template-rows: 18px 30px minmax(38px, auto) auto;
  align-content: start;
}

.console-stat-card .console-stat-copy span,
.console-stat-card .console-stat-copy b {
  display: block;
}

.console-stat-card .console-stat-copy span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 900;
  line-height: 18px;
}

.console-stat-card .stat-value {
  display: flex;
  align-items: baseline;
  gap: 3px;
  margin-top: 0;
  color: var(--tone);
  font-size: 28px;
  line-height: 1;
}

.console-stat-card .stat-value small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.console-stat-card .console-stat-copy b {
  margin-top: 4px;
  color: var(--text);
  font-size: 15px;
  line-height: 1.32;
  overflow-wrap: anywhere;
}

.console-stat-card .stat-progress {
  position: relative;
  display: block;
  height: 6px;
  margin-top: 8px;
  border-radius: 999px;
  overflow: hidden;
  background: color-mix(in srgb, var(--line) 56%, transparent);
}

.console-stat-card .stat-progress i {
  display: block;
  width: var(--progress, 0%);
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, color-mix(in srgb, var(--tone) 82%, #ffffff), var(--tone));
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--tone) 18%, transparent);
}

.console-stat-card.is-ring .console-stat-copy b {
  margin-top: 8px;
  font-size: 17px;
  line-height: 1.28;
}

@media (max-width: 1280px) {
  .overview-monitor-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .monitor-card {
    min-height: 118px;
  }
}

@media (max-width: 1120px) {
  .console-overview-grid {
    grid-template-areas:
      "runtime runtime"
      "trend trend"
      "quick todo"
      "assets updates";
  }

  .trend-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .accent-picker {
    grid-column: 1 / -1;
    width: 100%;
    overflow-x: auto;
    justify-content: flex-start;
  }

  .accent-choice {
    flex: 1 0 auto;
  }

  .overview-monitor-grid {
    grid-template-columns: 1fr;
  }

  .service-overview-strip,
  .server-overview-strip,
  .resource-overview-strip,
  .settings-overview-strip,
  .maintenance-overview-strip {
    grid-template-columns: 1fr;
  }

  .monitor-card {
    min-height: 112px;
    grid-template-columns: 82px minmax(0, 1fr);
  }

  .monitor-ring {
    width: 80px;
  }

  .monitor-ring strong {
    font-size: 22px;
  }

  .monitor-ring small {
    font-size: 10px;
  }

  .service-stat-card.console-stat-card,
  .server-stat-card.console-stat-card,
  .resource-stat-card.console-stat-card,
  .settings-stat-card.console-stat-card,
  .maintenance-stat-card.console-stat-card {
    min-height: 108px;
    grid-template-columns: 46px minmax(0, 1fr);
    padding: 14px;
  }

  .console-stat-card.is-ring {
    min-height: 112px;
    grid-template-columns: 82px minmax(0, 1fr);
  }

  .console-stat-card .stat-ring-wrap {
    width: 80px;
  }

  .console-stat-card .stat-value {
    font-size: 25px;
  }

  .console-stat-card .stat-number-icon {
    margin-top: 24px;
  }

  .console-stat-card .console-stat-copy {
    min-height: 80px;
    grid-template-rows: 18px 27px minmax(34px, auto) auto;
  }

  .console-stat-card .stat-card-icon {
    width: 28px;
    height: 28px;
  }

  .console-stat-card .console-stat-copy b {
    font-size: 14px;
  }

  .console-stat-card.is-ring .console-stat-copy b {
    font-size: 15px;
  }

  .console-overview-grid {
    grid-template-areas:
      "runtime"
      "trend"
      "quick"
      "todo"
      "updates"
      "assets";
  }

  .trend-chart {
    height: 140px;
  }

  .live-event-row {
    grid-template-columns: 12px minmax(0, 1fr);
  }

  .live-event-row time {
    grid-row: auto;
    grid-column: 2;
  }
}

/* Overview usability pass: compact summary, fewer repeated entries, action-ready tasks */
.system-head {
  min-height: 76px;
  padding: 13px 16px;
}

.system-head h2 {
  font-size: 22px;
}

.system-head p {
  max-width: 560px;
}

.system-head-actions:empty,
.system-head-actions[hidden] {
  display: none;
}

.overview-today-strip {
  --tone: var(--teal);
  min-width: 0;
  min-height: 58px;
  border: 1px solid color-mix(in srgb, var(--tone) 20%, var(--line));
  border-radius: 12px;
  display: grid;
  grid-template-columns: auto minmax(190px, 1fr) repeat(3, minmax(92px, 0.35fr)) auto;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--tone) 8%, transparent), transparent 54%),
    color-mix(in srgb, var(--surface) 94%, transparent);
  box-shadow:
    0 8px 22px rgba(15, 23, 42, 0.04),
    inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.overview-today-strip.tone-degraded {
  --tone: var(--amber);
}

.overview-today-strip.tone-planned {
  --tone: var(--slate);
}

.overview-today-strip .today-strip-icon {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: var(--tone);
  background: color-mix(in srgb, var(--tone) 10%, var(--surface-soft));
}

.overview-today-strip span,
.overview-today-strip strong {
  display: block;
  min-width: 0;
}

.overview-today-strip div:not(.today-strip-main) span,
.today-strip-main span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
}

.overview-today-strip strong {
  margin-top: 2px;
  color: var(--text);
  font-size: 13px;
  line-height: 1.25;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.today-strip-main strong {
  color: var(--tone);
  font-size: 16px;
}

.overview-today-strip .secondary-action {
  min-height: 36px;
  border-radius: 9px;
  white-space: nowrap;
}

.task-row {
  display: grid;
  grid-template-columns: 8px minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
}

.task-row.has-action {
  grid-template-columns: 8px minmax(0, 1fr) auto;
}

.task-row.is-featured {
  border-color: color-mix(in srgb, var(--teal) 18%, var(--line));
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--teal) 8%, transparent), transparent 62%),
    color-mix(in srgb, var(--surface) 90%, transparent);
}

.task-row.is-featured .task-copy strong {
  color: var(--teal-strong);
}

.task-row .task-dot {
  position: static;
  left: auto;
  top: auto;
}

.task-copy {
  min-width: 0;
}

.task-row-action {
  min-width: 0;
  display: flex;
  justify-content: flex-end;
}

.task-row-action .secondary-action,
.task-row-action .primary-action {
  min-height: 34px;
  border-radius: 9px;
  white-space: nowrap;
}

@media (max-width: 760px) {
  .dashboard-shell {
    gap: 12px;
  }

  .system-head {
    min-height: auto;
    gap: 10px;
    padding: 13px 14px;
  }

  .system-head h2 {
    font-size: 28px;
    line-height: 1.12;
  }

  .system-head p {
    display: none;
  }

  .system-head-meta {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .system-head-meta .status-pill {
    min-height: 34px;
  }

  .overview-today-strip {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    padding: 11px;
  }

  .overview-today-strip .today-strip-icon {
    display: none;
  }

  .today-strip-main {
    grid-column: 1 / -1;
  }

  .overview-today-strip .secondary-action {
    grid-column: 1 / -1;
    width: 100%;
    justify-content: center;
  }

  .overview-monitor-grid {
    display: flex;
    grid-template-columns: none;
    gap: 10px;
    overflow-x: auto;
    padding-bottom: 2px;
    scroll-snap-type: x proximity;
  }

  .monitor-card {
    flex: 0 0 224px;
    min-height: 94px;
    grid-template-columns: 60px minmax(0, 1fr);
    gap: 8px;
    padding: 10px;
    scroll-snap-align: start;
  }

  .monitor-ring {
    width: 58px;
  }

  .monitor-ring strong {
    font-size: 18px;
  }

  .monitor-ring small {
    font-size: 9px;
  }

  .monitor-card span {
    font-size: 11px;
  }

  .monitor-card b {
    margin-top: 4px;
    font-size: 13px;
  }

  .console-overview-grid {
    grid-template-areas:
      "quick"
      "runtime"
      "todo"
      "updates"
      "assets"
      "trend";
  }

  .quick-panel .quick-entry-group-grid,
  .quick-entry-group-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .trend-panel {
    min-height: auto;
  }

  .trend-chart {
    height: 110px;
  }

  .live-event-list {
    display: none;
  }

  .task-row.has-action {
    grid-template-columns: 8px minmax(0, 1fr);
  }

  .task-row-action {
    grid-column: 2;
    justify-content: stretch;
  }

  .task-row-action .secondary-action,
  .task-row-action .primary-action {
    width: 100%;
    justify-content: center;
  }
}

@media (max-width: 760px) {
  .view-panel[data-view="server"] .server-security-summary {
    min-height: auto;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 10px;
    padding: 11px;
  }

  .view-panel[data-view="server"] .server-security-summary .summary-icon {
    width: 38px;
    height: 38px;
  }

  .view-panel[data-view="server"] .server-security-summary strong {
    font-size: 15px;
  }

  .view-panel[data-view="server"] .server-security-summary p {
    font-size: 12px;
    line-height: 1.42;
  }

  .view-panel[data-view="server"] .server-summary-chips {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    justify-content: stretch;
  }

  .view-panel[data-view="server"] .server-summary-chips span {
    justify-content: center;
    min-height: 30px;
    padding: 0 6px;
    font-size: 11px;
  }

  .view-panel[data-view="server"] .server-today-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    padding: 10px;
  }

  .view-panel[data-view="server"] .server-today-icon {
    display: none;
  }

  .view-panel[data-view="server"] .server-today-main {
    grid-column: 1 / -1;
  }

  .view-panel[data-view="server"] .server-today-strip div:not(.server-today-main) {
    min-height: 52px;
    border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
    border-radius: 10px;
    padding: 8px;
    background: color-mix(in srgb, var(--surface) 82%, transparent);
  }

  .view-panel[data-view="server"] .server-overview-strip,
  .view-panel[data-view="server"] .server-backup-grid {
    display: flex;
    grid-template-columns: none;
    gap: 10px;
    overflow-x: auto;
    padding-bottom: 2px;
    scroll-snap-type: x proximity;
  }

  .view-panel[data-view="server"] .server-stat-card {
    flex: 0 0 214px;
    min-height: 84px;
    grid-template-columns: 38px minmax(0, 1fr);
    padding: 10px;
    scroll-snap-align: start;
  }

  .view-panel[data-view="server"] .server-stat-card > span {
    width: 34px;
    height: 34px;
  }

  .view-panel[data-view="server"] .server-stat-card strong {
    font-size: 19px;
  }

  .view-panel[data-view="server"] .server-stat-card small {
    font-size: 12px;
  }

  .view-panel[data-view="server"] .server-stat-card em {
    font-size: 11px;
  }

  .view-panel[data-view="server"] .server-group-grid {
    grid-template-columns: 1fr;
  }

  .view-panel[data-view="server"] .server-entry-card {
    grid-template-columns: 38px minmax(0, 1fr);
    align-items: start;
    padding: 11px;
  }

  .view-panel[data-view="server"] .server-entry-icon {
    width: 36px;
    height: 36px;
  }

  .view-panel[data-view="server"] .server-entry-action {
    grid-column: 1 / -1;
    width: 100%;
  }

  .view-panel[data-view="server"] .server-entry-main p,
  .view-panel[data-view="server"] .server-entry-main small {
    white-space: normal;
  }

  .view-panel[data-view="server"] .workbench-card {
    min-height: auto;
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    align-items: start;
    gap: 10px;
    padding: 12px;
  }

  .view-panel[data-view="server"] .workbench-card > div {
    min-width: 0;
  }

  .view-panel[data-view="server"] .workbench-card h3 {
    font-size: 16px;
    line-height: 1.25;
  }

  .view-panel[data-view="server"] .workbench-card p {
    font-size: 12px;
    line-height: 1.45;
  }

  .view-panel[data-view="server"] .workbench-card a {
    grid-column: 1 / -1;
    width: 100%;
    margin-top: 2px;
  }

  .view-panel[data-view="server"] .server-flow-panel,
  .view-panel[data-view="server"] .server-safety-panel,
  .view-panel[data-view="server"] .server-status-panel {
    padding: 11px;
  }

  .view-panel[data-view="server"] .server-flow-head {
    gap: 8px;
    padding-bottom: 8px;
  }

  .view-panel[data-view="server"] .server-flow-head > span {
    width: 34px;
    height: 34px;
  }

  .view-panel[data-view="server"] .server-flow-head h3 {
    font-size: 15px;
  }

  .view-panel[data-view="server"] .server-flow-head p {
    font-size: 12px;
    line-height: 1.45;
  }

  .view-panel[data-view="server"] .server-flow-steps div,
  .view-panel[data-view="server"] .server-check-list div,
  .view-panel[data-view="server"] .server-trouble-list div,
  .view-panel[data-view="server"] .server-status-list div {
    min-height: 48px;
    padding: 9px 10px;
  }

  .view-panel[data-view="server"] .server-flow-steps {
    grid-template-columns: 1fr;
  }

  .view-panel[data-view="server"] .server-flow-step::after {
    display: none;
  }

  .view-panel[data-view="server"] .server-status-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .view-panel[data-view="server"] .server-backup-item {
    flex: 0 0 218px;
    min-height: 126px;
    padding: 10px;
    gap: 7px;
    scroll-snap-align: start;
  }

  .view-panel[data-view="server"] .server-backup-item > span {
    width: 32px;
    height: 32px;
  }

  .view-panel[data-view="server"] .server-backup-check {
    flex: 0 0 286px;
    grid-template-columns: 22px 34px minmax(0, 1fr);
  }

  .view-panel[data-view="server"] .server-backup-check .server-backup-meta {
    grid-column: 2 / -1;
    justify-content: flex-start;
    max-width: none;
  }

  .view-panel[data-view="server"] .server-backup-check .server-backup-icon {
    width: 32px;
    height: 32px;
  }

  .view-panel[data-view="server"] .server-workspace {
    scroll-margin-top: 18px;
  }

  .view-panel[data-view="server"] .server-tabs {
    width: 100%;
    flex-wrap: nowrap;
    gap: 5px;
    margin-bottom: 10px;
    overflow-x: auto;
  }

  .view-panel[data-view="server"] .server-tabs .segment {
    flex: 1 1 0;
    min-width: 0;
    padding: 0 6px;
    gap: 5px;
  }

  .view-panel[data-view="server"] .server-tabs .segment span {
    font-size: 12px;
  }

  .view-panel[data-view="server"] .server-tabs .segment svg {
    width: 15px;
    height: 15px;
  }

  .view-panel[data-view="server"] .server-tabs .segment em {
    min-width: 18px;
    padding: 1px 5px;
    font-size: 10px;
  }

  .view-panel[data-view="server"] .server-panel-head {
    min-height: auto;
    align-items: flex-start;
    margin-bottom: 8px;
  }

  .view-panel[data-view="server"] .server-panel-head strong {
    font-size: 14px;
  }

  .view-panel[data-view="server"] .server-panel-head span {
    font-size: 12px;
  }

  .view-panel[data-view="resources"] .resource-launchpad {
    display: flex;
    grid-template-columns: none;
    gap: 10px;
    overflow-x: auto;
    padding-bottom: 2px;
    scroll-snap-type: x proximity;
  }

  .view-panel[data-view="resources"] .resource-overview-strip {
    display: flex;
    grid-template-columns: none;
    gap: 10px;
    overflow-x: auto;
    padding-bottom: 2px;
    scroll-snap-type: x proximity;
  }

  .view-panel[data-view="resources"] .resource-stat-card {
    flex: 0 0 220px;
    min-height: 86px;
    grid-template-columns: 38px minmax(0, 1fr);
    padding: 10px;
    scroll-snap-align: start;
  }

  .view-panel[data-view="resources"] .resource-launch-card {
    flex: 0 0 252px;
    min-height: 168px;
    scroll-snap-align: start;
  }

  .view-panel[data-view="resources"] .resource-workspace {
    margin-right: -14px;
    margin-left: -14px;
    border-right: 0;
    border-left: 0;
    border-radius: 0;
    padding: 12px 14px 14px;
  }

  .view-panel[data-view="resources"] .resource-tabs {
    flex-wrap: nowrap;
    gap: 5px;
    overflow-x: auto;
  }

  .view-panel[data-view="resources"] .resource-tabs .segment {
    flex: 0 0 auto;
    min-width: 96px;
    padding: 0 8px;
  }

  .view-panel[data-view="resources"] .resource-command-head {
    align-items: stretch;
    flex-direction: column;
    gap: 9px;
  }

  .view-panel[data-view="resources"] .command-pack-controls {
    grid-template-columns: 1fr;
  }

  .view-panel[data-view="resources"] .command-pack {
    grid-template-columns: 1fr;
    grid-template-areas:
      "head"
      "body"
      "actions"
      "code";
  }

  .view-panel[data-view="resources"] .command-exec-panel {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .view-panel[data-view="resources"] .command-exec-panel em {
    grid-column: 2;
    justify-self: start;
  }
}

/* Monitoring center color polish: closer to calm green status consoles */
:root {
  --teal: #0f766e;
  --teal-strong: #0b6b5c;
  --success: #15803d;
  --monitor-green: #15803d;
  --monitor-green-strong: #166534;
  --monitor-green-bg: #dcfce7;
  --monitor-green-soft: #f0fdf4;
  --monitor-green-line: #bbf7d0;
}

:root[data-theme="dark"] {
  --teal: #2dd4bf;
  --teal-strong: #7dd3fc;
  --success: #4ade80;
  --monitor-green: #4ade80;
  --monitor-green-strong: #86efac;
  --monitor-green-bg: rgba(34, 197, 94, 0.14);
  --monitor-green-soft: rgba(20, 83, 45, 0.34);
  --monitor-green-line: rgba(74, 222, 128, 0.28);
}

:root[data-accent="teal"] body {
  background:
    linear-gradient(180deg, #f8fafc 0%, #f5f8f7 46%, #eef7f4 100%),
    var(--bg);
}

.brand-mark {
  background:
    linear-gradient(180deg, #0f766e, #0b6b5c),
    var(--teal);
  box-shadow:
    0 14px 30px rgba(15, 118, 110, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

.primary-action {
  border-color: color-mix(in srgb, #0f766e 82%, transparent);
  background:
    linear-gradient(180deg, #0f8f83, #0f766e),
    var(--teal);
  box-shadow:
    0 12px 26px rgba(15, 118, 110, 0.2),
    inset 0 1px 0 rgba(255, 255, 255, 0.22);
}

.status-pill,
.status-pill.online,
.rail-status,
.nav-badge.protected {
  color: var(--monitor-green-strong);
  border: 1px solid var(--monitor-green-line);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--monitor-green-bg) 86%, var(--surface)), color-mix(in srgb, var(--monitor-green-soft) 72%, var(--surface))),
    var(--monitor-green-bg);
}

.status-pill svg,
.rail-status svg,
.rail-status .pulse-dot {
  color: var(--monitor-green);
}

.pulse-dot {
  background: var(--monitor-green);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--monitor-green) 16%, transparent);
}

.status-pill.protected,
.module-badge.protected {
  color: var(--blue);
  border-color: color-mix(in srgb, var(--blue) 22%, var(--line));
  background: color-mix(in srgb, var(--blue) 8%, var(--surface));
}

.status-pill.planned,
.status-pill.degraded,
.module-badge.planned {
  color: var(--amber);
  border-color: color-mix(in srgb, var(--amber) 22%, var(--line));
  background: color-mix(in srgb, var(--amber) 10%, var(--surface));
}

.status-pill.down {
  color: var(--coral);
  border-color: color-mix(in srgb, var(--coral) 22%, var(--line));
  background: color-mix(in srgb, var(--coral) 9%, var(--surface));
}

.accent-choice.active,
.segment.active,
.open-link,
.module-badge,
.download-kind.internal,
.domain-state.online {
  color: var(--monitor-green-strong);
  border-color: var(--monitor-green-line);
  background: color-mix(in srgb, var(--monitor-green-bg) 78%, var(--surface));
}

.global-search:focus-within,
.copy-line:hover,
.quick-entry-grid a:hover,
.secondary-action:hover,
.icon-button:hover {
  border-color: color-mix(in srgb, var(--monitor-green) 38%, var(--line));
  box-shadow:
    0 10px 24px color-mix(in srgb, var(--monitor-green) 10%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.26);
}

.console-stat-card.tone-teal,
.monitor-card,
.trend-chart-card,
.trend-line,
.trend-area {
  color: var(--teal);
}

/* Sidebar navigation polish */
.sidebar {
  gap: 18px;
  padding: 68px 16px 16px;
}

.brand {
  gap: 10px;
}

.brand-mark {
  width: 42px;
  height: 42px;
  border-radius: 13px;
}

.brand strong {
  font-size: 16px;
}

.brand small {
  font-size: 12px;
}

.sidebar-collapse {
  min-height: 34px;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 0 10px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-soft) 62%, transparent);
  font-size: 12px;
  font-weight: 900;
  box-shadow: none;
}

.sidebar-collapse svg {
  width: 16px;
  height: 16px;
}

.sidebar-collapse:hover {
  color: var(--text);
  border-color: color-mix(in srgb, var(--teal) 26%, var(--line));
  background: color-mix(in srgb, var(--teal) 7%, var(--surface));
}

.side-nav {
  gap: 12px;
}

.nav-group {
  gap: 4px;
}

.nav-group-external {
  padding-top: 12px;
}

.nav-section-label {
  margin: 0 8px 5px;
  font-size: 10px;
  letter-spacing: 0.02em;
}

.nav-subsection-label {
  margin: 9px 8px 3px;
  color: color-mix(in srgb, var(--muted) 78%, var(--text));
  font-size: 10px;
  font-weight: 900;
  line-height: 1;
}

.nav-subsection-label + a {
  margin-top: 0;
}

.side-nav a {
  min-height: 36px;
  border-radius: 10px;
  gap: 8px;
  padding: 0 9px;
  color: color-mix(in srgb, var(--muted) 88%, var(--text));
}

.side-nav a svg {
  width: 17px;
  height: 17px;
}

.side-nav a:hover {
  border-color: color-mix(in srgb, var(--teal) 16%, var(--line));
  background: color-mix(in srgb, var(--teal) 4%, var(--surface));
  color: var(--text);
  transform: none;
}

.side-nav a.active {
  color: var(--text);
  border-color: color-mix(in srgb, var(--teal) 22%, var(--line));
  background: color-mix(in srgb, var(--teal) 7%, var(--surface));
  box-shadow: inset 2px 0 0 var(--teal);
  transform: none;
}

.nav-status-dot {
  width: 7px;
  height: 7px;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--muted) 10%, transparent);
}

.nav-status-dot.online,
.nav-status-dot.protected {
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--teal) 13%, transparent);
}

.nav-status-dot.degraded,
.nav-status-dot.planned {
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--amber) 13%, transparent);
}

.nav-status-dot.down {
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--coral) 13%, transparent);
}

.nav-badge {
  min-width: 28px;
  min-height: 18px;
  padding: 0 6px;
  font-size: 10px;
}

.nav-badge.protected {
  color: var(--monitor-green-strong);
  border-color: var(--monitor-green-line);
  background: color-mix(in srgb, var(--monitor-green-bg) 78%, var(--surface));
}

.domain-box {
  border-radius: 12px;
  padding: 10px;
  box-shadow: none;
}

.domain-box .eyebrow {
  margin-bottom: 6px;
  font-size: 10px;
}

.copy-line {
  min-height: 34px;
  border-radius: 9px;
  margin-top: 0;
  padding: 0 10px;
  font-size: 14px;
}

.copy-line svg {
  width: 16px;
  height: 16px;
}

.rail-status {
  min-height: 28px;
  margin-top: 8px;
  border-radius: 9px;
  padding: 0 9px;
  font-size: 12px;
}

.pulse-dot {
  width: 8px;
  height: 8px;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--monitor-green) 14%, transparent);
}

.top-management-menu {
  position: relative;
  z-index: 14;
}

.top-management-menu summary {
  min-height: 40px;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 0 12px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  font-size: 13px;
  font-weight: 900;
  cursor: pointer;
  list-style: none;
}

.top-management-menu.is-compact summary {
  min-width: 40px !important;
  width: 40px;
  padding: 0;
}

.top-management-menu summary::-webkit-details-marker {
  display: none;
}

.top-management-menu summary:hover,
.top-management-menu[open] summary {
  color: var(--text);
  border-color: color-mix(in srgb, var(--teal) 28%, var(--line));
  background: color-mix(in srgb, var(--teal) 7%, var(--surface));
}

.top-management-menu svg {
  width: 17px;
  height: 17px;
}

.top-management-panel {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: min(270px, calc(100vw - 28px));
  border: 1px solid color-mix(in srgb, var(--line-strong) 74%, transparent);
  border-radius: 12px;
  display: grid;
  gap: 5px;
  padding: 8px;
  background: color-mix(in srgb, var(--surface) 98%, transparent);
  box-shadow: 0 20px 54px rgba(15, 23, 42, 0.16);
}

.top-management-panel a {
  min-width: 0;
  border-radius: 10px;
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 9px;
  align-items: center;
  padding: 9px;
  color: var(--text);
}

.top-management-panel a:hover {
  background: color-mix(in srgb, var(--teal) 7%, var(--surface-soft));
}

.top-management-panel a > i,
.top-management-panel a > svg {
  width: 34px;
  height: 34px;
  border-radius: 9px;
  padding: 8px;
  color: var(--teal-strong);
  background: color-mix(in srgb, var(--teal) 10%, var(--surface));
}

.top-management-panel strong,
.top-management-panel small {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.top-management-panel strong {
  font-size: 13px;
}

.top-management-panel small {
  margin-top: 2px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

@media (min-width: 1121px) {
  .app-shell.sidebar-collapsed {
    grid-template-columns: 86px minmax(0, 1fr);
  }

  .sidebar.is-collapsed {
    align-items: center;
    gap: 14px;
    padding-right: 12px;
    padding-left: 12px;
  }

  .sidebar.is-collapsed .brand {
    justify-content: center;
    padding: 0;
  }

  .sidebar.is-collapsed .brand > span:not(.brand-mark),
  .sidebar.is-collapsed .sidebar-collapse span,
  .sidebar.is-collapsed .nav-section-label,
  .sidebar.is-collapsed .nav-subsection-label,
  .sidebar.is-collapsed .nav-label,
  .sidebar.is-collapsed .nav-badge,
  .sidebar.is-collapsed .nav-status-dot,
  .sidebar.is-collapsed .domain-box {
    display: none;
  }

  .sidebar.is-collapsed .sidebar-collapse,
  .sidebar.is-collapsed .side-nav a {
    width: 42px;
    min-width: 42px;
    padding: 0;
  }

  .sidebar.is-collapsed .side-nav {
    width: 100%;
    justify-items: center;
  }

  .sidebar.is-collapsed .nav-group {
    justify-items: center;
  }

  .sidebar.is-collapsed .nav-group-external {
    width: 100%;
    border-top: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  }

  .sidebar.is-collapsed .side-nav a {
    justify-content: center;
  }

  .sidebar.is-collapsed .side-nav a.active {
    box-shadow: inset 0 -2px 0 var(--teal);
  }
}

@media (max-width: 1120px) {
  .sidebar-collapse {
    display: none;
  }

  .nav-subsection-label {
    grid-column: 1 / -1;
  }
}

@media (max-width: 760px) {
  .top-management-menu {
    width: fit-content;
    max-width: 100%;
  }

  .top-management-panel {
    left: 0;
    right: auto;
    width: min(320px, calc(100vw - 28px));
  }

  .top-management-panel strong,
  .top-management-panel small {
    white-space: normal;
  }

  .nav-subsection-label {
    display: none;
  }

  .service-maintenance-head {
    align-items: flex-start;
    flex-direction: column;
    gap: 4px;
  }

  .service-maintenance-list {
    grid-template-columns: 1fr;
  }
}

/* Calm compact launcher pass: reduce visual noise while keeping status rings. */
:root {
  --radius-lg: 16px;
  --radius-md: 10px;
  --radius-sm: 8px;
  --shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.05);
  --shadow-md: 0 8px 22px rgba(15, 23, 42, 0.08);
  --shadow-lg: 0 16px 48px rgba(15, 23, 42, 0.1);
}

:root[data-theme="dark"] {
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.28);
  --shadow-md: 0 10px 28px rgba(0, 0, 0, 0.34);
  --shadow-lg: 0 18px 56px rgba(0, 0, 0, 0.42);
}

body {
  background:
    linear-gradient(180deg, #f8fafc 0%, #f6f8fb 52%, #f2f6f8 100%),
    var(--bg);
}

body::before {
  opacity: 0.34;
  background-size: 36px 36px;
}

.app-shell {
  width: min(100% - 16px, 1520px);
  min-height: calc(100vh - 16px);
  margin: 8px auto;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
}

.desktop-chrome {
  height: 38px;
  gap: 10px;
  padding: 0 14px;
  background: color-mix(in srgb, var(--surface) 94%, transparent);
}

.desktop-chrome .window-dots {
  opacity: 0.42;
  transform: scale(0.82);
  transform-origin: left center;
}

.sidebar {
  gap: 12px;
  padding: 52px 12px 12px;
}

.brand {
  gap: 9px;
}

.brand-mark {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  box-shadow: none;
}

.brand strong {
  font-size: 15px;
}

.brand small,
.nav-section-label,
.nav-subsection-label {
  color: color-mix(in srgb, var(--muted) 82%, var(--text));
}

.side-nav {
  gap: 9px;
}

.nav-group {
  gap: 3px;
}

.side-nav a {
  min-height: 34px;
  border-radius: 8px;
  gap: 8px;
  padding: 0 8px;
}

.side-nav a svg {
  width: 16px;
  height: 16px;
}

.side-nav a.active {
  box-shadow: inset 2px 0 0 var(--teal);
}

.nav-status-dot {
  width: 6px;
  height: 6px;
}

.nav-badge {
  min-width: 24px;
  min-height: 16px;
  padding: 0 5px;
}

.domain-box {
  border-radius: 10px;
  padding: 9px;
}

.copy-line,
.rail-status {
  border-radius: 8px;
}

.workspace {
  padding: 58px 20px 20px;
}

.topbar {
  top: 38px;
  gap: 10px;
  margin: -58px -20px 16px;
  padding: 46px 20px 10px;
  background: color-mix(in srgb, var(--surface) 91%, transparent);
}

.topbar h1 {
  font-size: 24px;
}

.top-actions {
  gap: 7px;
}

.global-search {
  width: min(360px, 29vw);
  min-width: 240px;
  height: 38px;
  border-radius: 9px;
  box-shadow: none;
}

.global-search-results {
  border-radius: 10px;
  box-shadow: var(--shadow-md);
}

.global-search-result {
  min-height: 48px;
  border-radius: 8px;
}

.accent-picker {
  min-height: 34px;
  border-radius: 9px;
  opacity: 0.76;
  box-shadow: none;
}

.accent-choice {
  min-width: 38px;
  min-height: 26px;
  gap: 0;
  padding: 0 6px;
  color: transparent;
  font-size: 0;
}

.accent-choice.active {
  min-width: 52px;
  color: var(--teal-strong);
  font-size: 11px;
}

.accent-swatch {
  width: 9px;
  height: 9px;
  box-shadow: 0 0 0 2px color-mix(in srgb, currentColor 10%, transparent);
}

.icon-button,
.primary-action,
.secondary-action,
.open-link,
.ghost-link,
.ghost-button,
.ghost-copy,
.workbench-card a,
.top-management-menu summary {
  min-width: 72px;
  white-space: nowrap;
  word-break: keep-all;
  line-height: 1;
  min-height: 36px;
  border-radius: 8px;
  box-shadow: none;
}

.primary-action,
.secondary-action {
  padding: 0 11px;
}

.primary-action {
  box-shadow: 0 6px 14px color-mix(in srgb, var(--teal) 14%, transparent);
}

.dashboard-shell,
.settings-shell {
  gap: 10px;
}

.dashboard-head,
.settings-head,
.dashboard-panel,
.settings-list,
.page-hero,
.hero-panel,
.access-panel,
.resource-panel,
.service-card,
.workbench-card,
.route-card,
.roadmap-card,
.note-panel,
.script-card,
.resource-card,
.download-hero,
.download-terminal,
.domain-table,
.download-list,
.update-grid,
.trend-chart-card,
.live-event-list {
  border-radius: 10px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 98%, transparent), color-mix(in srgb, var(--surface-soft) 72%, transparent)),
    var(--surface);
  box-shadow: var(--shadow-sm);
}

.dashboard-head,
.settings-head {
  min-height: 72px;
  padding: 12px 14px;
}

.system-head {
  min-height: 66px;
  padding: 11px 13px;
}

.system-head h2 {
  font-size: 21px;
}

.system-head p {
  margin-top: 3px;
  font-size: 12px;
  line-height: 1.4;
}

.system-head-meta {
  gap: 5px;
}

.dashboard-panel {
  min-height: 198px;
  padding: 12px;
}

.dashboard-panel-head {
  min-height: 30px;
  margin-bottom: 10px;
  padding-bottom: 8px;
}

.dashboard-panel h3 {
  font-size: 17px;
}

.overview-today-strip {
  min-height: 48px;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 10px;
  box-shadow: var(--shadow-sm);
}

.overview-today-strip .today-strip-icon {
  width: 30px;
  height: 30px;
  border-radius: 8px;
}

.overview-today-strip strong {
  font-size: 12px;
}

.today-strip-main strong {
  font-size: 14px;
}

.overview-monitor-grid {
  gap: 8px;
}

.monitor-card {
  min-height: 104px;
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 9px;
  padding: 10px;
  border-radius: 10px;
  background: var(--surface);
  box-shadow: var(--shadow-sm);
}

.monitor-ring {
  width: 70px;
}

.monitor-ring strong {
  font-size: 20px;
}

.monitor-card span {
  font-size: 12px;
}

.monitor-card b {
  margin-top: 5px;
  font-size: 15px;
}

.console-stat-card.is-ring {
  min-height: 112px;
  grid-template-columns: 78px minmax(0, 1fr);
}

.console-stat-card .stat-ring-wrap {
  width: 76px;
}

.service-stat-card.console-stat-card,
.server-stat-card.console-stat-card,
.resource-stat-card.console-stat-card,
.settings-stat-card.console-stat-card,
.maintenance-stat-card.console-stat-card {
  min-height: 106px;
  gap: 9px;
  padding: 12px;
  border-radius: 10px;
  box-shadow: var(--shadow-sm);
}

.console-stat-card .stat-number-icon {
  width: 38px;
  height: 38px;
  margin-top: 20px;
  border-radius: 9px;
}

.console-stat-card .console-stat-copy {
  min-height: 76px;
  grid-template-rows: 16px 26px minmax(30px, auto) auto;
}

.console-stat-card .stat-value {
  font-size: 24px;
}

.console-stat-card .console-stat-copy b,
.console-stat-card.is-ring .console-stat-copy b {
  font-size: 14px;
  line-height: 1.25;
}

.health-grid,
.task-list,
.timeline-list,
.settings-list,
.modal-rule-list,
.live-kpi-grid,
.group-health-list,
.asset-table,
.service-grid {
  gap: 8px;
}

.health-item,
.task-row,
.setting-row,
.timeline-list div,
.asset-table div,
.live-kpi-grid div,
.group-health-item,
.modal-rule-list span {
  border-radius: 9px;
}

.health-item {
  min-height: 58px;
  gap: 9px;
  padding: 9px 10px;
}

.health-icon,
.setting-icon,
.card-icon {
  width: 36px;
  height: 36px;
  border-radius: 9px;
}

.task-row {
  min-height: 56px;
  padding: 9px 10px;
}

.task-row.has-action {
  grid-template-columns: 7px minmax(0, 1fr) auto;
}

.quick-entry-grid {
  gap: 8px;
}

.quick-entry-grid a {
  min-height: 44px;
  border-radius: 9px;
  gap: 8px;
  padding: 0 10px;
  box-shadow: none;
}

.quick-entry-grid a:hover,
.service-card:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.service-grid {
  grid-template-columns: repeat(auto-fit, minmax(238px, 1fr));
}

.service-card {
  min-height: 158px;
  gap: 10px;
  padding: 13px;
}

.service-card::before {
  width: 2px;
  opacity: 0.58;
}

.service-card h3 {
  font-size: 16px;
}

.service-card p {
  font-size: 13px;
  line-height: 1.42;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.status-pill,
.module-badge {
  min-height: 24px;
  border-radius: 999px;
  padding: 3px 8px;
  font-size: 11px;
}

.trend-layout {
  gap: 8px;
}

.trend-chart-card {
  padding: 10px 12px 8px;
}

.trend-chart {
  height: 136px;
}

.trend-line {
  stroke-width: 2.4;
  filter: none;
}

.live-event-list {
  gap: 6px;
  padding: 8px;
}

.live-event-row {
  min-height: 48px;
  border-radius: 8px;
  padding: 8px;
}

.top-management-panel {
  border-radius: 10px;
  box-shadow: var(--shadow-md);
}

@media (max-width: 1120px) {
  .sidebar {
    margin: 10px;
    border-radius: 12px;
    padding: 12px;
  }

  .workspace {
    padding: 0 14px 16px;
  }
}

@media (max-width: 760px) {
  body::before {
    opacity: 0.18;
  }

  .topbar {
    gap: 10px;
    margin-bottom: 12px;
  }

  .topbar h1 {
    font-size: 22px;
  }

  .global-search {
    width: 100%;
    min-width: 0;
  }

  .accent-picker {
    min-height: 32px;
  }

  .accent-choice {
    min-width: 32px;
  }

  .accent-choice.active {
    min-width: 48px;
  }

  .system-head h2 {
    font-size: 24px;
  }

  .overview-today-strip {
    padding: 9px;
  }

  .monitor-card {
    flex-basis: 196px;
    min-height: 84px;
    grid-template-columns: 54px minmax(0, 1fr);
    padding: 8px;
  }

  .monitor-ring,
  .console-stat-card .stat-ring-wrap {
    width: 54px;
  }

  .monitor-ring strong {
    font-size: 16px;
  }

  .monitor-card b {
    font-size: 13px;
  }

  .dashboard-panel,
  .service-card {
    padding: 11px;
  }

  .service-grid {
    grid-template-columns: 1fr;
  }
}

/* Launcher interaction pass: cleaner personal-entry shell, fewer colors. */
:root,
:root[data-accent="bluegray"],
:root[data-accent="indigo"],
:root[data-accent="violet"] {
  --bg: #f7f9fb;
  --surface: #ffffff;
  --surface-soft: #f3f6f8;
  --surface-strong: #e9eef2;
  --glass: rgba(255, 255, 255, 0.72);
  --glass-strong: rgba(255, 255, 255, 0.92);
  --glass-soft: rgba(255, 255, 255, 0.56);
  --text: #111827;
  --muted: #64748b;
  --line: rgba(148, 163, 184, 0.26);
  --line-strong: rgba(100, 116, 139, 0.3);
  --teal: #0f766e;
  --teal-strong: #0b5f59;
  --success: #168a55;
  --blue: #536579;
  --violet: #536579;
  --amber: #a16207;
  --coral: #c94f43;
  --radius-lg: 0;
  --shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.04);
  --shadow-md: 0 8px 24px rgba(15, 23, 42, 0.07);
  --shadow-lg: 0 16px 44px rgba(15, 23, 42, 0.09);
}

:root[data-theme="dark"] {
  --bg: #0d1117;
  --surface: #151b23;
  --surface-soft: #1b2430;
  --surface-strong: #263344;
  --text: #eef3f8;
  --muted: #a5b2c0;
  --line: rgba(146, 166, 190, 0.2);
  --line-strong: rgba(159, 178, 201, 0.28);
  --teal: #2dd4bf;
  --teal-strong: #7dd3fc;
  --success: #4ade80;
  --blue: #a5b2c0;
  --violet: #a5b2c0;
}

body {
  background:
    linear-gradient(180deg, #fbfcfd 0%, #f7f9fb 48%, #f2f6f7 100%),
    var(--bg);
}

:root[data-theme="dark"] body {
  background:
    linear-gradient(180deg, #0d1117 0%, #111820 100%),
    var(--bg);
}

body::before {
  opacity: 0.18;
  background-size: 40px 40px;
}

.desktop-chrome {
  display: none;
}

.app-shell {
  width: 100%;
  min-height: 100vh;
  margin: 0;
  border: 0;
  border-radius: 0;
  grid-template-columns: 236px minmax(0, 1fr);
  overflow: visible;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}

.sidebar {
  top: 0;
  height: 100vh;
  gap: 16px;
  padding: 24px 14px;
  border-right: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 84%, transparent);
  box-shadow: none;
  backdrop-filter: none;
}

.sidebar-collapse,
.domain-box {
  display: none;
}

.brand-mark {
  width: 42px;
  height: 42px;
  border-radius: 12px;
  background:
    linear-gradient(180deg, var(--teal), var(--teal-strong)),
    var(--teal);
  box-shadow: none;
}

.brand small {
  font-size: 12px;
}

.side-nav {
  gap: 8px;
}

.nav-section-label {
  margin: 2px 8px 3px;
  color: color-mix(in srgb, var(--muted) 78%, var(--text));
  font-size: 10px;
}

.side-nav a {
  min-height: 36px;
  border: 0;
  border-radius: 9px;
  padding: 0 9px;
  background: transparent;
  color: color-mix(in srgb, var(--muted) 86%, var(--text));
  box-shadow: none;
}

.side-nav a:hover,
.side-nav a.active {
  border: 0;
  background: color-mix(in srgb, var(--teal) 8%, var(--surface));
  color: var(--text);
  box-shadow: none;
  transform: none;
}

.side-nav a.active {
  color: var(--teal-strong);
  box-shadow: inset 2px 0 0 var(--teal);
}

.nav-status-dot {
  width: 6px;
  height: 6px;
  box-shadow: none;
}

.nav-badge {
  min-width: 22px;
  min-height: 16px;
  border-color: transparent;
  background: color-mix(in srgb, var(--teal) 9%, var(--surface));
}

.workspace {
  width: min(1180px, calc(100% - 48px));
  padding: 20px 0 40px;
}

.topbar {
  position: sticky;
  top: 0;
  gap: 16px;
  margin: 0 0 18px;
  padding: 10px 0;
  border-bottom: 0;
  background: color-mix(in srgb, var(--bg) 82%, transparent);
  backdrop-filter: blur(16px);
}

.topbar h1 {
  font-size: 25px;
}

.global-search {
  flex: 1 1 360px;
  width: auto;
  max-width: 560px;
  min-width: 260px;
  height: 42px;
  border-radius: 12px;
  background: var(--surface);
}

.global-search:focus-within {
  border-color: color-mix(in srgb, var(--teal) 34%, var(--line));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--teal) 8%, transparent);
}

.top-actions {
  gap: 8px;
}

.accent-picker {
  display: none;
}

.secondary-action,
.icon-button,
.top-management-menu summary {
  border-color: var(--line);
  background: var(--surface);
  color: color-mix(in srgb, var(--muted) 82%, var(--text));
}

.primary-action {
  background: var(--teal);
}

.dashboard-head,
.settings-head,
.dashboard-panel,
.settings-list,
.page-hero,
.hero-panel,
.access-panel,
.resource-panel,
.service-card,
.workbench-card,
.route-card,
.roadmap-card,
.note-panel,
.script-card,
.resource-card,
.download-hero,
.download-terminal,
.domain-table,
.download-list,
.update-grid,
.trend-chart-card,
.live-event-list {
  border-color: var(--line);
  border-radius: 12px;
  background: var(--surface);
  box-shadow: var(--shadow-sm);
  backdrop-filter: none;
}

.system-head {
  min-height: 82px;
  padding: 18px 20px;
}

.system-head h2 {
  font-size: 28px;
}

.system-head p {
  max-width: 760px;
  font-size: 13px;
}

.overview-today-strip {
  border-color: color-mix(in srgb, var(--teal) 18%, var(--line));
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--teal) 8%, transparent), transparent 58%),
    var(--surface);
}

.monitor-card,
.service-stat-card.console-stat-card,
.server-stat-card.console-stat-card,
.resource-stat-card.console-stat-card,
.settings-stat-card.console-stat-card,
.maintenance-stat-card.console-stat-card {
  border-color: var(--line);
  background: var(--surface);
}

.monitor-card.tone-blue,
.console-stat-card.tone-blue {
  --tone: var(--blue);
}

.service-card::before {
  display: none;
}

.service-card,
.quick-entry-grid a,
.health-item,
.task-row,
.timeline-list div,
.asset-table div,
.live-kpi-grid div {
  background: var(--surface);
}

.card-icon,
.health-icon,
.setting-icon,
.top-management-panel a > i,
.top-management-panel a > svg {
  background: var(--surface-soft);
}

.service-card.tone-blue,
.service-card.tone-slate {
  --tone: var(--blue);
}

.service-card.tone-amber {
  --tone: var(--amber);
}

.service-card.tone-coral {
  --tone: var(--coral);
}

.status-pill.online,
.rail-status,
.nav-badge.protected {
  color: var(--success);
  border-color: color-mix(in srgb, var(--success) 24%, var(--line));
  background: color-mix(in srgb, var(--success) 9%, var(--surface));
}

.status-pill.protected,
.module-badge.protected {
  color: var(--blue);
  border-color: color-mix(in srgb, var(--blue) 18%, var(--line));
  background: color-mix(in srgb, var(--blue) 8%, var(--surface));
}

.quick-entry-grid a:hover,
.service-card:hover,
.secondary-action:hover,
.icon-button:hover {
  border-color: color-mix(in srgb, var(--teal) 28%, var(--line));
  box-shadow: var(--shadow-md);
}

@media (max-width: 1120px) {
  .app-shell {
    display: block;
  }

  .sidebar {
    position: sticky;
    top: 0;
    z-index: 10;
    height: auto;
    margin: 0;
    border: 0;
    border-bottom: 1px solid var(--line);
    border-radius: 0;
    align-items: center;
    flex-direction: row;
    gap: 12px;
    padding: 12px;
    background: color-mix(in srgb, var(--surface) 96%, transparent);
  }

  .brand {
    flex: 0 0 auto;
  }

  .brand small {
    display: none;
  }

  .side-nav {
    flex: 1;
    width: auto;
    display: flex;
    gap: 6px;
    overflow-x: auto;
    scrollbar-width: none;
  }

  .side-nav::-webkit-scrollbar {
    display: none;
  }

  .nav-group {
    display: flex;
    gap: 6px;
  }

  .nav-section-label {
    display: none;
  }

  .side-nav a {
    flex: 0 0 auto;
    min-height: 34px;
    padding: 0 10px;
  }

  .workspace {
    width: min(100% - 24px, 1180px);
    padding: 14px 0 28px;
  }
}

/* Wide desktop pass: the launchpad should use the page, while rings keep visible progress color. */
@media (min-width: 1121px) {
  .workspace {
    width: min(1560px, calc(100% - 40px));
  }
}

.monitor-ring {
  position: relative;
  isolation: isolate;
  background:
    radial-gradient(
      circle,
      color-mix(in srgb, var(--tone) 15%, var(--surface)) 0 52%,
      color-mix(in srgb, var(--tone) 9%, var(--surface)) 53% calc(100% - 11px),
      transparent calc(100% - 10px)
    ),
    conic-gradient(
      from -90deg,
      var(--tone) 0 var(--progress, 0%),
      color-mix(in srgb, var(--tone) 22%, var(--line)) var(--progress, 0%) 100%
    );
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--tone) 18%, var(--line)),
    inset 0 0 0 9px color-mix(in srgb, var(--surface) 64%, transparent),
    0 0 0 6px color-mix(in srgb, var(--tone) 10%, transparent);
  animation: monitor-ring-breathe 2.8s ease-in-out infinite;
}

.monitor-ring::after {
  content: "";
  position: absolute;
  inset: -5px;
  z-index: -1;
  border-radius: inherit;
  background: radial-gradient(circle, color-mix(in srgb, var(--tone) 25%, transparent) 0 58%, transparent 64%);
  opacity: 0.18;
  transform: scale(0.92);
  animation: monitor-ring-halo 2.8s ease-in-out infinite;
  pointer-events: none;
}

.monitor-card:nth-child(2n) .monitor-ring,
.console-stat-card:nth-child(2n) .monitor-ring {
  animation-delay: 0.35s;
}

.monitor-card:nth-child(2n) .monitor-ring::after,
.console-stat-card:nth-child(2n) .monitor-ring::after {
  animation-delay: 0.35s;
}

.monitor-card:nth-child(3n) .monitor-ring,
.console-stat-card:nth-child(3n) .monitor-ring {
  animation-delay: 0.7s;
}

.monitor-card:nth-child(3n) .monitor-ring::after,
.console-stat-card:nth-child(3n) .monitor-ring::after {
  animation-delay: 0.7s;
}

@keyframes monitor-ring-breathe {
  0%,
  100% {
    filter: saturate(1) brightness(1);
    transform: translateY(0) scale(1);
  }

  50% {
    filter: saturate(1.24) brightness(1.07);
    transform: translateY(-1px) scale(1.015);
  }
}

@keyframes monitor-ring-halo {
  0%,
  100% {
    opacity: 0.14;
    transform: scale(0.9);
  }

  50% {
    opacity: 0.34;
    transform: scale(1.05);
  }
}

@media (prefers-reduced-motion: reduce) {
  .monitor-ring,
  .monitor-ring::after {
    animation: none;
  }
}

.monitor-card.tone-teal,
.console-stat-card.tone-teal {
  --tone: var(--teal);
}

@media (max-width: 760px) {
  .monitor-card[data-monitor-card="online"] .monitor-ring strong {
    font-size: 15px;
  }
}

@media (max-width: 760px) {
  .sidebar {
    align-items: flex-start;
    flex-wrap: nowrap;
    padding: 10px 12px;
  }

  .brand-mark {
    width: 36px;
    height: 36px;
  }

  .brand strong {
    font-size: 14px;
  }

  .nav-label-full {
    display: none;
  }

  .nav-label-short {
    display: inline;
  }

  .topbar {
    position: static;
    display: grid;
    gap: 10px;
    padding: 0;
    background: transparent;
    backdrop-filter: none;
  }

  .topbar h1 {
    font-size: 24px;
  }

  .global-search {
    min-width: 0;
    max-width: none;
    width: 100%;
  }

  .top-actions {
    justify-content: flex-start;
    overflow-x: auto;
    scrollbar-width: none;
  }

  .top-actions::-webkit-scrollbar {
    display: none;
  }

  .system-head {
    padding: 16px;
  }

  .system-head h2 {
    font-size: 28px;
  }
}

/* Overview status pass: keep the home page compact while leaving deeper monitoring to Status/Panel. */
.overview-today-strip {
  min-height: 50px;
  grid-template-columns: 34px minmax(170px, 1.15fr) repeat(3, minmax(104px, 0.42fr)) auto;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 11px;
}

.overview-today-strip .today-strip-icon {
  width: 30px;
  height: 30px;
  border-radius: 9px;
}

.overview-today-strip > div:not(.today-strip-main) {
  min-width: 0;
  border-left: 1px solid color-mix(in srgb, var(--tone) 14%, var(--line));
  padding: 3px 8px;
}

.today-strip-main strong {
  font-size: 15px;
}

.overview-today-strip .secondary-action {
  min-height: 32px;
  border-color: color-mix(in srgb, var(--line) 88%, transparent);
  color: var(--muted);
  background: color-mix(in srgb, var(--surface) 88%, transparent);
  box-shadow: none;
}

.trend-panel {
  min-height: 232px;
}

.trend-layout {
  grid-template-columns: minmax(0, 1fr) minmax(220px, 0.42fr);
  gap: 10px;
}

.trend-chart-card {
  padding: 10px 12px 8px;
}

.trend-chart-head {
  margin-bottom: 6px;
}

.trend-chart-head strong {
  font-size: 18px;
}

.trend-summary-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
  margin-bottom: 6px;
}

.trend-summary-row span {
  min-width: 0;
  border: 1px solid color-mix(in srgb, var(--teal) 13%, var(--line));
  border-radius: 8px;
  padding: 5px 7px;
  background: color-mix(in srgb, var(--teal) 5%, var(--surface));
}

.trend-summary-row b,
.trend-summary-row small {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.trend-summary-row b {
  color: var(--teal-strong);
  font-size: 13px;
  line-height: 1.1;
}

.trend-summary-row small {
  margin-top: 2px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
}

.trend-chart {
  height: 112px;
}

.trend-empty-state {
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 14px;
  min-height: 72px;
  border: 1px dashed color-mix(in srgb, var(--teal) 18%, var(--line));
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: var(--muted);
  background: color-mix(in srgb, var(--teal) 4%, transparent);
  font-size: 12px;
  font-weight: 900;
}

.trend-empty-state[hidden] {
  display: none;
}

.live-event-list {
  gap: 6px;
  padding: 8px;
}

.live-event-row {
  min-height: 44px;
  border-radius: 8px;
  padding: 8px;
}

@media (max-width: 1120px) {
  .trend-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .overview-today-strip {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 7px;
    padding: 10px;
  }

  .overview-today-strip > div:not(.today-strip-main) {
    border-left: 0;
    border-top: 1px solid color-mix(in srgb, var(--tone) 14%, var(--line));
    padding: 6px 0 0;
  }

  .today-strip-main {
    grid-column: 1 / -1;
  }

  .overview-today-strip .secondary-action {
    grid-column: 1 / -1;
    width: 100%;
    justify-content: center;
  }

  .trend-summary-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .trend-chart {
    height: 96px;
  }

  .trend-empty-state {
    min-height: 56px;
  }
}

/* Personal entry pass: the home overview should open services first, with status as a quiet helper. */
.overview-today-strip {
  min-height: 46px;
  grid-template-columns: 32px minmax(150px, 0.72fr) minmax(260px, 1fr) minmax(104px, 0.34fr) auto;
  gap: 8px;
  padding: 8px 10px;
}

.overview-today-strip p {
  min-width: 0;
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.35;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.overview-today-strip .today-strip-check {
  min-width: 0;
  border-left: 1px solid color-mix(in srgb, var(--tone) 14%, var(--line));
  padding: 2px 8px;
}

.overview-status-details {
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  border-radius: 12px;
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.overview-status-details summary {
  min-height: 42px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 0 12px;
  color: var(--muted);
  cursor: pointer;
  list-style: none;
}

.overview-status-details summary::-webkit-details-marker {
  display: none;
}

.overview-status-details summary span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--text);
}

.overview-status-details summary svg {
  width: 16px;
  height: 16px;
  color: var(--teal);
}

.overview-status-details summary strong {
  font-size: 13px;
}

.overview-status-details summary small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.overview-status-details[open] {
  padding-bottom: 10px;
}

.overview-status-details[open] .overview-monitor-grid {
  margin: 0 10px;
}

.runtime-panel,
.trend-panel {
  display: none;
}

.console-overview-grid {
  grid-template-columns: minmax(0, 1.08fr) minmax(0, 1fr) minmax(280px, 0.78fr);
  grid-template-areas:
    "quick todo assets"
    "updates updates assets";
}

.quick-panel {
  min-height: 236px;
}

.quick-panel .dashboard-panel-head .eyebrow {
  color: var(--teal-strong);
}

.category-panel {
  grid-area: category;
  min-height: 236px;
}

.recent-panel {
  grid-area: recent;
  min-height: 170px;
}

.search-panel {
  grid-area: search;
  min-height: 170px;
}

.overview-category-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.overview-category-card {
  --tone: var(--teal);
  min-width: 0;
  min-height: 86px;
  border: 1px solid color-mix(in srgb, var(--tone) 18%, var(--line));
  border-radius: 12px;
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto;
  grid-template-areas:
    "icon title count"
    "icon detail detail";
  align-items: center;
  gap: 4px 8px;
  padding: 11px;
  color: var(--text);
  text-align: left;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--tone) 8%, transparent), transparent 56%),
    var(--surface);
  cursor: pointer;
}

.overview-category-card:hover,
.overview-category-card:focus-visible {
  border-color: color-mix(in srgb, var(--tone) 38%, var(--line));
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}

.overview-category-card.tone-teal {
  --tone: var(--teal);
}

.overview-category-card.tone-blue {
  --tone: var(--blue);
}

.overview-category-card.tone-amber {
  --tone: var(--amber);
}

.overview-category-card.tone-slate {
  --tone: var(--slate);
}

.overview-category-card > span {
  grid-area: icon;
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: var(--tone);
  background: color-mix(in srgb, var(--tone) 11%, var(--surface-soft));
}

.overview-category-card svg {
  width: 17px;
  height: 17px;
}

.overview-category-card strong {
  grid-area: title;
  min-width: 0;
  font-size: 15px;
  line-height: 1.2;
}

.overview-category-card small {
  grid-area: detail;
  min-width: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.overview-category-card em {
  grid-area: count;
  justify-self: end;
  border-radius: 999px;
  padding: 2px 7px;
  color: var(--tone);
  background: color-mix(in srgb, var(--tone) 10%, transparent);
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
  white-space: nowrap;
}

.overview-recent-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.overview-recent-grid a,
.overview-empty-note {
  min-width: 0;
  min-height: 48px;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  border-radius: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 10px;
  color: var(--text);
  background: var(--surface);
  font-size: 13px;
  font-weight: 900;
}

.overview-recent-grid a:hover,
.overview-recent-grid a:focus-visible {
  border-color: color-mix(in srgb, var(--teal) 28%, var(--line));
  background: color-mix(in srgb, var(--teal) 6%, var(--surface));
}

.overview-recent-grid svg {
  width: 17px;
  height: 17px;
  color: var(--teal);
  flex: 0 0 auto;
}

.overview-recent-grid span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.overview-empty-note {
  grid-column: 1 / -1;
  justify-content: center;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-soft) 72%, transparent);
}

.overview-search-chip-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.overview-search-chip-grid button {
  min-height: 38px;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  border-radius: 999px;
  padding: 0 14px;
  color: var(--text);
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--teal) 7%, transparent), transparent 58%),
    var(--surface);
  font-size: 13px;
  font-weight: 900;
  cursor: pointer;
}

.overview-search-chip-grid button:hover,
.overview-search-chip-grid button:focus-visible {
  border-color: color-mix(in srgb, var(--teal) 34%, var(--line));
  color: var(--teal-strong);
  transform: translateY(-1px);
}

.console-overview-grid > .todo-panel,
.console-overview-grid > .updates-panel,
.console-overview-grid > .asset-panel {
  display: none;
}

.console-overview-grid {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.15fr);
  grid-template-areas:
    "quick category"
    "recent search";
}

@media (max-width: 1120px) {
  .overview-today-strip {
    grid-template-columns: 32px minmax(150px, 0.8fr) minmax(220px, 1fr) auto;
  }

  .overview-today-strip .today-strip-check {
    display: none;
  }

  .console-overview-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-areas:
      "quick category"
      "recent search";
  }
}

@media (max-width: 760px) {
  .overview-today-strip {
    grid-template-columns: 30px minmax(0, 1fr);
  }

  .overview-today-strip p {
    grid-column: 1 / -1;
    white-space: normal;
  }

  .overview-today-strip .secondary-action {
    grid-column: 1 / -1;
  }

  .overview-status-details summary {
    align-items: flex-start;
    flex-direction: column;
    padding: 10px 12px;
  }

  .overview-status-details[open] .overview-monitor-grid {
    margin: 0 10px;
  }

  .console-overview-grid {
    grid-template-columns: minmax(0, 1fr);
    grid-template-areas:
      "quick"
      "category"
      "recent"
      "search";
  }

  .quick-panel,
  .category-panel,
  .recent-panel,
  .search-panel {
    min-width: 0;
  }

  .overview-category-grid,
  .overview-recent-grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 760px) {
  .service-overview-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .service-stat-card {
    min-height: 74px;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 8px;
    padding: 10px;
  }

  .service-stat-card em {
    display: none;
  }
}

#serviceControlStrip {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) auto auto auto;
  align-items: center;
  gap: 8px;
}

#serviceControlStrip .segments {
  flex-wrap: nowrap;
  justify-content: center;
}

#serviceControlStrip .service-search-chips {
  grid-column: 1 / -1;
}

#serviceControlStrip .service-view-toggle button,
#serviceControlStrip .service-search-chips button {
  appearance: none;
  -webkit-appearance: none;
  border-radius: 999px;
  cursor: pointer;
  font: inherit;
}

#serviceControlStrip .service-view-toggle[hidden] {
  display: none !important;
}

@media (max-width: 980px) {
  #serviceControlStrip {
    grid-template-columns: minmax(0, 1fr);
  }

  #serviceControlStrip .search-box,
  #serviceControlStrip .service-result-summary,
  #serviceControlStrip .segments,
  #serviceControlStrip .service-view-toggle,
  #serviceControlStrip .service-search-chips {
    width: 100%;
  }

  #serviceControlStrip .service-result-summary,
  #serviceControlStrip .segments,
  #serviceControlStrip .service-view-toggle {
    justify-content: center;
  }

  #serviceControlStrip .segments {
    flex-wrap: wrap;
  }
}

/* Server color comfort pass: keep green as an accent, not a page wash. */
.view-panel[data-view="server"] {
  --server-accent: #0f766e;
  --server-accent-strong: #0b625b;
  --server-muted: #64748b;
  --server-line: #dbe3ea;
  --server-soft: #f7f9fb;
  --server-panel: #ffffff;
  --server-panel-soft: #fbfcfd;
}

:root[data-theme="dark"] .view-panel[data-view="server"] {
  --server-accent: var(--teal);
  --server-accent-strong: var(--teal-strong);
  --server-muted: var(--muted);
  --server-line: var(--line);
  --server-soft: #111820;
  --server-panel: var(--surface);
  --server-panel-soft: var(--surface-soft);
}

.view-panel[data-view="server"] .page-hero,
.view-panel[data-view="server"] .section-block,
.view-panel[data-view="server"] .server-tab-panel,
.view-panel[data-view="server"] .server-flow-panel,
.view-panel[data-view="server"] .server-safety-panel,
.view-panel[data-view="server"] .server-trouble-panel,
.view-panel[data-view="server"] .server-status-panel,
.view-panel[data-view="server"] .server-backup-item {
  border-color: var(--server-line);
  background: var(--server-panel);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.view-panel[data-view="server"] .page-hero {
  background:
    linear-gradient(180deg, #ffffff, var(--server-panel-soft)),
    var(--server-panel);
}

:root[data-theme="dark"] .view-panel[data-view="server"] .page-hero {
  background:
    linear-gradient(180deg, var(--server-panel), var(--server-panel-soft)),
    var(--server-panel);
}

.view-panel[data-view="server"] .page-hero h2,
.view-panel[data-view="server"] .server-panel-head strong,
.view-panel[data-view="server"] .server-entry-main h3,
.view-panel[data-view="server"] .server-backup-item h3 {
  color: #111827;
}

:root[data-theme="dark"] .view-panel[data-view="server"] .page-hero h2,
:root[data-theme="dark"] .view-panel[data-view="server"] .server-panel-head strong,
:root[data-theme="dark"] .view-panel[data-view="server"] .server-entry-main h3,
:root[data-theme="dark"] .view-panel[data-view="server"] .server-backup-item h3,
:root[data-theme="dark"] .view-panel[data-view="server"] .server-security-summary strong {
  color: var(--text);
}

.view-panel[data-view="server"] .page-hero p,
.view-panel[data-view="server"] .server-panel-head span,
.view-panel[data-view="server"] .server-entry-main small,
.view-panel[data-view="server"] .server-backup-item p {
  color: var(--server-muted);
}

.view-panel[data-view="server"] .page-hero .primary-action {
  background: var(--server-accent);
  box-shadow: 0 8px 18px rgba(15, 118, 110, 0.16);
}

.view-panel[data-view="server"] .page-hero .secondary-action,
.view-panel[data-view="server"] .server-entry-action {
  border-color: var(--server-line);
  color: #334155;
  background: #ffffff;
  box-shadow: none;
}

:root[data-theme="dark"] .view-panel[data-view="server"] .page-hero .secondary-action,
:root[data-theme="dark"] .view-panel[data-view="server"] .server-entry-action {
  color: var(--text);
  background: var(--server-panel-soft);
}

.view-panel[data-view="server"] .server-security-summary {
  border-color: var(--server-line);
  background:
    linear-gradient(90deg, rgba(15, 118, 110, 0.045), transparent 46%),
    var(--server-panel);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.035);
}

.view-panel[data-view="server"] .server-security-summary .summary-icon,
.view-panel[data-view="server"] .server-stat-card > span,
.view-panel[data-view="server"] .server-entry-icon {
  color: var(--server-accent);
  background: rgba(15, 118, 110, 0.075);
}

.view-panel[data-view="server"] .server-security-summary strong {
  color: #111827;
}

.view-panel[data-view="server"] .server-summary-chips span {
  border-color: var(--server-line);
  color: #475569;
  background: var(--server-soft);
}

.view-panel[data-view="server"] .server-stat-card {
  border-color: var(--server-line);
  background: var(--server-panel);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.view-panel[data-view="server"] .server-stat-card strong {
  color: var(--server-accent-strong);
}

.view-panel[data-view="server"] .server-workspace {
  border-top-color: var(--server-line);
  border-bottom-color: var(--server-line);
  background:
    linear-gradient(180deg, var(--server-soft), transparent 180px),
    #ffffff;
}

:root[data-theme="dark"] .view-panel[data-view="server"] .server-workspace {
  background:
    linear-gradient(180deg, var(--server-soft), transparent 180px),
    var(--bg);
}

.view-panel[data-view="server"] .server-workspace::before {
  background: var(--server-accent);
}

.view-panel[data-view="server"] .server-tabs {
  border-color: var(--server-line);
  background: #ffffff;
}

:root[data-theme="dark"] .view-panel[data-view="server"] .server-tabs {
  background: var(--server-panel);
}

.view-panel[data-view="server"] .server-tabs .segment.active {
  border-color: rgba(15, 118, 110, 0.26);
  color: var(--server-accent-strong);
  background: rgba(15, 118, 110, 0.055);
  box-shadow: none;
}

.view-panel[data-view="server"] .server-entry-group-head {
  border-color: var(--server-line);
  background: var(--server-soft);
}

.view-panel[data-view="server"] .server-entry-card {
  border-color: var(--server-line);
  background: var(--server-panel);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.view-panel[data-view="server"] .server-entry-card.tone-amber .server-entry-icon,
.view-panel[data-view="server"] .server-backup-check.tone-amber .server-backup-icon {
  color: #b45309;
  background: rgba(245, 158, 11, 0.09);
}

.view-panel[data-view="server"] .server-entry-card.tone-blue .server-entry-icon,
.view-panel[data-view="server"] .server-backup-check.tone-blue .server-backup-icon {
  color: #475569;
  background: rgba(100, 116, 139, 0.09);
}

.view-panel[data-view="server"] .server-entry-card.tone-coral .server-entry-icon,
.view-panel[data-view="server"] .server-backup-check.tone-coral .server-backup-icon {
  color: #b91c1c;
  background: rgba(239, 68, 68, 0.08);
}

.view-panel[data-view="server"] .server-flow-steps .server-flow-step,
.view-panel[data-view="server"] .server-check-list div,
.view-panel[data-view="server"] .server-trouble-list div,
.view-panel[data-view="server"] .server-status-list div {
  border-color: var(--server-line);
  background: var(--server-panel-soft);
}

.view-panel[data-view="server"] .server-flow-step em {
  background: var(--server-accent);
}

.view-panel[data-view="server"] .server-backup-check .server-backup-index {
  color: #64748b;
  background: #eef2f6;
}

:root[data-theme="dark"] .view-panel[data-view="server"] .server-backup-check .server-backup-index {
  color: var(--muted);
  background: var(--server-panel-soft);
}

@media (max-width: 760px) {
  .view-panel[data-view="server"] .server-overview-strip {
    gap: 8px;
  }

  .view-panel[data-view="server"] .server-stat-card {
    flex-basis: 204px;
  }
}

/* Resources page pass: make it a task command center, not a dense download directory. */
.view-panel[data-view="resources"] {
  --resource-accent: #0f766e;
  --resource-line: #dbe3ea;
  --resource-soft: #f7f9fb;
  --resource-panel: #ffffff;
  --resource-muted: #64748b;
}

:root[data-theme="dark"] .view-panel[data-view="resources"] {
  --resource-accent: var(--teal);
  --resource-line: var(--line);
  --resource-soft: #111820;
  --resource-panel: var(--surface);
  --resource-muted: var(--muted);
}

.view-panel[data-view="resources"] .page-hero,
.view-panel[data-view="resources"] .section-block,
.view-panel[data-view="resources"] .resource-workspace,
.view-panel[data-view="resources"] .resource-tab-panel,
.view-panel[data-view="resources"] .resource-panel,
.view-panel[data-view="resources"] .command-pack {
  border-color: var(--resource-line);
  background: var(--resource-panel);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.view-panel[data-view="resources"] .page-hero {
  background:
    linear-gradient(180deg, #ffffff, #fbfcfd),
    var(--resource-panel);
}

:root[data-theme="dark"] .view-panel[data-view="resources"] .page-hero {
  background:
    linear-gradient(180deg, var(--resource-panel), var(--surface-soft)),
    var(--resource-panel);
}

.view-panel[data-view="resources"] .resource-overview-strip {
  gap: 8px;
  margin-bottom: 10px;
}

.view-panel[data-view="resources"] .resource-stat-card {
  min-height: 64px;
  padding: 10px;
  gap: 8px;
  border-color: var(--resource-line);
  background: var(--resource-panel);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.view-panel[data-view="resources"] .resource-stat-card > span,
.view-panel[data-view="resources"] .resource-launch-card > span,
.view-panel[data-view="resources"] .command-pack-icon {
  width: 34px;
  height: 34px;
  color: var(--resource-accent);
  background: rgba(15, 118, 110, 0.075);
}

.view-panel[data-view="resources"] .resource-stat-card strong {
  color: #0b625b;
  font-size: 18px;
}

:root[data-theme="dark"] .view-panel[data-view="resources"] .resource-stat-card strong {
  color: var(--teal-strong);
}

.view-panel[data-view="resources"] .resource-stat-card small {
  font-size: 12px;
}

.view-panel[data-view="resources"] .resource-stat-card em {
  font-size: 11px;
}

.view-panel[data-view="resources"] .resource-launchpad {
  gap: 8px;
  margin-bottom: 12px;
}

.view-panel[data-view="resources"] .resource-launch-card {
  min-height: 132px;
  padding: 11px;
  gap: 8px;
  border-color: var(--resource-line);
  background: var(--resource-panel);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.view-panel[data-view="resources"] .resource-launch-card strong {
  font-size: 15px;
}

.view-panel[data-view="resources"] .resource-launch-card em {
  display: -webkit-box;
  min-height: 0;
  margin-top: 4px;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.view-panel[data-view="resources"] .resource-launch-meta {
  margin-top: 7px;
}

.view-panel[data-view="resources"] .resource-launch-actions {
  gap: 6px;
}

.view-panel[data-view="resources"] .resource-workspace {
  background:
    linear-gradient(180deg, var(--resource-soft), transparent 160px),
    var(--resource-panel);
}

:root[data-theme="dark"] .view-panel[data-view="resources"] .resource-workspace {
  background:
    linear-gradient(180deg, var(--resource-soft), transparent 160px),
    var(--bg);
}

.view-panel[data-view="resources"] .resource-tabs {
  border-color: var(--resource-line);
  background: #ffffff;
}

:root[data-theme="dark"] .view-panel[data-view="resources"] .resource-tabs {
  background: var(--resource-panel);
}

.view-panel[data-view="resources"] .resource-tabs .segment {
  min-height: 34px;
  font-size: 13px;
}

.view-panel[data-view="resources"] .resource-tabs .segment.active {
  border-color: rgba(15, 118, 110, 0.26);
  color: #0b625b;
  background: rgba(15, 118, 110, 0.055);
  box-shadow: none;
}

.view-panel[data-view="resources"] .resource-tabs [data-resource-tab="tools"]:not(.active) {
  color: var(--resource-muted);
}

.view-panel[data-view="resources"] .resource-command-head {
  min-height: 42px;
  margin-bottom: 10px;
  padding-bottom: 10px;
}

.view-panel[data-view="resources"] .command-pack-controls {
  background: #ffffff;
}

:root[data-theme="dark"] .view-panel[data-view="resources"] .command-pack-controls {
  background: var(--resource-panel);
}

@media (max-width: 760px) {
  .view-panel[data-view="resources"] .resource-overview-strip {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    overflow: visible;
    padding-bottom: 0;
  }

  .view-panel[data-view="resources"] .resource-stat-card {
    flex: initial;
    min-height: 76px;
    scroll-snap-align: none;
  }

  .view-panel[data-view="resources"] .resource-stat-card em {
    display: none;
  }

  .view-panel[data-view="resources"] .resource-stat-card .console-stat-copy b {
    display: none;
  }

  .view-panel[data-view="resources"] .resource-launchpad {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    overflow: visible;
    padding-bottom: 0;
  }

  .view-panel[data-view="resources"] .resource-launch-card {
    flex: initial;
    min-height: auto;
    scroll-snap-align: none;
  }

  .view-panel[data-view="resources"] .resource-tabs .segment {
    min-width: 76px;
  }
}

/* NexLei Calm System final style pass: neutral surfaces, one primary accent, restrained status colors. */
:root {
  --bg: #f6f8fb;
  --surface: #ffffff;
  --surface-soft: #f8fafc;
  --surface-strong: #eef2f6;
  --glass: rgba(255, 255, 255, 0.7);
  --glass-strong: rgba(255, 255, 255, 0.9);
  --glass-soft: rgba(255, 255, 255, 0.56);
  --text: #111827;
  --muted: #64748b;
  --line: rgba(148, 163, 184, 0.28);
  --line-strong: rgba(100, 116, 139, 0.34);
  --teal: #0f766e;
  --teal-strong: #0b625b;
  --blue: #2563eb;
  --amber: #b7791f;
  --coral: #c2410c;
  --slate: #64748b;
  --success: #15803d;
  --warning: #b7791f;
  --monitor-green: #0f766e;
  --monitor-green-strong: #0b625b;
  --monitor-green-bg: rgba(15, 118, 110, 0.1);
  --monitor-green-line: rgba(15, 118, 110, 0.24);
  --shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.04);
  --shadow-md: 0 10px 28px rgba(15, 23, 42, 0.08);
  --shadow-lg: 0 18px 54px rgba(15, 23, 42, 0.1);
}

:root[data-theme="dark"] {
  --bg: #0d1117;
  --surface: #151b23;
  --surface-soft: #1b2430;
  --surface-strong: #243244;
  --glass: rgba(21, 27, 35, 0.68);
  --glass-strong: rgba(21, 27, 35, 0.88);
  --glass-soft: rgba(27, 36, 48, 0.55);
  --text: #eef3f8;
  --muted: #a5b2c0;
  --line: rgba(148, 163, 184, 0.2);
  --line-strong: rgba(159, 178, 201, 0.3);
  --teal: #5cc8bb;
  --teal-strong: #8ee6dc;
  --blue: #8cbdf0;
  --amber: #e2b75f;
  --coral: #ee927d;
  --slate: #c5d0de;
  --success: #6bd995;
  --warning: #e2b75f;
  --monitor-green: #5cc8bb;
  --monitor-green-strong: #8ee6dc;
  --monitor-green-bg: rgba(92, 200, 187, 0.12);
  --monitor-green-line: rgba(92, 200, 187, 0.24);
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.22);
  --shadow-md: 0 14px 36px rgba(0, 0, 0, 0.28);
  --shadow-lg: 0 22px 66px rgba(0, 0, 0, 0.34);
}

body {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface-soft) 34%, transparent), transparent 380px),
    var(--bg);
  color: var(--text);
}

body::before {
  opacity: 0.08;
}

:root[data-theme="dark"] body::before {
  opacity: 0.14;
}

.app-shell {
  background: var(--bg);
  box-shadow: none;
}

.sidebar {
  background: color-mix(in srgb, var(--surface) 86%, transparent);
  box-shadow: none;
}

.topbar,
.dashboard-head,
.settings-head,
.hero-panel,
.page-hero,
.access-panel,
.dashboard-panel,
.settings-list,
.settings-group,
.settings-panel,
.metric-card,
.quick-card,
.service-card,
.service-app-card,
.service-row-card,
.ops-card,
.workbench-card,
.route-card,
.resource-panel,
.resource-stat-card,
.resource-launch-card,
.resource-workspace,
.resource-tab-panel,
.command-pack,
.command-pack-controls,
.server-security-summary,
.server-stat-card,
.server-workspace,
.server-tabs,
.server-tab-panel,
.server-flow-panel,
.server-safety-panel,
.server-trouble-panel,
.server-status-panel,
.server-entry-card,
.server-entry-group-head,
.server-backup-item,
.server-backup-check,
.note-panel,
.script-summary article,
.playbook-card,
.recipe-card,
.recovery-card,
.resource-card,
.script-card,
.domain-table,
.download-list,
.update-grid {
  border-color: var(--line);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 94%, transparent), color-mix(in srgb, var(--surface-soft) 58%, transparent)),
    var(--surface);
  box-shadow: var(--shadow-sm);
}

.page-hero,
.hero-panel,
.dashboard-head,
.settings-head,
.view-panel[data-view="server"] .page-hero,
.view-panel[data-view="resources"] .page-hero {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 96%, transparent), color-mix(in srgb, var(--surface-soft) 74%, transparent)),
    var(--surface);
}

.dashboard-panel::before,
.service-card::before,
.server-workspace::before,
.metric-card::after {
  background: var(--teal);
  opacity: 0.68;
}

.eyebrow,
.console-stat-card strong,
.settings-stat-card strong,
.maintenance-stat-card strong,
.resource-stat-card strong,
.server-stat-card strong,
.trend-chart-head strong,
.brand small {
  color: var(--teal-strong);
}

.primary-action,
.open-link,
.service-action-button.primary,
.command-line-copy,
.resource-launch-actions .primary-action,
.page-hero .primary-action,
.view-panel[data-view="server"] .page-hero .primary-action {
  border-color: color-mix(in srgb, var(--teal) 44%, var(--line));
  color: #06211f;
  background: var(--teal);
  box-shadow: none;
}

:root[data-theme="dark"] .primary-action,
:root[data-theme="dark"] .open-link,
:root[data-theme="dark"] .service-action-button.primary,
:root[data-theme="dark"] .command-line-copy,
:root[data-theme="dark"] .resource-launch-actions .primary-action,
:root[data-theme="dark"] .page-hero .primary-action,
:root[data-theme="dark"] .view-panel[data-view="server"] .page-hero .primary-action {
  color: #06211f;
}

.secondary-action,
.icon-button,
.ghost-link,
.ghost-button,
.copy-line,
.search-box,
.global-search,
.sidebar-home,
.service-view-button,
.service-result-summary,
.server-entry-action,
.view-panel[data-view="server"] .server-entry-action,
.view-panel[data-view="server"] .page-hero .secondary-action {
  border-color: var(--line);
  color: var(--text);
  background: var(--surface);
  box-shadow: none;
}

.primary-action:hover,
.secondary-action:hover,
.open-link:hover,
.icon-button:hover,
.service-card:hover,
.server-entry-card:hover,
.resource-launch-card:hover,
.workbench-card:hover {
  transform: none;
  border-color: color-mix(in srgb, var(--teal) 34%, var(--line));
  box-shadow: var(--shadow-md);
}

.segments,
.settings-tabs,
.server-tabs,
.resource-tabs,
.service-category-tabs,
.service-view-toggle {
  border-color: var(--line);
  background: var(--surface-soft);
  box-shadow: none;
}

.segment.active,
.settings-tab.active,
.server-tabs .segment.active,
.resource-tabs .segment.active,
.service-category-tab.active,
.service-view-button.active,
.accent-choice.active {
  color: var(--text);
  border-color: color-mix(in srgb, var(--teal) 24%, var(--line));
  background: color-mix(in srgb, var(--teal) 10%, var(--surface));
  box-shadow: none;
}

:root[data-theme="dark"] .segment.active,
:root[data-theme="dark"] .settings-tab.active,
:root[data-theme="dark"] .server-tabs .segment.active,
:root[data-theme="dark"] .resource-tabs .segment.active,
:root[data-theme="dark"] .service-category-tab.active,
:root[data-theme="dark"] .service-view-button.active,
:root[data-theme="dark"] .accent-choice.active {
  color: var(--text);
}

.brand-mark,
.metric-icon,
.card-icon,
.ops-icon,
.workbench-icon,
.playbook-icon,
.server-entry-icon,
.server-stat-card > span,
.server-security-summary .summary-icon,
.resource-stat-card > span,
.resource-launch-card > span,
.command-pack-icon,
.settings-stat-card > span,
.maintenance-stat-card > span,
.setting-icon,
.settings-group-head > span,
.settings-safety-item > span,
.entry-pet-toggle {
  color: var(--teal-strong);
  border: 1px solid color-mix(in srgb, var(--teal) 24%, var(--line));
  background: color-mix(in srgb, var(--teal) 9%, var(--surface));
  box-shadow: none;
}

.status-pill,
.module-badge,
.download-kind,
.command-risk-badge,
.command-runtime-badge,
.settings-panel-chip,
.setting-source-badge,
.setting-detail-pills span,
.resource-launch-meta b:not(.command-risk-badge),
.server-risk-pill,
.server-summary-chips span {
  border-color: var(--line);
  color: var(--muted);
  background: var(--surface-soft);
}

.status-pill.online,
.status-pill.success,
.domain-state.online,
.module-badge.shared,
.module-badge.internal,
.command-risk-badge.tone-teal,
.settings-channel-item.tone-online strong,
.settings-safety-item.tone-online em {
  color: var(--success);
  border-color: color-mix(in srgb, var(--success) 28%, var(--line));
  background: color-mix(in srgb, var(--success) 9%, var(--surface));
}

.status-pill.protected,
.status-pill.planned,
.server-risk-pill.tone-amber,
.command-risk-badge.tone-amber,
.settings-channel-item.tone-planned strong,
.settings-safety-item.tone-planned em {
  color: var(--warning);
  border-color: color-mix(in srgb, var(--warning) 30%, var(--line));
  background: color-mix(in srgb, var(--warning) 10%, var(--surface));
}

.status-pill.degraded,
.status-pill.down,
.command-risk-badge.tone-coral {
  color: var(--coral);
  border-color: color-mix(in srgb, var(--coral) 30%, var(--line));
  background: color-mix(in srgb, var(--coral) 9%, var(--surface));
}

.nav-status-dot,
.pulse-dot,
.brand-status-dot {
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--teal) 14%, transparent);
}

.view-panel[data-view="server"] {
  --server-accent: var(--teal);
  --server-accent-strong: var(--teal-strong);
  --server-muted: var(--muted);
  --server-line: var(--line);
  --server-soft: var(--surface-soft);
  --server-panel: var(--surface);
  --server-panel-soft: var(--surface-soft);
}

.view-panel[data-view="resources"] {
  --resource-accent: var(--teal);
  --resource-line: var(--line);
  --resource-soft: var(--surface-soft);
  --resource-panel: var(--surface);
  --resource-muted: var(--muted);
}

.view-panel[data-view="server"] .server-workspace,
.view-panel[data-view="resources"] .resource-workspace {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface-soft) 72%, transparent), transparent 180px),
    var(--bg);
}

.script-code,
.command-pack pre,
.download-terminal,
.command-preflight,
.command-exec-panel {
  border-color: var(--line);
  background: color-mix(in srgb, var(--surface-soft) 82%, transparent);
  box-shadow: none;
}

.toast {
  border-color: var(--line);
  color: var(--text);
  background: var(--surface);
  box-shadow: var(--shadow-md);
}

:root[data-theme="dark"] .toast {
  color: var(--text);
  background: var(--surface);
}

@media (max-width: 760px) {
  .topbar,
  .dashboard-head,
  .settings-head,
  .page-hero,
  .hero-panel {
    border-radius: 12px;
  }

  .primary-action,
  .secondary-action,
  .open-link,
  .icon-button {
    box-shadow: none;
  }
}

/* Entry polish pass: compact overview, explicit boundaries, safer restore actions. */
.console-overview-grid {
  gap: 10px;
}

.quick-panel,
.category-panel,
.recent-panel,
.search-panel {
  min-height: 0;
}

.console-overview-grid .dashboard-panel {
  padding: 14px;
}

.console-overview-grid .dashboard-panel-head {
  margin-bottom: 10px;
}

.system-quick-grid {
  gap: 8px;
}

.system-quick-grid a {
  min-height: 40px;
  border-radius: 11px;
}

.overview-category-grid {
  gap: 8px;
}

.overview-category-card {
  min-height: 72px;
  border-radius: 10px;
  padding: 9px;
}

.overview-category-card > span {
  width: 30px;
  height: 30px;
  border-radius: 9px;
}

.overview-category-card strong {
  font-size: 14px;
}

.overview-category-card small {
  font-size: 11px;
  line-height: 1.28;
}

.overview-recent-grid a,
.overview-empty-note {
  min-height: 42px;
  border-radius: 10px;
}

.overview-search-chip-grid button {
  min-height: 34px;
  padding: 0 12px;
}

.overview-today-strip {
  grid-template-columns: 32px minmax(130px, 0.42fr) minmax(0, 1fr) auto auto;
  align-items: center;
}

.overview-today-strip p {
  display: none;
}

.entry-health-summary {
  min-width: 0;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
}

.entry-health-chip {
  min-width: 0;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--line) 86%, transparent);
  border-radius: 10px;
  display: grid;
  gap: 2px;
  padding: 6px 8px;
  background: color-mix(in srgb, var(--surface) 82%, transparent);
}

.entry-health-chip b,
.entry-health-chip small {
  min-width: 0;
  max-width: 100%;
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.entry-health-chip b {
  color: var(--text);
  font-size: 12px;
}

.entry-health-chip small {
  color: var(--muted);
  font-size: 10px;
  font-weight: 800;
}

.entry-health-chip.tone-teal {
  border-color: color-mix(in srgb, var(--teal) 24%, var(--line));
}

.entry-health-chip.tone-blue {
  border-color: color-mix(in srgb, var(--blue) 24%, var(--line));
}

.entry-health-chip.tone-amber {
  border-color: color-mix(in srgb, var(--amber) 28%, var(--line));
}

.service-boundary-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin: 10px 0 12px;
}

.service-boundary-strip span,
.global-search-boundary {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 4px 8px;
  color: var(--muted);
  background: var(--surface-soft);
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
}

.service-boundary-strip .tone-teal,
.global-search-boundary.tone-teal {
  color: var(--success);
  border-color: color-mix(in srgb, var(--success) 28%, var(--line));
  background: color-mix(in srgb, var(--success) 8%, var(--surface));
}

.service-boundary-strip .tone-blue,
.global-search-boundary.tone-blue {
  color: var(--blue);
  border-color: color-mix(in srgb, var(--blue) 26%, var(--line));
  background: color-mix(in srgb, var(--blue) 8%, var(--surface));
}

.service-boundary-strip .tone-amber,
.global-search-boundary.tone-amber {
  color: var(--warning);
  border-color: color-mix(in srgb, var(--warning) 30%, var(--line));
  background: color-mix(in srgb, var(--warning) 9%, var(--surface));
}

.global-search-copy {
  min-width: 0;
  display: grid;
  gap: 4px;
}

.global-search-boundary {
  justify-self: start;
  display: inline-flex;
  max-width: 100%;
}

.service-related-empty {
  grid-column: 1 / -1;
  border: 1px dashed color-mix(in srgb, var(--line) 86%, transparent);
  border-radius: 12px;
  padding: 12px;
  color: var(--muted);
  background: var(--surface-soft);
  font-size: 13px;
  font-weight: 800;
}

.settings-reset-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.settings-reset-actions .secondary-action {
  min-height: 36px;
}

@media (max-width: 1120px) {
  .overview-today-strip {
    grid-template-columns: 30px minmax(120px, 0.45fr) minmax(0, 1fr) auto;
  }

  .overview-today-strip .today-strip-check {
    display: none;
  }

  .entry-health-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .console-overview-grid .dashboard-panel {
    padding: 12px;
  }

  .console-overview-grid {
    gap: 8px;
  }

  .overview-today-strip {
    grid-template-columns: 28px minmax(0, 1fr);
  }

  .entry-health-summary {
    grid-column: 1 / -1;
    display: flex;
    overflow-x: auto;
    padding-bottom: 2px;
  }

  .entry-health-chip {
    flex: 0 0 128px;
  }

  .overview-today-strip .secondary-action {
    display: none;
  }

  .overview-category-grid,
  .overview-recent-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .overview-category-card {
    min-height: 66px;
    grid-template-columns: 28px minmax(0, 1fr);
    grid-template-areas:
      "icon title"
      "detail detail";
  }

  .overview-category-card small {
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
  }

  .overview-category-card em {
    display: none;
  }

  .overview-search-chip-grid {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 2px;
  }

  .settings-reset-actions .secondary-action {
    flex: 1 1 132px;
  }
}

/* Font comfort pass: lift small UI text without loosening the layout. */
.workspace,
.side-nav a,
.primary-action,
.secondary-action,
.icon-button,
.quick-entry-grid a,
.overview-search-chip-grid button,
.service-launch-card,
.search-box input,
.global-search input,
.command-pack-search input {
  font-size: 14px;
}

.dashboard-head p,
.page-hero p,
.hero-panel p,
.service-card p,
.service-app-card p,
.service-row p,
.server-entry-card p,
.resource-launch-card small,
.command-pack p,
.setting-row p,
.settings-panel-head p,
.service-modal-section-head span,
.service-maintenance-head span,
.service-related-link small {
  font-size: 14px;
  line-height: 1.52;
}

.dashboard-panel h3,
.service-app-card h3,
.service-row-title h3,
.server-entry-card h3,
.resource-launch-card strong,
.command-pack h3,
.setting-row h3 {
  font-size: 17px;
  line-height: 1.28;
}

.eyebrow,
.nav-section-label,
.status-pill,
.module-badge,
.visibility-chip,
.download-kind,
.command-risk-badge,
.command-runtime-badge,
.settings-panel-chip,
.server-risk-pill,
.service-row-meta span,
.service-launch-card em,
.setting-source-badge,
.setting-detail-pills span,
.settings-preference-grid span,
.settings-system-grid span,
.settings-chip-item strong,
.settings-channel-item span,
.service-boundary-strip span,
.global-search-boundary {
  font-size: 12px;
}

.overview-category-card strong {
  font-size: 15px;
}

.overview-category-card small,
.overview-recent-grid a,
.overview-empty-note,
.overview-search-chip-grid button,
.global-search-result small,
.service-maintenance-list strong,
.service-detail-grid strong,
.service-related-empty {
  font-size: 13px;
  line-height: 1.42;
}

.entry-health-chip b {
  font-size: 13px;
}

.overview-search-chip-grid button {
  font-size: 14px;
}

.entry-health-chip small {
  font-size: 11px;
}

.quick-entry-group-label,
.service-detail-grid span,
.service-maintenance-list span {
  font-size: 12px;
}

@media (max-width: 760px) {
  .workspace,
  .side-nav a,
  .primary-action,
  .secondary-action,
  .icon-button,
  .search-box input,
  .global-search input,
  .command-pack-search input {
    font-size: 14px;
  }

  .system-head h2,
  .page-hero h2,
  .settings-head h2 {
    line-height: 1.16;
  }

  .dashboard-panel h3,
  .service-app-card h3,
  .service-row-title h3,
  .server-entry-card h3,
  .resource-launch-card strong,
  .command-pack h3,
  .setting-row h3 {
    font-size: 16px;
  }

  .entry-health-chip {
    flex-basis: 138px;
  }
}

/* Service control fix: keep natural shared/tools proportions and show view mode on common. */
#serviceControlStrip {
  grid-template-columns: minmax(260px, 1fr) auto auto auto;
}

#serviceControlStrip .search-box {
  min-width: 0;
}

@media (max-width: 980px) {
  #serviceControlStrip {
    grid-template-columns: minmax(0, 1fr);
  }
}

/* CSP-safe progress values for rings and bars. */
.progress-p0 { --progress: 0%; }
.progress-p5 { --progress: 5%; }
.progress-p10 { --progress: 10%; }
.progress-p15 { --progress: 15%; }
.progress-p20 { --progress: 20%; }
.progress-p25 { --progress: 25%; }
.progress-p30 { --progress: 30%; }
.progress-p35 { --progress: 35%; }
.progress-p40 { --progress: 40%; }
.progress-p45 { --progress: 45%; }
.progress-p50 { --progress: 50%; }
.progress-p55 { --progress: 55%; }
.progress-p60 { --progress: 60%; }
.progress-p65 { --progress: 65%; }
.progress-p70 { --progress: 70%; }
.progress-p75 { --progress: 75%; }
.progress-p80 { --progress: 80%; }
.progress-p85 { --progress: 85%; }
.progress-p90 { --progress: 90%; }
.progress-p95 { --progress: 95%; }
.progress-p100 { --progress: 100%; }

/* Server checkup polish: public-safe summary first, protected actions second. */
.view-panel[data-view="server"] .section-block[aria-label="服务器体检摘要"] {
  display: grid;
  gap: 10px;
  padding: 14px;
}

.view-panel[data-view="server"] .server-security-summary {
  min-height: 60px;
  margin-bottom: 0;
  padding: 10px 12px;
  gap: 10px;
}

.view-panel[data-view="server"] .server-security-summary .summary-icon {
  width: 34px;
  height: 34px;
  border-radius: 10px;
}

.view-panel[data-view="server"] .server-summary-chips {
  max-width: 360px;
}

.view-panel[data-view="server"] .server-summary-chips span {
  min-height: 24px;
  padding: 0 8px;
  font-size: 11px;
}

.view-panel[data-view="server"] .server-overview-strip {
  gap: 10px;
  margin-bottom: 0;
}

.view-panel[data-view="server"] .server-stat-card.console-stat-card {
  min-height: 96px;
  padding: 12px;
  grid-template-columns: 38px minmax(0, 1fr);
  gap: 9px;
}

.view-panel[data-view="server"] .server-stat-card.console-stat-card .stat-number-icon {
  width: 36px;
  height: 36px;
  margin-top: 16px;
  border-radius: 10px;
}

.view-panel[data-view="server"] .server-stat-card.console-stat-card .console-stat-copy {
  min-height: 72px;
  grid-template-rows: 17px 26px minmax(28px, auto);
}

.view-panel[data-view="server"] .server-stat-card.console-stat-card .stat-value {
  font-size: 23px;
}

.view-panel[data-view="server"] .server-stat-card.console-stat-card .console-stat-copy b {
  margin-top: 2px;
  font-size: 12px;
  line-height: 1.32;
}

.view-panel[data-view="server"] .server-workspace {
  margin-top: 18px;
  padding-top: 14px;
}

.view-panel[data-view="server"] .server-workspace .section-heading {
  margin-bottom: 10px;
  padding-bottom: 8px;
}

.view-panel[data-view="server"] .server-tabs {
  min-height: 42px;
  margin-bottom: 10px;
}

.view-panel[data-view="server"] .server-tabs .segment {
  min-height: 32px;
}

.view-panel[data-view="server"] .server-tab-panel {
  padding: 12px;
}

.view-panel[data-view="server"] .server-panel-head {
  min-height: 34px;
  margin-bottom: 10px;
  padding-bottom: 9px;
}

.view-panel[data-view="server"] .server-entry-group + .server-entry-group {
  margin-top: 10px;
}

.view-panel[data-view="server"] .server-entry-group-head {
  min-height: 34px;
  margin-bottom: 7px;
  padding: 7px 10px;
}

.view-panel[data-view="server"] .server-entry-card {
  min-height: 86px;
  grid-template-columns: 36px minmax(0, 1fr) auto;
  gap: 9px;
  padding: 10px;
}

.view-panel[data-view="server"] .server-entry-icon {
  width: 36px;
  height: 36px;
}

.view-panel[data-view="server"] .server-entry-main h3 {
  font-size: 15px;
}

.view-panel[data-view="server"] .server-entry-main p {
  margin-top: 5px;
  font-size: 12px;
}

.view-panel[data-view="server"] .server-entry-main small {
  margin-top: 3px;
}

.view-panel[data-view="server"] .server-entry-action {
  min-height: 32px;
  padding: 0 10px;
}

.view-panel[data-view="server"] .server-security-grid {
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
}

.view-panel[data-view="server"] .server-trouble-panel {
  grid-column: 1 / -1;
}

.view-panel[data-view="server"] .server-check-list {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.view-panel[data-view="server"] .server-trouble-list {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.view-panel[data-view="server"] .server-flow-panel,
.view-panel[data-view="server"] .server-safety-panel,
.view-panel[data-view="server"] .server-trouble-panel,
.view-panel[data-view="server"] .server-status-panel {
  padding: 11px;
}

.view-panel[data-view="server"] .server-flow-head {
  padding-bottom: 8px;
}

.view-panel[data-view="server"] .server-flow-head > span {
  width: 34px;
  height: 34px;
}

.view-panel[data-view="server"] .server-flow-head h3 {
  font-size: 15px;
}

.view-panel[data-view="server"] .server-flow-head p {
  font-size: 12px;
}

.view-panel[data-view="server"] .server-flow-steps div,
.view-panel[data-view="server"] .server-check-list div,
.view-panel[data-view="server"] .server-trouble-list div,
.view-panel[data-view="server"] .server-status-list div {
  min-height: 48px;
  padding: 9px;
}

@media (max-width: 760px) {
  .view-panel[data-view="server"] .section-block[aria-label="服务器体检摘要"] {
    padding: 11px;
  }

  .view-panel[data-view="server"] .server-summary-chips {
    max-width: none;
  }

  .view-panel[data-view="server"] .server-stat-card.console-stat-card {
    flex-basis: 202px;
    min-height: 90px;
  }

  .view-panel[data-view="server"] .server-security-grid,
  .view-panel[data-view="server"] .server-check-list,
  .view-panel[data-view="server"] .server-trouble-list {
    grid-template-columns: 1fr;
  }
}

/* Resources command-center polish: search first, copy first, details on demand. */
.view-panel[data-view="resources"] .section-block[aria-labelledby="resources-title"] {
  padding-top: 14px;
}

.view-panel[data-view="resources"] .resource-overview-strip {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 10px;
}

.view-panel[data-view="resources"] .resource-stat-card {
  min-height: 54px;
  grid-template-columns: 30px minmax(0, 1fr);
  gap: 8px;
  padding: 8px 10px;
  border-radius: 10px;
}

.view-panel[data-view="resources"] .resource-stat-card > span {
  width: 30px;
  height: 30px;
  border-radius: 9px;
}

.view-panel[data-view="resources"] .resource-stat-card small {
  margin: 0;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
}

.view-panel[data-view="resources"] .resource-stat-card strong {
  display: inline;
  margin-right: 6px;
  color: var(--resource-accent);
  font-size: 17px;
  line-height: 1.1;
}

.view-panel[data-view="resources"] .resource-stat-card em {
  display: inline;
  color: var(--text);
  font-size: 12px;
  font-weight: 850;
}

.view-panel[data-view="resources"] .resource-launchpad {
  margin-bottom: 10px;
}

.view-panel[data-view="resources"] .resource-launch-card {
  min-height: 118px;
}

.view-panel[data-view="resources"] .resource-launch-actions .primary-action {
  order: -1;
}

.view-panel[data-view="resources"] .resource-workspace {
  margin-top: 10px;
  padding: 12px;
}

.view-panel[data-view="resources"] .resource-tabs {
  min-height: 42px;
  margin-bottom: 10px;
  padding: 4px;
}

.view-panel[data-view="resources"] .resource-tabs .segment {
  min-height: 32px;
}

.view-panel[data-view="resources"] .resource-command-head {
  min-height: 36px;
  margin-bottom: 8px;
  padding-bottom: 8px;
}

.view-panel[data-view="resources"] .resource-command-head h3 {
  font-size: 17px;
}

.view-panel[data-view="resources"] .command-pack-controls {
  grid-template-columns: minmax(340px, 1fr) auto;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
  padding: 8px;
  border-color: color-mix(in srgb, var(--resource-accent) 18%, var(--resource-line));
  border-radius: 10px;
}

.view-panel[data-view="resources"] .command-pack-search {
  min-height: 36px;
  border-color: color-mix(in srgb, var(--resource-accent) 18%, var(--resource-line));
}

.view-panel[data-view="resources"] .command-pack-segment {
  min-height: 30px;
}

.view-panel[data-view="resources"] .command-pack-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 9px;
}

.view-panel[data-view="resources"] .command-pack {
  grid-template-columns: minmax(0, 1fr);
  grid-template-areas:
    "head"
    "body"
    "actions"
    "code";
  gap: 8px;
  padding: 12px;
}

.view-panel[data-view="resources"] .command-pack-head {
  grid-template-columns: 34px minmax(0, 1fr) 32px;
  gap: 8px;
}

.view-panel[data-view="resources"] .command-pack-icon {
  width: 32px;
  height: 32px;
}

.view-panel[data-view="resources"] .command-pack h3 {
  font-size: 16px;
}

.view-panel[data-view="resources"] .command-pack p {
  display: -webkit-box;
  margin-top: 4px;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.view-panel[data-view="resources"] .command-pack-actions {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
}

.view-panel[data-view="resources"] .command-pack-actions .primary-action {
  justify-content: center;
}

.command-detail-block {
  margin-top: 8px;
}

.command-detail-block summary {
  min-height: 30px;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: 9px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 0 9px;
  color: var(--muted);
  background: var(--surface-soft);
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
  list-style: none;
}

.command-detail-block summary::-webkit-details-marker {
  display: none;
}

.command-detail-block summary svg {
  width: 14px;
  height: 14px;
  transition: transform 160ms ease;
}

.command-detail-block[open] summary svg {
  transform: rotate(180deg);
}

.command-detail-block div {
  display: grid;
  gap: 6px;
  margin-top: 8px;
}

.command-detail-block div span {
  min-height: 28px;
  border: 1px solid color-mix(in srgb, var(--line) 80%, transparent);
  border-radius: 8px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 6px;
  padding: 5px 8px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface) 82%, transparent);
  font-size: 12px;
  line-height: 1.35;
}

.command-detail-block div svg {
  width: 14px;
  height: 14px;
  color: var(--teal-strong);
}

body[data-active-view="resources"] .entry-pet {
  right: 16px;
  bottom: 18px;
  transform: scale(0.72);
  transform-origin: bottom right;
}

@media (min-width: 761px) {
  body[data-active-view="resources"] .entry-pet {
    right: auto;
    left: 164px;
  }
}

@media (max-width: 980px) {
  .view-panel[data-view="resources"] .command-pack-controls {
    grid-template-columns: minmax(0, 1fr);
  }

  .view-panel[data-view="resources"] .command-pack-segments {
    justify-content: flex-start;
  }

  .view-panel[data-view="resources"] .command-pack-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .view-panel[data-view="resources"] .resource-overview-strip {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    overflow-x: visible;
    padding-bottom: 2px;
    scroll-snap-type: none;
  }

  .view-panel[data-view="resources"] .resource-stat-card {
    min-width: 0;
    min-height: 58px;
    scroll-snap-align: none;
  }

  .view-panel[data-view="resources"] .resource-stat-card em {
    display: inline;
  }

  .view-panel[data-view="resources"] .resource-launch-card {
    min-height: auto;
  }

  .view-panel[data-view="resources"] .command-pack-actions {
    grid-template-columns: 1fr;
  }

  body[data-active-view="resources"] .entry-pet {
    bottom: 76px;
    transform: scale(0.66);
  }
}
