:root {
  color-scheme: dark;
  --bg: #030604;
  --bg-glow: rgba(23, 142, 83, 0.18);
  --panel: #0b110d;
  --panel-strong: #111a14;
  --surface: #101711;
  --surface-soft: #151d17;
  --field: #0f1611;
  --ink: #f4fbf6;
  --muted: #9caf9f;
  --line: rgba(177, 235, 196, 0.16);
  --accent: #0d6b3d;
  --accent-strong: #063f24;
  --accent-soft: rgba(13, 107, 61, 0.2);
  --button-gradient: linear-gradient(135deg, #0f7a46 0%, #0a5c34 52%, #063f24 100%);
  --button-gradient-hover: linear-gradient(135deg, #128c50 0%, #0d6b3d 48%, #064428 100%);
  --bot: #111a14;
  --user: #12361f;
  --code-bg: #050806;
  --code-ink: #e9fff0;
  --danger: #d85e47;
  --danger-bg: rgba(216, 94, 71, 0.12);
  --shadow: 0 28px 90px rgba(0, 0, 0, 0.42);
}

html[data-theme="light"] {
  color-scheme: light;
  --bg: #f5f8f4;
  --bg-glow: rgba(29, 187, 104, 0.1);
  --panel: #ffffff;
  --panel-strong: #f8fbf7;
  --surface: #ffffff;
  --surface-soft: #f1f6f0;
  --field: #ffffff;
  --ink: #101611;
  --muted: #627065;
  --line: #dbe8dc;
  --accent: #12844a;
  --accent-strong: #0d6539;
  --accent-soft: #e8f7ee;
  --button-gradient: linear-gradient(135deg, #14884e 0%, #0f7442 52%, #0b6035 100%);
  --button-gradient-hover: linear-gradient(135deg, #159958 0%, #12844a 50%, #0d6539 100%);
  --bot: #f7faf6;
  --user: #e4f6ea;
  --code-bg: #111812;
  --code-ink: #f4fff7;
  --danger: #9b3526;
  --danger-bg: #fff4f1;
  --shadow: 0 24px 80px rgba(15, 24, 17, 0.12);
}

html[data-accent="blue"] {
  --accent: #2f7ee6;
  --accent-strong: #1850a8;
  --accent-soft: rgba(47, 126, 230, 0.18);
  --button-gradient: linear-gradient(135deg, #3f92ff 0%, #2f7ee6 52%, #174a96 100%);
  --button-gradient-hover: linear-gradient(135deg, #5ca5ff 0%, #347edf 48%, #143d7a 100%);
}

html[data-accent="pink"] {
  --accent: #d54f8b;
  --accent-strong: #8f2757;
  --accent-soft: rgba(213, 79, 139, 0.18);
  --button-gradient: linear-gradient(135deg, #ef6ca4 0%, #d54f8b 52%, #82264f 100%);
  --button-gradient-hover: linear-gradient(135deg, #fb82b5 0%, #df5b95 48%, #762247 100%);
}

html[data-accent="purple"] {
  --accent: #875df0;
  --accent-strong: #5430ad;
  --accent-soft: rgba(135, 93, 240, 0.18);
  --button-gradient: linear-gradient(135deg, #9b75ff 0%, #875df0 52%, #472693 100%);
  --button-gradient-hover: linear-gradient(135deg, #aa8aff 0%, #8c63ec 48%, #3a1d79 100%);
}

* {
  box-sizing: border-box;
}

[hidden] {
  display: none !important;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:
    radial-gradient(circle at top left, var(--bg-glow), transparent 32rem),
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), transparent 18rem),
    var(--bg);
  color: var(--ink);
}

button,
textarea,
input {
  font: inherit;
}

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

.shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 64px minmax(340px, 0.9fr) minmax(420px, 1fr) minmax(300px, 0.8fr);
  align-items: stretch;
  justify-content: center;
  gap: 10px;
  padding: 8px 14px 14px 6px;
}

.app-rail {
  height: calc(100vh - 16px);
  position: sticky;
  top: 8px;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: linear-gradient(180deg, #0d2518, #07150d);
  padding: 10px 6px;
  box-shadow: var(--shadow);
  overflow: hidden;
}

body.settings-rail-open .workspace-shell {
  grid-template-columns: 156px minmax(0, 1fr);
}

body.settings-rail-open .app-rail {
  padding: 10px 8px;
}

html[data-theme="light"] .app-rail {
  background: linear-gradient(180deg, #e9f7ed, #f7fbf8);
}

.rail-brand {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  margin: 0 auto;
  border-radius: 12px;
  background: var(--button-gradient);
  color: #fff;
  font-weight: 800;
  letter-spacing: 0;
}

.rail-nav {
  display: grid;
  align-content: start;
  gap: 8px;
  min-height: 0;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding-top: 8px;
  padding-right: 2px;
  border-top: 1px solid var(--line);
  scrollbar-width: thin;
}

.settings-rail-nav {
  display: none;
  border-top: 0;
  padding-top: 0;
}

body.settings-rail-open .primary-rail-nav,
body.settings-rail-open .rail-brand,
body.settings-rail-open .rail-account {
  display: none !important;
}

body.settings-rail-open .settings-rail-nav {
  display: grid;
}

.settings-back-button {
  min-height: 34px;
  border: 0;
  border-radius: 6px;
  background: var(--surface-soft);
  color: var(--ink);
  cursor: pointer;
  padding: 0 10px;
  text-align: left;
  font-weight: 800;
}

.settings-rail-title {
  margin-top: 8px;
  color: var(--ink);
  font-size: 16px;
}

.rail-button {
  display: grid;
  place-items: center;
  gap: 4px;
  width: 100%;
  min-width: 0;
  min-height: 56px;
  border: 1px solid transparent;
  border-radius: 10px;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  text-align: center;
}

.rail-button span {
  font-size: 18px;
  line-height: 1;
}

.rail-icon {
  width: 21px;
  height: 21px;
  display: grid;
  place-items: center;
}

.rail-icon svg {
  width: 21px;
  height: 21px;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  fill: none;
}

.rail-button small {
  max-width: 100%;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 11px;
  font-weight: 700;
}

.rail-button.active,
.rail-button:hover {
  border-color: color-mix(in srgb, var(--accent) 45%, var(--line));
  background: var(--accent-soft);
  color: var(--ink);
}

.rail-account {
  position: relative;
  display: grid;
  place-items: center;
  padding-top: 10px;
  border-top: 1px solid var(--line);
}

.account-avatar {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--button-gradient);
  color: #fff;
  cursor: pointer;
  font-weight: 800;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.22);
}

.account-avatar[aria-expanded="true"] {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.account-menu {
  position: absolute;
  left: calc(100% + 12px);
  bottom: 0;
  z-index: 70;
  width: min(330px, calc(100vw - 96px));
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--panel);
  box-shadow: var(--shadow);
  padding: 10px;
}

.account-menu-profile,
.account-menu-row,
.account-menu-field,
.account-menu-switch {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  color: var(--ink);
  padding: 10px;
}

.account-menu-profile,
.account-menu-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  cursor: pointer;
  text-align: left;
}

.account-menu-profile {
  display: grid;
  justify-items: start;
}

.account-menu-profile small,
.account-menu-field > span,
.account-menu-switch span,
.account-menu-row.muted {
  color: var(--muted);
}

.account-menu-row:hover,
.account-menu-profile:hover {
  border-color: var(--accent);
  background: var(--accent-soft);
}

.account-menu-field,
.account-menu-switch {
  display: grid;
  gap: 8px;
}

.account-menu-switch {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.account-menu-field select {
  width: 100%;
  height: 36px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 0 10px;
}

.accent-swatches {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.accent-swatch {
  width: 28px;
  height: 28px;
  border: 2px solid transparent;
  border-radius: 999px;
  cursor: pointer;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.18);
}

.accent-swatch.green {
  background: linear-gradient(135deg, #14884e, #063f24);
}

.accent-swatch.blue {
  background: linear-gradient(135deg, #55a2ff, #1850a8);
}

.accent-swatch.pink {
  background: linear-gradient(135deg, #f37cad, #8f2757);
}

.accent-swatch.purple {
  background: linear-gradient(135deg, #a986ff, #5430ad);
}

.accent-swatch.active {
  border-color: var(--ink);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.panel {
  width: 100%;
  height: calc(100vh - 22px);
  min-height: 620px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: var(--shadow);
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr) auto;
  overflow: hidden;
}

.webhook-panel {
  height: calc(100vh - 22px);
  min-height: 620px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: var(--shadow);
  display: grid;
  grid-template-rows: auto 1fr;
  overflow: hidden;
}

.prompt-panel {
  height: calc(100vh - 22px);
  min-height: 620px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: var(--shadow);
  display: grid;
  grid-template-rows: auto 1fr;
  overflow: hidden;
}

.prompt-tab {
  min-height: 0;
  display: grid;
  grid-template-rows: minmax(110px, 190px) auto 1fr;
}

.flow-canvas {
  display: grid;
  grid-template-columns: minmax(78px, 1fr) 36px minmax(78px, 1fr) 36px minmax(88px, 1fr);
  align-items: center;
  gap: 8px;
  padding: 14px;
  border-bottom: 1px solid var(--line);
  background:
    radial-gradient(circle, rgba(156, 175, 159, 0.13) 1px, transparent 1px),
    var(--panel-strong);
  background-size: 14px 14px;
}

.flow-node {
  min-height: 72px;
  display: grid;
  place-items: center;
  gap: 5px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface);
  text-align: center;
  padding: 10px;
}

.flow-node span {
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: var(--surface-soft);
  color: var(--accent);
  font-size: 12px;
  font-weight: 800;
}

.flow-node strong {
  font-size: 12px;
}

.flow-node.active {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.flow-node.start span {
  background: var(--button-gradient);
  color: #fff;
}

.flow-link {
  height: 1px;
  background: linear-gradient(90deg, var(--line), var(--accent), var(--line));
}

.bot-settings-form {
  display: grid;
  gap: 10px;
  padding: 14px;
  background: var(--surface);
}

.bot-settings-form label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 13px;
}

.bot-settings-form input[type="text"],
.bot-settings-form input[type="number"],
.bot-settings-form input[type="file"],
.bot-settings-form textarea,
.bot-settings-form select {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  background: var(--field);
  color: var(--ink);
  min-width: 0;
}

.bot-settings-form input[type="text"],
.bot-settings-form input[type="number"],
.bot-settings-form select {
  min-height: 38px;
}

.media-uploader {
  display: grid;
  gap: 8px;
}

.media-list {
  display: grid;
  gap: 6px;
}

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

.media-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px;
  background: var(--field);
  color: var(--ink);
  font-size: 13px;
}

.media-item span {
  min-width: 0;
  overflow-wrap: anywhere;
}

.media-item button {
  border: 1px solid color-mix(in srgb, var(--danger) 45%, var(--line));
  border-radius: 8px;
  background: var(--danger-bg);
  color: var(--danger);
  min-height: 32px;
  padding: 0 10px;
  cursor: pointer;
}

.bot-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}

.bot-danger-zone {
  display: flex;
  justify-content: flex-end;
  padding-top: 12px;
  margin-top: 10px;
  border-top: 1px solid var(--line);
}

.trash-button {
  width: 38px;
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid color-mix(in srgb, var(--danger) 45%, var(--line));
  border-radius: 8px;
  background: var(--danger-bg);
  color: var(--danger);
  cursor: pointer;
}

.trash-button svg {
  width: 19px;
  height: 19px;
  fill: currentColor;
}

.trash-button:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.memory-tab {
  min-height: 0;
  display: grid;
  grid-template-rows: minmax(120px, 220px) 1fr;
}

.memory-shell {
  min-height: 100vh;
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 18px;
  padding: 24px;
}

.page-shell {
  grid-template-columns: 78px minmax(0, 1fr);
  grid-template-rows: auto auto 1fr;
  gap: 14px;
  padding: 14px 22px 22px 14px;
}

.page-shell .app-rail {
  grid-row: 1 / 4;
}

.page-shell.knowledge-shell {
  grid-template-rows: auto 1fr;
}

.page-shell.knowledge-shell .app-rail {
  grid-row: 1 / 3;
}

.page-shell .memory-topbar,
.page-shell .memory-workspace,
.page-shell .page-metrics {
  width: 100%;
  max-width: none;
  margin: 0;
}

.page-shell .page-metrics {
  padding: 0;
  border-bottom: 0;
  background: transparent;
}

.memory-topbar {
  width: min(1480px, 100%);
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.memory-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.contact-mapping-panel {
  width: min(1480px, 100%);
  margin: 0 auto;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--panel);
  box-shadow: var(--shadow);
  padding: 14px;
  display: grid;
  gap: 12px;
}

.contact-mapping-panel h2 {
  margin: 0;
  font-size: 18px;
}

.contact-field-mapping-list {
  display: grid;
  gap: 8px;
}

.contact-field-mapping-list.compact {
  max-height: min(48vh, 420px);
  overflow: auto;
  gap: 6px;
  padding-right: 4px;
}

.contact-field-mapping-row {
  display: grid;
  grid-template-columns: minmax(150px, 0.8fr) minmax(190px, 1.1fr) minmax(220px, 1.25fr) auto;
  align-items: end;
  gap: 8px;
}

.contact-field-mapping-list.compact .contact-field-mapping-row {
  grid-template-columns: minmax(130px, 0.8fr) minmax(170px, 1fr) minmax(240px, 1.25fr) 34px;
  gap: 6px;
  align-items: end;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-soft);
  padding: 8px;
}

.contact-field-mapping-row label,
.manual-message-panel {
  display: grid;
  gap: 4px;
}

.contact-field-mapping-row span {
  color: var(--muted);
  font-size: 11px;
  text-transform: uppercase;
}

.contact-field-mapping-row input,
.contact-field-mapping-row select,
.manual-message-panel textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 9px 10px;
  margin: 0;
  outline: none;
}

.contact-field-mapping-list.compact .contact-field-mapping-row input {
  min-height: 34px;
  padding: 0 9px;
}

.contact-field-mapping-list.compact .contact-field-mapping-row select {
  min-height: 34px;
  padding: 0 9px;
}

.contact-field-mapping-list.compact .normalized-mapping-remove {
  width: 34px;
  min-height: 34px;
  align-self: end;
}

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

.contact-field-mapping-row input:focus,
.contact-field-mapping-row select:focus,
.manual-message-panel textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.memory-workspace {
  width: min(1480px, 100%);
  min-height: 0;
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
  gap: 18px;
}

.knowledge-workspace {
  grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
}

.memory-sidebar,
.contact-detail.full {
  min-height: 0;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: var(--shadow);
  overflow: hidden;
}

.memory-sidebar {
  display: grid;
  grid-template-rows: auto 1fr;
}

.memory-search {
  padding: 14px;
  border-bottom: 1px solid var(--line);
  background: var(--surface);
}

.memory-search input {
  width: 100%;
  min-height: 40px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 0 10px;
  color: var(--ink);
  background: var(--field);
  outline: none;
}

.knowledge-select-label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 13px;
}

.knowledge-select-label select,
.knowledge-editor textarea,
.knowledge-editor input[type="text"],
.knowledge-editor input[type="file"] {
  width: 100%;
  min-height: 40px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 10px;
  outline: none;
}

.knowledge-editor textarea {
  resize: vertical;
}

.knowledge-section {
  display: grid;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface);
  padding: 14px;
}

.knowledge-section h3 {
  margin: 0;
  font-size: 16px;
}

.inline-check {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--muted);
  font-size: 13px;
}

.faq-list {
  display: grid;
  gap: 12px;
}

.faq-item {
  display: grid;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-soft);
  padding: 12px;
}

.faq-item label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 13px;
}

.memory-search input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.webhook-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
  padding: 16px 18px;
  border-bottom: 1px solid var(--line);
  background: var(--panel);
}

.webhook-header h2 {
  margin: 0;
  font-size: 20px;
  overflow-wrap: anywhere;
}

.refresh {
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-soft);
  color: var(--ink);
  padding: 0 12px;
  cursor: pointer;
}

.refresh.active-tab {
  border-color: var(--accent);
  color: var(--accent);
  background: var(--accent-soft);
}

.prompt-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  width: 100%;
}

.prompt-actions .refresh {
  min-height: 32px;
  padding: 0 10px;
  font-size: 12px;
}

.settings-tabs {
  display: none;
  align-content: start;
  gap: 8px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--panel);
  padding: 8px;
  position: sticky;
  top: 12px;
}

.settings-tab-button {
  min-height: 46px;
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: transparent;
  color: var(--muted);
  padding: 7px 8px;
  cursor: pointer;
  text-align: left;
  font-weight: 800;
  display: flex;
  align-items: center;
  gap: 8px;
}

.settings-tab-button span {
  display: grid;
  place-items: center;
  width: 26px;
  height: 26px;
  flex: 0 0 26px;
  border-radius: 7px;
  background: var(--surface);
  color: var(--ink);
  font-size: 10px;
}

.settings-tab-button small {
  min-width: 0;
  color: inherit;
  font-size: 12px;
  line-height: 1.15;
  overflow-wrap: anywhere;
}

.settings-tab-button.active {
  border-color: var(--accent);
  background: var(--accent-soft);
  color: var(--accent);
}

.settings-webhook-panel {
  min-width: 0;
}

.settings-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 12px;
  align-items: start;
}

.settings-content,
.settings-panel-grid {
  display: grid;
  gap: 12px;
  min-width: 0;
  width: 100%;
}

.phone-system-tabs {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.phone-system-tab {
  min-height: 36px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-soft);
  color: var(--muted);
  padding: 0 12px;
  cursor: pointer;
  font-weight: 800;
}

.phone-system-tab.active {
  border-color: var(--accent);
  background: var(--accent-soft);
  color: var(--accent);
}

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

.phone-system-card {
  display: grid;
  gap: 14px;
}

.danger {
  border-color: color-mix(in srgb, var(--danger) 45%, var(--line));
  color: var(--danger);
  background: var(--danger-bg);
}

.danger:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.webhook-empty,
.webhook-card {
  overflow: auto;
  padding: 18px;
}

.webhook-empty {
  color: var(--muted);
}

.webhook-card {
  display: grid;
  align-content: start;
  gap: 16px;
}

.webhook-meta {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 8px 12px;
  margin: 0;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-soft);
  font-size: 13px;
}

.webhook-meta dt {
  color: var(--muted);
}

.webhook-meta dd {
  margin: 0;
  overflow-wrap: anywhere;
}

.webhook-card section {
  display: grid;
  gap: 8px;
}

.webhook-card h3 {
  margin: 0;
  font-size: 14px;
}

.section-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

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

.copy-button {
  min-height: 30px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-soft);
  color: var(--ink);
  padding: 0 10px;
  font-size: 12px;
  cursor: pointer;
}

.copy-button.copied {
  border-color: var(--accent);
  color: var(--accent);
}

