@import url("/static/shell.css?v=surface-split-7");

body.surface-admin {
  --accent: #256f8f;
  --accent2: #74a6b8;
  --panel: rgba(255,255,255,.70);
  --panel-strong: rgba(255,255,255,.84);
  --shadow: 0 18px 48px rgba(38,65,78,.12);
  background:
    linear-gradient(145deg, rgba(246,250,251,.96), rgba(225,237,240,.88) 55%, rgba(211,226,232,.86)),
    linear-gradient(180deg, rgba(255,255,255,.78), rgba(255,255,255,0));
}

.surface-switch {
  position: fixed;
  z-index: 10020;
  right: calc(22px + env(safe-area-inset-right));
  bottom: calc(22px + env(safe-area-inset-bottom));
  width: 62px;
  height: 62px;
  display: none;
  margin: 0;
  padding: 0;
  border: 0;
  pointer-events: auto;
}

.surface-switch summary {
  position: relative;
  overflow: hidden;
  width: 62px;
  height: 62px;
  display: flex;
  align-items: center;
  justify-content: center;
  list-style: none;
  cursor: pointer;
  touch-action: none;
  user-select: none;
  border: 1px solid rgba(255,255,255,.80);
  border-radius: 999px;
  color: #174557;
  background:
    radial-gradient(circle at 32% 23%, rgba(255,255,255,.98) 0, rgba(255,255,255,.72) 13%, rgba(255,255,255,0) 31%),
    radial-gradient(circle at 72% 78%, rgba(91,175,205,.38), rgba(91,175,205,0) 42%),
    conic-gradient(from 222deg, rgba(102,198,214,.92), rgba(125,220,190,.90), rgba(244,190,179,.74), rgba(102,198,214,.92));
  box-shadow:
    0 22px 54px rgba(42,96,118,.24),
    0 7px 18px rgba(71,160,177,.15),
    inset 0 1px 0 rgba(255,255,255,.82),
    inset 0 -10px 18px rgba(58,126,153,.16);
  backdrop-filter: blur(20px) saturate(1.2);
  -webkit-backdrop-filter: blur(20px) saturate(1.2);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.surface-switch summary::before {
  content: "";
  position: absolute;
  inset: 8px;
  border-radius: inherit;
  background:
    linear-gradient(145deg, rgba(255,255,255,.30), rgba(255,255,255,0) 58%),
    radial-gradient(circle at 72% 74%, rgba(255,255,255,.20), rgba(255,255,255,0) 38%);
  pointer-events: none;
}

.surface-switch summary::-webkit-details-marker {
  display: none;
}

.surface-switch summary:hover,
.surface-switch[open] summary {
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.92);
  box-shadow:
    0 28px 68px rgba(42,96,118,.28),
    0 10px 24px rgba(71,160,177,.18),
    inset 0 1px 0 rgba(255,255,255,.86),
    inset 0 -10px 18px rgba(58,126,153,.15);
}

.surface-switch.is-dragging summary {
  cursor: grabbing;
  transform: scale(.98);
  box-shadow:
    0 18px 42px rgba(42,96,118,.24),
    inset 0 1px 0 rgba(255,255,255,.78);
}

.surface-switch .scene-label {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
}

.surface-switch summary svg {
  position: relative;
  z-index: 1;
  width: 25px;
  height: 25px;
  stroke-width: 1.85;
  filter: drop-shadow(0 2px 4px rgba(255,255,255,.38));
}

.surface-switch .scene-current {
  display: none;
}

.surface-switch .scene-list {
  position: absolute;
  right: 0;
  bottom: calc(100% + 10px);
  display: grid;
  gap: 6px;
  width: 168px;
  padding: 9px;
  border: 1px solid rgba(255,255,255,.78);
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.90), rgba(240,250,250,.76)),
    rgba(255,255,255,.70);
  box-shadow:
    0 24px 58px rgba(38,65,78,.18),
    inset 0 1px 0 rgba(255,255,255,.76);
  backdrop-filter: blur(24px) saturate(1.18);
  -webkit-backdrop-filter: blur(24px) saturate(1.18);
}

.surface-switch[data-menu-y="down"] .scene-list {
  top: calc(100% + 10px);
  bottom: auto;
}

.surface-switch[data-menu-x="right"] .scene-list {
  left: 0;
  right: auto;
}

.surface-switch a {
  min-height: 40px;
  padding: 0 13px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  border: 1px solid transparent;
  border-radius: 13px;
  color: rgba(48,76,92,.84);
  background: rgba(255,255,255,.30);
  text-decoration: none;
  font-size: 13px;
  font-weight: 760;
  line-height: 1;
  white-space: nowrap;
  transition: color .18s ease, background .18s ease, border-color .18s ease, transform .18s ease;
}

.surface-switch a:hover,
.surface-switch a[aria-current="page"] {
  color: var(--accent);
  border-color: rgba(87,134,153,.20);
  background: rgba(255,255,255,.72);
  transform: translateX(-1px);
}

body.scene-switch-ready .surface-switch {
  display: block;
}

.surface-cover {
  position: relative;
  margin: 0 0 16px;
  padding: 2px 1px 16px;
  border-bottom: 1px solid rgba(87,134,153,.12);
}

.surface-cover::after {
  content: "";
  position: absolute;
  left: 2px;
  bottom: -1px;
  width: 42px;
  height: 1px;
  border-radius: 999px;
  background: rgba(87,134,153,.52);
}

