/* ============================================================
   LEAD HOME · NEW DEAL MODAL · SETTINGS · CONFIGURATORS
   v5 stylesheet
   ============================================================ */

/* ── Deal home: lead chip on header ── */
.tp-head__leadchip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px 4px 8px;
  margin-bottom: 6px;
  background: rgba(26,26,26,0.04);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  font-size: 12px;
  color: var(--fg2);
  cursor: pointer;
  transition: background 0.12s var(--ease-out);
}
.tp-head__leadchip:hover { background: rgba(237,8,0,0.06); color: var(--red); border-color: rgba(237,8,0,0.3); }
.tp-head__leadchip .t-label { font-size: 9px; }
.tp-head__leadchip-arrow { color: var(--fg3); margin-left: 2px; }
.tp-head__leadchip:hover .tp-head__leadchip-arrow { color: var(--red); }

[data-mode="banzai"] .tp-head__leadchip { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.10); color: rgba(255,255,255,0.85); }

/* ── Deal home: products + sites lists in side rail ── */
.dh-products, .dh-sites {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 8px;
}
.dh-products li, .dh-sites li {
  padding: 10px 12px;
  background: var(--bg-primary);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
}
.dh-product__title { display: flex; align-items: baseline; gap: 6px; font-size: 13px; }
.dh-product__qty { font-size: 11px; color: var(--fg3); }
.dh-product__meta { font-size: 11px; color: var(--fg3); margin-top: 2px; text-wrap: pretty; }

.dh-site__hd { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 3px; }
.dh-site__label { font-size: 13px; font-weight: 600; color: var(--fg1); }
.dh-site__status { font-size: 9px; color: var(--fg3); letter-spacing: 0.10em; }
.dh-site__line { font-size: 12px; color: var(--fg2); margin-bottom: 4px; }
.dh-site__meta { font-size: 9px; letter-spacing: 0.10em; color: var(--fg3); }

[data-mode="banzai"] .dh-products li,
[data-mode="banzai"] .dh-sites li { background: rgba(255,255,255,0.03); border-color: rgba(255,255,255,0.10); }
[data-mode="banzai"] .dh-site__label { color: rgba(255,255,255,0.95); }

/* ============================================================
   LEAD HOME
   ============================================================ */

.tool-pane--lead, .tool-pane--settings { overflow: auto; }

.lh { padding: 20px 24px 60px; display: flex; flex-direction: column; gap: 16px; }
.lh-head {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 24px;
  padding: 18px 22px; background: var(--bg-elevated);
  border: 1px solid var(--stroke); border-radius: var(--radius);
}
.lh-head__l { flex: 1; min-width: 0; }
.lh-head__l .t-label { font-size: 9px; }
.lh-head__title { font-family: var(--font-head); font-weight: 600; font-size: 28px; letter-spacing: -0.02em; margin: 4px 0 8px; }
.lh-head__meta { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--fg3); flex-wrap: wrap; }
.lh-head__code { color: var(--fg2); }
.lh-head__r { display: flex; gap: 8px; flex-shrink: 0; }

.lh-stats {
  display: grid; grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  background: var(--bg-elevated);
  border: 1px solid var(--stroke); border-radius: var(--radius);
  overflow: hidden;
}
.lh-stat {
  padding: 16px 20px;
  border-right: 1px solid var(--stroke);
}
.lh-stat:last-child { border-right: 0; }
.lh-stat__v {
  font-family: var(--font-head); font-weight: 600;
  font-size: 26px; letter-spacing: -0.02em;
  margin: 4px 0 2px;
}
.lh-stat__sub { font-size: 11px; color: var(--fg3); }

[data-mode="banzai"] .lh-head,
[data-mode="banzai"] .lh-stats { background: var(--bg-elevated); border-color: rgba(255,255,255,0.10); }
[data-mode="banzai"] .lh-stat { border-right-color: rgba(255,255,255,0.10); }

.lh-intake-hint {
  display: flex; align-items: center; justify-content: space-between; gap: 18px;
  padding: 16px 18px;
  background: rgba(237,8,0,0.04);
  border: 1px solid rgba(237,8,0,0.22);
  border-radius: var(--radius);
}
.lh-intake-hint__copy { min-width: 0; }
.lh-intake-hint h2 { margin: 4px 0 10px; font-family: var(--font-head); font-size: 18px; font-weight: 600; letter-spacing: -0.01em; }
.lh-intake-hint__grid { display: flex; gap: 8px; flex-wrap: wrap; }
.lh-intake-hint__grid span {
  display: inline-flex; align-items: center; gap: 6px;
  max-width: min(100%, 340px);
  padding: 5px 8px;
  background: var(--bg-elevated);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  font-size: 12px;
  color: var(--fg2);
}
.lh-intake-hint__grid strong { color: var(--fg1); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; }

[data-mode="banzai"] .lh-intake-hint { background: rgba(237,8,0,0.10); border-color: rgba(237,8,0,0.35); }
[data-mode="banzai"] .lh-intake-hint__grid span { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.10); }

.lh-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 16px;
  align-items: start;
}
.lh-main { display: flex; flex-direction: column; gap: 16px; min-width: 0; }
.lh-side { display: flex; flex-direction: column; gap: 12px; position: sticky; top: 96px; }