.payload-search {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.payload-search input {
  width: min(320px, 48vw);
  min-height: 32px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 0 10px;
  outline: none;
}

.payload-search input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.payload-search-status {
  margin: -4px 0 8px;
  color: var(--muted);
  font-size: 12px;
}

.payload-highlight {
  border-radius: 4px;
  background: rgba(34, 197, 94, 0.35);
  color: inherit;
  padding: 0 2px;
}

.webhook-card pre {
  margin: 0;
  max-height: 240px;
  overflow: auto;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--code-bg);
  color: var(--code-ink);
  padding: 12px;
  font-size: 12px;
  line-height: 1.45;
}

.prompt-list {
  overflow: auto;
  display: grid;
  align-content: start;
  gap: 7px;
  padding: 14px;
  border-bottom: 1px solid var(--line);
  background: var(--surface);
}

.contact-list {
  overflow: auto;
  display: grid;
  align-content: start;
  gap: 8px;
  padding: 14px;
  border-bottom: 1px solid var(--line);
  background: var(--surface);
}

.contact-list.full {
  border-bottom: 0;
}

.contact-list.full::before {
  content: "Contacts";
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: uppercase;
}

.prompt-item,
.contact-item {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  padding: 11px;
  text-align: left;
}

.prompt-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
}

.prompt-select {
  min-width: 0;
  border: 0;
  background: transparent;
  color: var(--ink);
  padding: 0;
  text-align: left;
  cursor: pointer;
}

.prompt-open-builder {
  min-height: 32px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-soft);
  color: var(--ink);
  padding: 0 10px;
  cursor: pointer;
  white-space: nowrap;
}

.prompt-open-builder:hover {
  border-color: var(--accent);
  background: var(--accent-soft);
}

.contact-item {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  cursor: pointer;
}

.contact-avatar {
  width: 38px;
  height: 38px;
  display: inline-grid;
  place-items: center;
  border-radius: 50%;
  background: linear-gradient(135deg, #0d7a44, #062f20);
  color: #ffffff;
  font-size: 13px;
  font-weight: 800;
  flex: 0 0 auto;
}

.contact-avatar.large {
  width: 58px;
  height: 58px;
  font-size: 18px;
}

.contact-row-main,
.contact-row-side {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.contact-row-side {
  justify-items: end;
}

.contact-row-side small {
  color: var(--muted);
  font-size: 11px;
  white-space: nowrap;
}

.prompt-item strong,
.prompt-item span,
.contact-item strong,
.contact-item span {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.prompt-item span,
.contact-item span {
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
}

.prompt-item.active,
.contact-item.active {
  border-color: var(--accent);
  box-shadow: inset 3px 0 0 var(--accent), 0 0 0 1px var(--accent-soft);
}

.contact-detail {
  overflow: auto;
  display: grid;
  align-content: start;
  gap: 12px;
  padding: 14px;
}

.contact-detail.full {
  padding: 18px;
}

.crm-profile-grid {
  display: grid;
  grid-template-columns: minmax(280px, 0.85fr) minmax(0, 1.15fr);
  gap: 12px;
  align-items: start;
}

.crm-profile-column,
.crm-action-panel {
  display: grid;
  gap: 12px;
}

.crm-action-panel {
  grid-column: 1 / -1;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.contact-detail-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: var(--surface-soft);
}

.crm-profile-header {
  align-items: center;
  background: linear-gradient(180deg, var(--surface-soft), var(--panel));
}

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

.crm-profile-title > div {
  min-width: 0;
}

.crm-pill-row {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 8px;
}

.crm-pill {
  min-height: 24px;
  display: inline-flex;
  align-items: center;
  border: 1px solid color-mix(in srgb, var(--accent) 35%, var(--line));
  border-radius: 999px;
  background: var(--accent-soft);
  color: var(--accent);
  padding: 0 9px;
  font-size: 12px;
  font-weight: 700;
}

.contact-memory-actions,
.modal-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.contact-memory-actions.vertical {
  align-items: stretch;
  flex-direction: column;
}

.contact-memory-actions.vertical .refresh {
  width: 100%;
}

.crm-phone-dialer-button svg,
.crm-call-icon svg {
  width: 18px;
  height: 18px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.crm-send-from-control {
  min-height: 38px;
  display: inline-grid;
  grid-template-columns: auto minmax(136px, 1fr);
  align-items: center;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 4px 6px 4px 10px;
}

.crm-send-from-control.active {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.crm-send-from-control span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}

.crm-send-from-control select {
  min-height: 28px;
  border: 0;
  outline: 0;
  background: transparent;
  color: var(--ink);
  font: inherit;
}

.contact-detail-header h3,
.contact-detail-header p {
  margin: 0;
  overflow-wrap: anywhere;
}

.contact-detail-header h3 {
  font-size: 16px;
}

.contact-detail-header p {
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
}

.lead-info-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-soft);
  padding: 12px;
  display: grid;
  gap: 10px;
}

.crm-conversation-panel {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-soft);
  padding: 12px;
  display: grid;
  gap: 10px;
}

.crm-muted {
  color: var(--muted);
  font-size: 12px;
}

.lead-info-card.expanded {
  max-height: min(50vh, 520px);
  overflow: auto;
}

.lead-field-grid {
  margin: 0;
  display: grid;
  grid-template-columns: minmax(120px, 0.45fr) minmax(0, 1fr);
  gap: 8px 12px;
}

.lead-field-grid.compact {
  grid-template-columns: minmax(96px, 0.55fr) minmax(0, 1fr);
  gap: 7px 10px;
}

.lead-field-grid dt {
  color: var(--muted);
  font-size: 12px;
}

.lead-field-grid dd {
  margin: 0;
  overflow-wrap: anywhere;
}

.lead-info-modal {
  width: min(860px, calc(100vw - 28px));
  max-height: calc(100vh - 48px);
  overflow: auto;
}

.confirm-modal.contact-mapping-modal {
  width: min(760px, calc(100vw - 32px));
  max-height: min(82vh, 720px);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 12px;
  overflow: hidden;
}

.contact-entry-modal {
  width: min(720px, calc(100vw - 32px));
  max-height: calc(100vh - 48px);
  overflow: auto;
}

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

.contact-entry-form label {
  display: grid;
  gap: 6px;
}

.contact-entry-form label span {
  color: var(--muted);
  font-size: 11px;
  text-transform: uppercase;
}

.contact-entry-form .full-row {
  grid-column: 1 / -1;
}

.contact-entry-form input,
.contact-entry-form textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 0 10px;
  outline: none;
}

.contact-entry-form input {
  min-height: 38px;
}

.contact-entry-form textarea {
  min-height: 96px;
  padding-top: 10px;
  resize: vertical;
}

.contact-entry-form input:focus,
.contact-entry-form textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.lead-info-header {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.manual-message-panel {
  margin-top: 14px;
  display: grid;
  gap: 10px;
}

.manual-message-panel h3 {
  margin: 0;
  font-size: 15px;
}

#contactEditFields {
  display: grid;
  gap: 6px;
  max-height: min(32vh, 280px);
  overflow: auto;
  padding-right: 4px;
}

.contact-edit-row {
  display: grid;
  grid-template-columns: minmax(120px, 0.75fr) minmax(180px, 1.25fr) 32px;
  gap: 6px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-soft);
  padding: 5px;
}

.contact-edit-row + .contact-edit-row {
  margin-top: 0;
}

.contact-edit-row label {
  display: block;
  min-width: 0;
}

.contact-edit-row span {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
}

.contact-edit-row input {
  width: 100%;
  min-height: 30px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 0 8px;
  outline: none;
}

.contact-edit-row input[readonly] {
  opacity: 0.75;
}

.contact-edit-row input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.contact-edit-row .normalized-mapping-remove {
  width: 30px;
  min-height: 30px;
  border-radius: 7px;
}

.refresh.active-action {
  border-color: var(--accent);
  background: var(--accent-soft);
  color: var(--accent);
}

.memory-messages {
  display: grid;
  gap: 10px;
}

.memory-messages.full {
  align-content: start;
  grid-template-columns: minmax(0, 1fr);
}

.memory-message {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: var(--surface-soft);
}

.memory-message.bot {
  background: var(--bot);
}

.memory-message.customer {
  background: var(--user);
  border-color: color-mix(in srgb, var(--accent) 35%, var(--line));
}

.memory-message strong,
.memory-message small {
  display: block;
  color: var(--muted);
  font-size: 12px;
  overflow-wrap: anywhere;
}

.memory-message p {
  margin: 6px 0 0;
  line-height: 1.45;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
}

.memory-message pre {
  margin: 8px 0 0;
  max-height: 180px;
  overflow: auto;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--code-bg);
  color: var(--code-ink);
  padding: 10px;
  font-size: 12px;
}

.modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 20;
  display: grid;
  place-items: center;
  padding: 24px;
  background: rgba(23, 23, 23, 0.5);
}

#flowBuilderModal {
  padding: clamp(12px, 2vw, 24px);
  background: var(--bg);
}

.confirm-modal {
  width: min(460px, 100%);
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--panel);
  box-shadow: var(--shadow);
  padding: 18px;
}

.confirm-modal h2,
.confirm-modal p {
  margin: 0;
}

.confirm-modal h2 {
  font-size: 20px;
}

.confirm-modal p {
  margin-top: 8px;
  color: var(--muted);
  line-height: 1.45;
}

.confirm-modal input {
  width: 100%;
  min-height: 42px;
  margin-top: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 0 10px;
  outline: none;
  color: var(--ink);
  background: var(--field);
}

.confirm-modal input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.voice-background-card {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 10px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  padding: 12px;
}

.voice-background-card > div,
.voice-upload-preview {
  display: grid;
  gap: 4px;
}

.voice-background-card span,
.voice-upload-dropzone span,
.voice-upload-volume span {
  color: var(--muted);
  font-size: 13px;
}

.voice-background-card strong,
.voice-upload-preview strong,
.voice-upload-volume strong {
  color: var(--ink);
}

.voice-background-card label,
.voice-upload-volume {
  grid-column: 1 / -1;
  display: grid;
  gap: 8px;
  margin: 0;
}

.voice-background-card label {
  width: min(520px, 100%);
  max-width: 50%;
}

.voice-background-card input[type="range"],
.voice-upload-volume input[type="range"] {
  width: 100%;
  accent-color: var(--accent);
}

.voice-background-upload-modal {
  width: min(540px, 100%);
}

.voice-upload-dropzone {
  display: grid;
  gap: 8px;
  margin-top: 16px;
}

.voice-upload-dropzone input[type="file"] {
  padding: 10px;
}

.voice-upload-preview {
  margin-top: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  padding: 12px;
}

.voice-upload-preview audio {
  width: 100%;
}

.delete-confirm-modal {
  width: min(520px, 100%);
}

.delete-target {
  display: grid;
  gap: 4px;
  margin-top: 14px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  padding: 12px;
}

.delete-target span,
.delete-confirm-label span,
.delete-confirm-error {
  color: var(--muted);
  font-size: 13px;
}

.delete-target strong {
  overflow-wrap: anywhere;
}

.delete-confirm-label {
  display: grid;
  gap: 6px;
  margin-top: 14px;
}

.delete-confirm-label input {
  margin-top: 0;
}

.delete-confirm-error {
  min-height: 20px;
  color: var(--danger);
}

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

.prompt-editor {
  overflow: auto;
  display: grid;
  align-content: start;
  gap: 12px;
  padding: 16px;
  background: var(--surface);
}

.prompt-editor label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 13px;
}

.prompt-editor input[type="text"],
.prompt-editor input[type="email"],
.prompt-editor input[type="tel"],
.prompt-editor input[type="password"],
.prompt-editor select,
.prompt-editor textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  color: var(--ink);
  background: var(--field);
  outline: none;
  min-width: 0;
}

.settings-form {
  min-height: 0;
  width: 100%;
  background: transparent;
  padding: 0;
  overflow: visible;
}

.connector-section {
  display: grid;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 12px;
  background: var(--surface-soft);
}

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

.connector-card {
  min-width: 0;
  display: grid;
  align-content: start;
  gap: 7px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 12px;
  background: var(--field);
}

.connector-card.connected {
  border-color: color-mix(in srgb, var(--accent) 38%, var(--line));
}

.connector-card > span {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background: var(--accent-soft);
  color: var(--accent);
  font-size: 12px;
  font-weight: 800;
}

.connector-card strong {
  overflow-wrap: anywhere;
}

.connector-card p {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

.source-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.source-summary article {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface-soft);
  padding: 10px;
}

.source-summary span {
  display: block;
  color: var(--muted);
  font-size: 11px;
}

.source-summary strong {
  display: block;
  margin-top: 5px;
  overflow-wrap: anywhere;
  font-size: 12px;
}

.settings-copy-field {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-soft);
  padding: 10px;
}

.settings-copy-field span {
  display: block;
  margin-bottom: 6px;
  color: var(--muted);
  font-size: 13px;
}

.settings-copy-field code {
  display: block;
  color: var(--ink);
  font-size: 13px;
  line-height: 1.4;
  overflow-wrap: anywhere;
}

.settings-form select {
  width: 100%;
  min-height: 40px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 0 10px;
  font: inherit;
  min-width: 0;
}

.channel-picker {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin: 0;
  padding: 0;
  border: 0;
}

.channel-picker.compact {
  gap: 6px;
}

.channel-picker.channel-landscape {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 8px;
}

.channel-picker.channel-landscape legend {
  grid-column: 1 / -1;
}

.channel-picker legend {
  width: 100%;
  margin-bottom: 6px;
  color: var(--muted);
  font-size: 13px;
}

.channel-picker label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 36px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 0 10px;
  background: var(--surface-soft);
  color: var(--ink);
  cursor: pointer;
}

.channel-picker input {
  margin: 0;
}

.channel-picker label:has(input:checked) {
  border-color: var(--accent);
  color: var(--accent);
  background: var(--accent-soft);
}

.knowledge-sources {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-soft);
}

.knowledge-sources legend {
  color: var(--muted);
  font-size: 13px;
}

.knowledge-sources label {
  grid-template-columns: auto 1fr;
  align-items: center;
}

.knowledge-sources input[type="text"] {
  width: 100%;
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 0 10px;
  outline: none;
}

.normalized-mapping-list {
  display: grid;
  gap: 8px;
}

.normalized-mapping-row {
  display: grid;
  gap: 8px;
  grid-template-columns: minmax(120px, 0.8fr) minmax(180px, 1.3fr) minmax(170px, 1fr) auto;
  align-items: start;
}

.normalized-mapping-row input[type="text"],
.normalized-mapping-row select {
  width: 100%;
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 0 10px;
  outline: none;
}

.normalized-mapping-row input:focus,
.normalized-mapping-row select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.normalized-mapping-remove {
  width: 38px;
  min-height: 38px;
  padding: 0;
}

.normalized-mapping-add {
  margin-top: 4px;
  width: fit-content;
  align-self: start;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-soft);
  color: var(--ink);
  min-height: 36px;
  padding: 0 12px;
}

.normalized-mapping-add:hover {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.knowledge-sources input[type="text"]:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.settings-note {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.4;
}

.prompt-editor input:focus,
.prompt-editor textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.prompt-options {
  display: grid;
  gap: 8px;
}

.prompt-options label {
  grid-template-columns: auto 1fr;
  align-items: center;
}

.autopilot-toggle {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 0;
  padding: 12px;
  border: 1px solid color-mix(in srgb, var(--accent) 36%, var(--line));
  border-radius: 12px;
  background: linear-gradient(135deg, var(--accent-soft), transparent 72%), var(--surface-soft);
}

.autopilot-toggle legend {
  grid-column: 1 / -1;
  color: var(--muted);
  font-size: 13px;
}

.autopilot-toggle label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 42px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 0 12px;
  color: var(--muted);
  background: var(--field);
  cursor: pointer;
}

.autopilot-toggle label:has(input:checked) {
  border-color: var(--accent);
  color: var(--ink);
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 32%, transparent), var(--accent-soft));
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.autopilot-toggle input {
  margin: 0;
}

.autopilot-toggle p {
  grid-column: 1 / -1;
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-direction: row;
  padding: 18px 20px;
  border-bottom: 1px solid var(--line);
  background:
    linear-gradient(135deg, var(--accent-soft), transparent 55%),
    var(--panel);
}

.controls {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.model-control {
  display: grid;
  gap: 5px;
  min-width: 0;
  flex: 0 1 240px;
  color: var(--muted);
  font-size: 13px;
}

.model-control select {
  width: 100%;
  min-height: 40px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 0 10px;
  font: inherit;
  outline: none;
}

.model-control select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.eyebrow {
  margin: 0 0 4px;
  color: var(--muted);
  font-size: 13px;
}

h1 {
  margin: 0;
  font-size: 26px;
  line-height: 1.1;
  overflow-wrap: anywhere;
}

.status {
  flex: 0 0 auto;
  color: var(--muted);
  font-size: 14px;
}

.dashboard-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--line);
  background: var(--surface);
}

.dashboard-metrics article {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface-soft);
  padding: 12px;
}

.dashboard-metrics span {
  display: block;
  color: var(--muted);
  font-size: 12px;
}

.dashboard-metrics strong {
  display: block;
  margin-top: 5px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 16px;
}

.chat {
  overflow-y: auto;
  padding: 20px 18px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  background:
    linear-gradient(180deg, var(--surface), transparent 220px),
    var(--panel-strong);
}

.bubble {
  max-width: min(680px, 90%);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 14px 16px;
  line-height: 1.5;
  white-space: pre-wrap;
}

.bubble.bot {
  align-self: flex-start;
  background: var(--bot);
}

.bubble.user {
  align-self: flex-end;
  background: var(--user);
  border-color: color-mix(in srgb, var(--accent) 35%, var(--line));
}

.bubble img {
  display: block;
  width: min(340px, 100%);
  max-height: 340px;
  object-fit: contain;
  margin-top: 10px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--field);
}

.composer {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  padding: 14px 16px;
  border-top: 1px solid var(--line);
  background: var(--panel);
}

.upload,
.send,
.icon-button {
  min-height: 44px;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.upload {
  padding: 0 14px;
  color: var(--ink);
  background: var(--surface-soft);
  width: 100%;
}

.upload input {
  display: none;
}

textarea {
  width: 100%;
  min-height: 84px;
  resize: vertical;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  outline: none;
  background: var(--field);
  color: var(--ink);
}

textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.send {
  padding: 0 18px;
  border-color: var(--accent);
  background: var(--button-gradient);
  color: #ffffff;
  width: 100%;
  min-width: 0;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.14),
    0 10px 24px rgba(0, 0, 0, 0.22);
}

.send:hover {
  background: var(--button-gradient-hover);
}

.send.flow-save-saving,
.send.flow-save-confirmed {
  border-color: color-mix(in srgb, var(--accent) 70%, #000000);
  background: color-mix(in srgb, var(--accent) 55%, #050505);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 8px 18px rgba(0, 0, 0, 0.32);
}

.send.flow-save-confirmed {
  background: color-mix(in srgb, var(--accent) 42%, #030303);
}

.send:disabled {
  opacity: 0.65;
  cursor: wait;
}

.preview {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-soft);
  min-width: 0;
}

.preview img {
  width: 72px;
  height: 72px;
  object-fit: cover;
  border-radius: 8px;
}

.icon-button {
  width: 36px;
  min-height: 36px;
  background: var(--field);
  color: var(--ink);
}

.workspace-shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 78px minmax(0, 1fr);
  gap: 14px;
  padding: 14px 22px 22px 14px;
}

.workspace-main {
  min-width: 0;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 12px;
}

.workspace-topbar {
  display: grid;
  grid-template-columns: minmax(180px, 280px) minmax(260px, 1fr) auto;
  align-items: center;
  gap: 16px;
  min-height: 64px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--panel);
  box-shadow: var(--shadow);
  padding: 12px 16px;
}