.surface-kicker {
  margin-bottom: 6px;
  color: rgba(82,103,118,.66);
  font-size: 10px;
  font-weight: 760;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.surface-cover-title {
  max-width: 172px;
  color: #203040;
  font-size: 22px;
  font-weight: 820;
  line-height: 1.18;
}

.surface-cover-subtitle {
  margin-top: 8px;
  color: rgba(93,112,127,.72);
  font-size: 11px;
  font-weight: 650;
  line-height: 1.45;
}

.surface-admin .surface-cover::after {
  background: rgba(37,111,143,.58);
}

.surface-admin .surface-kicker {
  color: rgba(43,103,129,.70);
}

.surface-admin .surface-cover-title {
  color: #1f3542;
}

.surface-admin .card,
.surface-admin .add-form,
.surface-admin .runtime-section,
.surface-admin .api-item,
.surface-admin .mem-item,
.surface-admin .toolbar {
  border-radius: 8px;
  box-shadow: 0 10px 28px rgba(38,65,78,.08);
}

.surface-admin .page-title {
  font-family: var(--font-ui);
  font-size: 26px;
}

.surface-admin .runtime-card {
  padding: 12px;
}

@media (max-width: 760px) {
  .surface-switch {
    right: calc(14px + env(safe-area-inset-right));
    bottom: calc(var(--admin-mobile-nav-height, 62px) + env(safe-area-inset-bottom) + 14px);
    width: 56px;
    height: 56px;
  }

  .surface-switch summary {
    width: 56px;
    height: 56px;
  }

  .surface-switch .scene-list {
    width: 158px;
    bottom: calc(100% + 8px);
  }

  .surface-main.main {
    padding-top: calc(18px + env(safe-area-inset-top));
  }

  .surface-cover,
  .status-badge {
    display: none;
  }

  .surface-nav {
    display: flex;
    flex-direction: row;
    align-items: center;
    overflow-x: auto;
  }

  .surface-nav .nav-item {
    flex: 0 0 auto;
    min-width: 86px;
    padding-inline: 10px;
    justify-content: center;
    white-space: nowrap;
  }

  .surface-nav .nav-item span {
    overflow: visible;
    text-overflow: clip;
  }
}

@media (min-width: 761px) {
  .surface-nav.sidebar {
    width: 204px;
    padding: 20px 14px 18px;
    gap: 3px;
  }

  .surface-main.main {
    margin-left: 204px;
    width: calc(100% - 204px);
    padding: 38px 46px 58px;
  }

  .surface-nav .nav-item {
    min-height: 34px;
    padding: 0 10px;
    border-radius: 8px;
    gap: 9px;
    color: rgba(102,120,136,.80);
    font-size: 13px;
    font-weight: 760;
  }

  .surface-nav .nav-item svg {
    width: 16px;
    height: 16px;
    stroke-width: 1.65;
  }

  .surface-nav .nav-item.active {
    border-color: rgba(255,255,255,.56);
    background: rgba(255,255,255,.56);
    box-shadow: 0 8px 20px rgba(57,104,123,.08), var(--glass-inset);
  }

  .surface-nav .status-badge {
    min-height: 34px;
    margin: auto 0 0;
    padding: 8px 10px;
    border-radius: 8px;
  }
}

/* Heartbeat observation deck */
.surface-admin #page-heartbeat-history {
  width: 100%;
  max-width: none;
  --hb-ink: #183342;
  --hb-muted: rgba(88,112,128,.76);
  --hb-soft: rgba(255,255,255,.68);
  --hb-line: rgba(96,139,158,.16);
  --hb-blue: #256f8f;
  --hb-green: #1f8a76;
  --hb-rose: #bd5f7c;
  --hb-amber: #b97718;
}

.surface-admin #page-heartbeat-history .heartbeat-page-title {
  margin: 0 0 18px;
  color: var(--hb-ink);
  font-size: 30px;
  font-weight: 820;
  letter-spacing: 0;
}

.surface-admin #page-heartbeat-history .heartbeat-page-title span {
  color: var(--hb-blue);
}

.surface-admin .heartbeat-shell {
  display: grid;
  gap: 14px;
}

.surface-admin .heartbeat-shell > .mem-header {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin: 0;
  padding: 16px 18px;
  border: 1px solid var(--hb-line);
  border-radius: 14px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.84), rgba(244,249,251,.64)),
    rgba(255,255,255,.58);
  box-shadow: 0 14px 36px rgba(38,65,78,.08), inset 0 1px 0 rgba(255,255,255,.72);
}

.surface-admin .heartbeat-shell > .mem-header::before {
  content: "";
  flex: 0 0 auto;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--hb-green);
  box-shadow: 0 0 0 6px rgba(31,138,118,.11);
}

.surface-admin .heartbeat-shell > .mem-header .mem-count {
  flex: 1 1 auto;
  color: var(--hb-muted);
  font-size: 13px;
  font-weight: 720;
  line-height: 1.5;
}

.surface-admin .heartbeat-shell .btn {
  border-radius: 999px;
}

.surface-admin .heartbeat-stats {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  margin: 0;
}

.surface-admin .heartbeat-stat {
  position: relative;
  min-height: 116px;
  padding: 14px 14px 12px;
  border: 1px solid var(--hb-line);
  border-radius: 14px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.82), rgba(248,252,253,.58)),
    rgba(255,255,255,.54);
  box-shadow: 0 10px 26px rgba(38,65,78,.065), inset 0 1px 0 rgba(255,255,255,.72);
  overflow: hidden;
}

.surface-admin .heartbeat-stat::after {
  content: "";
  position: absolute;
  inset: auto 12px 10px 12px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(37,111,143,.18), transparent);
}

.surface-admin .heartbeat-stat-label {
  margin: 0 0 7px;
  color: rgba(74,101,117,.68);
  font-size: 11px;
  font-weight: 760;
  letter-spacing: .04em;
}

.surface-admin .heartbeat-stat-value {
  color: var(--hb-ink);
  font-family: var(--font-ui);
  font-size: 24px;
  font-weight: 820;
  line-height: 1.08;
}

.surface-admin .heartbeat-sparkline {
  height: 34px;
  margin-top: 10px;
  color: var(--hb-blue);
  opacity: .86;
}

.surface-admin .heartbeat-sparkline svg {
  height: 34px;
}

.surface-admin .heartbeat-sparkline-area {
  fill: rgba(37,111,143,.08);
}

.surface-admin .heartbeat-sparkline-line {
  stroke-width: 1.7;
}

.surface-admin .heartbeat-contract {
  margin: 0;
  padding: 14px;
  border: 1px solid var(--hb-line);
  border-radius: 14px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.78), rgba(247,251,252,.54)),
    rgba(255,255,255,.52);
  box-shadow: 0 12px 32px rgba(38,65,78,.07), inset 0 1px 0 rgba(255,255,255,.72);
}

.surface-admin .heartbeat-contract-head,
.surface-admin .heartbeat-pool-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin: 0 0 12px;
}

.surface-admin .heartbeat-pool-panel {
  padding: 0;
  overflow: hidden;
}

.surface-admin .heartbeat-pool-summary {
  margin: 0;
  padding: 15px 16px;
  cursor: pointer;
}

.surface-admin .heartbeat-pool-summary::after {
  color: var(--hb-muted);
  font-size: 12px;
  font-weight: 760;
}

.surface-admin .heartbeat-pool-body {
  padding: 0 14px 14px;
}

.surface-admin .heartbeat-pool-tools {
  display: flex;
  justify-content: flex-end;
  margin: 0 0 10px;
}

.surface-admin .heartbeat-contract-title {
  color: var(--hb-ink);
  font-size: 15px;
  font-weight: 820;
  letter-spacing: 0;
}

.surface-admin .heartbeat-contract-grid,
.surface-admin .heartbeat-pool-grid {
  display: grid;
  gap: 9px;
}

.surface-admin .heartbeat-contract-grid {
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
}

.surface-admin .heartbeat-pool-grid {
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
}