/* deals list */
.lh-deals { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.lh-deal-item {
  position: relative;
}
.lh-deal {
  display: grid; grid-template-columns: 1fr auto;
  gap: 18px; align-items: center;
  width: 100%;
  padding: 14px 16px;
  background: var(--bg-primary);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  text-align: left; cursor: pointer;
  transition: background 0.12s var(--ease-out), border-color 0.12s var(--ease-out);
  color: inherit;
}
.lh-deal:hover { background: var(--bg-elevated); border-color: var(--stroke-firm); }
.lh-deal__l { min-width: 0; }
.lh-deal__hd { display: flex; align-items: center; gap: 8px; margin-bottom: 4px; flex-wrap: wrap; }
.lh-deal__code { font-size: 11px; color: var(--fg2); }
.lh-deal__title {
  font-family: var(--font-head); font-weight: 600;
  font-size: 16px; letter-spacing: -0.01em;
  margin-bottom: 6px;
}
.lh-deal__plus { color: var(--fg3); font-weight: 400; }
.lh-deal__sites { display: flex; gap: 5px; flex-wrap: wrap; }
.lh-deal__chip {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 8px;
  background: rgba(26,26,26,0.04);
  border-radius: var(--radius);
  font-size: 11px; color: var(--fg2);
}
.lh-deal__chip--more { font-family: var(--font-mono); color: var(--fg3); }
.lh-deal__r { display: flex; flex-direction: column; align-items: flex-end; gap: 2px; flex-shrink: 0; }
.lh-deal__val { font-family: var(--font-head); font-weight: 600; font-size: 16px; letter-spacing: -0.01em; color: var(--fg1); }
.lh-deal__sub { font-size: 10px; color: var(--fg3); font-family: var(--font-mono); letter-spacing: 0.08em; text-transform: uppercase; }
.lh-deal__arrow { color: var(--fg3); margin-top: 4px; }
.lh-deal:hover .lh-deal__arrow { color: var(--red); }
.lh-deal-actions {
  position: absolute;
  top: 10px;
  right: 10px;
}
.lh-deal-menu-btn {
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid transparent;
  border-radius: var(--radius);
  background: transparent;
  color: var(--fg3);
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: 16px;
  line-height: 1;
}
.lh-deal-menu-btn:hover,
.lh-deal-actions.is-open .lh-deal-menu-btn {
  background: var(--bg-elevated);
  border-color: var(--stroke);
  color: var(--fg1);
}
.lh-deal-menu {
  position: absolute;
  top: 34px;
  right: 0;
  z-index: 20;
  min-width: 184px;
  padding: 8px;
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  background: var(--bg-elevated);
  box-shadow: 0 18px 50px rgba(0,0,0,0.16);
}
.lh-deal-menu button {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  border: 0;
  border-radius: calc(var(--radius) - 2px);
  background: transparent;
  color: var(--fg2);
  cursor: pointer;
  font: inherit;
  font-size: 12px;
  padding: 8px 9px;
  text-align: left;
}
.lh-deal-menu button:hover:not(:disabled) {
  background: var(--bg-primary);
  color: var(--fg1);
}
.lh-deal-menu button:disabled {
  cursor: not-allowed;
  color: var(--fg3);
  opacity: 0.58;
}
.lh-deal-menu button.is-danger {
  color: var(--red);
}
.lh-deal-menu__rule {
  display: block;
  height: 1px;
  margin: 7px 0;
  background: var(--stroke);
}
.lh-deal-menu small {
  display: block;
  padding: 2px 9px 4px;
  color: var(--fg3);
  font-size: 10px;
  line-height: 1.3;
}
.lh-delete-error {
  margin: 10px 0 0;
  color: var(--red);
  font-size: 12px;
}

.lh-deals__empty {
  padding: 24px;
  text-align: center;
  color: var(--fg3);
  display: flex; flex-direction: column; gap: 8px; align-items: center;
}
.lh-deals__empty p { margin: 0; font-size: 13px; }

[data-mode="banzai"] .lh-deal { background: rgba(255,255,255,0.03); border-color: rgba(255,255,255,0.10); color: rgba(255,255,255,0.92); }
[data-mode="banzai"] .lh-deal:hover { background: rgba(255,255,255,0.06); }
[data-mode="banzai"] .lh-deal__chip { background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.75); }
[data-mode="banzai"] .lh-deal__val { color: #fff; }
[data-mode="banzai"] .lh-deal-menu,
[data-mode="banzai"] .lh-deal-menu-btn:hover,
[data-mode="banzai"] .lh-deal-actions.is-open .lh-deal-menu-btn {
  background: var(--bg-elevated);
  border-color: rgba(255,255,255,0.12);
}

/* address log */
.lh-addrs { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; }
.lh-addrs > li {
  display: grid; grid-template-columns: 1fr auto; gap: 12px;
  padding: 12px 0; border-top: 1px solid var(--stroke);
  align-items: center;
}
.lh-addrs > li:first-child { border-top: 0; }
.lh-addr__label { font-size: 13px; font-weight: 600; color: var(--fg1); margin-bottom: 2px; }
.lh-addr__line { font-size: 12px; color: var(--fg2); margin-bottom: 3px; }
.lh-addr__meta { font-size: 9px; color: var(--fg3); letter-spacing: 0.10em; }
.lh-addr__status {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.08em; padding: 3px 8px; border-radius: var(--radius);
  background: rgba(26,26,26,0.06); color: var(--fg2);
}
[data-mode="banzai"] .lh-addrs > li { border-top-color: rgba(255,255,255,0.08); }
[data-mode="banzai"] .lh-addr__status { background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.75); }