.workspace-search {
  min-width: 0;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  min-height: 42px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--field);
  padding: 0 12px;
  color: var(--muted);
  font-size: 13px;
}

.workspace-search input,
.toolbar-row input,
.toolbar-row select,
.persona-editor input[type="text"],
.persona-editor input[type="number"],
.persona-editor input[type="range"],
.persona-editor input[type="file"],
.persona-editor textarea,
.persona-editor select,
.settings-card select {
  width: 100%;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 10px;
  outline: none;
}

.workspace-search input {
  border: 0;
  padding: 0;
  min-height: 38px;
}

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

.workspace-view {
  display: none;
  min-width: 0;
  min-height: 0;
}

.workspace-view.active {
  display: grid;
  align-content: start;
  gap: 12px;
}

.overview-metrics {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  padding: 0;
  border-bottom: 0;
  background: transparent;
}

.home-grid {
  display: grid;
  grid-template-columns: minmax(320px, 0.85fr) minmax(420px, 1.15fr);
  gap: 12px;
  align-items: start;
}

.agent-list-layout,
.voice-agent-list-layout,
.agent-editor-layout,
.voice-agent-editor-layout {
  display: grid;
  gap: 12px;
  align-items: start;
}

.agent-list-layout,
.voice-agent-list-layout {
  grid-template-columns: minmax(0, 1fr);
}

.agent-editor-layout {
  grid-template-columns: minmax(320px, 0.9fr) minmax(460px, 1.1fr);
}

.voice-agent-editor-layout {
  grid-template-columns: minmax(0, 1fr);
}

.agent-editor-toolbar {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.agent-editor-toolbar h3 {
  margin: 0;
}

.agent-hub,
.agent-hub-panel,
.agent-subpanel {
  display: grid;
  gap: 12px;
  min-width: 0;
}

.agent-hub-header,
.agent-hub-tabs,
.agent-subtabs {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.agent-hub-header {
  justify-content: space-between;
}

.agent-hub-header h2 {
  margin: 0;
}

.agent-hub-tab,
.agent-subtab {
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-soft);
  color: var(--muted);
  padding: 0 14px;
  cursor: pointer;
  font-weight: 800;
}

.agent-hub-tab.active,
.agent-subtab.active {
  border-color: var(--accent);
  background: var(--accent-soft);
  color: var(--accent);
}

.agent-hub-panel[hidden],
.agent-subpanel[hidden] {
  display: none !important;
}

.ai-dashboard-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 28px;
  margin-top: 18px;
}

.ai-dashboard-controls {
  display: grid;
  grid-template-columns: minmax(150px, 0.7fr) minmax(150px, 0.8fr) minmax(150px, 0.8fr) minmax(170px, 0.8fr);
  gap: 10px;
  align-items: end;
  margin-top: 8px;
}

.ai-dashboard-controls label {
  min-width: 0;
  display: grid;
  gap: 5px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.ai-dashboard-controls select,
.ai-dashboard-controls input {
  width: 100%;
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
  color: var(--ink);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
  padding: 0 12px;
}

.ai-stat-card {
  min-width: 0;
  display: grid;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
  box-shadow: var(--shadow);
  min-height: 124px;
  padding: 20px 22px;
}

.ai-stat-card:first-child {
  border-color: var(--accent);
  box-shadow: inset 0 0 0 1px var(--accent), var(--shadow);
}

.ai-stat-card span,
.ai-stat-card small {
  color: var(--muted);
}

.ai-stat-card strong {
  font-size: clamp(28px, 3vw, 36px);
  line-height: 1;
}

.ai-stat-card strong small {
  font-size: 13px;
  color: var(--ink);
}

.ai-stat-card small.positive,
.ai-summary-card small.positive {
  color: #15803d;
}

.ai-stat-card small.negative,
.ai-summary-card small.negative {
  color: #dc2626;
}

.ai-chart-card {
  display: grid;
  gap: 16px;
  margin-top: 18px;
  border-radius: 8px;
}

.ai-chart-wrap {
  min-height: 280px;
  overflow-x: auto;
}

.ai-chart-svg {
  width: 100%;
  min-width: 720px;
  height: auto;
  display: block;
}

.ai-chart-grid-line {
  stroke: var(--line);
  stroke-width: 1;
}

.ai-chart-axis {
  stroke: color-mix(in srgb, var(--muted) 45%, transparent);
  stroke-width: 1.5;
}

.ai-chart-axis-label {
  fill: var(--muted);
  font-size: 11px;
  font-weight: 700;
}

.ai-chart-area {
  fill: color-mix(in srgb, var(--accent) 16%, transparent);
}

.ai-chart-line {
  fill: none;
  stroke: var(--accent);
  stroke-width: 2;
}

.ai-chart-dot {
  fill: var(--accent);
  stroke: var(--panel);
  stroke-width: 2;
}

.ai-summary-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: 24px;
}

.ai-summary-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  min-height: 92px;
  border-radius: 8px;
}

.ai-summary-card span,
.ai-summary-card small {
  color: var(--muted);
}

.ai-summary-card strong {
  grid-column: 1;
  font-size: clamp(26px, 3vw, 34px);
  line-height: 1;
}

.ai-summary-card small {
  align-self: end;
  justify-self: end;
}

.ai-contact-board {
  display: grid;
  gap: 12px;
  margin-top: 24px;
}

.ai-contact-table {
  display: grid;
  gap: 8px;
}

.ai-contact-row {
  display: grid;
  grid-template-columns: minmax(220px, 1.4fr) repeat(4, minmax(90px, 0.55fr));
  gap: 12px;
  align-items: center;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  color: var(--ink);
  padding: 10px 12px;
  text-decoration: none;
}

.ai-contact-head {
  background: transparent;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.ai-contact-person {
  min-width: 0;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 2px 10px;
  align-items: center;
}

.ai-contact-person .contact-avatar {
  grid-row: 1 / span 2;
}

.ai-contact-person strong,
.ai-contact-person small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ai-contact-person small {
  color: var(--muted);
}

.voice-dashboard-shell {
  gap: 18px;
}

.voice-dashboard-controls {
  grid-template-columns: minmax(150px, 0.8fr) minmax(150px, 0.8fr) minmax(190px, 1fr);
}

.voice-direction-section {
  display: grid;
  gap: 12px;
}

.voice-direction-heading {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.voice-direction-heading h3 {
  margin: 0;
}

.voice-direction-pill {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface-soft);
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  padding: 0 12px;
}

.voice-dashboard-grid {
  gap: 12px;
  margin-top: 0;
}

.voice-chart-card,
.voice-call-board {
  margin-top: 6px;
}

.voice-chart-legend {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.voice-chart-legend span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.voice-chart-legend i {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--accent);
}

.voice-chart-legend i.outbound {
  background: #2563eb;
}

.voice-chart-line.inbound {
  fill: none;
  stroke: var(--accent);
  stroke-width: 2;
}

.voice-chart-line.outbound {
  fill: none;
  stroke: #2563eb;
  stroke-width: 2;
}

.voice-chart-dot.inbound {
  fill: var(--accent);
  stroke: var(--panel);
  stroke-width: 2;
}

.voice-chart-dot.outbound {
  fill: #2563eb;
  stroke: var(--panel);
  stroke-width: 2;
}

.voice-call-table {
  display: grid;
  gap: 8px;
}

.voice-call-row {
  display: grid;
  grid-template-columns: minmax(160px, 1.2fr) minmax(90px, 0.65fr) minmax(95px, 0.65fr) minmax(90px, 0.6fr) minmax(75px, 0.5fr) minmax(140px, 0.85fr);
  gap: 10px;
  align-items: center;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  color: var(--ink);
  padding: 10px 12px;
}

.voice-call-head {
  background: transparent;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.voice-call-row span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.voice-agent-form {
  display: grid;
  gap: 12px;
}

.voice-provider-box label {
  display: grid;
  gap: 6px;
}

.voice-provider-box input {
  width: 100%;
}

.voice-agent-meta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.voice-agent-meta span {
  min-height: 22px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  padding: 3px 8px;
}

.voice-flow-steps {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.voice-flow-steps span {
  min-height: 64px;
  display: grid;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-soft);
  color: var(--ink);
  font-weight: 800;
  text-align: center;
  padding: 10px;
}

.voice-agent-api-card {
  display: grid;
  gap: 16px;
}

.voice-agent-editor-card[hidden],
.voice-agent-preview-card[hidden],
.voice-agent-api-card[hidden],
.voice-agent-metrics-card[hidden],
.voice-agent-api-settings-card[hidden],
[data-tts-section][hidden] {
  display: none;
}

.tts-preview-panel {
  display: grid;
  gap: 14px;
  align-content: start;
}

.tts-preview-panel audio {
  width: 100%;
}

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

.cartesia-resource-grid > div,
.cartesia-test-call,
.cartesia-call-subsection {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-soft);
  padding: 14px;
}

.cartesia-call-subsection {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}

.cartesia-resource-list {
  display: grid;
  gap: 8px;
  min-height: 72px;
  margin: 10px 0;
}

.cartesia-call-row {
  display: grid;
  grid-template-columns: minmax(160px, 1.4fr) repeat(4, minmax(110px, 1fr));
  gap: 8px;
  align-items: center;
}

.cartesia-call-row small {
  grid-column: 1 / -1;
  color: var(--muted);
}

.cartesia-profile-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.cartesia-profile-item > div {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.internal-voice-test {
  display: grid;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
  padding: 12px;
  margin-bottom: 14px;
}

.internal-voice-messages {
  min-height: 180px;
  max-height: 300px;
  overflow: auto;
}

.voice-live-call {
  display: grid;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: color-mix(in srgb, var(--panel) 92%, #030303);
  padding: 16px;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02);
}

.voice-live-call-header {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 28px;
}

.voice-live-call-header strong {
  color: var(--ink);
}

.voice-live-call-header span:last-child {
  margin-left: auto;
  font-weight: 800;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
}

.voice-live-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--muted);
  box-shadow: 0 0 0 0 rgba(20, 132, 78, 0);
}

.voice-live-call[data-live="true"] .voice-live-dot {
  background: #14844e;
  animation: voiceLivePulse 1.4s ease-in-out infinite;
}

.voice-live-lanes {
  display: grid;
  gap: 8px;
  padding: 8px 0 2px;
}

.voice-live-lane {
  display: grid;
  grid-template-columns: 1fr;
  align-items: center;
  gap: 8px;
  min-height: 54px;
  border: 0;
  border-radius: 0;
  background: transparent;
  padding: 0 4px;
  position: relative;
}

.voice-live-lane[data-speaking="true"] {
  border-color: rgba(20, 132, 78, 0.5);
  box-shadow: 0 0 0 3px rgba(20, 132, 78, 0.08);
}

.voice-live-lane.agent[data-speaking="true"] {
  border-color: rgba(37, 99, 235, 0.45);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.08);
}

.voice-live-avatar {
  position: absolute;
  left: 0;
  top: 6px;
  z-index: 2;
  width: 38px;
  height: 38px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: var(--surface-soft);
  border: 1px solid var(--line);
  color: var(--ink);
  font-weight: 900;
}

.voice-live-lane strong,
.voice-live-lane small {
  display: block;
}

.voice-live-lane > div:nth-child(2) {
  position: absolute;
  left: 48px;
  top: 7px;
  z-index: 2;
  min-width: 88px;
  padding: 3px 7px;
  border-radius: 8px;
  background: color-mix(in srgb, var(--panel) 78%, transparent);
  backdrop-filter: blur(4px);
}

.voice-live-lane small {
  margin-top: 3px;
  color: var(--muted);
}

.voice-wave {
  height: 50px;
  display: flex;
  align-items: center;
  gap: 0;
  min-width: 0;
  padding: 0 2px;
  border-bottom: 2px dotted color-mix(in srgb, var(--muted) 42%, transparent);
  overflow: hidden;
  width: 100%;
}

.voice-wave span {
  flex: 1 1 0;
  min-width: 3px;
  margin-left: -1px;
  height: calc(6px + (var(--h, 0.08) * 40px));
  min-height: 6px;
  max-height: 46px;
  border-radius: 999px;
  background: #14844e;
  opacity: 0.5;
  transition: height 90ms ease, opacity 90ms ease, background 90ms ease;
}

.voice-live-lane.agent .voice-wave span {
  background: #2563eb;
}

.voice-live-lane[data-speaking="true"] .voice-wave span {
  opacity: 0.9;
}

.voice-call-actions {
  justify-content: center;
}

.voice-start-call-button {
  min-height: 56px;
  width: 360px;
  max-width: 100%;
  border-radius: 8px;
  font-size: 1rem;
  font-weight: 900;
}

@keyframes voiceLivePulse {
  0% {
    box-shadow: 0 0 0 0 rgba(20, 132, 78, 0.25);
  }
  70% {
    box-shadow: 0 0 0 8px rgba(20, 132, 78, 0);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(20, 132, 78, 0);
  }
}

.internal-voice-test audio {
  width: 100%;
}

.cartesia-resource-item {
  display: grid;
  grid-template-columns: minmax(105px, 0.3fr) minmax(0, 0.7fr);
  gap: 10px;
  align-items: start;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
  padding: 10px;
}

.cartesia-resource-item strong {
  color: var(--ink);
  overflow-wrap: anywhere;
}

.cartesia-resource-item span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
  overflow-wrap: anywhere;
}


.agent-empty-panel {
  min-height: 280px;
  align-content: center;
}

.embedded-knowledge-workspace {
  min-height: 680px;
  border: 1px solid var(--line);
  border-radius: 14px;
  overflow: hidden;
  background: var(--panel);
}

.board-card {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--panel);
  box-shadow: var(--shadow);
  padding: 16px;
}

.board-card h2,
.board-card h3,
.sources-header h2,
.settings-category h2 {
  margin: 0;
}

.usage-card,
.chart-card,
.setup-card {
  min-height: 190px;
}

.usage-card {
  grid-column: 1 / -1;
}

.usage-lines {
  display: grid;
  gap: 14px;
  margin-top: 18px;
}

.usage-lines span {
  height: 12px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--surface-soft), color-mix(in srgb, var(--accent) 25%, var(--surface-soft)));
}

.usage-lines span:nth-child(2),
.usage-lines span:nth-child(4) {
  width: 72%;
}

.segmented {
  display: flex;
  border: 1px solid var(--line);
  border-radius: 9px;
  overflow: hidden;
  background: var(--surface-soft);
}

.segmented button {
  min-height: 34px;
  border: 0;
  border-right: 1px solid var(--line);
  background: transparent;
  color: var(--muted);
  padding: 0 12px;
  cursor: pointer;
}

.segmented button:last-child {
  border-right: 0;
}

.segmented button.active {
  color: var(--accent);
  background: var(--accent-soft);
}

.bar-chart {
  display: flex;
  align-items: end;
  gap: 16px;
  height: 240px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface);
}

.bar-chart span {
  flex: 1;
  min-width: 18px;
  border-radius: 8px 8px 0 0;
  background: linear-gradient(180deg, var(--accent), var(--accent-strong));
}

.metric-updated {
  color: var(--muted);
  font-size: 12px;
  white-space: nowrap;
}

.metric-bars {
  display: grid;
  gap: 14px;
  margin-top: 18px;
}

.metric-bars article {
  display: grid;
  gap: 8px;
}

.metric-bars article > div:first-child,
.metric-support {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.metric-bars span,
.metric-support {
  color: var(--muted);
  font-size: 12px;
}

.metric-bars strong,
.metric-support strong {
  color: var(--text);
  font-size: 15px;
}

.metric-bar-track {
  height: 12px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface-soft);
}

.metric-bar-track span {
  display: block;
  width: 6%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--accent-strong), color-mix(in srgb, var(--accent) 78%, white 8%));
  transition: width 180ms ease;
}

.metric-support {
  flex-wrap: wrap;
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}

.checklist {
  display: grid;
  gap: 12px;
  margin: 16px 0 0;
  padding: 0;
  list-style: none;
}

.checklist li {
  display: flex;
  gap: 10px;
  align-items: center;
  color: var(--muted);
}

.checklist span {
  width: 18px;
  height: 18px;
  border-radius: 999px;
  border: 1px solid var(--accent);
  background: var(--accent-soft);
}

.persona-editor-card {
  grid-column: 1;
  grid-row: 1;
}

.flow-editor-card {
  grid-column: 2;
  grid-row: 1;
}

.flow-list-card[hidden] {
  display: none !important;
}

.test-console {
  grid-column: 1 / -1;
  grid-row: 3;
}

.prompt-bot-test-card {
  position: fixed;
  top: 96px;
  right: 24px;
  bottom: 24px;
  z-index: 25;
  width: min(440px, calc(100vw - 112px));
  min-height: 0;
  display: grid;
  grid-template-rows: auto minmax(220px, 1fr) auto;
  overflow: hidden;
  box-shadow: 0 28px 80px rgba(0, 0, 0, 0.46);
  transform: translateX(16px);
  opacity: 0;
}

.prompt-bot-test-card.open {
  transform: translateX(0);
  opacity: 1;
}

.persona-form-actions {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  align-items: center;
}

.toolbar-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 14px;
}

.toolbar-row input,
.toolbar-row select {
  flex: 1 1 180px;
  min-height: 38px;
}

.compact-send {
  width: auto;
  min-height: 38px;
  padding: 0 14px;
  white-space: nowrap;
}

.persona-cards {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}

.persona-card {
  min-width: 0;
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr) auto;
  gap: 2px 8px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--field);
  color: var(--ink);
  padding: 10px 12px;
  text-align: left;
  cursor: pointer;
}

.persona-card-content {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.persona-card-actions {
  justify-self: end;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.persona-card.active {
  border-color: var(--accent);
  box-shadow: inset 3px 0 0 var(--accent);
}

.avatar-badge {
  grid-row: 1 / 4;
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 11px;
  background: var(--button-gradient);
  color: #fff;
  font-weight: 800;
}

.persona-card strong,
.persona-card small,
.persona-card em {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.persona-card small,
.persona-card em {
  color: var(--muted);
  font-size: 11px;
}

.persona-card small,
.persona-card em {
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
}

.primary-badge {
  justify-self: end;
  font-size: 11px;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 4px 8px;
  color: var(--muted);
  background: transparent;
  white-space: nowrap;
  cursor: pointer;
}

.primary-badge.is-primary {
  border-color: var(--accent);
  background: color-mix(in hsl, var(--accent) 12%, transparent);
  color: var(--accent);
}

.flow-list {
  max-height: 360px;
  padding: 0;
  margin-top: 14px;
  border-bottom: 0;
  background: transparent;
}

.persona-editor {
  display: grid;
  gap: 12px;
}

.persona-editor label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 13px;
}

.tone-picker {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin: 0;
  padding: 0;
  border: 0;
}

.tone-picker legend {
  width: 100%;
  color: var(--muted);
  font-size: 13px;
}

.tone-picker label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 34px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface-soft);
  padding: 0 12px;
}