.surface-admin .heartbeat-organ {
  padding: 11px 12px;
  border: 1px solid rgba(96,139,158,.14);
  border-radius: 12px;
  background: rgba(255,255,255,.52);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.66);
  transition: transform .16s ease, border-color .16s ease, background .16s ease, box-shadow .16s ease;
}

.surface-admin .heartbeat-organ:hover {
  transform: translateY(-1px);
  border-color: rgba(37,111,143,.28);
  background: rgba(255,255,255,.72);
  box-shadow: 0 10px 22px rgba(38,65,78,.07), inset 0 1px 0 rgba(255,255,255,.78);
}

.surface-admin .heartbeat-organ.selected {
  border-color: rgba(37,111,143,.42);
  background: rgba(245,251,253,.82);
}

.surface-admin .heartbeat-organ-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin: 0 0 6px;
  color: var(--hb-ink);
  font-size: 13px;
  font-weight: 800;
}

.surface-admin .heartbeat-organ-detail {
  color: var(--hb-muted);
  font-size: 12px;
  font-weight: 620;
  line-height: 1.45;
}

.surface-admin .heartbeat-status-badge {
  min-height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 760;
}

.surface-admin .heartbeat-organ-inspector {
  margin-top: 10px;
  padding: 14px;
  border: 1px solid rgba(96,139,158,.15);
  border-radius: 13px;
  background: rgba(255,255,255,.58);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.70);
}

.surface-admin .heartbeat-timeline {
  display: grid;
  gap: 9px;
  max-height: 620px;
  margin: 0;
  padding-right: 4px;
}

.surface-admin .heartbeat-timeline-item {
  padding: 13px 14px;
  border: 1px solid rgba(96,139,158,.13);
  border-radius: 13px;
  background: rgba(255,255,255,.56);
  box-shadow: 0 8px 20px rgba(38,65,78,.045), inset 0 1px 0 rgba(255,255,255,.70);
}

.surface-admin .heartbeat-line {
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr);
  gap: 11px;
  align-items: start;
}

.surface-admin .heartbeat-dot {
  width: 9px;
  height: 9px;
  margin: 7px auto 0;
  border-radius: 999px;
  background: var(--hb-rose);
  box-shadow: 0 0 0 5px rgba(189,95,124,.10);
}

.surface-admin .heartbeat-dot.dice {
  background: var(--hb-green);
  box-shadow: 0 0 0 5px rgba(31,138,118,.10);
}

.surface-admin .heartbeat-dot.sajiao {
  background: var(--hb-rose);
  box-shadow: 0 0 0 5px rgba(189,95,124,.11);
}

.surface-admin .heartbeat-dot.manual {
  background: #8fa0ad;
  box-shadow: 0 0 0 5px rgba(110,118,129,.10);
}

.surface-admin .heartbeat-timeline .mem-session {
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
}

.surface-admin .heartbeat-timeline .mem-session > span:first-child {
  color: rgba(47,70,85,.86);
  font-size: 12px;
  font-weight: 760;
}

.surface-admin .heartbeat-timeline .meta-row {
  gap: 6px;
  margin: 0 0 8px;
}

.surface-admin .heartbeat-timeline .tag {
  min-height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.56);
  font-size: 11px;
  line-height: 1;
}

.surface-admin .heartbeat-reason {
  margin: 0 0 7px;
  color: var(--hb-ink);
  font-size: 13px;
  font-weight: 760;
  line-height: 1.5;
}

.surface-admin .heartbeat-detail,
.surface-admin .heartbeat-message {
  border-radius: 11px;
  background: rgba(247,250,251,.62);
  color: rgba(70,94,110,.82);
  font-size: 12px;
  line-height: 1.55;
}

.surface-admin .heartbeat-context-raw {
  margin-top: 10px;
}

@media (max-width: 1100px) {
  .surface-admin .heartbeat-stats {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .surface-admin #page-heartbeat-history .heartbeat-page-title {
    font-size: 24px;
    margin-bottom: 12px;
  }

  .surface-admin .heartbeat-shell {
    gap: 10px;
  }

  .surface-admin .heartbeat-shell > .mem-header,
  .surface-admin .heartbeat-contract,
  .surface-admin .heartbeat-timeline-item,
  .surface-admin .heartbeat-organ-inspector {
    border-radius: 12px;
  }

  .surface-admin .heartbeat-shell > .mem-header,
  .surface-admin .heartbeat-contract-head,
  .surface-admin .heartbeat-pool-summary {
    align-items: stretch;
    flex-direction: column;
  }

  .surface-admin .heartbeat-shell > .mem-header::before {
    display: none;
  }

  .surface-admin .heartbeat-stats,
  .surface-admin .heartbeat-contract-grid,
  .surface-admin .heartbeat-pool-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .surface-admin .heartbeat-stat {
    min-height: 96px;
  }

  .surface-admin .heartbeat-line {
    grid-template-columns: 12px minmax(0, 1fr);
    gap: 8px;
  }

  .surface-admin .heartbeat-dot {
    margin-top: 6px;
  }
}

/* Heartbeat observation deck refinement */
.surface-admin #page-heartbeat-history {
  --hb-card-shadow: 0 18px 42px rgba(38,65,78,.075);
  --hb-card-bg: linear-gradient(145deg, rgba(255,255,255,.88), rgba(248,252,253,.68));
}

.surface-admin #page-heartbeat-history .heartbeat-page-title {
  display: inline-flex;
  align-items: baseline;
  gap: 2px;
  margin-bottom: 16px;
  font-size: 31px;
}

.surface-admin .heartbeat-shell {
  gap: 12px;
}

.surface-admin .heartbeat-shell > .mem-header {
  min-height: 62px;
  padding: 14px 16px;
  border-color: rgba(96,139,158,.14);
  border-radius: 16px;
  background: var(--hb-card-bg);
  box-shadow: var(--hb-card-shadow), inset 0 1px 0 rgba(255,255,255,.78);
}