.lh-notes { margin: 0; font-size: 13px; color: var(--fg2); line-height: 1.5; text-wrap: pretty; }
.lh-meta-thread {
  width: min(560px, 100%);
  display: grid;
  gap: 8px;
}
.lh-meta-thread__msg {
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  background: var(--bg-recessed);
  padding: 9px 10px;
}
.lh-meta-thread__msg.is-inbound { border-left: 3px solid #5f7c37; }
.lh-meta-thread__msg.is-outbound { border-left: 3px solid #456f95; }
.lh-meta-thread__msg.is-internal { border-left: 3px solid var(--fg3); }
.lh-meta-thread__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  font-size: 10px;
  color: var(--fg3);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.lh-meta-thread__msg p {
  margin: 5px 0 0;
  color: var(--fg1);
  font-size: 13px;
  line-height: 1.45;
  overflow-wrap: anywhere;
}
.lh-checks { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.lh-checks > li { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--fg2); }
.lh-checks > li.is-done { color: var(--fg1); }
.lh-checks em { font-style: normal; color: var(--fg3); }

/* ============================================================
   NEW DEAL MODAL
   ============================================================ */

.modal {
  position: fixed; inset: 0; z-index: 80;
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
}
.modal__scrim { position: absolute; inset: 0; background: rgba(20,20,18,0.42); backdrop-filter: blur(2px); }
.modal__card {
  position: relative;
  width: min(820px, 100%);
  max-height: calc(100vh - 48px);
  background: var(--bg-elevated);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  display: flex; flex-direction: column;
  box-shadow: 0 28px 60px rgba(20,20,18,0.20);
  overflow: hidden;
}
.modal__card--narrow {
  width: min(520px, 100%);
}
.modal__hd {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 16px;
  padding: 18px 22px; border-bottom: 1px solid var(--stroke);
}
.modal__title { font-family: var(--font-head); font-weight: 600; font-size: 20px; letter-spacing: -0.02em; margin: 4px 0 0; }
.modal__close { width: 28px; height: 28px; border-radius: var(--radius); color: var(--fg3); }
.modal__close:hover { background: var(--row-hover); color: var(--fg1); }

.modal__steps {
  list-style: none; margin: 0; padding: 0;
  display: grid; grid-template-columns: repeat(3, minmax(0, 1fr));
  background: var(--bg-recessed);
  border-bottom: 1px solid var(--stroke);
}
.modal__steps li {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 18px;
  border-right: 1px solid var(--stroke);
  color: var(--fg3);
  font-size: 13px;
}
.modal__steps li:last-child { border-right: 0; }
.modal__steps li.is-active { background: var(--bg-elevated); color: var(--fg1); }
.modal__steps li.is-active .modal__step-n { background: var(--red); color: #fff; border-color: var(--red); }
.modal__steps li.is-done { color: var(--fg2); }
.modal__steps li.is-done .modal__step-n { background: var(--ink); color: #fff; border-color: var(--ink); }
.modal__steps li .t-label { font-size: 9px; margin-left: auto; }
.modal__step-n {
  display: inline-flex; align-items: center; justify-content: center;
  width: 26px; height: 26px;
  border: 1px solid var(--stroke); border-radius: var(--radius);
  font-family: var(--font-mono); font-size: 10px; color: var(--fg3);
}

.modal__body { padding: 22px; overflow: auto; flex: 1; }
.modal__step-body { display: flex; flex-direction: column; gap: 18px; }
.modal__hint { margin: 0; font-size: 13px; color: var(--fg2); }
.modal__seg { display: flex; gap: 4px; padding: 4px; background: var(--bg-recessed); border-radius: var(--radius); width: fit-content; }
.modal__seg-btn {
  padding: 6px 14px; border-radius: var(--radius);
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.06em;
  color: var(--fg3);
}
.modal__seg-btn:hover { color: var(--fg1); }
.modal__seg-btn.is-on { background: var(--bg-elevated); color: var(--fg1); box-shadow: 0 1px 3px rgba(26,26,26,0.05); }
.modal__seg-btn:disabled { opacity: 0.4; cursor: not-allowed; }

.modal__addrs { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.modal__addr {
  display: flex; gap: 10px; align-items: flex-start;
  padding: 12px 14px;
  background: var(--bg-primary);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  cursor: pointer;
}
.modal__addr.is-on { background: rgba(237,8,0,0.04); border-color: var(--red); box-shadow: inset 0 0 0 1px var(--red); }
.modal__addr input[type="radio"] { margin-top: 3px; }
.modal__addr-label { font-size: 13px; font-weight: 600; color: var(--fg1); }
.modal__addr-line { font-size: 12px; color: var(--fg2); margin: 2px 0 4px; }
.modal__addr-meta { font-size: 9px; }
.modal__empty { padding: 24px; text-align: center; color: var(--fg3); font-size: 13px; }

.modal__grid {
  display: grid; grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.modal__field { display: flex; flex-direction: column; gap: 4px; }
.modal__field--wide { grid-column: 1 / -1; }
.modal__field input,
.modal__field textarea {
  width: 100%; padding: 8px 10px;
  border: 1px solid var(--stroke); border-radius: var(--radius);
  background: var(--bg-primary); font-size: 13px;
}
.modal__field input:focus { border-color: var(--ink); outline: none; }

.modal__review { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.modal__review-card {
  padding: 14px 16px;
  background: var(--bg-primary);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
}
.modal__review-h { font-family: var(--font-head); font-weight: 600; font-size: 17px; letter-spacing: -0.01em; margin: 4px 0 4px; }
.modal__review-l { font-size: 13px; color: var(--fg2); margin-bottom: 6px; }
.modal__review-foot {
  grid-column: 1 / -1;
  display: flex; justify-content: space-between;
  padding: 10px 12px; background: var(--bg-recessed); border-radius: var(--radius);
}

.modal__ft {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 12px 22px;
  border-top: 1px solid var(--stroke);
  background: var(--bg-primary);
}
.modal__ft-l { display: flex; align-items: center; gap: 8px; }
.modal__ft-r { display: flex; gap: 8px; }
.btn:disabled { opacity: 0.4; cursor: not-allowed; }

[data-mode="banzai"] .modal__card,
[data-mode="banzai"] .modal__ft { background: var(--bg-elevated); border-color: rgba(255,255,255,0.10); }
[data-mode="banzai"] .modal__steps,
[data-mode="banzai"] .modal__seg { background: rgba(255,255,255,0.04); }
[data-mode="banzai"] .modal__seg-btn.is-on { background: rgba(255,255,255,0.08); color: #fff; }
[data-mode="banzai"] .modal__addr,
[data-mode="banzai"] .modal__review-card { background: rgba(255,255,255,0.03); border-color: rgba(255,255,255,0.10); }
[data-mode="banzai"] .modal__field input,
[data-mode="banzai"] .modal__field textarea { background: rgba(255,255,255,0.04); color: rgba(255,255,255,0.92); border-color: rgba(255,255,255,0.10); }
[data-mode="banzai"] .modal__review-foot,
[data-mode="banzai"] .modal__steps { background: rgba(0,0,0,0.20); }

/* ============================================================
   SETTINGS BACKSTAGE
   ============================================================ */

.stg { padding: 20px 24px 60px; display: flex; flex-direction: column; gap: 16px; }
.stg-head {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 16px;
  padding: 18px 22px;
  background: var(--bg-elevated);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  position: relative;
}
.stg-head::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0;
  width: 3px; background: var(--red);
}
.stg-head__l { padding-left: 6px; }
.stg-head__title { font-family: var(--font-head); font-weight: 600; font-size: 24px; letter-spacing: -0.02em; margin: 4px 0 4px; }
.stg-head__sub { font-size: 13px; color: var(--fg2); margin: 0; max-width: 540px; }
.stg-head__r { display: flex; align-items: center; gap: 12px; }

.stg-role {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px; border-radius: var(--radius);
  background: rgba(46,125,80,0.12); color: #1f5e3a;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase;
}
.stg-role__dot { width: 6px; height: 6px; border-radius: 50%; background: #2e7d50; }

.lh-access-grid { display: grid; gap: 8px; margin-top: 10px; }
.lh-access-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: 8px;
}
.lh-access-actions .btn {
  justify-content: center;
}
.lh-followers {
  display: grid;
  gap: 7px;
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid var(--stroke);
}
.lh-follower-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 6px;
  align-items: center;
}
.lh-follower-row__main {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  min-width: 0;
  gap: 2px;
  border: 0;
  background: transparent;
  color: inherit;
  cursor: pointer;
  padding: 0;
  text-align: left;
}
.lh-follower-row__main strong {
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
}
.lh-follower-row__main span {
  color: var(--fg3);
  font-size: 10px;
}
.lh-follower-row > button:not(.lh-follower-row__main) {
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  background: var(--bg-recessed);
  color: var(--fg2);
  padding: 5px 7px;
  font-size: 11px;
}
.lh-follower-row > button:disabled { opacity: 0.5; cursor: not-allowed; }
.lh-access-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 6px;
  align-items: center;
}
.lh-access-row strong { font-family: var(--font-head); font-size: 12px; }
.lh-access-row button {
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  background: var(--bg-recessed);
  color: var(--fg2);
  padding: 5px 7px;
  cursor: pointer;
  font-size: 11px;
}
.lh-access-row button.is-on {
  background: var(--ink);
  border-color: var(--ink);
  color: #fff;
}
.lh-access-row button:disabled { opacity: 0.5; cursor: not-allowed; }

.stg-switcher {
  display: grid;
  grid-template-columns: minmax(240px, 0.78fr) minmax(0, 1.55fr);
  gap: 8px;
  padding: 6px;
  background: var(--bg-elevated);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
}
.stg-switcher__current {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  background: var(--bg-primary);
  min-width: 0;
}
.stg-switcher__glyph {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: var(--radius);
  background: var(--red);
  color: #fff;
}
.stg-switcher__current h2 {
  margin: 2px 0 3px;
  font-family: var(--font-head);
  font-size: 18px;
  line-height: 1.05;
  letter-spacing: 0;
}
.stg-switcher__current p {
  margin: 0;
  color: var(--fg2);
  font-size: 12px;
  line-height: 1.35;
}
.stg-tabs {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
  min-width: 0;
}
.stg-tab {
  min-width: 0;
  display: flex; align-items: center; gap: 10px;
  padding: 9px 10px;
  border: 1px solid transparent;
  border-radius: var(--radius);
  text-align: left;
  color: var(--fg2);
  background: transparent;
  transition: background 0.12s var(--ease-out);
}
.stg-tab:hover { background: var(--row-hover); color: var(--fg1); }
.stg-tab.is-on { background: var(--bg-primary); color: var(--fg1); border-color: var(--stroke); box-shadow: 0 1px 3px rgba(26,26,26,0.04); }
.stg-tab.is-on .stg-tab__glyph { background: var(--red); color: #fff; }
.stg-tab__glyph {
  flex: 0 0 auto;
  display: inline-flex; align-items: center; justify-content: center;
  width: 26px; height: 26px;
  background: var(--bg-recessed);
  border-radius: var(--radius);
  color: var(--fg2);
}
.stg-tab__l { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.stg-tab__l > span:first-child {
  font-family: var(--font-head);
  font-weight: 600;
  font-size: 13px;
  line-height: 1.05;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.stg-tab__l .t-label { font-size: 9px; color: var(--fg3); }

.stg-body { display: flex; flex-direction: column; gap: 16px; }
.stg-stub { padding: 60px; text-align: center; color: var(--fg3); border: 1px dashed var(--stroke); border-radius: var(--radius); }
.stg-stub h2 { font-family: var(--font-head); font-weight: 600; font-size: 18px; color: var(--fg1); margin: 8px 0; }
.stg-stub p { max-width: 460px; margin: 0 auto; font-size: 13px; line-height: 1.5; }

[data-mode="banzai"] .stg-head,
[data-mode="banzai"] .stg-switcher { background: var(--bg-elevated); border-color: rgba(255,255,255,0.10); }
[data-mode="banzai"] .stg-switcher__current { background: rgba(255,255,255,0.03); border-color: rgba(255,255,255,0.10); }
[data-mode="banzai"] .stg-tab.is-on { background: rgba(255,255,255,0.06); color: #fff; box-shadow: 0 0 0 1px rgba(255,255,255,0.10); }
[data-mode="banzai"] .stg-tab__glyph { background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.85); }

/* ============================================================
   QUALIFY CONFIGURATOR
   ============================================================ */

.qc { display: flex; flex-direction: column; gap: 14px; }
.qc-top {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 14px 18px; background: var(--bg-elevated);
  border: 1px solid var(--stroke); border-radius: var(--radius);
}
.qc-top__l, .qc-top__r { display: flex; align-items: center; gap: 14px; }
.qc-top__l .t-label { margin-right: 4px; }
.qc-variants { display: flex; gap: 6px; }
.qc-variant {
  display: flex; flex-direction: column; gap: 2px; align-items: flex-start;
  padding: 7px 14px;
  background: var(--bg-primary);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  font-family: var(--font-head); font-weight: 600; font-size: 13px;
  text-align: left;
}
.qc-variant:hover { background: var(--bg-elevated); border-color: var(--stroke-firm); }
.qc-variant.is-on { background: var(--ink); color: #fff; border-color: var(--ink); }
.qc-variant.is-on .t-label { color: rgba(255,255,255,0.65); }
.qc-variant .t-label { font-size: 9px; }
.qc-meta { display: flex; flex-direction: column; align-items: flex-end; }
.qc-meta__v { font-family: var(--font-head); font-weight: 600; font-size: 20px; letter-spacing: -0.02em; }

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

.qc-rail {
  background: var(--bg-elevated);
  border: 1px solid var(--stroke); border-radius: var(--radius);
  padding: 12px 12px 14px;
  position: sticky; top: 96px;
}
.qc-rail__hd { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.qc-secs { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 2px; }
.qc-secs > li { position: relative; display: flex; align-items: center; gap: 4px; padding-right: 4px; border-radius: var(--radius); }
.qc-secs > li.is-on { background: rgba(237,8,0,0.06); }
.qc-secs > li:hover { background: var(--row-hover); }
.qc-secs > li.is-on:hover { background: rgba(237,8,0,0.10); }
.qc-sec {
  flex: 1;
  display: grid; grid-template-columns: 32px 1fr; gap: 8px; align-items: center;
  padding: 8px 10px;
  text-align: left;
  min-width: 0;
}
.qc-sec__n { font-size: 11px; color: var(--fg3); }
.qc-sec__title { font-size: 13px; font-weight: 600; color: var(--fg1); display: block; }
.qc-sec__l .t-label { font-size: 9px; }
.qc-sec__actions { display: flex; gap: 1px; }
.qc-sec__actions > button {
  width: 22px; height: 22px;
  border-radius: var(--radius);
  color: var(--fg3); font-size: 12px;
  opacity: 0;
}
.qc-secs > li:hover .qc-sec__actions > button { opacity: 1; }
.qc-sec__actions > button:hover { background: var(--row-hover); color: var(--fg1); }
.qc-sec__actions > button:disabled { opacity: 0.2; cursor: not-allowed; }

.qc-main { display: flex; flex-direction: column; gap: 12px; min-width: 0; }
.qc-card {
  background: var(--bg-elevated);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  padding: 14px 16px;
  display: flex; flex-direction: column; gap: 12px;
}
.qc-field { display: flex; flex-direction: column; gap: 4px; }
.qc-field--inline { flex-direction: row; align-items: center; gap: 12px; }
.qc-field--inline .t-label { margin-right: 4px; }
.qc-field--inline input[type="range"] { flex: 1; }
.qc-field--row { display: flex; flex-direction: row; gap: 12px; align-items: flex-end; }
.qc-field--grow { flex: 1; }
.qc-field--check { flex-direction: row; align-items: center; gap: 8px; font-size: 13px; }
.qc-field input,
.qc-field textarea,
.qc-field select {
  width: 100%; padding: 7px 10px;
  border: 1px solid var(--stroke); border-radius: var(--radius);
  background: var(--bg-primary); font-size: 13px; font-family: inherit;
}
.qc-field textarea { resize: vertical; }
.qc-field input:focus, .qc-field textarea:focus { border-color: var(--ink); outline: none; }

.qc-qhd { display: flex; align-items: center; justify-content: space-between; padding: 4px 4px 0; }
.qc-qs { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.qc-qs > li { display: flex; gap: 4px; align-items: center; padding-right: 4px; border-radius: var(--radius); background: var(--bg-elevated); border: 1px solid var(--stroke); }
.qc-qs > li.is-on { border-color: var(--red); box-shadow: 0 0 0 1px var(--red); }
.qc-q { flex: 1; display: grid; grid-template-columns: 36px 1fr auto; gap: 10px; align-items: center; padding: 10px 12px; text-align: left; min-width: 0; }
.qc-q__n { font-size: 11px; color: var(--fg3); }
.qc-q__text { font-size: 13px; font-weight: 500; color: var(--fg1); display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.qc-q__l .t-label { font-size: 9px; color: var(--fg3); }
.qc-q__pip { font-size: 10px; color: var(--fg3); padding: 2px 6px; background: var(--bg-recessed); border-radius: var(--radius); }
.qc-q__actions { display: flex; gap: 1px; flex-shrink: 0; }
.qc-q__actions > button {
  width: 22px; height: 22px;
  border-radius: var(--radius);
  color: var(--fg3); font-size: 12px;
  opacity: 0;
}
.qc-qs > li:hover .qc-q__actions > button,
.qc-qs > li.is-on .qc-q__actions > button { opacity: 1; }
.qc-q__actions > button:hover { background: var(--row-hover); color: var(--fg1); }
.qc-q__actions > button:disabled { opacity: 0.2; cursor: not-allowed; }
.qc-qs__empty { padding: 24px; text-align: center; color: var(--fg3); border: 1px dashed var(--stroke); border-radius: var(--radius); font-size: 13px; }

.qc-insp {
  background: var(--bg-elevated);
  border: 1px solid var(--stroke); border-radius: var(--radius);
  padding: 14px 16px;
  display: flex; flex-direction: column; gap: 12px;
  position: sticky; top: 96px;
}
.qc-insp__hd { display: flex; align-items: center; justify-content: space-between; padding-bottom: 8px; border-bottom: 1px solid var(--stroke); }
.qc-types { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 4px; }
.qc-type {
  display: flex; align-items: center; gap: 5px;
  padding: 6px 8px;
  border: 1px solid var(--stroke);
  background: var(--bg-primary);
  border-radius: var(--radius);
  font-size: 11px; color: var(--fg2);
  text-align: left;
}
.qc-type:hover { background: var(--row-hover); color: var(--fg1); border-color: var(--stroke-firm); }
.qc-type.is-on { background: var(--ink); color: #fff; border-color: var(--ink); }

.qc-opts__hd { display: flex; align-items: center; justify-content: space-between; }
.qc-opts { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 4px; }
.qc-opts > li {
  display: grid; grid-template-columns: 1fr auto auto;
  gap: 6px; align-items: center;
  padding: 4px 4px 4px 6px;
  border-radius: var(--radius);
  border: 1px solid var(--stroke);
  background: var(--bg-primary);
}
.qc-opt__label { border: 0; background: transparent; padding: 4px 6px; font-size: 12px; }
.qc-opt__label:focus { outline: none; }
.qc-opt__score { display: inline-flex; align-items: center; gap: 4px; padding: 2px 4px; background: var(--bg-recessed); border-radius: var(--radius); }
.qc-opt__score input { width: 38px; border: 0; background: transparent; text-align: right; font-family: var(--font-mono); font-size: 12px; padding: 2px 4px; outline: none; }
.qc-opt__score .t-label { font-size: 8px; }
.qc-opt__rm { color: var(--fg3); padding: 4px 6px; font-size: 14px; }
.qc-opt__rm:hover { color: var(--red); }

.qc-insp__preview { margin-top: 6px; padding-top: 12px; border-top: 1px solid var(--stroke); }
.qc-preview {
  padding: 10px 12px;
  background: var(--bg-recessed);
  border-radius: var(--radius);
  margin-top: 6px;
  display: flex; flex-direction: column; gap: 8px;
}
.qc-preview__q { font-size: 13px; font-weight: 600; color: var(--fg1); }
.qc-preview__req { color: var(--red); margin-left: 2px; }
.qc-preview__help { font-size: 11px; color: var(--fg3); }
.qc-preview__inp { width: 100%; padding: 6px 8px; border: 1px solid var(--stroke); border-radius: var(--radius); background: var(--bg-primary); font-size: 12px; }
.qc-preview__check { display: flex; align-items: center; gap: 6px; font-size: 12px; padding: 4px 0; }
.qc-stub { padding: 40px 20px; text-align: center; color: var(--fg3); font-size: 13px; }

[data-mode="banzai"] .qc-card,
[data-mode="banzai"] .qc-rail,
[data-mode="banzai"] .qc-insp,
[data-mode="banzai"] .qc-top { background: var(--bg-elevated); border-color: rgba(255,255,255,0.10); }
[data-mode="banzai"] .qc-variant,
[data-mode="banzai"] .qc-field input,
[data-mode="banzai"] .qc-field textarea,
[data-mode="banzai"] .qc-type,
[data-mode="banzai"] .qc-opts > li,
[data-mode="banzai"] .qc-preview__inp,
[data-mode="banzai"] .qc-qs > li { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.10); color: rgba(255,255,255,0.92); }
[data-mode="banzai"] .qc-variant.is-on,
[data-mode="banzai"] .qc-type.is-on { background: #fff; color: #141412; border-color: #fff; }
[data-mode="banzai"] .qc-q__pip,
[data-mode="banzai"] .qc-preview,
[data-mode="banzai"] .qc-opt__score { background: rgba(0,0,0,0.25); }

/* ============================================================
   RATE LIBRARY CONFIGURATOR
   ============================================================ */

.rc { display: flex; flex-direction: column; gap: 14px; }
.rc-top {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 8px 12px;
  background: var(--bg-elevated);
  border: 1px solid var(--stroke); border-radius: var(--radius);
}
.rc-segs { display: flex; gap: 4px; }
.rc-seg {
  display: flex; flex-direction: column; align-items: flex-start; gap: 1px;
  padding: 8px 16px;
  border-radius: var(--radius);
  color: var(--fg2); text-align: left;
}
.rc-seg:hover { background: var(--row-hover); color: var(--fg1); }
.rc-seg.is-on { background: var(--bg-primary); color: var(--fg1); box-shadow: inset 0 0 0 1px var(--stroke); }
.rc-seg.is-on > span:first-child { color: var(--fg1); }
.rc-seg > span:first-child { font-family: var(--font-head); font-weight: 600; font-size: 13px; }
.rc-seg .t-label { font-size: 9px; color: var(--fg3); }
.rc-top__r { display: flex; align-items: center; gap: 12px; }

.rc-grid { display: grid; gap: 12px; align-items: start; }
.rc-grid--lib { grid-template-columns: 240px minmax(0, 1fr); }
.rc-grid--tpl { grid-template-columns: 240px minmax(0, 1fr) 300px; }

.rc-main { display: flex; flex-direction: column; gap: 12px; min-width: 0; }

.rc-items {
  background: var(--bg-elevated);
  border: 1px solid var(--stroke); border-radius: var(--radius);
  overflow-x: auto;
}
.rc-items__hd, .rc-items__row {
  display: grid;
  grid-template-columns: 110px minmax(150px, 0.9fr) minmax(220px, 1.2fr) 50px 80px 28px;
  gap: 8px;
  align-items: center;
  padding: 8px 12px;
}
.rc-items--lines .rc-items__hd,
.rc-items__row--line {
  grid-template-columns: 100px minmax(150px, 0.9fr) minmax(220px, 1.2fr) 60px 50px 80px 90px 28px;
}
.rc-items__hd {
  background: var(--bg-recessed);
  color: var(--fg3);
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.08em; text-transform: uppercase;
}
.rc-items__row { border-top: 1px solid var(--stroke); }
.rc-items__row:first-of-type { border-top: 0; }
.rc-items__row:hover { background: var(--row-hover); }
.rc-items__row .r { text-align: right; }
.rc-items__hd .r { text-align: right; }
.rc-items__inp { border: 0; background: transparent; padding: 4px 6px; font-size: 12px; outline: none; width: 100%; border-radius: var(--radius); }
.rc-items__inp:focus { background: var(--bg-primary); box-shadow: inset 0 0 0 1px var(--ink); }
.rc-items__inp.r { text-align: right; }
.rc-items__rm {
  width: 22px; height: 22px; border-radius: var(--radius);
  color: var(--fg3); font-size: 14px;
  opacity: 0;
}
.rc-items__row:hover .rc-items__rm { opacity: 1; }
.rc-items__rm:hover { color: var(--red); background: var(--row-hover); }
.rc-items__empty { padding: 28px; text-align: center; color: var(--fg3); font-size: 13px; border: 1px dashed var(--stroke); border-radius: var(--radius); }

[data-mode="banzai"] .rc-top,
[data-mode="banzai"] .rc-items { background: var(--bg-elevated); border-color: rgba(255,255,255,0.10); }
[data-mode="banzai"] .rc-seg.is-on { background: rgba(255,255,255,0.06); }
[data-mode="banzai"] .rc-items__hd { background: rgba(0,0,0,0.25); }
[data-mode="banzai"] .rc-items__row { border-top-color: rgba(255,255,255,0.06); }
[data-mode="banzai"] .rc-items__inp { color: rgba(255,255,255,0.92); }
[data-mode="banzai"] .rc-items__inp:focus { background: rgba(255,255,255,0.06); }

/* templates */
.rc-tpls { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 2px; }
.rc-tpls > li.is-on { background: rgba(237,8,0,0.06); border-radius: var(--radius); }
.rc-tpls > li:hover:not(.is-on) { background: var(--row-hover); border-radius: var(--radius); }
.rc-tpl {
  width: 100%;
  display: flex; flex-direction: column; gap: 2px;
  padding: 10px 12px;
  text-align: left;
  border-radius: var(--radius);
}
.rc-tpl__name { font-family: var(--font-head); font-weight: 600; font-size: 13px; color: var(--fg1); }
.rc-tpl .t-label { font-size: 9px; }
.rc-tpl__meta { display: flex; align-items: center; gap: 6px; margin-top: 4px; }
.rc-tpl__meta .mono { font-size: 11px; color: var(--fg1); font-weight: 600; }

.rc-pinned { padding: 7px 10px; font-size: 13px; background: var(--bg-recessed); border-radius: var(--radius); color: var(--fg2); }

.rc-vbody { display: flex; flex-direction: column; gap: 8px; }
.rc-vbody__total { font-size: 14px; font-weight: 600; }
.rc-cats { display: flex; flex-direction: column; gap: 8px; }
.rc-cat {
  background: var(--bg-elevated);
  border: 1px solid var(--stroke); border-radius: var(--radius);
  overflow: hidden;
}
.rc-cat__hd {
  display: grid; grid-template-columns: 60px 1fr auto;
  gap: 10px; align-items: center;
  padding: 10px 14px;
  background: var(--bg-recessed);
  border-bottom: 1px solid var(--stroke);
}
.rc-cat__code { font-size: 12px; font-weight: 600; color: var(--fg2); }
.rc-cat__name { font-size: 13px; font-weight: 600; color: var(--fg1); }
.rc-cat__total { font-size: 13px; font-weight: 600; color: var(--fg1); }

[data-mode="banzai"] .rc-cat { background: var(--bg-elevated); border-color: rgba(255,255,255,0.10); }
[data-mode="banzai"] .rc-cat__hd { background: rgba(0,0,0,0.25); border-bottom-color: rgba(255,255,255,0.08); }
[data-mode="banzai"] .rc-pinned { background: rgba(255,255,255,0.04); color: rgba(255,255,255,0.85); }

/* library palette */
.rc-palette {
  background: var(--bg-elevated);
  border: 1px solid var(--stroke); border-radius: var(--radius);
  padding: 12px 12px 16px;
  position: sticky; top: 96px;
  max-height: calc(100vh - 120px);
  overflow: auto;
}
.rc-palette__hint { margin: 6px 0 12px; font-size: 11px; color: var(--fg3); line-height: 1.4; }
.rc-palette__list { display: flex; flex-direction: column; gap: 4px; }
.rc-palette__cat summary {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 8px;
  border-radius: var(--radius);
  cursor: pointer; list-style: none;
}
.rc-palette__cat summary::-webkit-details-marker { display: none; }
.rc-palette__cat summary::before { content: "▸"; font-size: 9px; color: var(--fg3); }
.rc-palette__cat[open] summary::before { content: "▾"; }
.rc-palette__cat summary:hover { background: var(--row-hover); }
.rc-palette__code { font-size: 11px; color: var(--fg2); font-weight: 600; min-width: 30px; }
.rc-palette__name { flex: 1; font-size: 12px; color: var(--fg1); }
.rc-palette__cat ol { list-style: none; padding: 0 0 4px 18px; margin: 4px 0 0; display: flex; flex-direction: column; gap: 2px; }
.rc-palette__item {
  display: grid; grid-template-columns: 1fr auto;
  gap: 6px; align-items: center;
  padding: 6px 8px;
  width: 100%; text-align: left;
  border-radius: var(--radius);
  font-size: 11px;
  color: var(--fg2);
}
.rc-palette__item:hover { background: var(--row-hover); color: var(--fg1); }
.rc-palette__item:disabled { opacity: 0.4; cursor: not-allowed; }
.rc-palette__icode { font-size: 9px; color: var(--fg3); grid-column: 1; grid-row: 1; }
.rc-palette__idesc { grid-column: 1; grid-row: 2; font-size: 12px; color: var(--fg1); }
.rc-palette__irate { grid-column: 2; grid-row: 1 / span 2; align-self: center; font-size: 11px; color: var(--fg3); }

[data-mode="banzai"] .rc-palette { background: var(--bg-elevated); border-color: rgba(255,255,255,0.10); }

/* ── responsive collapses ── */
@media (max-width: 1400px) {
  .qc-grid { grid-template-columns: 220px 1fr 320px; }
  .rc-grid--tpl { grid-template-columns: 220px 1fr 280px; }
}
@media (max-width: 1200px) {
  .lh-grid { grid-template-columns: 1fr; }
  .lh-side { position: static; flex-direction: row; flex-wrap: wrap; }
  .lh-side > .dh-card { flex: 1 1 240px; }
  .stg-switcher { grid-template-columns: minmax(0, 1fr); }
  .qc-grid { grid-template-columns: 1fr; }
  .qc-rail, .qc-insp { position: static; }
  .rc-grid--tpl { grid-template-columns: 1fr; }
  .rc-palette { position: static; max-height: 360px; }
}
@media (max-width: 760px) {
  .stg { padding: 14px 14px 40px; }
  .stg-head,
  .stg-head__r { flex-direction: column; align-items: stretch; }
  .stg-tabs { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 460px) {
  .stg-switcher__current { align-items: start; }
}