.tone-picker label:has(input:checked) {
  border-color: var(--accent);
  color: var(--accent);
  background: var(--accent-soft);
}

.provider-box,
.settings-card {
  display: grid;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface-soft);
  padding: 12px;
}

.provider-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 12px;
}

.provider-row > span {
  display: grid;
  place-items: center;
  min-width: 76px;
  min-height: 38px;
  border-radius: 10px;
  background: var(--accent-soft);
  color: var(--accent);
  font-weight: 800;
}

.slider-grid,
.two-column-form,
.account-settings-grid,
.settings-panel-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

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

.account-settings-grid .settings-card:first-child {
  grid-column: auto;
}

.settings-panel-grid .settings-card,
.settings-panel-grid .settings-webhook-panel {
  min-width: 0;
}

.settings-panel-grid .settings-data-library-card,
.settings-panel-grid .settings-webhook-panel,
.settings-integrations-panel .sources-header,
.settings-integrations-panel .overview-metrics,
.settings-integrations-panel .board-card {
  grid-column: 1 / -1;
}

.profile-initial-preview {
  display: flex;
  align-items: center;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface);
  padding: 10px;
}

.profile-initial-preview > span {
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  flex: 0 0 auto;
  border-radius: 999px;
  background: var(--button-gradient);
  color: #fff;
  font-weight: 800;
}

.profile-initial-preview strong {
  display: block;
  overflow-wrap: anywhere;
}

.profile-initial-preview p {
  margin: 2px 0 0;
}

.compact-fields {
  gap: 10px;
}

.appearance-choice {
  display: grid;
  gap: 8px;
}

.appearance-choice > span,
.switch-row span {
  color: var(--muted);
  font-size: 13px;
}

.switch-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  min-height: 36px;
}

.voice-interruption-slider {
  grid-column: 1 / -1;
  width: min(520px, 100%);
  max-width: 50%;
}

.voice-interruption-slider > span {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.voice-interruption-slider strong {
  color: var(--ink);
  font-size: 13px;
}

.voice-interruption-slider input[type="range"] {
  width: 100%;
  accent-color: var(--accent);
}

.voice-interruption-scale {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
}

.voice-interruption-scale span:nth-child(2),
.voice-interruption-scale span:nth-child(3) {
  text-align: center;
}

.voice-interruption-scale span:last-child {
  text-align: right;
}

@media (max-width: 760px) {
  .voice-background-card label,
  .voice-interruption-slider {
    width: 100%;
    max-width: 100%;
  }
}

.settings-card input[type="color"] {
  width: 100%;
  height: 38px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--field);
  padding: 4px;
  cursor: pointer;
}

.settings-card input:disabled {
  opacity: 0.75;
  cursor: not-allowed;
}

.slider-grid strong {
  color: var(--ink);
  font-weight: 700;
}

.breakup-delay-field {
  display: grid;
  gap: 6px;
  max-width: 360px;
  color: var(--muted);
  font-size: 13px;
}

.breakup-delay-field[hidden] {
  display: none !important;
}

.test-console {
  display: grid;
  gap: 12px;
}

.test-console[hidden] {
  display: none;
}

.test-console .chat {
  min-height: 260px;
  max-height: 420px;
  border: 1px solid var(--line);
  border-radius: 12px;
}

.prompt-bot-test-card .chat {
  min-height: 0;
  max-height: none;
  border-radius: 12px;
}

.test-console .composer {
  border: 1px solid var(--line);
  border-radius: 12px;
}

.test-console .composer label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 13px;
}

.test-console .composer input[type="url"],
.test-console .composer input[type="file"] {
  width: 100%;
  min-height: 40px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 0 10px;
  outline: none;
}

.test-console .composer input[type="url"]:focus,
.test-console .composer input[type="file"]:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.sources-header,
.settings-category {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--panel);
  box-shadow: var(--shadow);
  padding: 16px;
}

.data-table {
  display: grid;
  margin-top: 14px;
  overflow-x: auto;
}

.table-row {
  min-width: 820px;
  display: grid;
  grid-template-columns: 1.2fr 1fr 1.4fr 1.2fr 0.8fr;
  gap: 14px;
  align-items: center;
  border-bottom: 1px solid var(--line);
  padding: 12px;
  color: var(--muted);
}

.source-table .table-row {
  min-width: 1080px;
  grid-template-columns: 1.15fr 0.9fr 1.35fr 0.55fr 1.15fr 0.8fr auto;
}

.table-row strong {
  color: var(--ink);
}

.table-head {
  background: var(--surface-soft);
  color: var(--ink);
  font-size: 12px;
  font-weight: 700;
}

.pill-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 28px;
  border: 1px solid var(--accent);
  border-radius: 999px;
  background: var(--accent-soft);
  color: var(--accent);
  padding: 0 10px;
  font-size: 12px;
}

.standalone-panel {
  height: auto;
  min-height: calc(100vh - 110px);
}

.settings-board {
  max-width: none;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

.settings-card h3 {
  margin: 0;
}

.source-modal {
  width: min(680px, 100%);
}

.flow-builder-modal {
  width: min(1600px, 100%);
  height: min(960px, calc(100vh - 32px));
  max-height: calc(100vh - 32px);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 0;
  overflow: hidden;
}

.flow-builder-shell {
  height: 100%;
  min-height: 0;
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
}

.flow-builder-steps {
  display: grid;
  align-content: start;
  gap: 12px;
  padding: 18px;
  border-right: 1px solid var(--line);
  background:
    radial-gradient(circle at top left, var(--accent-soft), transparent 18rem),
    var(--panel-strong);
}

.flow-builder-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
  color: var(--ink);
}

.flow-builder-brand span {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: var(--button-gradient);
  color: #fff;
  font-weight: 800;
}

.flow-step-pill {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 2px 10px;
  align-items: center;
  min-height: 76px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface);
  color: var(--ink);
  padding: 12px;
  text-align: left;
  cursor: pointer;
}

.flow-step-pill span {
  grid-row: span 2;
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border-radius: 999px;
  background: var(--surface-soft);
  color: var(--accent);
  font-weight: 800;
}

.flow-step-pill strong,
.flow-step-pill small {
  min-width: 0;
  overflow-wrap: anywhere;
}

.flow-step-pill small {
  color: var(--muted);
}

.flow-step-pill.active {
  border-color: var(--accent);
  background: linear-gradient(135deg, var(--accent-soft), var(--surface));
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.flow-builder-content {
  position: relative;
  min-width: 0;
  min-height: 0;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  background: var(--panel);
}

.flow-builder-title {
  padding: 18px;
  border-bottom: 1px solid var(--line);
  align-items: flex-start;
  gap: 16px;
  position: relative;
}

.flow-builder-header-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  flex-wrap: wrap;
  margin-left: auto;
}

.flow-studio-tabs-inline {
  flex-wrap: wrap;
  justify-content: flex-end;
}

.flow-builder-panel {
  min-height: 0;
  display: none;
  align-content: start;
  gap: 16px;
  padding: 18px;
  overflow: auto;
}

.flow-builder-panel.active {
  display: grid;
}

.builder-copy h3,
.builder-copy p {
  margin: 0;
}

.builder-copy h3 {
  font-size: 22px;
}

.builder-copy p {
  margin-top: 6px;
  color: var(--muted);
}

.flow-builder-panel label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 13px;
}

.flow-builder-panel input,
.flow-builder-panel select {
  width: 100%;
  min-height: 44px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 0 12px;
  outline: none;
}

.flow-builder-panel input:focus,
.flow-builder-panel select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.flow-builder-summary {
  min-height: 52px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  color: var(--muted);
  padding: 14px;
}

.flow-source-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.flow-source-grid .connector-card {
  min-height: 150px;
  text-align: left;
  color: var(--ink);
  cursor: pointer;
}

.flow-template-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
  max-height: 228px;
  overflow: auto;
  padding-right: 4px;
}

.flow-template {
  display: grid;
  gap: 6px;
  min-height: 72px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface);
  color: var(--ink);
  padding: 14px;
  text-align: left;
  cursor: pointer;
  align-content: start;
}

.flow-template span {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.4;
}

.flow-template.active {
  border-color: var(--accent);
  background: linear-gradient(135deg, var(--accent-soft), var(--surface));
}

.flow-studio-shell {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 12px;
  min-height: 0;
  height: 100%;
}

.flow-studio-tabs {
  display: flex;
  align-items: center;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 2px;
}

.flow-studio-tabs button {
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface);
  color: var(--muted);
  padding: 0 14px;
  font-weight: 800;
  white-space: nowrap;
  cursor: pointer;
}

.flow-studio-tabs button.active {
  border-color: var(--accent);
  background: var(--accent-soft);
  color: var(--ink);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.flow-studio-panel {
  display: none;
  min-height: 0;
  overflow: auto;
}

.flow-studio-panel.active {
  display: grid;
}

.flow-studio-settings.active {
  grid-template-rows: auto minmax(0, 1fr);
}

.flow-studio-panel[data-flow-studio-panel="builder"].active {
  overflow: hidden;
}

.flow-insights-panel.active {
  grid-template-rows: auto auto minmax(0, 1fr);
}

.flow-insights-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  padding: 18px 22px;
  border-bottom: 1px solid var(--line);
  background: var(--surface);
}

.flow-insights-header strong,
.flow-insights-header small {
  display: block;
}

.flow-insights-header small {
  margin-top: 4px;
  color: var(--muted);
  line-height: 1.35;
}

.flow-studio-settings,
.flow-insights-panel {
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--panel-strong);
  overflow: hidden;
}

.flow-settings-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  align-content: start;
  padding: 16px;
}

#settingsView .settings-category {
  border-radius: 12px;
  box-shadow: none;
}

.flow-settings-grid label {
  min-width: 0;
}

.flow-setting-check {
  display: flex !important;
  grid-template-columns: none !important;
  align-items: center;
  gap: 10px !important;
  min-height: 44px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  padding: 0 12px;
}

.flow-setting-check input {
  width: auto !important;
  min-height: auto !important;
}

.flow-setting-summary {
  display: grid;
  gap: 4px;
  min-height: 82px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  padding: 12px;
}

.flow-setting-summary span,
.flow-setting-summary small {
  color: var(--muted);
  font-size: 12px;
}

.flow-setting-summary strong {
  color: var(--ink);
  font-size: 18px;
}

.flow-insights-filters {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(180px, 240px);
  gap: 10px;
  padding: 14px 22px;
  border-bottom: 1px solid var(--line);
  background: var(--panel);
}

.flow-insights-filters input,
.flow-insights-filters select {
  width: 100%;
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 0 10px;
}

.flow-run-layout {
  display: grid;
  grid-template-columns: minmax(260px, 34%) minmax(0, 1fr);
  min-width: 0;
  min-height: 0;
  height: 100%;
  overflow: hidden;
}

.flow-run-list,
.flow-execution-list {
  display: grid;
  align-content: start;
  gap: 10px;
  min-width: 0;
  min-height: 0;
  overflow: auto;
  padding: 18px 22px;
}

.flow-run-list {
  border-right: 1px solid var(--line);
}

.flow-run-row {
  display: grid;
  grid-template-columns: 12px minmax(0, 1fr);
  gap: 6px 10px;
  align-items: start;
  width: 100%;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  color: var(--ink);
  padding: 12px;
  text-align: left;
  cursor: pointer;
}

.flow-run-row.active {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.flow-run-row strong,
.flow-run-row small,
.flow-run-row em {
  min-width: 0;
  overflow-wrap: anywhere;
}

.flow-run-row em {
  grid-column: 2;
}

.flow-run-row small,
.flow-run-row em {
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
}

.flow-run-current {
  grid-column: 2;
}

.flow-run-detail {
  display: grid;
  align-content: start;
  gap: 14px;
  min-width: 0;
  min-height: 0;
  overflow: auto;
  padding: 20px 24px;
}

.flow-detail-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  min-width: 0;
}

.flow-detail-header strong,
.flow-detail-header small {
  display: block;
}

.flow-detail-header small {
  margin-top: 4px;
  color: var(--muted);
}

.flow-detail-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 8px;
}

.flow-detail-meta {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
  min-width: 0;
}

.flow-detail-meta span {
  display: grid;
  gap: 3px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  color: var(--muted);
  padding: 10px;
  overflow-wrap: anywhere;
}

.flow-detail-meta strong {
  color: var(--ink);
  font-size: 12px;
}

.flow-detail-meta a {
  color: var(--accent);
}

.flow-run-badge {
  grid-column: 2;
  justify-self: start;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface-soft);
  color: var(--muted);
  padding: 4px 8px;
  font-size: 11px;
  font-weight: 800;
  white-space: nowrap;
}

.flow-run-badge.completed {
  border-color: color-mix(in srgb, var(--accent) 50%, var(--line));
  color: var(--accent);
}

.flow-run-badge.completed_with_issues,
.flow-run-badge.error {
  border-color: color-mix(in srgb, var(--danger) 58%, var(--line));
  color: var(--danger);
}

.flow-run-badge.running {
  border-color: #d9a321;
  color: #d9a321;
}

.flow-trace-list,
.flow-external-logs,
.flow-output-preview,
.flow-execution-card {
  display: grid;
  gap: 10px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface);
  padding: 14px 16px;
}

.flow-trace-list > strong,
.flow-external-logs > strong,
.flow-output-preview > strong {
  color: var(--ink);
}

.flow-trace-list ol,
.flow-log-list {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
}

.flow-trace-list li,
.flow-log-row {
  display: grid;
  grid-template-columns: 12px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface-soft);
  padding: 9px 10px;
}

.flow-trace-list li {
  list-style: none;
}

.flow-trace-list small,
.flow-log-row small,
.flow-output-preview p {
  color: var(--muted);
  line-height: 1.4;
  overflow-wrap: anywhere;
}

.flow-log-details {
  margin-top: 8px;
}

.flow-log-details summary {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  width: fit-content;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  color: var(--ink);
  padding: 0 10px;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
  list-style: none;
}

.flow-log-details summary::-webkit-details-marker {
  display: none;
}

.flow-log-details pre {
  max-height: 300px;
  overflow: auto;
  margin: 8px 0 0;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--panel);
  color: var(--ink);
  padding: 10px;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  font-size: 12px;
}

.flow-output-preview p {
  margin: 0;
  white-space: pre-wrap;
}

.flow-status-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--muted);
  margin-top: 4px;
}

.flow-status-dot.completed,
.flow-status-dot.completed_with_issues {
  background: var(--accent);
}

.flow-status-dot.running {
  background: #d9a321;
  box-shadow: 0 0 0 4px rgba(217, 163, 33, 0.16);
}

.flow-status-dot.issue,
.flow-status-dot.error {
  background: var(--danger);
  box-shadow: 0 0 0 4px var(--danger-bg);
}

.flow-status-dot.skipped,
.flow-status-dot.waiting {
  background: color-mix(in srgb, var(--muted) 70%, transparent);
}

.flow-insights-empty {
  border: 1px dashed var(--line);
  border-radius: 10px;
  color: var(--muted);
  padding: 18px;
  text-align: center;
}

@media (max-width: 900px) {
  .flow-settings-grid,
  .flow-insights-filters,
  .flow-run-layout,
  .flow-detail-meta {
    grid-template-columns: 1fr;
  }

  .flow-run-list {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }
}

#flowBuilderModal.editing-flow #flowStepBuild > .builder-copy,
#flowBuilderModal.editing-flow .flow-template-row {
  display: none;
}

.flow-node-builder {
  display: grid;
  grid-template-columns: minmax(140px, var(--flow-rail-size, 20%)) 12px minmax(0, 1fr);
  gap: 0;
  min-height: 0;
  height: 100%;
}

.flow-node-builder.palette-collapsed {
  grid-template-columns: minmax(0, 1fr);
}

.flow-node-builder.palette-collapsed .node-palette,
.flow-node-builder.palette-collapsed .flow-rail-resizer {
  display: none;
}

.flow-node-builder.resizing-rail,
.flow-node-builder.resizing-rail * {
  cursor: col-resize !important;
  user-select: none;
}

.flow-rail-resizer {
  position: relative;
  width: 12px;
  min-width: 12px;
  min-height: 0;
  border: 0;
  background: transparent;
  cursor: col-resize;
  padding: 0;
}

.flow-rail-resizer::before {
  content: "";
  position: absolute;
  top: 14px;
  bottom: 14px;
  left: 50%;
  width: 2px;
  border-radius: 999px;
  background: var(--line);
  transform: translateX(-50%);
  transition: background 160ms ease, box-shadow 160ms ease;
}

.flow-rail-resizer:hover::before,
.flow-rail-resizer:focus-visible::before,
.flow-node-builder.resizing-rail .flow-rail-resizer::before {
  background: var(--accent);
  box-shadow: 0 0 0 4px var(--accent-soft);
}

.node-palette {
  display: grid;
  align-content: start;
  gap: 10px;
  min-height: 0;
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--surface);
  padding: 12px;
}

.node-palette-sections {
  display: grid;
  gap: 10px;
}

.node-palette-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.node-palette-header span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

.node-palette-close {
  width: 30px;
  min-width: 30px;
  min-height: 30px !important;
  display: grid;
  place-items: center;
  border-radius: 999px !important;
  padding: 0 !important;
  font-size: 16px;
  line-height: 1;
}

.node-palette-section {
  display: grid;
  gap: 8px;
  border-bottom: 1px solid var(--line);
  padding-bottom: 10px;
}

.node-palette.has-selected-node > span,
.node-palette.has-selected-node .node-palette-section,
.node-palette.has-selected-node .node-palette-sections,
.node-palette.has-selected-node .flow-canvas-panel-content,
.node-palette:not(.has-selected-node) .selected-node-tools {
  display: none;
}

.node-palette.show-canvas-panel .node-palette-sections,
.node-palette.show-canvas-panel .selected-node-tools {
  display: none;
}

.node-palette.show-canvas-panel .flow-canvas-panel-content {
  display: grid;
}

.node-palette-section strong {
  color: var(--muted);
  font-size: 12px;
  text-transform: uppercase;
}

.node-palette button {
  min-height: 42px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface-soft);
  color: var(--ink);
  cursor: pointer;
}

.node-palette-section button {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  min-width: 0;
  padding: 7px 10px;
  text-align: left;
}

.node-palette button:hover {
  border-color: var(--accent);
  color: var(--accent);
}

.node-option-icon {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  min-width: 28px;
  border-radius: 8px;
  background: var(--button-gradient);
  color: #fff;
}