.surface-admin .heartbeat-shell > .mem-header::before {
  width: 11px;
  height: 11px;
  background: linear-gradient(180deg, #3bb89d, #1f8a76);
}

.surface-admin .heartbeat-shell > .mem-header .mem-count {
  color: rgba(67,94,112,.80);
  font-size: 13px;
  font-weight: 760;
}

.surface-admin .heartbeat-shell > .mem-header .btn-row {
  margin: 0;
}

.surface-admin .heartbeat-stats {
  gap: 11px;
}

.surface-admin .heartbeat-stat {
  min-height: 122px;
  padding: 15px 16px 12px;
  border-color: rgba(96,139,158,.13);
  border-radius: 15px;
  background: var(--hb-card-bg);
  box-shadow: 0 14px 34px rgba(38,65,78,.065), inset 0 1px 0 rgba(255,255,255,.76);
}

.surface-admin .heartbeat-stat::after {
  display: none;
}

.surface-admin .heartbeat-stat::before {
  content: "";
  position: absolute;
  top: 14px;
  right: 14px;
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: rgba(37,111,143,.30);
}

.surface-admin .heartbeat-stat:nth-child(1)::before { background: rgba(31,138,118,.44); }
.surface-admin .heartbeat-stat:nth-child(2)::before { background: rgba(37,111,143,.44); }
.surface-admin .heartbeat-stat:nth-child(4)::before { background: rgba(189,95,124,.42); }
.surface-admin .heartbeat-stat:nth-child(5)::before { background: rgba(143,160,173,.44); }

.surface-admin .heartbeat-stat-label {
  color: rgba(75,104,121,.68);
  font-size: 11px;
  font-weight: 800;
}

.surface-admin .heartbeat-stat-value {
  color: #183342;
  font-size: 26px;
}

.surface-admin .heartbeat-sparkline {
  margin-top: 12px;
  height: 38px;
}

.surface-admin .heartbeat-sparkline svg {
  height: 38px;
}

.surface-admin .heartbeat-sparkline-line {
  stroke-width: 1.8;
}

.surface-admin .heartbeat-contract,
.surface-admin .heartbeat-section-head {
  border: 1px solid rgba(96,139,158,.13);
  border-radius: 16px;
  background: var(--hb-card-bg);
  box-shadow: var(--hb-card-shadow), inset 0 1px 0 rgba(255,255,255,.76);
}

.surface-admin .heartbeat-contract {
  padding: 15px;
}

.surface-admin .heartbeat-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 58px;
  padding: 14px 16px;
}

.surface-admin .heartbeat-contract-title {
  font-size: 15px;
  font-weight: 840;
}

.surface-admin .heartbeat-contract .mem-count,
.surface-admin .heartbeat-section-head .mem-count {
  color: rgba(91,114,127,.76);
  font-size: 12px;
  font-weight: 650;
  line-height: 1.45;
}

.surface-admin .heartbeat-contract-grid {
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 10px;
}

.surface-admin .heartbeat-mood-panel {
  display: grid;
  gap: 10px;
  margin: 0 0 12px;
  padding: 13px;
  border: 1px solid rgba(31,138,118,.16);
  border-radius: 13px;
  background: rgba(250,253,252,.72);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.78);
}

.surface-admin .heartbeat-mood-main {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.surface-admin .heartbeat-mood-kicker {
  color: rgba(91,114,127,.78);
  font-size: 12px;
  font-weight: 760;
}

.surface-admin .heartbeat-mood-climate {
  margin-top: 2px;
  color: var(--hb-ink);
  font-size: 16px;
  font-weight: 840;
  line-height: 1.35;
}

.surface-admin .heartbeat-mood-tags,
.surface-admin .heartbeat-mood-needs {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.surface-admin .heartbeat-mood-lines {
  display: grid;
  gap: 7px;
}

.surface-admin .heartbeat-mood-lines div {
  color: rgba(45,67,78,.86);
  font-size: 13px;
  font-weight: 650;
  line-height: 1.45;
}

.surface-admin .heartbeat-mood-lines span {
  display: inline-block;
  min-width: 64px;
  margin-right: 8px;
  color: rgba(91,114,127,.78);
  font-size: 12px;
  font-weight: 760;
}

.surface-admin .heartbeat-mood-needs span {
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(31,138,118,.08);
  color: rgba(38,91,84,.92);
  font-size: 12px;
  font-weight: 720;
}

.surface-admin .heartbeat-mood-moves {
  display: grid;
  gap: 6px;
}

.surface-admin .heartbeat-mood-moves div {
  padding: 7px 9px;
  border-radius: 10px;
  background: rgba(255,255,255,.62);
  color: rgba(45,67,78,.84);
  font-size: 12px;
  font-weight: 650;
  line-height: 1.45;
}

.surface-admin .heartbeat-pool-grid {
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 10px;
}

.surface-admin .heartbeat-organ {
  min-height: 82px;
  padding: 12px 13px;
  border-color: rgba(96,139,158,.13);
  border-radius: 13px;
  background: rgba(255,255,255,.60);
}

.surface-admin .heartbeat-organ.status-available {
  border-color: rgba(31,138,118,.18);
}

.surface-admin .heartbeat-organ.status-placeholder,
.surface-admin .heartbeat-organ.status-error {
  background: rgba(255,255,255,.48);
}

.surface-admin .heartbeat-organ-top span:first-child {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.surface-admin .heartbeat-status-badge {
  box-shadow: inset 0 1px 0 rgba(255,255,255,.66);
}

.surface-admin .heartbeat-timeline {
  gap: 10px;
}

.surface-admin .heartbeat-timeline-item {
  position: relative;
  padding: 15px 16px;
  border-color: rgba(96,139,158,.12);
  border-radius: 16px;
  background: var(--hb-card-bg);
  box-shadow: 0 12px 30px rgba(38,65,78,.055), inset 0 1px 0 rgba(255,255,255,.76);
  transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease;
}

.surface-admin .heartbeat-timeline-item:hover {
  transform: translateY(-1px);
  border-color: rgba(37,111,143,.22);
  box-shadow: 0 16px 38px rgba(38,65,78,.075), inset 0 1px 0 rgba(255,255,255,.78);
}

.surface-admin .heartbeat-line {
  grid-template-columns: 18px minmax(0, 1fr);
}

.surface-admin .heartbeat-line::before {
  content: "";
  position: absolute;
  left: 24px;
  top: 30px;
  bottom: 18px;
  width: 1px;
  background: rgba(96,139,158,.12);
}

.surface-admin .heartbeat-dot {
  position: relative;
  z-index: 1;
  margin-top: 8px;
}

.surface-admin .heartbeat-entry-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 10px;
}

.surface-admin .heartbeat-entry-copy {
  min-width: 0;
}

.surface-admin .heartbeat-entry-title {
  color: var(--hb-ink);
  font-size: 14px;
  font-weight: 820;
  line-height: 1.42;
  overflow-wrap: anywhere;
}

.surface-admin .heartbeat-entry-time {
  margin-top: 4px;
  color: rgba(82,108,123,.70);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 650;
}

.surface-admin .heartbeat-source {
  flex: 0 0 auto;
  min-height: 24px;
  padding: 0 9px;
  border-radius: 999px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.70);
}

.surface-admin .heartbeat-entry-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin: 0 0 9px;
}

.surface-admin .heartbeat-entry-metrics span {
  min-width: 0;
  padding: 9px 10px;
  border: 1px solid rgba(96,139,158,.10);
  border-radius: 12px;
  background: rgba(255,255,255,.46);
}