.node-option-icon svg {
  width: 16px;
  height: 16px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.node-option-label {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 800;
}

.node-option-tooltip {
  position: fixed;
  z-index: 2147483647;
  display: grid;
  gap: 5px;
  width: min(280px, calc(100vw - 24px));
  border: 1px solid color-mix(in srgb, var(--accent) 44%, var(--line));
  border-radius: 10px;
  background: var(--surface);
  color: var(--ink);
  padding: 10px 12px;
  box-shadow: 0 18px 46px rgba(0, 0, 0, 0.34);
  pointer-events: none;
}

.node-option-tooltip[hidden] {
  display: none;
}

.node-option-tooltip strong {
  font-size: 12px;
}

.node-option-tooltip span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.flow-canvas-panel-content {
  display: grid;
  gap: 12px;
}

.flow-canvas-panel-copy {
  display: grid;
  gap: 5px;
  padding: 2px 2px 4px;
}

.flow-canvas-panel-copy strong {
  font-size: 14px;
}

.flow-canvas-panel-copy small,
.flow-canvas-panel-empty {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.flow-canvas-panel-grid {
  display: grid;
  gap: 10px;
}

.flow-canvas-panel-card {
  display: grid;
  gap: 6px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface-soft);
  padding: 12px;
}

.flow-canvas-panel-card strong {
  font-size: 13px;
}

.flow-canvas-panel-card small,
.flow-canvas-panel-card span,
.flow-canvas-panel-card p {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
  margin: 0;
}

.flow-canvas-panel-list {
  display: grid;
  gap: 8px;
}

.flow-canvas-panel-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.flow-canvas-panel-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 34px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface-soft);
  color: var(--ink);
  padding: 0 12px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
}

.flow-canvas-panel-chip:hover,
.flow-canvas-panel-chip:focus-visible {
  border-color: var(--accent);
  color: var(--accent);
}

.flow-canvas-panel-disclosure {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface-soft);
  overflow: hidden;
}

.flow-canvas-panel-disclosure summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px;
  cursor: pointer;
  list-style: none;
  font-size: 13px;
  font-weight: 800;
}

.flow-canvas-panel-disclosure summary::-webkit-details-marker {
  display: none;
}

.flow-canvas-panel-disclosure summary span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.flow-canvas-panel-disclosure summary::after {
  content: "+";
  color: var(--muted);
  font-size: 16px;
  line-height: 1;
}

.flow-canvas-panel-disclosure[open] summary::after {
  content: "-";
}

.flow-canvas-panel-disclosure-body {
  display: grid;
  gap: 10px;
  padding: 0 12px 12px;
  border-top: 1px solid var(--line);
}

.flow-canvas-panel-form {
  display: grid;
  gap: 10px;
}

.flow-canvas-panel-form-grid {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.flow-canvas-panel-form-grid input {
  width: 100%;
  min-width: 0;
}

.flow-canvas-panel-form-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

.flow-canvas-panel-form-actions small,
.flow-canvas-panel-status {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

.flow-canvas-panel-status {
  min-height: 17px;
}

.flow-canvas-panel-kv {
  display: grid;
  gap: 8px;
}

.flow-canvas-panel-kv > div {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}

.flow-canvas-panel-kv dt {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.flow-canvas-panel-kv dd {
  margin: 0;
  color: var(--ink);
  font-size: 12px;
  text-align: right;
}

.flow-canvas-panel-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.flow-canvas-panel-badge {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  border-radius: 999px;
  background: var(--accent-soft);
  color: var(--accent);
  padding: 0 10px;
  font-size: 11px;
  font-weight: 800;
}

.flow-canvas-sidebar {
  position: absolute;
  top: 98px;
  left: 16px;
  z-index: 6;
  display: grid;
  gap: 10px;
  width: 58px;
  padding: 10px 8px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.22);
  backdrop-filter: blur(12px);
}

.flow-canvas-sidebar-button {
  position: relative;
  display: grid;
  place-items: center;
  width: 40px;
  min-width: 40px;
  min-height: 40px !important;
  border: 1px solid transparent !important;
  border-radius: 12px !important;
  background: color-mix(in srgb, var(--surface-soft) 88%, transparent) !important;
  color: var(--muted) !important;
  padding: 0 !important;
  transition: transform 160ms ease, border-color 160ms ease, background 160ms ease, color 160ms ease, box-shadow 160ms ease;
}

.flow-canvas-sidebar-button::before {
  content: "";
  width: 18px;
  height: 18px;
  background: currentColor;
  -webkit-mask: var(--flow-canvas-sidebar-icon) center / contain no-repeat;
  mask: var(--flow-canvas-sidebar-icon) center / contain no-repeat;
}

.flow-canvas-sidebar-button:hover,
.flow-canvas-sidebar-button:focus-visible,
.flow-canvas-sidebar-button.active {
  border-color: color-mix(in srgb, var(--accent) 45%, var(--line)) !important;
  background: color-mix(in srgb, var(--accent) 16%, var(--surface)) !important;
  color: var(--accent) !important;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.14);
  transform: translateX(1px);
}

.flow-canvas-sidebar-button[data-flow-canvas-tab="add"] {
  --flow-canvas-sidebar-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M11 5h2v6h6v2h-6v6h-2v-6H5v-2h6z'/%3E%3C/svg%3E");
}

.flow-canvas-sidebar-button[data-flow-canvas-tab="custom_tools"] {
  --flow-canvas-sidebar-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='m14.7 6.3 3 3-8.4 8.4-3.6.6.6-3.6zM16.1 4.9l1.4-1.4a2 2 0 0 1 2.8 0l.2.2a2 2 0 0 1 0 2.8l-1.4 1.4zM3 20h18v2H3z'/%3E%3C/svg%3E");
}

.flow-canvas-sidebar-button[data-flow-canvas-tab="job_information"] {
  --flow-canvas-sidebar-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 3h6l1 2h4v14H4V5h4zm0 4v2h6V7zm0 4v2h6v-2zm0 4v2h4v-2z'/%3E%3C/svg%3E");
}

.flow-canvas-sidebar-button[data-flow-canvas-tab="personas"] {
  --flow-canvas-sidebar-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 3a5 5 0 0 1 5 5v1h1a2 2 0 0 1 2 2v6a4 4 0 0 1-4 4H8a4 4 0 0 1-4-4v-6a2 2 0 0 1 2-2h1V8a5 5 0 0 1 5-5m-3 6h6V8a3 3 0 0 0-6 0zm1 4v2h4v-2z'/%3E%3C/svg%3E");
}

.flow-canvas-sidebar-button[data-flow-canvas-tab="followups"] {
  --flow-canvas-sidebar-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 2a10 10 0 1 1-7.1 2.9L7 7H2V2l1.5 1.5A12 12 0 1 0 12 0zm-1 5h2v6l5 2-.7 1.9-6.3-2.4z'/%3E%3C/svg%3E");
}

.flow-canvas-sidebar-button[data-flow-canvas-tab="settings"] {
  --flow-canvas-sidebar-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='m12 2 1.3 2.7 3 .4.7 2.9 2.5 1.7-1 2.8 1 2.8-2.5 1.7-.7 2.9-3 .4L12 22l-1.3-2.7-3-.4-.7-2.9L4.5 14l1-2.8-1-2.8L7 6.7l.7-2.9 3-.4zm0 6a4 4 0 1 0 0 8 4 4 0 0 0 0-8'/%3E%3C/svg%3E");
}

.flow-canvas-sidebar-button[data-flow-canvas-tab="sources"] {
  --flow-canvas-sidebar-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 3c4.4 0 8 1.3 8 3s-3.6 3-8 3-8-1.3-8-3 3.6-3 8-3m-8 6c0 1.7 3.6 3 8 3s8-1.3 8-3v4c0 1.7-3.6 3-8 3s-8-1.3-8-3zm0 7c0 1.7 3.6 3 8 3s8-1.3 8-3v2c0 1.7-3.6 3-8 3s-8-1.3-8-3z'/%3E%3C/svg%3E");
}

.flow-canvas-sidebar-button[data-flow-canvas-tab="custom_fields"] {
  --flow-canvas-sidebar-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M5 4h14v4H5zm0 6h8v4H5zm0 6h14v4H5zm10-6h4v4h-4z'/%3E%3C/svg%3E");
}

.node-board {
  position: relative;
  min-width: 0;
  min-height: 0;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  border: 1px solid var(--line);
  border-radius: 14px;
  background:
    radial-gradient(circle, rgba(156, 175, 159, 0.12) 1px, transparent 1px),
    var(--panel-strong);
  background-size: 14px 14px;
  overflow: hidden;
}

.node-board-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 14px;
  border-bottom: 1px solid var(--line);
  background: var(--surface);
}

.node-board-header > div:first-child {
  display: grid;
  justify-items: start;
  gap: 6px;
}

.node-board-header span {
  color: var(--muted);
  font-size: 13px;
}

.node-board-header strong,
.node-board-header small {
  display: block;
}

.node-board-header small {
  margin-top: 3px;
  color: var(--muted);
}

.node-board-tools {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.node-board-tools .refresh {
  min-height: 32px;
}

.palette-toggle-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-width: 136px;
  min-height: 42px;
  margin-top: 6px;
  border-color: color-mix(in srgb, var(--accent) 65%, var(--line));
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 82%, #032414), #075f36);
  color: #fff;
  padding: 0 16px;
  font-size: 15px;
  font-weight: 800;
  box-shadow: 0 10px 28px rgba(0, 110, 63, 0.28);
}

#flowPaletteToggle[hidden] {
  display: none !important;
}

.palette-toggle-button > span:first-child {
  display: grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.16);
  font-size: 20px;
  line-height: 1;
}

.palette-toggle-button:hover,
.palette-toggle-button:focus-visible {
  border-color: var(--accent);
  filter: brightness(1.08);
}

.node-board-tools .history-button {
  min-width: 58px;
}

.node-board-tools .refresh:disabled {
  opacity: 0.45;
  cursor: default;
}

.node-board-tools strong {
  min-width: 48px;
  color: var(--ink);
  font-size: 13px;
  text-align: center;
}

.flow-test-button {
  display: inline-flex;
  align-items: center;
  gap: 7px;
}

.flow-test-icon {
  position: relative;
  width: 14px;
  height: 18px;
  display: inline-block;
  border-top: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
}

.flow-test-icon::before,
.flow-test-icon::after {
  content: "";
  position: absolute;
  left: 3px;
  width: 0;
  height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
}

.flow-test-icon::before {
  top: 2px;
  border-top: 6px solid currentColor;
}

.flow-test-icon::after {
  bottom: 2px;
  border-bottom: 6px solid currentColor;
}

.flow-canvas-viewport {
  position: relative;
  min-height: 0;
  overflow: auto;
  cursor: grab;
  overscroll-behavior: contain;
  touch-action: none;
  user-select: none;
  padding-left: 92px;
}

.flow-canvas-viewport.panning {
  cursor: grabbing;
}

.flow-node-list {
  position: relative;
  min-width: 100%;
  min-height: 100%;
  user-select: none;
}

.flow-test-panel {
  position: absolute;
  right: 24px;
  bottom: 24px;
  z-index: 8;
  width: min(460px, calc(100% - 48px));
  max-height: calc(100% - 48px);
  display: grid;
  grid-template-rows: auto minmax(180px, 1fr) auto;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--surface);
  box-shadow: 0 22px 70px rgba(0, 0, 0, 0.38);
  overflow: hidden;
}

.flow-test-panel[hidden] {
  display: none;
}

.flow-test-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid var(--line);
  padding: 14px;
}

.flow-test-header strong,
.flow-test-header small {
  display: block;
}

.flow-test-header small {
  margin-top: 3px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.flow-test-toolbar {
  display: grid;
  gap: 10px;
  padding: 12px 14px 0;
}

.flow-test-toolbar-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.flow-test-toggle {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 12px;
  padding: 10px 14px 0;
}

.flow-test-toggle span,
.flow-test-toggle small {
  display: block;
}

.flow-test-toggle small {
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.flow-test-contact-meta {
  padding: 0 14px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

.flow-test-messages {
  display: flex;
  flex-direction: column;
  gap: 10px;
  overflow: auto;
  padding: 14px;
}

.flow-test-empty {
  border: 1px dashed var(--line);
  border-radius: 10px;
  color: var(--muted);
  padding: 14px;
  text-align: center;
}

.flow-test-message {
  display: grid;
  gap: 6px;
  max-width: 92%;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 10px 12px;
}

.flow-test-message.customer {
  align-self: flex-end;
  background: var(--accent-soft);
}

.flow-test-message.bot {
  align-self: flex-start;
  background: var(--surface-soft);
}

.flow-test-message strong {
  color: var(--ink);
  font-size: 12px;
}

.flow-test-message p {
  margin: 0;
  color: var(--ink);
  font-size: 13px;
  line-height: 1.45;
  white-space: pre-wrap;
}

.flow-test-trace {
  border-top: 1px solid var(--line);
  color: var(--muted);
  padding-top: 7px;
}

.flow-test-trace summary {
  cursor: pointer;
  font-size: 12px;
}

.flow-test-current-step {
  margin-top: 8px;
  font-size: 12px;
  font-weight: 700;
  color: var(--text);
}

.flow-test-trace ol {
  display: grid;
  gap: 5px;
  margin: 8px 0 0;
  padding-left: 18px;
  font-size: 12px;
  line-height: 1.35;
}

.flow-test-result-block {
  display: grid;
  gap: 6px;
  margin-top: 10px;
}

.flow-test-result-block pre {
  margin: 0;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  font-size: 11px;
  line-height: 1.4;
  white-space: pre-wrap;
  word-break: break-word;
}

.flow-test-form {
  display: grid;
  gap: 10px;
  border-top: 1px solid var(--line);
  padding: 12px;
}

.flow-test-form textarea {
  width: 100%;
  min-height: 76px;
  resize: vertical;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--field);
  color: var(--ink);
  padding: 10px;
}

.flow-test-uploads {
  display: grid;
  gap: 6px;
  padding: 0 4px;
}

.flow-test-upload-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 6px 8px;
  color: var(--muted);
  font-size: 12px;
}

.flow-test-upload-item span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.flow-test-media-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(96px, 1fr));
  gap: 8px;
}

.flow-test-attached-image {
  width: 100%;
  border-radius: 8px;
  border: 1px solid var(--line);
}

.flow-test-audio-list {
  display: grid;
  gap: 6px;
}

.flow-test-audio-list audio {
  width: 100%;
}

.builder-node {
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr);
  align-items: center;
  gap: 16px;
  border: 1px solid color-mix(in srgb, var(--line) 88%, #ffffff 12%);
  border-radius: 16px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 90%, #ffffff 10%), color-mix(in srgb, var(--surface) 96%, #0b1020 4%)),
    linear-gradient(135deg, color-mix(in srgb, var(--accent) 8%, transparent), transparent 54%);
  padding: 18px 18px;
  box-sizing: border-box;
  backdrop-filter: blur(8px);
}

.flow-canvas-node {
  position: absolute;
  z-index: 2;
  width: 280px;
  height: 128px;
  min-height: 128px;
  overflow: visible;
  cursor: grab;
  box-shadow: 0 20px 42px rgba(0, 0, 0, 0.2);
  transition: transform 140ms ease, box-shadow 140ms ease, border-color 140ms ease;
}

.flow-canvas-node > div {
  min-width: 0;
  overflow: visible;
}

.flow-canvas-node.selected {
  border-color: var(--accent);
  box-shadow:
    0 0 0 3px var(--accent-soft),
    0 24px 48px rgba(0, 0, 0, 0.28);
}

.flow-canvas-node.connecting-source {
  border-color: var(--accent);
  box-shadow:
    0 0 0 4px color-mix(in srgb, var(--accent) 22%, transparent),
    0 22px 52px rgba(0, 0, 0, 0.3);
}

.flow-canvas-node.connectable-target {
  border-color: color-mix(in srgb, var(--accent) 52%, var(--line));
}

.flow-canvas-node.test-active {
  border-color: var(--accent);
  box-shadow:
    0 0 0 4px color-mix(in srgb, var(--accent) 28%, transparent),
    0 0 34px color-mix(in srgb, var(--accent) 54%, transparent),
    0 22px 54px rgba(0, 0, 0, 0.34);
  animation: nodeTestGlow 1.15s ease-in-out infinite;
}

.flow-canvas-node.test-active .builder-node-icon {
  box-shadow: 0 0 0 5px color-mix(in srgb, var(--accent) 18%, transparent);
}

.node-test-badge {
  position: absolute;
  right: 12px;
  bottom: -13px;
  z-index: 3;
  border: 1px solid color-mix(in srgb, var(--accent) 70%, var(--line));
  border-radius: 999px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 78%, #032414), #064f30);
  color: #fff;
  padding: 4px 9px;
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.24);
  pointer-events: none;
}

@keyframes nodeTestGlow {
  0%,
  100% {
    filter: brightness(1);
  }
  50% {
    filter: brightness(1.08);
  }
}

.flow-canvas-node:active {
  cursor: grabbing;
}

.flow-canvas-node:hover {
  transform: translateY(-2px);
  box-shadow: 0 24px 46px rgba(0, 0, 0, 0.24);
}

.builder-node.locked {
  border-style: dashed;
  cursor: default;
}

.builder-node-icon {
  display: grid;
  place-items: center;
  width: 58px;
  height: 58px;
  border-radius: 999px;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,0.28), transparent 48%),
    var(--button-gradient);
  color: #fff;
  font-size: 14px;
  font-weight: 800;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.18),
    0 12px 24px rgba(0, 0, 0, 0.18);
}

.builder-node-icon svg {
  width: 30px;
  height: 30px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.builder-node strong,
.builder-node p {
  margin: 0;
  overflow-wrap: anywhere;
}

.builder-node strong {
  display: -webkit-box;
  max-width: 100%;
  overflow: hidden;
  color: var(--ink);
  font-size: 15px;
  line-height: 1.3;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.node-content {
  min-width: 0;
  display: grid;
  align-content: center;
  gap: 6px;
}

.node-content::after {
  content: "";
  width: 56px;
  height: 4px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 26%, transparent);
}

.builder-node p {
  display: none;
  margin-top: 4px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.4;
}

.node-tool-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 9px;
}

.node-tool-chip {
  max-width: 138px;
  border: 1px solid color-mix(in srgb, var(--accent) 42%, var(--line));
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color: var(--ink);
  padding: 3px 7px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 11px;
  font-weight: 800;
}

.node-tool-chip.muted {
  color: var(--muted);
}

.node-inline-actions {
  display: flex;
  position: absolute;
  top: 8px;
  right: 8px;
  z-index: 5;
  gap: 6px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 160ms ease;
}

.flow-canvas-node.selected .node-inline-actions {
  opacity: 1;
  pointer-events: auto;
}

.node-remove,
.node-duplicate {
  width: 30px;
  height: 30px;
  min-height: 30px;
  display: grid;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--danger) 40%, var(--line));
  border-radius: 8px;
  background: var(--danger-bg);
  color: var(--danger);
  padding: 0;
  cursor: pointer;
  transition: transform 160ms ease;
}

.node-duplicate {
  border-color: color-mix(in srgb, var(--accent) 42%, var(--line));
  background: color-mix(in srgb, var(--accent) 12%, var(--surface));
  color: var(--accent);
}

.node-remove svg,
.node-duplicate svg {
  width: 15px;
  height: 15px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.node-remove svg path {
  fill: currentColor;
  stroke: none;
}

.node-remove:hover:not(:disabled),
.node-duplicate:hover:not(:disabled) {
  transform: translateY(-1px);
}

.node-remove:hover:not(:disabled) {
  border-color: var(--danger);
  color: var(--danger);
}

.node-duplicate:hover:not(:disabled) {
  border-color: var(--accent);
  color: var(--accent);
}

.node-remove:disabled,
.node-duplicate:disabled {
  opacity: 0.55;
  cursor: default;
}

.node-resize-handle {
  display: none;
}

.node-port {
  position: absolute;
  top: 50%;
  z-index: 10;
  width: 20px;
  height: 20px;
  min-height: 20px;
  display: grid;
  place-items: center;
  border: 2px solid var(--accent);
  border-radius: 999px;
  background: var(--panel);
  color: #fff;
  padding: 0;
  cursor: crosshair;
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  transform: translateY(-50%);
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.24);
  transition:
    transform 160ms ease,
    box-shadow 160ms ease,
    background 160ms ease,
    border-color 160ms ease;
}

.node-port.input {
  left: -11px;
}

.node-port.input::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: currentColor;
  color: var(--accent);
}

.node-port.output {
  right: -11px;
  background: var(--button-gradient);
}

.node-port:hover:not(:disabled),
.flow-canvas-node.connecting-source .node-port.output,
.flow-canvas-node.connectable-target .node-port.input {
  transform: translateY(-50%) scale(1.12);
  box-shadow:
    0 0 0 5px color-mix(in srgb, var(--accent) 20%, transparent),
    0 12px 22px rgba(0, 0, 0, 0.3);
}

.node-port:disabled {
  opacity: 0.36;
  cursor: not-allowed;
  box-shadow: none;
}

.flow-connector-layer {
  position: absolute;
  inset: 0;
  z-index: 1;
  color: color-mix(in srgb, var(--accent) 70%, var(--line));
  pointer-events: auto;
}

.flow-edge-path {
  pointer-events: none;
  transition: stroke-width 160ms ease, color 160ms ease;
}

.flow-preview-layer {
  z-index: 1;
  color: var(--accent);
  pointer-events: none;
}

.flow-preview-path {
  stroke-dasharray: 8 8;
  animation: flow-preview-dash 1s linear infinite;
}

@keyframes flow-preview-dash {
  to {
    stroke-dashoffset: -16;
  }
}

.flow-edge-hitbox {
  cursor: pointer;
  pointer-events: all;
}

.flow-edge-path:hover,
.flow-edge-path.selected {
  stroke-width: 4;
  color: var(--accent);
}

.edge-remove,
.edge-handle {
  position: absolute;
  z-index: 4;
  transform: translate(-50%, -50%);
}

.edge-remove {
  z-index: 6;
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--danger) 40%, var(--line));
  border-radius: 8px;
  background: var(--danger-bg);
  color: var(--danger);
  padding: 0;
  cursor: pointer;
}

.edge-remove svg {
  width: 15px;
  height: 15px;
  fill: currentColor;
}

.edge-handle {
  z-index: 5;
  width: 16px;
  height: 16px;
  border: 2px solid var(--accent);
  border-radius: 999px;
  background: var(--panel);
  cursor: grab;
}

.edge-handle:active {
  cursor: grabbing;
}

.flow-minimap {
  position: sticky;
  left: 16px;
  bottom: 16px;
  z-index: 3;
  width: 140px;
  height: 90px;
  margin: 0 0 16px 16px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background:
    radial-gradient(circle, color-mix(in srgb, var(--accent) 42%, transparent) 2px, transparent 3px),
    var(--surface);
  background-size: 36px 24px;
  opacity: 0.86;
  pointer-events: none;
}

.flow-minimap span {
  position: absolute;
  width: 18px;
  height: 10px;
  border-radius: 3px;
  background: var(--accent);
}

.flow-minimap span:first-child {
  left: 40px;
  top: 36px;
}

.flow-minimap span:last-child {
  right: 36px;
  top: 42px;
}

.selected-node-tools {
  display: grid;
  gap: 10px;
  margin-top: 8px;
  border-top: 1px solid var(--line);
  padding-top: 12px;
}

#flowBuilderModal.build-mode .selected-node-tools {
  order: -1;
  margin-top: 0;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--panel-strong);
  padding: 12px;
}

.selected-node-tools > span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

.selected-node-tools strong {
  overflow-wrap: anywhere;
}

.selected-node-tools label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 12px;
}

.selected-node-tools input,
.selected-node-tools textarea,
.selected-node-tools select {
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 9px;
}

.selected-node-tools textarea {
  min-height: 78px;
}

.selected-node-config {
  display: grid;
  gap: 9px;
  max-height: 430px;
  overflow-y: auto;
  overflow-x: hidden;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: color-mix(in srgb, var(--surface) 88%, transparent);
  padding: 10px;
}

.node-config-header {
  display: grid;
  gap: 3px;
  border-bottom: 1px solid var(--line);
  padding-bottom: 8px;
}

.node-config-header small,
.node-config-empty {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

.node-setting-section {
  display: grid;
  gap: 3px;
  margin-top: 4px;
  border-top: 1px solid var(--line);
  padding-top: 10px;
}

.node-setting-section:first-of-type {
  margin-top: 0;
}

.node-setting-section strong {
  color: var(--ink);
  font-size: 13px;
}

.node-setting-section small {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

.node-action-button {
  min-height: 38px;
  border: 1px solid color-mix(in srgb, var(--accent) 46%, var(--line));
  border-radius: 10px;
  background: color-mix(in srgb, var(--accent) 14%, var(--surface));
  color: var(--ink);
  cursor: pointer;
  font-weight: 800;
}

.node-action-button:hover {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 24%, var(--surface));
}

.node-segmented-options {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
}

.node-segmented-option {
  min-height: 36px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface-soft);
  color: var(--ink);
  padding: 7px 9px;
  cursor: pointer;
  font-size: 12px;
  font-weight: 800;
}

.node-segmented-option.active {
  border-color: color-mix(in srgb, var(--accent) 65%, var(--line));
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 30%, var(--surface)), color-mix(in srgb, var(--accent) 14%, var(--surface-soft)));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 35%, transparent);
}

.node-setting-field.checkbox-field {
  display: flex;
  align-items: center;
  gap: 8px;
}

.node-setting-field.checkbox-field input {
  width: auto;
  min-height: auto;
}

.node-setting-objectives {
  display: grid;
  gap: 8px;
}

.node-setting-caption {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.node-objective-list {
  display: grid;
  gap: 8px;
}

.objective-row-card {
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: color-mix(in srgb, var(--surface-soft) 70%, transparent);
  padding: 8px;
}

.objective-row-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.objective-row-actions {
  display: flex;
  align-items: center;
  gap: 6px;
}

.objective-row-header strong {
  color: var(--ink);
  font-size: 13px;
}

.objective-refine-button {
  min-height: 30px;
  padding: 5px 9px;
  font-size: 11px;
}

.objective-row-field textarea {
  min-height: 58px;
}

.objective-answer-examples {
  display: grid;
  gap: 6px;
}

.objective-answer-examples-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  color: var(--ink);
  font-size: 12px;
  font-weight: 700;
}

.objective-answer-example-field input {
  min-height: 34px;
}

.objective-row-check {
  display: flex !important;
  grid-template-columns: none !important;
  align-items: center;
  justify-content: flex-start;
  gap: 8px !important;
  min-height: 28px;
}

.objective-row-check input {
  width: 14px !important;
  height: 14px !important;
  min-height: 14px !important;
  flex: 0 0 14px;
  margin: 0;
}

.agent-config-shell {
  display: grid;
  gap: 12px;
}

.agent-preset-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.agent-preset-card {
  display: grid;
  gap: 4px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface-soft);
  color: var(--ink);
  padding: 10px;
  text-align: left;
}

.agent-preset-card strong {
  font-size: 13px;
}

.agent-preset-card span,
.agent-panel-copy small,
.agent-reference-empty,
.agent-reference-chip span,
.agent-tool-card small {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

.agent-preset-card.active {
  border-color: color-mix(in srgb, var(--accent) 60%, var(--line));
  background: color-mix(in srgb, var(--accent) 14%, var(--surface));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 24%, transparent);
}

.agent-tab-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.agent-tab-button {
  min-height: 36px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface-soft);
  color: var(--ink);
  padding: 0 12px;
  font-size: 12px;
  font-weight: 800;
}

.agent-tab-button.active {
  border-color: color-mix(in srgb, var(--accent) 65%, var(--line));
  background: color-mix(in srgb, var(--accent) 18%, var(--surface));
}

.agent-panel,
.agent-tool-list,
.agent-section-list,
.agent-reference-drawer,
.agent-reference-list,
.agent-panel-copy,
.agent-reference-group,
.agent-reference-group-header,
.agent-section-card,
.agent-section-card-header {
  display: grid;
  gap: 10px;
}

.agent-panel {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: color-mix(in srgb, var(--surface-soft) 86%, transparent);
  min-width: 0;
  padding: 12px;
}

.agent-panel-copy strong,
.agent-reference-group-header strong,
.agent-section-card-header strong,
.agent-tool-card strong {
  color: var(--ink);
}

.agent-reference-group {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  padding: 10px;
}

.agent-reference-group-header {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
}

.agent-reference-toggle {
  min-height: 32px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface-soft);
  color: var(--ink);
  padding: 0 12px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
}

.agent-reference-toggle:hover {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 10%, var(--surface));
}

.agent-reference-drawer[hidden] {
  display: none;
}

.agent-reference-drawer {
  max-height: 240px;
  overflow-y: auto;
  padding-right: 4px;
}

.agent-reference-list {
  grid-template-columns: minmax(0, 1fr);
}

.agent-reference-chip {
  display: grid;
  gap: 3px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface-soft);
  color: var(--ink);
  padding: 8px 10px;
  text-align: left;
}

.agent-reference-chip strong {
  font-size: 12px;
  overflow-wrap: anywhere;
}

.agent-reference-chip:hover,
.agent-tool-card:hover,
.agent-preset-card:hover {
  border-color: var(--accent);
}

.agent-reference-chip:disabled {
  cursor: not-allowed;
  opacity: 0.6;
}

.agent-section-card {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  padding: 10px;
}

.agent-section-card-header {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.agent-section-body {
  min-height: 110px;
  resize: vertical;
}

.agent-section-card .node-setting-field {
  position: relative;
}

.agent-mention-menu {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 6px);
  z-index: 30;
  display: grid;
  gap: 6px;
  max-height: 220px;
  overflow-y: auto;
  border: 1px solid color-mix(in srgb, var(--accent) 38%, var(--line));
  border-radius: 10px;
  background: var(--surface);
  padding: 8px;
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.28);
}

.agent-mention-menu[hidden] {
  display: none;
}

.agent-mention-option {
  display: grid;
  gap: 3px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-soft);
  color: var(--ink);
  padding: 8px 10px;
  text-align: left;
}

.agent-mention-option strong {
  font-size: 12px;
  overflow-wrap: anywhere;
}

.agent-mention-option span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.agent-mention-option.active,
.agent-mention-option:hover {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 14%, var(--surface));
}

.agent-mention-option:disabled {
  cursor: not-allowed;
  opacity: 0.6;
}

.agent-tool-card {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  min-width: 0;
  padding: 10px;
}

.agent-tool-card-top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: start;
}

@media (max-width: 720px) {
  .agent-preset-grid,
  .agent-reference-list {
    grid-template-columns: 1fr;
  }
}

.selected-node-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.selected-node-actions .refresh {
  min-width: 0;
  padding: 0 8px;
}

.flow-builder-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 16px 18px;
  border-top: 1px solid var(--line);
  background: var(--surface);
}

.flow-builder-footer > div {
  display: flex;
  gap: 10px;
}

.flow-builder-footer .send,
.flow-builder-footer .refresh {
  width: auto;
}

#flowBuilderModal.build-mode .flow-builder-modal {
  width: 100%;
  height: 100%;
  max-height: 100%;
  border: 1px solid var(--line);
  border-radius: 16px;
}

#flowBuilderModal.build-mode .flow-builder-shell {
  grid-template-columns: minmax(0, 1fr);
}

#flowBuilderModal.build-mode .flow-builder-steps,
#flowBuilderModal.build-mode #flowStepBuild > .builder-copy,
#flowBuilderModal.build-mode .flow-template-row,
#flowBuilderModal.build-mode #flowBuilderCancel {
  display: none;
}

#flowBuilderModal.build-mode .flow-builder-content {
  grid-template-rows: auto minmax(0, 1fr);
  height: 100%;
  min-height: 0;
}

#flowBuilderModal.build-mode .flow-builder-title {
  min-height: 58px;
  padding: 10px 16px;
  align-items: center;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 12px;
}

#flowBuilderModal.build-mode .flow-builder-title .eyebrow {
  display: none;
}

#flowBuilderModal.build-mode .flow-builder-title h2 {
  font-size: 17px;
}

#flowBuilderModal.build-mode .flow-builder-title > div:first-child {
  grid-column: 1;
  position: relative;
  z-index: 2;
}

#flowBuilderModal.build-mode .flow-builder-header-actions {
  display: contents;
}

#flowBuilderModal.build-mode .flow-studio-shell {
  gap: 0;
}

#flowBuilderModal.build-mode .flow-studio-tabs-inline {
  grid-column: 2;
  justify-self: center;
  align-self: center;
  min-height: auto;
  border-bottom: 0;
  background: transparent;
  padding: 0;
  width: fit-content;
  max-width: calc(100% - 320px);
  overflow: visible;
}

#flowBuilderModal.build-mode .flow-studio-tabs-inline button {
  min-height: 34px;
  padding: 0 12px;
}

#flowBuilderModal.build-mode #closeFlowBuilder {
  grid-column: 3;
  justify-self: end;
  position: relative;
  z-index: 2;
}

#flowBuilderModal.build-mode .flow-studio-panel {
  min-height: 0;
}

#flowBuilderModal.build-mode .flow-studio-settings,
#flowBuilderModal.build-mode .flow-insights-panel {
  border: 0;
  border-radius: 0;
}

#flowBuilderModal.build-mode .flow-run-layout {
  min-height: 0;
}

#flowBuilderModal.build-mode #flowStepBuild.flow-builder-panel.active {
  display: grid;
  grid-template-rows: minmax(0, 1fr);
  align-content: stretch;
  gap: 0;
  padding: 0;
  overflow: hidden;
  height: calc(100% - 58px);
  min-height: 0;
}

#flowBuilderModal.build-mode .flow-node-builder {
  position: relative;
  grid-template-columns: minmax(0, 1fr);
  gap: 0;
  height: 100%;
  min-height: 0;
  overflow: hidden;
  isolation: isolate;
}

#flowBuilderModal.build-mode .flow-node-builder.palette-collapsed {
  grid-template-columns: minmax(0, 1fr);
}

#flowBuilderModal.build-mode .flow-rail-resizer {
  position: absolute;
  top: 0;
  bottom: 0;
  left: calc(clamp(280px, var(--flow-rail-size, 20%), 420px) - 6px);
  z-index: 11;
  background: transparent;
  border-right: 0;
}

#flowBuilderModal.build-mode .node-palette {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  z-index: 10;
  width: clamp(280px, var(--flow-rail-size, 20%), 420px);
  max-width: min(420px, calc(100% - 96px));
  border-width: 0 1px 0 0;
  border-radius: 0 0 14px 0;
  box-shadow: 18px 0 42px rgba(0, 0, 0, 0.18);
  padding: 12px;
  animation: flowNodePanelSlideIn 180ms ease;
}

#flowBuilderModal.build-mode .node-board {
  border: 0;
  border-radius: 0 0 16px 16px;
  height: 100%;
  min-height: 0;
}

@keyframes flowNodePanelSlideIn {
  from {
    opacity: 0;
    transform: translateX(-18px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

#flowBuilderModal.build-mode .node-board-header {
  min-height: 52px;
  padding: 10px 18px;
}

#flowBuilderModal.build-mode .flow-builder-footer {
  position: absolute;
  top: 12px;
  right: 74px;
  z-index: 12;
  padding: 0;
  border: 0;
  background: transparent;
}

#flowBuilderModal.build-mode .flow-builder-footer > div {
  align-items: center;
  gap: 8px;
}

#flowBuilderModal.build-mode .flow-builder-footer .send,
#flowBuilderModal.build-mode .flow-builder-footer .refresh {
  min-height: 36px;
  padding: 0 14px;
}

.source-type-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 16px;
}

.source-type-grid .connector-card {
  text-align: left;
  color: var(--ink);
  cursor: pointer;
}

.source-edit-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 16px;
}

.source-edit-form label {
  min-width: 0;
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 13px;
}

.source-edit-form input,
.source-edit-form select {
  width: 100%;
  min-height: 40px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 0 10px;
  outline: none;
}

.source-edit-form input:focus,
.source-edit-form select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.source-builder-modal {
  width: min(1280px, calc(100vw - 48px));
  max-height: calc(100vh - 48px);
  overflow: auto;
  display: grid;
  gap: 14px;
}

.source-builder-modal input,
.source-builder-modal textarea,
.source-builder-modal select {
  margin-top: 0;
}

.source-builder-modal input[type="checkbox"],
.source-builder-modal input[type="radio"] {
  width: auto;
  min-height: auto;
  margin: 0;
}

.source-builder-modal textarea,
.source-builder-modal select,
.source-builder-modal input[type="time"],
.source-builder-modal input[type="number"],
.source-builder-modal input[type="color"] {
  width: 100%;
  min-width: 0;
  min-height: 40px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 0 10px;
  outline: none;
  font: inherit;
}

.source-builder-modal textarea {
  min-height: 96px;
  padding: 10px;
}

.source-editor-layout {
  min-height: min(620px, calc(100vh - 360px));
  display: grid;
  grid-template-columns: minmax(190px, 240px) minmax(0, 1fr);
  border: 1px solid var(--line);
  border-radius: 14px;
  overflow: hidden;
  background: var(--surface);
}

.source-editor-sidebar {
  display: grid;
  align-content: start;
  gap: 6px;
  border-right: 1px solid var(--line);
  background: var(--panel-strong);
  padding: 14px;
}

.source-editor-sidebar h3 {
  margin: 12px 0 4px;
  color: var(--ink);
  font-size: 13px;
}

.modal-backdrop[data-source-type="openai"] .source-editor-sidebar h3:not(:first-of-type),
.modal-backdrop[data-source-type="openai"] .source-editor-sidebar .source-tab-button[data-source-editor-tab="settings"],
.modal-backdrop[data-source-type="openai"] .source-editor-sidebar .source-tab-button[data-source-editor-tab="access"],
.modal-backdrop[data-source-type="openai"] .source-editor-sidebar .source-tab-button[data-source-editor-tab="variables"],
.modal-backdrop[data-source-type="openai"] .source-editor-sidebar .source-tab-button[data-source-editor-tab="reply"],
.modal-backdrop[data-source-type="openai"] .source-editor-sidebar .source-tab-button[data-source-editor-tab="followup"],
.modal-backdrop[data-source-type="openai"] .source-editor-sidebar .source-tab-button[data-source-editor-tab="widgets"],
.modal-backdrop[data-source-type="openai"] .source-editor-sidebar .source-tab-button[data-source-editor-tab="webhook"] {
  display: none !important;
}