.surface-admin .heartbeat-entry-metrics strong {
  display: block;
  color: #183342;
  font-family: var(--font-ui);
  font-size: 14px;
  font-weight: 820;
  line-height: 1.15;
}

.surface-admin .heartbeat-entry-metrics small {
  display: block;
  margin-top: 3px;
  color: rgba(91,114,127,.72);
  font-size: 10px;
  font-weight: 720;
}

.surface-admin .heartbeat-entry-tags {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  margin: 0 0 9px;
}

.surface-admin .heartbeat-entry-tags .tag,
.surface-admin .heartbeat-timeline .tag {
  border-color: rgba(96,139,158,.13);
  background: rgba(255,255,255,.58);
}

.surface-admin .heartbeat-detail,
.surface-admin .heartbeat-message {
  margin-top: 8px;
  padding: 10px 12px;
  border: 1px solid rgba(96,139,158,.10);
  background: rgba(255,255,255,.48);
}

@media (min-width: 1400px) {
  .surface-admin .heartbeat-contract-grid {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  }

  .surface-admin .heartbeat-entry-metrics {
    max-width: 560px;
  }
}

@media (max-width: 760px) {
  .surface-admin #page-heartbeat-history .heartbeat-page-title {
    font-size: 25px;
  }

  .surface-admin .heartbeat-shell > .mem-header,
  .surface-admin .heartbeat-contract,
  .surface-admin .heartbeat-section-head,
  .surface-admin .heartbeat-timeline-item {
    padding: 13px;
    border-radius: 14px;
  }

  .surface-admin .heartbeat-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .surface-admin .heartbeat-stat {
    min-height: 96px;
    padding: 12px;
    border-radius: 14px;
  }

  .surface-admin .heartbeat-stat:nth-child(5) {
    grid-column: 1 / -1;
    min-height: 82px;
  }

  .surface-admin .heartbeat-stat-label {
    margin-bottom: 5px;
    font-size: 10px;
  }

  .surface-admin .heartbeat-stat-value {
    font-size: 21px;
  }

  .surface-admin .heartbeat-sparkline,
  .surface-admin .heartbeat-sparkline svg {
    height: 28px;
  }

  .surface-admin .heartbeat-sparkline {
    margin-top: 8px;
  }

  .surface-admin .heartbeat-entry-head {
    flex-direction: column;
    gap: 8px;
  }

  .surface-admin .heartbeat-entry-metrics {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
  }

  .surface-admin .heartbeat-entry-metrics span {
    padding: 8px 7px;
  }

  .surface-admin .heartbeat-entry-metrics strong {
    font-size: 13px;
    white-space: nowrap;
  }

  .surface-admin .heartbeat-entry-metrics small {
    font-size: 10px;
  }

  .surface-admin .heartbeat-line::before {
    left: 18px;
  }
}

@media (max-width: 410px) {
  .surface-admin #page-heartbeat-history .heartbeat-page-title {
    font-size: 24px;
  }

  .surface-admin .heartbeat-shell {
    gap: 9px;
  }

  .surface-admin .heartbeat-shell > .mem-header .mem-count {
    font-size: 12px;
  }

  .surface-admin .heartbeat-stats {
    gap: 7px;
  }

  .surface-admin .heartbeat-stat {
    min-height: 88px;
    padding: 11px;
  }

  .surface-admin .heartbeat-stat:nth-child(5) {
    min-height: 78px;
  }

  .surface-admin .heartbeat-sparkline,
  .surface-admin .heartbeat-sparkline svg {
    height: 24px;
  }
}

.system-rule-heading-actions,
.system-rule-bulk-actions,
.system-rule-card-top,
.system-rule-meta,
.system-rule-actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}

.system-rule-controls {
  display: grid;
  gap: 12px;
}

.system-rule-controls .form-row.compact {
  display: grid;
  grid-template-columns: auto minmax(120px, 180px) auto minmax(160px, 260px) auto minmax(180px, 1fr) auto;
  gap: 8px;
  align-items: center;
}

.system-rule-summary,
.system-rule-count,
.system-rule-card-top,
.system-rule-meta {
  color: var(--muted, #64748b);
  font-size: 12px;
}

.system-rule-groups {
  display: grid;
  gap: 14px;
}

.system-rule-group {
  border: 1px solid var(--line, #e2e8f0);
  border-radius: 8px;
  background: var(--card, #fff);
  overflow: hidden;
}

.system-rule-group-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 13px 15px;
  border-bottom: 1px solid var(--line, #e2e8f0);
  background: rgba(15, 23, 42, 0.03);
}

.system-rule-scope {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-weight: 700;
  color: var(--text, #0f172a);
}

.system-rule-card-list {
  display: grid;
  gap: 1px;
}

.system-rule-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  padding: 13px 15px;
  border-left: 4px solid #94a3b8;
  background: var(--card, #fff);
}

.system-rule-card.status-current { border-left-color: #16a34a; }
.system-rule-card.status-candidate { border-left-color: #2563eb; }
.system-rule-card.status-conflict_review { border-left-color: #d97706; }
.system-rule-card.status-superseded { border-left-color: #94a3b8; opacity: 0.82; }

.system-rule-card-main {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.system-rule-status,
.system-rule-meta span {
  border: 1px solid var(--line, #e2e8f0);
  border-radius: 999px;
  padding: 2px 7px;
  background: rgba(255, 255, 255, 0.7);
}

.system-rule-text {
  line-height: 1.55;
  color: var(--text, #0f172a);
  overflow-wrap: anywhere;
}

.system-rule-actions .icon-btn {
  width: 32px;
  height: 32px;
}

.system-rule-superseded {
  border-top: 1px solid var(--line, #e2e8f0);
  background: rgba(15, 23, 42, 0.025);
}

.system-rule-superseded summary {
  cursor: pointer;
  padding: 10px 15px;
  color: var(--muted, #64748b);
  font-size: 13px;
}

.system-rule-payload {
  margin: 0;
  padding: 14px;
  max-height: 70vh;
  overflow: auto;
  border: 1px solid var(--line, #e2e8f0);
  border-radius: 8px;
  background: #0f172a;
  color: #e2e8f0;
  font-size: 12px;
  line-height: 1.5;
}

@media (max-width: 900px) {
  .system-rule-controls .form-row.compact {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

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

/* Living-room aligned admin polish: warm liquid glass, calmer density. */
body.surface-admin {
  --accent: #6f627d;
  --accent2: #64bfb2;
  --green: #1b8f78;
  --red: #b4575b;
  --text: #243344;
  --muted: rgba(83, 103, 118, .72);
  --line: rgba(117, 147, 159, .18);
  --panel: rgba(255, 255, 255, .48);
  --panel-strong: rgba(255, 255, 255, .68);
  --shadow: 0 26px 72px rgba(54, 70, 80, .13);
  color: var(--text);
  background:
    linear-gradient(145deg, rgba(255, 250, 245, .98), rgba(246, 242, 238, .92) 46%, rgba(231, 245, 241, .90)),
    linear-gradient(90deg, rgba(226, 171, 176, .15), rgba(255, 255, 255, 0) 44%, rgba(104, 197, 185, .12));
  font-family: var(--font-ui), "PingFang SC", "Microsoft YaHei", sans-serif;
  font-variant-numeric: tabular-nums;
}

body.surface-admin::before {
  background:
    linear-gradient(115deg, rgba(255, 255, 255, .58), rgba(255, 255, 255, 0) 35%),
    linear-gradient(245deg, rgba(199, 225, 218, .20), rgba(255, 255, 255, 0) 46%),
    linear-gradient(180deg, rgba(255, 255, 255, .20), rgba(255, 255, 255, 0));
  opacity: .95;
}

.surface-admin .surface-cover,
.surface-admin .surface-kicker,
.surface-admin .surface-cover-title,
.surface-admin .surface-cover-subtitle,
.surface-admin .page-title,
.surface-admin .card-title,
.surface-admin .nav-item,
.surface-admin .btn,
.surface-admin .api-name,
.surface-admin .api-url,
.surface-admin .api-model {
  letter-spacing: 0;
}

@media (min-width: 761px) {
  .surface-admin .surface-nav.sidebar {
    width: 260px;
    padding: 22px 18px 20px;
    gap: 5px;
    border-right: 1px solid rgba(255, 255, 255, .56);
    background:
      linear-gradient(155deg, rgba(255, 255, 255, .62), rgba(255, 255, 255, .28)),
      linear-gradient(180deg, rgba(255, 249, 244, .76), rgba(234, 247, 243, .58));
    box-shadow:
      inset -1px 0 0 rgba(113, 147, 155, .10),
      18px 0 58px rgba(62, 83, 92, .08);
    backdrop-filter: blur(28px) saturate(1.18);
    -webkit-backdrop-filter: blur(28px) saturate(1.18);
  }

  .surface-admin .surface-main.main {
    width: calc(100% - 260px);
    margin-left: 260px;
    padding: 42px 56px 66px;
  }
}

.surface-admin .surface-cover {
  margin-bottom: 18px;
  padding-bottom: 18px;
  border-bottom-color: rgba(111, 98, 125, .14);
}

.surface-admin .surface-cover::after {
  width: 58px;
  height: 2px;
  background: linear-gradient(90deg, rgba(111, 98, 125, .58), rgba(100, 191, 178, .48));
}

.surface-admin .surface-kicker {
  color: rgba(92, 116, 132, .76);
  font-size: 11px;
  font-weight: 780;
  text-transform: uppercase;
}

.surface-admin .surface-cover-title {
  max-width: 212px;
  color: #223246;
  font-family: var(--font-romance), var(--font-ui), sans-serif;
  font-size: 28px;
  font-weight: 700;
  line-height: 1.14;
}

.surface-admin .surface-cover-subtitle {
  color: rgba(84, 103, 117, .70);
  font-size: 12px;
  font-weight: 680;
}

.surface-admin .surface-nav .nav-item {
  min-height: 44px;
  padding: 0 15px;
  border: 1px solid transparent;
  border-radius: 16px;
  color: rgba(64, 82, 98, .68);
  font-size: 15px;
  font-weight: 780;
  background: transparent;
  transition: transform .18s ease, color .18s ease, background .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.surface-admin .surface-nav .nav-item svg {
  color: rgba(71, 100, 116, .64);
  stroke-width: 1.85;
}

.surface-admin .surface-nav .nav-item:hover,
.surface-admin .surface-nav .nav-item.active {
  color: #26384b;
  border-color: rgba(255, 255, 255, .72);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, .74), rgba(255, 255, 255, .36)),
    linear-gradient(90deg, rgba(246, 204, 201, .20), rgba(122, 202, 190, .12));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, .80),
    0 14px 34px rgba(62, 82, 92, .09);
}

.surface-admin .surface-nav .nav-item:hover {
  transform: translateX(1px);
}

.surface-admin .surface-nav .nav-item.active svg {
  color: var(--accent);
}

.surface-admin .surface-nav .status-badge {
  min-height: 42px;
  padding: 0 13px;
  border-radius: 15px;
  border-color: rgba(100, 191, 178, .35);
  color: #237d72;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, .66), rgba(255, 255, 255, .30)),
    rgba(91, 190, 175, .08);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .76);
}

.surface-admin .page-heading {
  align-items: flex-start;
  margin-bottom: 28px;
}

.surface-admin .page-title {
  color: #223247;
  font-family: var(--font-ui), "PingFang SC", sans-serif;
  font-size: 36px;
  font-weight: 820;
  line-height: 1.08;
}

.surface-admin .page-title span {
  color: var(--accent);
  font-family: var(--font-romance), var(--font-ui), sans-serif;
  font-weight: 700;
}

.surface-admin .card,
.surface-admin .add-form,
.surface-admin .runtime-section,
.surface-admin .mem-item,
.surface-admin .toolbar {
  border: 1px solid rgba(255, 255, 255, .62);
  border-radius: 22px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, .62), rgba(255, 255, 255, .30)),
    linear-gradient(315deg, rgba(246, 216, 205, .18), rgba(202, 232, 225, .14));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, .82),
    inset 0 -1px 0 rgba(255, 255, 255, .26),
    var(--shadow);
  backdrop-filter: blur(26px) saturate(1.20);
  -webkit-backdrop-filter: blur(26px) saturate(1.20);
}

.surface-admin #page-api > .card {
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.surface-admin #page-api > .card > .card-title {
  margin: 0 0 18px;
  color: rgba(72, 91, 108, .72);
  font-family: var(--font-romance), var(--font-ui), sans-serif;
  font-size: 17px;
  font-weight: 700;
}

.surface-admin .cache-metrics-panel {
  display: grid;
  gap: 12px;
  margin: 14px 0 18px;
  padding: 14px;
  border: 1px solid rgba(100, 191, 178, .24);
  border-radius: 16px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, .58), rgba(255, 255, 255, .26)),
    rgba(100, 191, 178, .06);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .72);
}

.surface-admin .cache-metrics-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.surface-admin .cache-metrics-title {
  color: #25384a;
  font-size: 15px;
  font-weight: 780;
}

.surface-admin .cache-metrics-sub,
.surface-admin .cache-metrics-foot {
  color: rgba(83, 103, 118, .72);
  font-size: 12px;
  line-height: 1.5;
}

.surface-admin .cache-metrics-alerts {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.surface-admin .cache-metrics-alert {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 5px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 650;
}

.surface-admin .cache-metrics-alert.ok {
  color: #247667;
  background: rgba(100, 191, 178, .13);
}

.surface-admin .cache-metrics-alert.warn {
  color: #a75546;
  background: rgba(216, 129, 104, .14);
}

.surface-admin .cache-metrics-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 8px;
}

.surface-admin .cache-metric-card {
  min-width: 0;
  padding: 10px 11px;
  border: 1px solid rgba(255, 255, 255, .58);
  border-radius: 12px;
  background: rgba(255, 255, 255, .46);
}

.surface-admin .cache-metric-card span {
  display: block;
  overflow: hidden;
  color: rgba(83, 103, 118, .72);
  font-size: 11px;
  font-weight: 700;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.surface-admin .cache-metric-card strong {
  display: block;
  margin-top: 6px;
  overflow: hidden;
  color: #223247;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 20px;
  line-height: 1.05;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.surface-admin .cache-metrics-labels {
  display: grid;
  gap: 4px;
}

.surface-admin .cache-label-head,
.surface-admin .cache-label-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 58px 76px 76px;
  gap: 8px;
  align-items: center;
  min-height: 28px;
  color: rgba(83, 103, 118, .76);
  font-size: 12px;
}

.surface-admin .cache-label-head {
  color: rgba(83, 103, 118, .55);
  font-weight: 750;
  text-transform: uppercase;
}

.surface-admin .cache-label-row {
  padding: 5px 8px;
  border-radius: 10px;
  background: rgba(255, 255, 255, .34);
}

.surface-admin .cache-label-row span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.surface-admin .cache-label-row b,
.surface-admin .cache-label-head b {
  text-align: right;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-weight: 700;
}

@media (max-width: 900px) {
  .surface-admin .cache-metrics-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .surface-admin .cache-metrics-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .surface-admin .cache-metrics-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .surface-admin .cache-label-head,
  .surface-admin .cache-label-row {
    grid-template-columns: minmax(0, 1fr) 42px 58px 58px;
  }
}

.surface-admin .api-list {
  display: grid;
  gap: 10px;
}

.surface-admin #page-api .api-item,
.surface-admin #page-subapi .api-item {
  position: relative;
  display: grid;
  grid-template-columns: 8px minmax(0, 1fr) minmax(220px, 320px);
  align-items: center;
  gap: 12px;
  min-height: 0;
  padding: 12px 14px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, .58);
  border-radius: 14px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, .58), rgba(255, 255, 255, .22)),
    linear-gradient(315deg, rgba(246, 216, 205, .13), rgba(200, 229, 224, .16));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, .72),
    0 10px 28px rgba(52, 73, 82, .08);
  backdrop-filter: blur(20px) saturate(1.18);
  -webkit-backdrop-filter: blur(20px) saturate(1.18);
}

.surface-admin #page-api .api-item::after,
.surface-admin #page-subapi .api-item::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(120deg, rgba(255, 255, 255, .46), rgba(255, 255, 255, 0) 34%, rgba(100, 191, 178, .08));
}

.surface-admin #page-api .api-item.active-api,
.surface-admin #page-subapi .api-item.active-api {
  border-color: rgba(100, 191, 178, .36);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, .78),
    0 12px 32px rgba(65, 116, 111, .11);
}