.source-back-button,
.source-tab-button {
  min-height: 36px;
  border: 1px solid transparent;
  border-radius: 8px;
  background: transparent;
  color: var(--muted);
  text-align: left;
  padding: 0 10px;
  cursor: pointer;
}

.source-back-button {
  color: var(--accent);
}

.source-tab-button.active {
  border-color: color-mix(in srgb, var(--accent) 40%, var(--line));
  background: var(--accent-soft);
  color: var(--accent);
}

.source-tab-button.danger-link {
  margin-top: 12px;
  color: var(--danger);
}

.source-editor-main {
  min-width: 0;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
}

.source-editor-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid var(--line);
  padding: 14px 16px;
}

.source-editor-summary div {
  min-width: 0;
  display: grid;
  gap: 4px;
}

.source-editor-summary strong,
.source-editor-summary span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.source-editor-summary span {
  color: var(--muted);
  font-size: 12px;
}

#sourceEditorContent {
  min-width: 0;
  overflow: auto;
  padding: 18px;
}

.source-pane {
  display: grid;
  gap: 14px;
}

.source-pane h2,
.source-pane h3 {
  margin: 0;
}

.source-settings-card {
  display: grid;
  gap: 14px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface-soft);
  padding: 16px;
}

.source-settings-card label {
  display: grid;
  gap: 6px;
  min-width: 0;
  color: var(--muted);
  font-size: 13px;
}

.source-settings-card label > span,
.source-settings-card legend {
  color: var(--muted);
  font-size: 12px;
  text-transform: uppercase;
}

.source-settings-card input[type="text"],
.source-settings-card input[type="url"],
.source-settings-card input:not([type]),
.source-settings-card textarea,
.source-settings-card select {
  width: 100%;
}

.source-card-header,
.source-section-title,
.source-inline-action {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.source-card-header {
  align-items: flex-start;
}

.source-card-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.source-code-block {
  display: block;
  overflow-x: auto;
  white-space: pre-wrap;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--code-bg);
  color: var(--code-ink);
  padding: 12px;
  font-size: 12px;
  line-height: 1.5;
}

.pill-status.warning {
  border-color: color-mix(in srgb, #f5b642 50%, var(--line));
  background: rgba(245, 182, 66, 0.12);
  color: #f5b642;
}

.source-toggle-card {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  border-top: 1px solid var(--line);
  padding-top: 14px;
}

.source-toggle-card:first-of-type {
  border-top: 0;
  padding-top: 0;
}

.source-toggle-card strong {
  color: var(--ink);
}

.source-toggle-card input[type="checkbox"] {
  appearance: none;
  width: 44px;
  height: 24px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--field);
  position: relative;
  cursor: pointer;
}

.source-toggle-card input[type="checkbox"]::after {
  content: "";
  position: absolute;
  top: 3px;
  left: 3px;
  width: 16px;
  height: 16px;
  border-radius: 999px;
  background: var(--muted);
  transition: transform 150ms ease, background 150ms ease;
}

.source-toggle-card input[type="checkbox"]:checked {
  border-color: var(--accent);
  background: var(--accent);
}

.source-toggle-card input[type="checkbox"]:checked::after {
  transform: translateX(20px);
  background: #fff;
}

.source-access-list,
.source-day-list,
.source-rule-section,
.source-variable-table {
  display: grid;
  gap: 10px;
}

.source-list-row,
.source-variable-row,
.source-rule-row,
.source-day-row,
.source-time-row,
.source-form-field-row {
  display: grid;
  align-items: center;
  gap: 10px;
}

.source-list-row {
  grid-template-columns: minmax(0, 1fr) auto;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 10px;
}

.source-variable-row {
  grid-template-columns: minmax(120px, 0.75fr) minmax(170px, 1fr) minmax(170px, 1fr) minmax(150px, 0.8fr) auto;
}

.source-channel-chips,
.source-icon-options {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.source-channel-chips label,
.source-icon-options label {
  display: inline-flex;
  grid-template-columns: none;
  align-items: center;
  gap: 6px;
  min-height: 34px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--field);
  padding: 0 10px;
  cursor: pointer;
}

.source-channel-chips label:has(input:checked),
.source-icon-options label:has(input:checked) {
  border-color: var(--accent);
  background: var(--accent-soft);
  color: var(--accent);
}

.source-segmented {
  display: inline-flex;
  width: fit-content;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--field);
}

.source-segmented label {
  display: inline-flex;
  grid-template-columns: none;
  align-items: center;
  gap: 6px;
  min-height: 36px;
  border-right: 1px solid var(--line);
  padding: 0 12px;
  cursor: pointer;
}

.source-segmented label:last-child {
  border-right: 0;
}

.source-segmented label:has(input:checked) {
  color: var(--accent);
  background: var(--accent-soft);
}

.source-day-row {
  grid-template-columns: minmax(140px, 1fr) minmax(280px, auto);
  min-height: 48px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 10px;
}

.source-day-row > label,
.source-time-row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.source-time-row input[type="time"] {
  width: 130px;
}

.source-widget-pane {
  min-height: 540px;
}

.source-widget-tabs {
  display: flex;
  gap: 18px;
  border-bottom: 1px solid var(--line);
}

.source-widget-tabs button {
  min-height: 36px;
  border: 0;
  border-bottom: 2px solid transparent;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
}

.source-widget-tabs button.active {
  border-bottom-color: var(--accent);
  color: var(--accent);
}

.source-widget-grid {
  display: grid;
  grid-template-columns: minmax(320px, 520px) minmax(280px, 1fr);
  gap: 18px;
  align-items: start;
}

.source-widget-settings {
  max-height: 560px;
  overflow: auto;
}

.source-form-field-row {
  grid-template-columns: minmax(90px, 0.8fr) auto auto minmax(130px, 1fr);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 10px;
}

.source-form-field-row label {
  display: inline-flex;
  grid-template-columns: none;
  align-items: center;
  gap: 6px;
}

.source-radio-stack {
  display: grid;
  gap: 8px;
  margin: 0;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 12px;
}

.source-radio-stack label {
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
}

.source-radio-stack span {
  display: block;
  grid-column: 2;
  color: var(--muted);
  font-size: 12px;
}

.source-rule-row {
  grid-template-columns: minmax(120px, 0.8fr) minmax(130px, 0.8fr) minmax(140px, 1fr) auto;
}

.source-widget-preview {
  display: grid;
  justify-content: center;
  min-height: 520px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: radial-gradient(circle at top, var(--accent-soft), transparent 32%), var(--surface);
  padding: 24px;
}

.widget-preview-phone {
  align-self: start;
  width: min(360px, 100%);
  min-height: 520px;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #07110d;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.35);
}

.widget-preview-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 4px 8px;
  align-items: center;
  color: #fff;
  padding: 14px 16px;
}

.widget-preview-header span {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: #55e071;
}

.widget-preview-header small {
  grid-column: 1 / -1;
  font-size: 11px;
}

.widget-preview-body {
  display: grid;
  align-content: start;
  gap: 10px;
  padding: 16px;
}

.widget-message,
.widget-preview-form {
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.08);
  padding: 10px;
}

.widget-message.user {
  justify-self: end;
  width: 42%;
  height: 34px;
  background: var(--accent);
}

.widget-preview-form {
  display: grid;
  gap: 8px;
}

.widget-preview-form input {
  min-height: 36px;
  border: 0;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  padding: 0 10px;
}

.widget-preview-form button,
.widget-preview-composer button {
  min-height: 38px;
  border: 0;
  border-radius: 8px;
  color: #fff;
  font-weight: 700;
}

.widget-preview-composer {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 44px;
  gap: 8px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding: 12px;
}

.widget-preview-composer input {
  min-height: 40px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.06);
  color: #fff;
  padding: 0 10px;
}

.danger-card {
  border-color: color-mix(in srgb, var(--danger) 35%, var(--line));
  background: var(--danger-bg);
}

.source-table .compact-action {
  width: auto;
  min-height: 32px;
  padding: 0 12px;
  justify-self: end;
}

.crm-page-shell {
  grid-template-rows: auto auto minmax(0, 1fr);
}

.crm-topbar a {
  color: inherit;
  text-decoration: none;
}

.crm-tabs {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}

.crm-table-board,
.crm-inbox,
.crm-calendar-shell,
.crm-calendar-settings,
.crm-contact-profile {
  min-height: 0;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--panel);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.crm-table-toolbar,
.crm-calendar-header,
.crm-inbox-toolbar,
.crm-thread-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px;
  border-bottom: 1px solid var(--line);
  background: var(--surface);
}

.crm-toolbar-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

.crm-toolbar-actions input,
.crm-toolbar-actions select,
.crm-inbox-toolbar input,
#crmConversationPageSize,
.crm-thread-composer textarea,
.crm-profile-conversation select {
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 0 10px;
  outline: none;
}

.crm-table-scroll {
  overflow: auto;
}

.crm-contact-table {
  width: 100%;
  min-width: 980px;
  border-collapse: collapse;
}

.crm-contact-table th,
.crm-contact-table td {
  border-bottom: 1px solid var(--line);
  padding: 12px;
  text-align: left;
  vertical-align: middle;
}

.crm-contact-table th {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
  background: var(--surface-soft);
}

.crm-contact-table tbody tr {
  cursor: pointer;
}

.crm-contact-table tbody tr:hover {
  background: var(--surface-soft);
}

.crm-contact-name-cell,
.crm-conversation-row,
.crm-thread-header > div {
  display: flex;
  gap: 10px;
  align-items: center;
  min-width: 0;
}

.crm-contact-name-cell span:last-child,
.crm-conversation-row span:nth-child(2) {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.crm-contact-name-cell small,
.crm-conversation-row small,
.crm-conversation-row em {
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.crm-tag-list {
  display: flex;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
}

.crm-field-picker {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 16px;
}

.crm-inbox {
  display: grid;
  grid-template-columns: minmax(260px, 25%) 8px minmax(0, 1fr) minmax(230px, 300px);
}

[data-crm-page="conversations"] .crm-inbox {
  height: calc(100vh - 178px);
}

.crm-inbox-list,
.crm-thread,
.crm-thread-contact {
  min-height: 0;
  overflow: hidden;
}

.crm-inbox-list,
.crm-inbox-resizer,
.crm-thread {
  border-right: 1px solid var(--line);
}

.crm-inbox-resizer {
  width: 8px;
  min-width: 8px;
  padding: 0;
  border-top: 0;
  border-bottom: 0;
  border-left: 0;
  background:
    linear-gradient(180deg, transparent, var(--accent-soft), transparent),
    var(--panel);
  cursor: col-resize;
  touch-action: none;
  position: relative;
}

.crm-inbox-resizer::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 3px;
  height: 56px;
  border-radius: 999px;
  background: var(--accent);
  transform: translate(-50%, -50%);
  opacity: 0.75;
}

.crm-inbox-resizer:hover::after,
.is-resizing-inbox .crm-inbox-resizer::after {
  opacity: 1;
  box-shadow: 0 0 0 4px var(--accent-soft);
}

.crm-inbox-list {
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
}

.crm-inbox-filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 10px;
  border-bottom: 1px solid var(--line);
}

.crm-advanced-filters {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 8px;
  padding: 10px;
  border-bottom: 1px solid var(--line);
  background: var(--surface);
}

.crm-advanced-filters label {
  display: grid;
  gap: 5px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
}

.crm-advanced-filters input,
.crm-advanced-filters select {
  min-height: 36px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 0 10px;
}

.crm-advanced-filters .inline-check {
  display: flex;
  align-items: center;
  text-transform: none;
}

.crm-conversation-list {
  overflow: auto;
  display: grid;
  align-content: start;
  gap: 6px;
  padding: 10px;
}

.crm-conversation-row {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 10px;
  text-align: left;
  cursor: pointer;
}

.crm-conversation-row.active {
  border-color: var(--accent);
  background: var(--accent-soft);
}

.crm-unread-dot {
  justify-self: end;
  border-radius: 999px;
  background: var(--accent);
  color: #fff;
  padding: 3px 7px;
  font-size: 10px;
  line-height: 1;
}

.crm-monitor-panel {
  min-height: 0;
}

.crm-monitor-panel .board-card {
  display: grid;
  gap: 14px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--panel);
  box-shadow: var(--shadow);
  padding: 14px;
}

.crm-monitor-form {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.crm-monitor-form label,
.crm-monitor-channels {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

.crm-monitor-form input,
.crm-monitor-form select,
.crm-monitor-form textarea,
.crm-opportunity-card textarea {
  width: 100%;
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 9px 10px;
  outline: none;
}

.crm-monitor-form .inline-check,
.crm-monitor-channels label {
  display: flex;
  align-items: center;
  text-transform: none;
}

.crm-monitor-channels {
  grid-column: span 2;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
}

.crm-monitor-channels legend,
.crm-monitor-prompt,
.crm-monitor-form .contact-memory-actions {
  grid-column: 1 / -1;
}

.crm-opportunity-list {
  display: grid;
  gap: 10px;
  align-content: start;
}

.crm-opportunity-workspace {
  display: grid;
  grid-template-columns: minmax(190px, 240px) minmax(0, 1fr);
  gap: 12px;
  min-height: 0;
}

.crm-opportunity-folders {
  display: grid;
  align-content: start;
  gap: 8px;
}

.crm-folder-button {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 4px 8px;
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 10px;
  text-align: left;
  cursor: pointer;
}

.crm-folder-button.active {
  border-color: var(--accent);
  background: var(--accent-soft);
}

.crm-folder-button small {
  grid-column: 1 / -1;
  color: var(--muted);
  font-size: 11px;
  line-height: 1.35;
}

.crm-opportunity-card {
  display: grid;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--field);
  padding: 12px;
}

.crm-opportunity-card > div:first-child {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.crm-opportunity-card span,
.crm-opportunity-card p {
  color: var(--muted);
  font-size: 12px;
}

.crm-lead-badge {
  align-self: start;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 5px 9px;
  background: var(--panel);
  color: var(--ink) !important;
  font-weight: 800;
}

.crm-lead-badge.hot {
  border-color: #f97316;
  background: #fff7ed;
}

.crm-lead-badge.cold,
.crm-lead-badge.not_good {
  border-color: #94a3b8;
  background: #f8fafc;
}

.crm-opportunity-details {
  border-top: 1px solid var(--line);
  padding-top: 8px;
}

.crm-opportunity-controls {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.crm-opportunity-controls label {
  display: grid;
  gap: 4px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
}

.crm-opportunity-controls select {
  width: 100%;
  min-height: 36px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
  color: var(--ink);
  padding: 0 9px;
}

.crm-opportunity-modal-backdrop {
  align-items: start;
  padding-top: 72px;
  background: rgba(3, 6, 4, 0.72);
  backdrop-filter: blur(8px);
}

.crm-opportunity-modal {
  width: min(720px, 100%);
  border-radius: 12px;
  background: var(--panel);
  padding: 18px;
}

.crm-opportunity-modal-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}

.crm-opportunity-modal-form label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

.crm-opportunity-modal-form input,
.crm-opportunity-modal-form select,
.crm-opportunity-modal-form textarea {
  width: 100%;
  min-height: 40px;
  margin: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 9px 10px;
  outline: none;
}

.crm-opportunity-modal-form input:focus,
.crm-opportunity-modal-form select:focus,
.crm-opportunity-modal-form textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.crm-opportunity-modal-full,
.crm-opportunity-modal-actions {
  grid-column: 1 / -1;
}

.crm-opportunity-modal-actions {
  justify-content: end;
}

.crm-opportunity-modal-actions .settings-note {
  margin-right: auto;
}

.crm-opportunity-create-folder-toggle {
  display: flex !important;
  align-items: center;
  gap: 8px;
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  padding: 8px 10px;
  text-transform: none !important;
}

.crm-opportunity-create-folder-toggle input {
  width: auto;
  min-height: auto;
  margin: 0;
}

.crm-opportunity-new-folder {
  display: grid;
  grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  padding: 12px;
}

.crm-opportunity-new-folder[hidden] {
  display: none !important;
}

@media (max-width: 900px) {
  .crm-opportunity-workspace {
    grid-template-columns: 1fr;
  }

  .crm-opportunity-controls {
    grid-template-columns: 1fr;
  }

  .crm-opportunity-modal-backdrop {
    padding: 16px;
  }

  .crm-opportunity-modal-form {
    grid-template-columns: 1fr;
  }

  .crm-opportunity-new-folder {
    grid-template-columns: 1fr;
  }
}

.crm-thread {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
}

.crm-thread-body {
  overflow: auto;
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 14px;
  background: var(--surface);
}

.profile-thread {
  flex-direction: column;
}

.crm-channel-divider {
  align-self: center;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  background: var(--panel);
  padding: 4px 10px;
  font-size: 12px;
}

.crm-thread-composer {
  display: grid;
  gap: 10px;
  padding: 12px;
  border-top: 1px solid var(--line);
}

.crm-thread-composer textarea {
  min-height: 82px;
  padding: 10px;
  resize: vertical;
}

.crm-thread-contact {
  overflow: auto;
  padding: 12px;
}

.crm-phone-dialer-modal {
  display: grid;
  gap: 12px;
}

.crm-phone-dialer-modal .section-title {
  align-items: center;
}

.crm-phone-dialer-modal label,
.crm-inline-dialer label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.crm-phone-dialer-modal input,
.crm-phone-dialer-modal select,
.crm-inline-dialer select {
  width: 100%;
  min-height: 40px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 0 10px;
}

.crm-dialer-display {
  display: grid;
  gap: 8px;
}

.crm-dialer-display input {
  min-height: 54px;
  text-align: center;
  font-size: 22px;
  font-weight: 800;
}

.crm-dialer-edit-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.crm-dialer-keypad {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.crm-dialer-keypad button {
  min-height: 58px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--field);
  color: var(--ink);
  cursor: pointer;
  display: grid;
  place-items: center;
  gap: 2px;
}

.crm-dialer-keypad button:hover {
  border-color: var(--accent);
  background: var(--surface-soft);
}

.crm-dialer-keypad strong {
  font-size: 22px;
  line-height: 1;
}

.crm-dialer-keypad small {
  min-height: 12px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 800;
}

.crm-dialer-actions {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  align-items: stretch;
}

.crm-phone-dialer-modal .send,
.crm-phone-dialer-modal .refresh,
.crm-dialer-edit-actions .refresh {
  width: auto;
  min-height: 40px;
  padding: 0 16px;
}

.crm-call-start {
  min-height: 48px;
  border-color: #15803d;
  background: linear-gradient(180deg, #22a455, #15803d);
  color: #ffffff;
}

.crm-call-start:hover {
  background: linear-gradient(180deg, #2ebd66, #166534);
}

.crm-call-end {
  min-height: 48px;
  border-color: #b42318;
  background: linear-gradient(180deg, #d92d20, #9f1d14);
  color: #ffffff;
}

.crm-call-end:hover {
  background: linear-gradient(180deg, #ef4444, #991b1b);
}

.crm-inline-dialer {
  display: grid;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
  padding: 10px;
}

.crm-inline-dialer[hidden] {
  display: none;
}

.crm-inline-dialer-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.crm-inline-dialer .send,
.crm-inline-dialer .refresh {
  width: auto;
  min-height: 38px;
  padding: 0 14px;
}

.crm-call-icon {
  flex: 0 0 auto;
}

.crm-contact-profile {
  display: grid;
  grid-template-columns: minmax(260px, 330px) minmax(0, 1fr) minmax(250px, 310px);
}

.crm-profile-left {
  display: grid;
  align-content: start;
  gap: 12px;
  padding: 12px;
  border-right: 1px solid var(--line);
  background: var(--surface);
  overflow: auto;
}

.crm-contact-summary-card .crm-profile-title {
  align-items: flex-start;
}

.crm-profile-danger-row {
  display: flex;
  justify-content: flex-end;
  margin-top: 14px;
}

.crm-profile-detail-list dd,
.crm-profile-custom-row strong,
.crm-activity-item p {
  overflow-wrap: anywhere;
}

.crm-profile-edit-list {
  display: grid;
  gap: 10px;
}

.crm-profile-edit-list label,
.crm-profile-add-row {
  display: grid;
  gap: 5px;
}

.crm-profile-edit-list span {
  color: var(--muted);
  font-size: 12px;
}

.crm-profile-edit-list input,
.crm-profile-add-row input,
.crm-profile-custom-row input {
  width: 100%;
  min-height: 36px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 0 10px;
  outline: none;
}

.crm-profile-add-row {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
}

.crm-profile-add-row.custom {
  grid-template-columns: minmax(92px, 0.7fr) minmax(0, 1fr) auto;
}

.crm-tag-remove {
  border: 1px solid var(--line);
  cursor: pointer;
}

.crm-profile-save-row {
  position: sticky;
  bottom: 0;
  z-index: 2;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  padding: 10px 0 0;
  background: var(--surface);
}

.settings-data-library,
.settings-library-section,
.settings-library-list {
  display: grid;
  gap: 10px;
}

.settings-library-section {
  padding-top: 2px;
}

.settings-library-add-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto;
  gap: 8px;
  align-items: end;
}

.settings-library-add-row input {
  min-height: 36px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 0 10px;
}

.settings-library-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  padding: 8px 0;
  border-bottom: 1px solid var(--line);
}

.settings-library-row span {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.settings-library-row small {
  color: var(--muted);
  overflow-wrap: anywhere;
}

.settings-library-tags {
  min-height: 30px;
}

.crm-profile-tags {
  min-height: 28px;
}

.crm-empty-state {
  color: var(--muted);
  font-size: 13px;
}

.crm-profile-custom-card details {
  display: grid;
  gap: 10px;
}

.crm-profile-custom-card summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  cursor: pointer;
  font-weight: 700;
  list-style: none;
}

.crm-profile-custom-card summary::-webkit-details-marker {
  display: none;
}

.crm-profile-custom-card summary small {
  color: var(--muted);
  font-size: 12px;
}

.crm-profile-search {
  width: 100%;
  min-height: 36px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 0 10px;
  outline: none;
}

.crm-profile-custom-values {
  display: grid;
  gap: 8px;
  max-height: 280px;
  overflow: auto;
}

.crm-profile-custom-row {
  display: grid;
  grid-template-columns: minmax(92px, 0.75fr) minmax(0, 1fr);
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1px solid var(--line);
}

.crm-profile-custom-row span,
.crm-activity-item span {
  color: var(--muted);
  font-size: 12px;
}

.crm-profile-custom-row strong,
.crm-activity-item strong {
  font-size: 13px;
  font-weight: 700;
}

.crm-activity-list {
  display: grid;
  gap: 8px;
  max-height: 300px;
  overflow: auto;
}

.crm-activity-item {
  display: grid;
  gap: 3px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--line);
}

.crm-activity-item p {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
}

.crm-profile-conversation {
  min-width: 0;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  border-right: 1px solid var(--line);
}

.crm-profile-activity {
  min-width: 0;
  overflow: auto;
  padding: 12px;
  background: var(--surface);
}

.crm-profile-activity .lead-info-card {
  min-height: 100%;
  align-content: start;
}

.crm-pagination {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: flex-end;
  padding: 10px 14px;
  border-top: 1px solid var(--line);
  color: var(--muted);
  font-size: 13px;
}

.crm-calendar-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 320px);
}

.crm-calendar-board {
  min-width: 0;
  border-right: 1px solid var(--line);
}

.crm-week-grid {
  min-width: 900px;
  overflow: auto;
}

.crm-week-row {
  display: grid;
  grid-template-columns: 64px repeat(7, minmax(110px, 1fr));
  min-height: 42px;
  border-bottom: 1px solid var(--line);
}

.crm-week-row > * {
  border-right: 1px solid var(--line);
  padding: 8px;
  color: var(--muted);
  font-size: 12px;
}

.crm-week-row.header {
  position: sticky;
  top: 0;
  z-index: 1;
  background: var(--surface-soft);
}

.crm-calendar-sidebar,
.crm-calendar-settings {
  display: grid;
  gap: 12px;
  align-content: start;
  padding: 12px;
  overflow: auto;
}

.crm-calendar-event,
.crm-availability-row {
  display: grid;
  gap: 4px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  padding: 10px;
}

.crm-calendar-event span,
.crm-calendar-event small,
.crm-availability-row span {
  color: var(--muted);
  font-size: 12px;
}

.crm-availability-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.sites-page-shell {
  grid-template-rows: auto auto minmax(0, 1fr);
}

.sites-workspace {
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 14px;
}

.sites-sidebar,
.sites-projects,
.sites-builder-card,
.sites-preview-card {
  min-height: 0;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--panel);
  box-shadow: var(--shadow);
}