.surface-admin .api-dot {
  width: 7px;
  height: 7px;
  margin-top: 0;
  border-radius: 999px;
  border: 2px solid rgba(255, 255, 255, .74);
  background: rgba(111, 128, 142, .32);
  box-shadow: 0 0 0 1px rgba(90, 111, 124, .08);
}

.surface-admin .api-dot.on {
  background: var(--green);
  box-shadow:
    0 0 0 1px rgba(27, 143, 120, .14),
    0 0 0 4px rgba(27, 143, 120, .07);
}

.surface-admin .api-info {
  position: relative;
  z-index: 1;
  min-width: 0;
}

.surface-admin .api-name {
  color: #243247;
  font-family: var(--font-romance), var(--font-ui), sans-serif;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.18;
}

.surface-admin .api-url {
  margin-top: 4px;
  color: rgba(48, 69, 86, .68);
  font-family: var(--font-mono), ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 13px;
  font-weight: 600;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.surface-admin .api-model {
  margin-top: 3px;
  color: rgba(82, 103, 118, .60);
  font-size: 12px;
  font-weight: 680;
  line-height: 1.3;
  overflow-wrap: anywhere;
}

.surface-admin #page-api .api-actions,
.surface-admin #page-subapi .api-actions {
  position: relative;
  z-index: 1;
  grid-column: 3;
  grid-row: 1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
  margin-top: 0;
}

.surface-admin .btn {
  min-height: 32px;
  padding: 0 12px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 760;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}

.surface-admin .btn:hover {
  transform: translateY(-1px);
}

.surface-admin .btn-ghost {
  border-color: rgba(118, 151, 164, .20);
  color: rgba(55, 74, 91, .78);
  background: rgba(255, 255, 255, .30);
}

.surface-admin .btn-ghost:hover {
  border-color: rgba(111, 98, 125, .28);
  background: rgba(255, 255, 255, .58);
  box-shadow: 0 12px 26px rgba(57, 78, 90, .09);
}

.surface-admin .btn-success,
.surface-admin #page-api .api-actions .btn-success,
.surface-admin #page-subapi .api-actions .btn-success {
  border-color: rgba(27, 143, 120, .26);
  color: #16806d;
  background: rgba(54, 184, 158, .09);
}

.surface-admin .btn-primary {
  border-color: rgba(111, 98, 125, .18);
  color: #fff;
  background: linear-gradient(135deg, #7a6a88, #58b4a8);
  box-shadow: 0 16px 34px rgba(90, 130, 132, .18);
}

.surface-admin .btn-danger,
.surface-admin #page-api .api-actions .btn-danger,
.surface-admin #page-subapi .api-actions .btn-danger {
  border-color: rgba(180, 87, 91, .22);
  color: #a6484d;
  background: rgba(180, 87, 91, .06);
}

.surface-admin .api-actions > span {
  min-height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(27, 143, 120, .22);
  border-radius: 10px;
  color: #16806d !important;
  background: rgba(54, 184, 158, .08);
  font-size: 13px !important;
  font-weight: 760;
}

.surface-admin input,
.surface-admin select,
.surface-admin textarea,
.surface-admin .model-picker {
  border-color: rgba(115, 145, 158, .20);
  border-radius: 15px;
  color: #26384b;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, .68), rgba(255, 255, 255, .34)),
    rgba(255, 255, 255, .30);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .70);
}