.sites-sidebar {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 12px;
  padding: 14px;
  overflow: visible;
}

.sites-sidebar > .section-title {
  display: none;
}

.sites-projects {
  display: grid;
  align-content: start;
  gap: 12px;
  padding: 14px;
  overflow: auto;
}

.sites-main {
  min-width: 0;
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(340px, 420px) minmax(0, 1fr);
  align-items: start;
  gap: 14px;
}

.sites-category-list {
  display: grid;
  grid-template-columns: repeat(7, minmax(112px, 1fr));
  gap: 8px;
  align-items: stretch;
}

.sites-project-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 8px;
}

.sites-category,
.sites-project {
  width: 100%;
  display: grid;
  gap: 5px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 12px;
  text-align: left;
  cursor: pointer;
}

.sites-category {
  min-height: 58px;
  align-content: center;
  justify-items: center;
  text-align: center;
}

.sites-category span {
  display: none;
}

.sites-project span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

.sites-category.active,
.sites-project.active {
  border-color: var(--accent);
  background: var(--accent-soft);
}

.sites-github-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(200px, 280px) minmax(200px, 280px);
  gap: 10px;
  box-shadow: none;
}

.sites-github-card .section-title,
.sites-github-card .settings-note {
  grid-column: 1 / -1;
}

.sites-github-card label,
.sites-builder-form label,
.site-code-field {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

.sites-github-card input,
.sites-builder-form input,
.sites-builder-form select,
.sites-builder-form textarea,
.site-code-field textarea,
.sites-asset-item input {
  width: 100%;
  min-height: 40px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 10px;
  outline: none;
}

.sites-builder-card,
.sites-preview-card {
  padding: 14px;
  overflow: hidden;
}

.sites-builder-form {
  display: grid;
  gap: 14px;
}

.sites-builder-form .full-row,
.sites-builder-actions.full-row {
  grid-column: 1 / -1;
}

.sites-control-panel,
.sites-asset-panel {
  display: grid;
  gap: 12px;
}

.sites-asset-panel article {
  display: grid;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  padding: 12px;
}

.sites-asset-panel h3 {
  margin: 0;
  color: var(--ink);
}

.sites-brand-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.site-inline-check {
  min-height: 36px;
  text-transform: none;
}

.sites-builder-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.sites-ai-disabled {
  opacity: 0.72;
}

.sites-preview-card {
  min-height: 0;
  display: grid;
  grid-template-rows: auto minmax(560px, 66vh) auto;
  gap: 12px;
}

.sites-view-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

.sites-file-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

.copy-button.active {
  border-color: var(--accent);
  background: var(--accent-soft);
  color: var(--ink);
}

.sites-preview-frame {
  min-height: 560px;
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: hidden;
  background: #fff;
}

.sites-preview-frame iframe {
  width: 100%;
  height: 100%;
  border: 0;
  background: #fff;
}

.site-code-field textarea {
  min-height: 180px;
  font-family: "IBM Plex Mono", Consolas, monospace;
  font-size: 12px;
  line-height: 1.5;
  resize: vertical;
}

.is-hidden {
  display: none !important;
}

.sites-recommendations-card,
.sites-publish-card {
  grid-column: 1 / -1;
  display: grid;
  gap: 12px;
  padding: 14px;
}

.sites-files-card {
  grid-column: 1 / -1;
  display: grid;
  gap: 12px;
  padding: 14px;
}

.sites-recommendation-list,
.sites-file-list,
.sites-build-log {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 8px;
}

.sites-recommendation,
.sites-asset-item,
.sites-file-item,
.sites-build-log-item {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 10px;
}

.sites-recommendation,
.sites-file-item {
  width: 100%;
  text-align: left;
  cursor: pointer;
}

.sites-recommendation {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
}

.sites-recommendation strong {
  color: var(--accent);
  font-size: 12px;
}

.sites-recommendation:hover,
.sites-file-item:hover {
  border-color: var(--accent);
  background: var(--accent-soft);
}

.sites-file-item.active {
  border-color: var(--accent);
  background: var(--accent-soft);
}

.sites-file-item,
.sites-build-log-item {
  display: grid;
  gap: 4px;
}

.sites-file-item span {
  color: var(--muted);
  font-size: 12px;
}

.sites-build-log-card {
  display: grid;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  padding: 12px;
}

.sites-build-log-card h3 {
  margin: 0;
}

.sites-publish-grid {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(220px, 1fr) minmax(260px, 1.4fr) auto;
  gap: 10px;
  align-items: end;
}

.sites-publish-grid label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

.sites-publish-grid input,
.sites-live-url code {
  width: 100%;
  min-height: 40px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  color: var(--ink);
  padding: 10px;
}

.sites-live-url code {
  display: block;
  overflow-wrap: anywhere;
  text-transform: none;
  font-weight: 600;
}

.sites-dns-box {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 8px;
}

.sites-dns-box article {
  display: grid;
  gap: 6px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--field);
  padding: 10px;
}

.sites-dns-box span {
  color: var(--muted);
  font-size: 12px;
  overflow-wrap: anywhere;
}

.sites-asset-list {
  display: grid;
  gap: 8px;
}

.sites-asset-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 6px 8px;
  align-items: center;
}

.sites-asset-item span,
.sites-token-status span {
  color: var(--muted);
  font-size: 12px;
}

.sites-asset-item input {
  grid-column: 1 / -1;
  min-height: 34px;
}

.icon-danger {
  width: 30px;
  height: 30px;
  border: 1px solid color-mix(in srgb, var(--danger) 45%, var(--line));
  border-radius: 8px;
  background: var(--danger-bg);
  color: var(--danger);
  cursor: pointer;
}

.sites-token-status {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
}

@media (max-width: 1400px) {
  .home-grid,
  .agent-editor-layout,
  .voice-agent-editor-layout {
    grid-template-columns: minmax(0, 1fr);
  }

  .persona-editor-card,
  .flow-editor-card,
  .flow-list-card,
  .voice-agent-editor-card,
  .voice-agent-preview-card,
  .voice-agent-api-card,
  .test-console {
    grid-column: auto;
    grid-row: auto;
  }

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

  .webhook-panel {
    grid-column: 2 / 4;
  }

  .webhook-panel,
  .prompt-panel,
  .panel {
    width: 100%;
    height: auto;
    min-height: 520px;
  }
}

@media (min-width: 1500px) {
  .crm-profile-grid {
    grid-template-columns: minmax(280px, 0.75fr) minmax(420px, 1.25fr) minmax(230px, 0.65fr);
  }

  .crm-action-panel {
    grid-column: auto;
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 980px) {
  .workspace-shell {
    grid-template-columns: 64px minmax(0, 1fr);
  }

  .workspace-topbar {
    grid-template-columns: minmax(0, 1fr);
  }

  .overview-metrics,
  .ai-dashboard-grid,
  .ai-dashboard-controls,
  .ai-summary-row,
  .account-settings-grid,
  .settings-shell,
  .settings-panel-grid,
  .voice-flow-steps,
  .cartesia-resource-grid,
  .slider-grid,
  .two-column-form,
  .persona-form-actions {
    grid-template-columns: minmax(0, 1fr);
  }

  .ai-contact-row {
    grid-template-columns: minmax(180px, 1fr) repeat(2, minmax(72px, auto));
  }

  .ai-contact-row span:nth-child(4),
  .ai-contact-row span:nth-child(5) {
    display: none;
  }

  .voice-call-row {
    grid-template-columns: minmax(150px, 1fr) repeat(2, minmax(76px, auto));
  }

  .voice-call-row span:nth-child(4),
  .voice-call-row span:nth-child(6) {
    display: none;
  }

  .voice-live-lanes,
  .voice-live-lane {
    grid-template-columns: 1fr;
  }

  .voice-wave {
    width: 100%;
  }

  .prompt-bot-test-card {
    top: 80px;
    right: 12px;
    bottom: 12px;
    width: min(440px, calc(100vw - 88px));
  }

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

  .panel,
  .prompt-panel,
  .webhook-panel {
    grid-column: 2;
  }

  .memory-workspace {
    grid-template-columns: minmax(0, 1fr);
  }

  .crm-profile-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .crm-action-panel {
    grid-template-columns: minmax(0, 1fr);
  }

  .crm-inbox,
  .crm-contact-profile,
  .crm-calendar-shell,
  .sites-workspace {
    grid-template-columns: minmax(0, 1fr);
  }

  .crm-inbox-resizer {
    display: none;
  }

  .crm-inbox-list,
  .crm-thread,
  .crm-profile-left,
  .crm-profile-conversation,
  .crm-profile-activity,
  .crm-calendar-board {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .memory-sidebar {
    min-height: 360px;
  }

  .sites-main {
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: auto auto;
  }

  .sites-builder-form {
    grid-template-columns: minmax(0, 1fr);
  }

  .sites-github-card {
    grid-template-columns: minmax(0, 1fr);
  }

  .sites-category-list {
    grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
  }
}

@media (max-width: 720px) {
  .workspace-shell {
    grid-template-columns: minmax(0, 1fr);
    gap: 0;
    padding: 0;
  }

  .workspace-main {
    gap: 0;
  }

  .workspace-topbar,
  .board-card,
  .sources-header,
  .settings-category,
  .settings-board,
  .standalone-panel {
    border-radius: 0;
    border-left: 0;
    border-right: 0;
    box-shadow: none;
  }

  .workspace-view.active {
    gap: 0;
  }

  .overview-metrics {
    padding: 12px;
  }

  .source-type-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .source-edit-form {
    grid-template-columns: minmax(0, 1fr);
  }

  .source-builder-modal {
    width: min(100%, calc(100vw - 24px));
    max-height: calc(100vh - 24px);
  }

  .source-editor-layout,
  .source-widget-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .source-editor-sidebar {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .source-day-row,
  .source-variable-row,
  .source-form-field-row,
  .source-rule-row {
    grid-template-columns: minmax(0, 1fr);
  }

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

  .page-shell {
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: auto auto auto 1fr;
    gap: 0;
    padding: 0;
  }

  .page-shell.knowledge-shell {
    grid-template-rows: auto auto 1fr;
  }

  .app-rail {
    position: static;
    height: auto;
    grid-template-columns: auto 1fr auto;
    grid-template-rows: auto;
    border-radius: 0;
  }

  .rail-nav {
    display: flex;
    overflow-x: auto;
    overflow-y: hidden;
    border-top: 0;
    padding-top: 0;
    padding-right: 0;
    padding-bottom: 4px;
  }

  .rail-button {
    min-width: 62px;
    min-height: 48px;
  }

  .panel,
  .prompt-panel,
  .webhook-panel {
    grid-column: 1;
  }

  .page-shell .app-rail,
  .page-shell.knowledge-shell .app-rail,
  .page-shell .memory-topbar,
  .page-shell .memory-workspace,
  .page-shell .page-metrics {
    grid-column: 1;
    grid-row: auto;
  }

  .page-shell .page-metrics {
    padding: 12px;
    background: var(--surface);
    border-bottom: 1px solid var(--line);
  }

  .panel,
  .webhook-panel,
  .prompt-panel {
    min-height: 100vh;
    height: 100vh;
    border-radius: 0;
    border: 0;
  }

  .composer {
    grid-template-columns: 1fr;
  }

  .topbar,
  .controls {
    align-items: stretch;
    flex-direction: column;
  }

  .contact-item {
    grid-template-columns: 34px minmax(0, 1fr);
  }

  .contact-row-side {
    grid-column: 2;
    justify-items: start;
    display: flex;
    gap: 8px;
  }

  .crm-profile-header,
  .crm-profile-title {
    align-items: flex-start;
    flex-direction: column;
  }

  .dashboard-metrics,
  .source-summary,
  .connector-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .flow-canvas {
    grid-template-columns: minmax(0, 1fr);
  }

  .flow-builder-modal {
    width: 100%;
    height: calc(100vh - 24px);
  }

  .flow-builder-shell {
    grid-template-columns: 1fr;
    min-height: 0;
  }

  .flow-builder-steps {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .flow-builder-brand {
    grid-column: 1 / -1;
  }

  .flow-step-pill {
    grid-template-columns: 1fr;
    min-height: 86px;
  }

  .flow-step-pill span {
    grid-row: auto;
  }

  .flow-source-grid,
  .flow-template-row,
  .flow-node-builder {
    grid-template-columns: 1fr;
  }

  .builder-node {
    grid-template-columns: 38px minmax(0, 1fr);
  }

  .flow-builder-footer {
    align-items: stretch;
    flex-direction: column;
  }

  .flow-builder-footer > div {
    justify-content: stretch;
  }

  .flow-builder-footer .send,
  .flow-builder-footer .refresh {
    flex: 1;
  }

  #flowBuilderModal.build-mode .flow-node-builder {
    grid-template-columns: minmax(0, 1fr);
  }

  .flow-rail-resizer {
    display: none;
  }

  #flowBuilderModal.build-mode .node-palette {
    max-height: 220px;
    border-width: 0 0 1px 0;
  }

  #flowBuilderModal.build-mode .flow-builder-footer {
    left: 16px;
    right: 74px;
  }

  .flow-link {
    width: 1px;
    height: 24px;
    justify-self: center;
  }

  .model-control {
    min-width: 100%;
  }

  .send,
  .upload {
    width: 100%;
  }

  .memory-shell {
    padding: 0;
  }

  .memory-topbar,
  .memory-workspace {
    width: 100%;
  }

  .memory-topbar {
    padding: 18px;
    background: var(--panel);
    border-bottom: 1px solid var(--line);
  }

  .memory-sidebar,
  .contact-detail.full {
    border-radius: 0;
    border-left: 0;
    border-right: 0;
    box-shadow: none;
  }
}