.surface-admin input:focus,
.surface-admin select:focus,
.surface-admin textarea:focus {
  border-color: rgba(100, 191, 178, .48);
  box-shadow:
    0 0 0 3px rgba(100, 191, 178, .12),
    inset 0 1px 0 rgba(255, 255, 255, .72);
}

.surface-admin #page-api > .card > .btn {
  margin-top: 16px;
  width: 100%;
  border-style: dashed;
}

.surface-admin .system-rules-heading {
  display: flex;
  justify-content: space-between;
  gap: 18px;
}

.surface-admin .page-subtitle {
  margin-top: 8px;
  color: rgba(72, 91, 108, .68);
  font-size: 13px;
  font-weight: 650;
}

.surface-admin .system-rules-heading-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.surface-admin .system-rules-heading-actions .btn,
.surface-admin .system-rule-actions .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}

.surface-admin .system-rules-heading-actions svg {
  width: 15px;
  height: 15px;
}

.surface-admin .system-rules-card,
.surface-admin .system-rules-inspector-card {
  padding: 14px;
}

.surface-admin .system-rules-card {
  display: grid;
  gap: 12px;
}

.surface-admin .system-rules-toolbar {
  display: grid;
  grid-template-columns: minmax(180px, 1.1fr) minmax(180px, 1fr) minmax(140px, .58fr) auto;
  gap: 10px;
  align-items: end;
}

.surface-admin .system-rules-toolbar label {
  display: grid;
  gap: 6px;
  min-width: 0;
  color: rgba(72, 91, 108, .72);
  font-size: 12px;
  font-weight: 760;
}

.surface-admin .system-rules-toolbar input,
.surface-admin .system-rules-toolbar select {
  width: 100%;
}

.surface-admin .system-rules-meta {
  min-height: 20px;
  color: rgba(72, 91, 108, .70);
  font-size: 12px;
  font-weight: 700;
}

.surface-admin .system-rules-list {
  display: grid;
  gap: 12px;
}

.surface-admin .system-rules-group {
  display: grid;
  gap: 8px;
}

.surface-admin .system-rules-group-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 0 2px;
  color: rgba(43, 66, 84, .76);
  font-size: 12px;
  font-weight: 820;
}

.surface-admin .system-rules-group-head b {
  min-width: 28px;
  padding: 3px 8px;
  border-radius: 999px;
  color: #256f8f;
  background: rgba(255, 255, 255, .58);
  text-align: center;
}

.surface-admin .system-rule-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, auto);
  gap: 12px;
  align-items: start;
  padding: 13px;
  border: 1px solid rgba(255, 255, 255, .62);
  border-radius: 15px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, .76), rgba(255, 255, 255, .38)),
    linear-gradient(315deg, rgba(116, 166, 184, .12), rgba(116, 191, 174, .10));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .78);
}

.surface-admin .system-rule-item.is-active {
  border-color: rgba(37, 111, 143, .36);
  box-shadow:
    0 0 0 3px rgba(37, 111, 143, .10),
    inset 0 1px 0 rgba(255, 255, 255, .82);
}

.surface-admin .system-rule-main {
  min-width: 0;
}

.surface-admin .system-rule-head,
.surface-admin .system-rule-tags {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
}

.surface-admin .system-rule-head {
  margin-bottom: 8px;
  color: rgba(72, 91, 108, .68);
  font-size: 11px;
  font-weight: 760;
}

.surface-admin .system-rule-head > span,
.surface-admin .system-rule-tags > span {
  max-width: 100%;
  padding: 3px 8px;
  border: 1px solid rgba(86, 125, 143, .12);
  border-radius: 999px;
  background: rgba(255, 255, 255, .46);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.surface-admin .system-rule-status-current {
  color: #11695e;
  border-color: rgba(66, 190, 169, .25) !important;
  background: rgba(66, 190, 169, .14) !important;
}

.surface-admin .system-rule-status-conflict_review {
  color: #98691d;
  border-color: rgba(214, 158, 46, .28) !important;
  background: rgba(214, 158, 46, .14) !important;
}

.surface-admin .system-rule-status-superseded {
  color: rgba(79, 92, 105, .72);
}

.surface-admin .system-rule-text {
  color: #203040;
  font-size: 14px;
  font-weight: 760;
  line-height: 1.55;
  overflow-wrap: anywhere;
}

.surface-admin .system-rule-tags {
  margin-top: 9px;
  color: rgba(72, 91, 108, .68);
  font-size: 11px;
  font-weight: 700;
}

.surface-admin .system-rule-note {
  margin-top: 8px;
  color: rgba(114, 73, 60, .74);
  font-size: 12px;
  line-height: 1.45;
}

.surface-admin .system-rule-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(92px, 1fr));
  gap: 8px;
}

.surface-admin .system-rules-inspector-card {
  margin-top: 14px;
}

.surface-admin .system-rules-inspector {
  margin: 10px 0 0;
  min-height: 180px;
  max-height: 420px;
  padding: 13px;
  overflow: auto;
  border: 1px solid rgba(86, 125, 143, .14);
  border-radius: 14px;
  color: #23374d;
  background: rgba(255, 255, 255, .54);
  font-family: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 12px;
  line-height: 1.55;
  white-space: pre-wrap;
}

@media (max-width: 760px) {
  .surface-admin .surface-main.main {
    padding: calc(18px + env(safe-area-inset-top)) 14px calc(86px + env(safe-area-inset-bottom));
  }

  .surface-admin .page-heading {
    gap: 14px;
    margin-bottom: 22px;
  }

  .surface-admin .page-title {
    font-size: 30px;
  }

  .surface-admin .surface-nav .nav-item {
    min-height: 40px;
    padding: 0 13px;
    border-radius: 14px;
    white-space: nowrap;
  }

  .surface-admin .system-rules-heading,
  .surface-admin .system-rules-heading-actions {
    align-items: stretch;
    justify-content: flex-start;
  }

  .surface-admin .system-rules-heading-actions .btn {
    flex: 1 1 140px;
  }

  .surface-admin .system-rules-toolbar,
  .surface-admin .system-rule-item {
    grid-template-columns: 1fr;
  }

  .surface-admin .system-rule-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .surface-admin #page-api .api-item,
  .surface-admin #page-subapi .api-item {
    grid-template-columns: 8px minmax(0, 1fr);
    align-items: start;
    gap: 9px;
    min-height: 0;
    padding: 12px;
    border-radius: 14px;
  }

  .surface-admin #page-api .api-actions,
  .surface-admin #page-subapi .api-actions {
    grid-column: 2;
    grid-row: auto;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
    margin-top: 8px;
  }

  .surface-admin .api-name {
    font-size: 15px;
  }

  .surface-admin .api-url {
    font-size: 12px;
  }
}
