* {
  box-sizing: border-box;
}

html {
  max-width: 100%;
  overflow-x: hidden;
}

body {
  margin: 0;
  max-width: 100%;
  overflow-x: hidden;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:
    radial-gradient(circle at top left, rgba(79, 70, 229, 0.12), transparent 30%),
    #f8fafc;
  color: #0f172a;
}

.container {
  max-width: 1100px;
  margin: 24px auto;
  padding: 0 16px 32px;
}

html[data-public-auth="landing"] .public-nav,
html[data-public-auth="login"] .public-nav,
html[data-public-auth="register"] .public-nav {
  position: sticky;
  top: 0;
  z-index: 20;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 18px;
  height: 72px;
  margin-bottom: 10px;
  padding: 10px 16px;
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 14px;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.04);
  backdrop-filter: blur(6px);
}

html[data-public-auth="landing"] .public-nav-brand,
html[data-public-auth="login"] .public-nav-brand,
html[data-public-auth="register"] .public-nav-brand {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
}

.public-nav-logo {
  height: 36px;
  width: auto;
  display: block;
  object-fit: contain;
}

html[data-public-auth="landing"] .public-nav-center,
html[data-public-auth="login"] .public-nav-center,
html[data-public-auth="register"] .public-nav-center {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
}

html[data-public-auth="landing"] .public-nav-actions,
html[data-public-auth="login"] .public-nav-actions,
html[data-public-auth="register"] .public-nav-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}

html[data-public-auth="landing"] .public-nav-actions.hidden,
html[data-public-auth="login"] .public-nav-actions.hidden,
html[data-public-auth="register"] .public-nav-actions.hidden {
  display: none;
}

html[data-public-auth="landing"] .public-nav-link,
html[data-public-auth="login"] .public-nav-link,
html[data-public-auth="register"] .public-nav-link {
  color: #334155;
  text-decoration: none;
  font-weight: 600;
  letter-spacing: 0.01em;
  font-size: 14px;
}

html[data-public-auth="landing"] .public-nav-link:hover,
html[data-public-auth="login"] .public-nav-link:hover,
html[data-public-auth="register"] .public-nav-link:hover {
  color: #4338ca;
}

html[data-public-auth="landing"] .public-nav-cta,
html[data-public-auth="login"] .public-nav-cta,
html[data-public-auth="register"] .public-nav-cta {
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  background: linear-gradient(135deg, #4f46e5, #7c3aed);
  color: #fff;
  box-shadow: 0 10px 24px rgba(79, 70, 229, 0.2);
}

html[data-public-auth="landing"] .public-nav-actions-logged-in,
html[data-public-auth="login"] .public-nav-actions-logged-in,
html[data-public-auth="register"] .public-nav-actions-logged-in {
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px 12px;
}

.public-nav-user-pill {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0 6px;
  max-width: min(100%, 18rem);
  padding: 6px 12px;
  border-radius: 999px;
  background: #f1f5f9;
  border: 1px solid #e2e8f0;
  font-size: 13px;
  font-weight: 600;
  color: #334155;
}

.public-nav-user-pill .public-nav-user-name {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.public-nav-user-pill .public-nav-user-sep {
  color: #94a3b8;
  font-weight: 500;
}

.public-nav-user-pill .public-nav-user-role {
  color: #4338ca;
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}

.public-nav-auth-buttons {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}

.public-nav-pill-btn {
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  padding: 7px 14px;
  border-radius: 8px;
  border: 1px solid #e2e8f0;
  background: #fff;
  color: #475569;
  cursor: pointer;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
  transition: background 140ms ease, border-color 140ms ease, color 140ms ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.public-nav-pill-btn:hover {
  background: #f8fafc;
  border-color: #cbd5e1;
  color: #334155;
}

.public-nav-pill-btn:focus-visible {
  outline: 2px solid rgba(99, 102, 241, 0.45);
  outline-offset: 2px;
}

.public-nav-pill-btn--primary {
  background: linear-gradient(135deg, #4f46e5, #7c3aed);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 8px 18px rgba(79, 70, 229, 0.22);
}

.public-nav-pill-btn--primary:hover {
  filter: brightness(1.04);
  color: #fff;
}

.public-nav-pill-btn--ghost {
  background: transparent;
  box-shadow: none;
}

.public-nav-pill-btn--ghost:hover {
  background: rgba(148, 163, 184, 0.14);
}

@media (max-width: 900px) {
  html[data-public-auth="landing"] .public-nav,
  html[data-public-auth="login"] .public-nav,
  html[data-public-auth="register"] .public-nav {
    grid-template-columns: auto 1fr;
    gap: 12px;
    padding: 10px 12px;
  }

  html[data-public-auth="landing"] .public-nav-center,
  html[data-public-auth="login"] .public-nav-center,
  html[data-public-auth="register"] .public-nav-center {
    display: none;
  }

  html[data-public-auth="landing"] .public-nav-right,
  html[data-public-auth="login"] .public-nav-right,
  html[data-public-auth="register"] .public-nav-right {
    justify-self: end;
  }
}

@media (max-width: 560px) {
  html[data-public-auth="landing"] .public-nav,
  html[data-public-auth="login"] .public-nav,
  html[data-public-auth="register"] .public-nav {
    height: auto;
    min-height: 64px;
  }

  html[data-public-auth="landing"] .public-nav-logo,
  html[data-public-auth="login"] .public-nav-logo,
  html[data-public-auth="register"] .public-nav-logo {
    height: 30px;
  }

  html[data-public-auth="landing"] .public-nav-actions,
  html[data-public-auth="login"] .public-nav-actions,
  html[data-public-auth="register"] .public-nav-actions {
    gap: 8px;
  }

  html[data-public-auth="landing"] .public-nav-actions-logged-in,
  html[data-public-auth="login"] .public-nav-actions-logged-in,
  html[data-public-auth="register"] .public-nav-actions-logged-in {
    flex-direction: column;
    align-items: stretch;
    width: 100%;
    max-width: min(100%, 320px);
  }

  html[data-public-auth="landing"] .public-nav-user-pill,
  html[data-public-auth="login"] .public-nav-user-pill,
  html[data-public-auth="register"] .public-nav-user-pill {
    max-width: 100%;
    justify-content: center;
    text-align: center;
  }

  html[data-public-auth="landing"] .public-nav-user-pill .public-nav-user-name,
  html[data-public-auth="login"] .public-nav-user-pill .public-nav-user-name,
  html[data-public-auth="register"] .public-nav-user-pill .public-nav-user-name {
    white-space: normal;
    overflow: visible;
    text-overflow: unset;
  }

  html[data-public-auth="landing"] .public-nav-auth-buttons,
  html[data-public-auth="login"] .public-nav-auth-buttons,
  html[data-public-auth="register"] .public-nav-auth-buttons {
    display: flex;
    width: 100%;
    gap: 8px;
  }

  html[data-public-auth="landing"] .public-nav-auth-buttons .public-nav-pill-btn,
  html[data-public-auth="login"] .public-nav-auth-buttons .public-nav-pill-btn,
  html[data-public-auth="register"] .public-nav-auth-buttons .public-nav-pill-btn {
    flex: 1;
    min-height: 40px;
    justify-content: center;
  }

  html[data-public-auth="landing"] .public-nav-link,
  html[data-public-auth="login"] .public-nav-link,
  html[data-public-auth="register"] .public-nav-link {
    font-size: 13px;
  }
}

.auth-screen-message {
  min-height: 1.25em;
  margin: 0 0 8px;
}

html[data-public-auth="landing"] #authMessage:empty {
  display: none;
  min-height: 0;
  margin: 0;
}

html[data-public-auth="login"] #routeLanding,
html[data-public-auth="login"] #registerCard {
  display: none !important;
}

html[data-public-auth="login"] #phoneLoginCard {
  display: block !important;
}

html[data-public-auth="register"] #routeLanding,
html[data-public-auth="register"] #phoneLoginCard {
  display: none !important;
}

html[data-public-auth="register"] #registerCard {
  display: block !important;
}

.card {
  background: #fff;
  border: 1px solid rgba(226, 232, 240, 0.9);
  border-radius: 16px;
  padding: 22px;
  margin-bottom: 22px;
  box-shadow: 0 18px 45px rgba(15, 23, 42, 0.06);
}

.layer-card {
  padding: 14px;
}

.layer-card > details {
  border: 0;
  background: transparent;
  padding: 0;
}

.layer-card > details > summary {
  font-size: 16px;
}

h1, h2 {
  margin: 0 0 12px;
}

.container h2 {
  font-size: 26px;
  line-height: 1.15;
  letter-spacing: -0.03em;
}

.flow-hint {
  font-weight: 600;
}

.landing-hero {
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px;
  align-items: center;
  min-height: 680px;
  overflow: hidden;
  position: relative;
  padding: 58px 28px;
  background:
    radial-gradient(circle at 78% 18%, rgba(99, 102, 241, 0.52), transparent 28%),
    radial-gradient(circle at 18% 12%, rgba(14, 165, 233, 0.2), transparent 28%),
    linear-gradient(135deg, #020617 0%, #111827 50%, #312e81 100%);
  border-color: rgba(99, 102, 241, 0.34);
  color: #fff;
}

.landing-hero::after {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.045) 1px, transparent 1px);
  background-size: 42px 42px;
  content: "";
  pointer-events: none;
  mask-image: linear-gradient(90deg, rgba(0, 0, 0, 0.72), transparent);
}

.landing-hero-copy,
.landing-hero-card {
  position: relative;
  z-index: 1;
}

.landing-hero h1 {
  max-width: 700px;
  font-size: clamp(48px, 8vw, 86px);
  line-height: 1.1;
  letter-spacing: -0.045em;
  word-spacing: normal;
  word-break: normal;
  overflow-wrap: break-word;
  hyphens: manual;
  margin-bottom: 26px;
  color: #fff;
}

.landing-eyebrow {
  margin: 0 0 10px;
  color: #4f46e5;
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.landing-subtitle {
  max-width: 680px;
  color: #111827;
  font-size: 26px;
  line-height: 1.32;
  margin: 0;
}

.landing-description {
  max-width: 640px;
  margin: 14px 0 0;
  color: #cbd5e1;
  font-size: 20px;
  line-height: 1.7;
}

.landing-actions {
  align-items: stretch;
  flex-direction: column;
  margin-top: 28px;
  gap: 12px;
}

.landing-actions.landing-actions--hero {
  width: 100%;
  max-width: 100%;
  min-width: 0;
}

.button-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 52px;
  padding: 14px 18px;
  border-radius: 12px;
  background: linear-gradient(135deg, #4f46e5, #7c3aed);
  color: #fff;
  font-size: 16px;
  font-weight: 800;
  text-decoration: none;
  box-shadow: 0 14px 26px rgba(79, 70, 229, 0.26);
  transition: transform 160ms ease, box-shadow 160ms ease, background 160ms ease;
}

.button-link:hover {
  background: linear-gradient(135deg, #4338ca, #6d28d9);
  box-shadow: 0 18px 34px rgba(79, 70, 229, 0.32);
  transform: translateY(-2px);
}

.button-link.secondary {
  background: #fff;
  color: #4f46e5;
  border: 1px solid rgba(79, 70, 229, 0.22);
  box-shadow: 0 12px 24px rgba(15, 23, 42, 0.08);
}

.button-link.secondary:hover {
  background: #f8fafc;
}

button.button-link {
  border: none;
  cursor: pointer;
  font: inherit;
}

.landing-trust-text {
  margin: 16px 0 0;
  color: #64748b;
  font-size: 14px;
  font-weight: 700;
}

.landing-hero .landing-trust-text {
  color: #cbd5e1;
}

.landing-hero .landing-eyebrow {
  color: #a5b4fc;
}

.landing-hero .button-link {
  min-height: 56px;
  padding: 15px 22px;
  background: linear-gradient(135deg, #ffffff, #e0e7ff);
  color: #312e81;
  box-shadow: 0 22px 46px rgba(0, 0, 0, 0.28);
}

.landing-hero .button-link:hover {
  background: linear-gradient(135deg, #ffffff, #c7d2fe);
  box-shadow: 0 26px 56px rgba(0, 0, 0, 0.36);
}

.landing-hero .button-link.secondary {
  border: 1px solid rgba(255, 255, 255, 0.24);
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
  backdrop-filter: blur(12px);
}

.landing-hero .button-link.secondary:hover {
  background: rgba(255, 255, 255, 0.16);
}

.landing-hero-card {
  position: relative;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 28px;
  padding: 26px;
  background: rgba(15, 23, 42, 0.58);
  box-shadow: 0 32px 90px rgba(0, 0, 0, 0.36);
  backdrop-filter: blur(18px);
  transition: transform 180ms ease, box-shadow 180ms ease;
}

.landing-hero-card:hover {
  box-shadow: 0 38px 105px rgba(0, 0, 0, 0.44);
  transform: translateY(-4px);
}

.landing-hero-card::before {
  position: absolute;
  inset: -1px;
  z-index: -1;
  border-radius: 28px;
  background: linear-gradient(135deg, rgba(129, 140, 248, 0.5), rgba(14, 165, 233, 0.2));
  content: "";
  transform: rotate(-2deg);
}

.landing-mock-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 18px;
}

.landing-mock-header strong,
.landing-mock-header span {
  display: block;
}

.landing-mock-header strong {
  color: #fff;
  font-size: 16px;
}

.landing-mock-header span {
  margin-top: 3px;
  color: #94a3b8;
  font-size: 12px;
}

.landing-live-pill,
.landing-popular-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 6px 10px;
  background: #dcfce7;
  color: #047857;
  font-size: 12px;
  font-weight: 800;
}

.landing-chat-bubble {
  max-width: 92%;
  margin-bottom: 14px;
  padding: 14px 16px;
  border-radius: 16px 16px 16px 5px;
  background: rgba(255, 255, 255, 0.94);
  color: #1e1b4b;
  font-size: 15px;
  font-weight: 700;
}

.landing-chat-bubble span {
  display: block;
  margin-bottom: 6px;
  color: #64748b;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.landing-progress-panel {
  margin-bottom: 16px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 18px;
  padding: 16px;
  background: rgba(255, 255, 255, 0.08);
}

.landing-progress-panel > div:first-child {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.landing-progress-panel span {
  color: #cbd5e1;
  font-size: 13px;
  font-weight: 700;
}

.landing-progress-panel strong {
  color: #fff;
  font-size: 28px;
}

.landing-hero-card .landing-progress-panel strong {
  font-size: 15px;
  line-height: 1.3;
  font-weight: 800;
}

.landing-mock-readiness {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 14px;
}

.landing-mock-chip {
  display: inline-flex;
  align-items: center;
  font-size: 11px;
  font-weight: 700;
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.18);
  color: #e2e8f0;
}

.landing-progress-track {
  height: 10px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.14);
}

.landing-progress-track span {
  display: block;
  width: 82%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #22c55e, #a3e635);
}

.landing-campaign-progress {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin: 18px 0;
}

.landing-campaign-progress div,
.landing-result-grid div {
  border: 1px solid rgba(226, 232, 240, 0.9);
  border-radius: 16px;
  padding: 14px;
  background: #f8fafc;
}

.landing-hero-card .landing-campaign-progress div {
  border-color: rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.08);
}

.landing-campaign-progress span,
.landing-result-grid span {
  display: block;
  color: #64748b;
  font-size: 12px;
  font-weight: 700;
}

.landing-campaign-progress strong {
  display: block;
  margin-top: 4px;
  color: #0f172a;
  font-size: 24px;
  line-height: 1;
}

.landing-hero-card .landing-campaign-progress strong {
  color: #fff;
}

.landing-status-list {
  display: grid;
  gap: 10px;
  margin-top: 16px;
}

.landing-status-list div {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 12px;
  padding: 10px 12px;
  color: #cbd5e1;
  font-size: 13px;
  background: rgba(255, 255, 255, 0.07);
}

.landing-status-list strong {
  margin-left: auto;
  color: #fff;
}

.landing-status-dot {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  flex: 0 0 auto;
}

.landing-status-dot.sent {
  background: #22c55e;
}

.landing-status-dot.pending {
  background: #f59e0b;
}

.landing-status-dot.failed {
  background: #ef4444;
}

.landing-chat-bubble.alt {
  margin-left: auto;
  border-radius: 16px 16px 5px 16px;
  background: #ecfdf5;
  color: #047857;
}

.landing-chat-status {
  padding-top: 4px;
  color: #94a3b8;
  font-size: 13px;
  text-align: right;
}

.landing-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 22px;
}

.landing-list {
  margin: 0;
  padding-left: 20px;
  color: #64748b;
  line-height: 1.85;
}

.landing-warning {
  margin: 18px 0 0;
  color: #b91c1c;
  font-size: 18px;
  font-weight: 800;
}

.landing-solution {
  text-align: center;
}

.landing-how-it-works .landing-steps {
  margin-top: 28px;
  text-align: left;
}

.landing-flow {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin-top: 22px;
  color: #111827;
  font-size: 18px;
  font-weight: 800;
}

.landing-flow span {
  padding: 16px;
  border: 1px solid rgba(199, 210, 254, 0.9);
  border-radius: 16px;
  background: #eef2ff;
  box-shadow: 0 12px 28px rgba(79, 70, 229, 0.08);
}

.landing-flow strong {
  color: #4f46e5;
}

.landing-steps,
.landing-feature-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}

.landing-steps div,
.landing-feature-grid div {
  border: 1px solid rgba(226, 232, 240, 0.9);
  border-radius: 16px;
  padding: 18px;
  background: #f8fafc;
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.landing-steps div:hover,
.landing-feature-grid div:hover,
.landing-pricing-grid .card:hover {
  border-color: rgba(79, 70, 229, 0.26);
  box-shadow: 0 18px 38px rgba(15, 23, 42, 0.09);
  transform: translateY(-3px);
}

.landing-steps strong,
.landing-feature-grid strong {
  display: block;
  margin-bottom: 6px;
  color: #0f172a;
}

.landing-steps span,
.landing-feature-grid span {
  display: block;
  color: #64748b;
  font-size: 14px;
  line-height: 1.55;
}

.landing-pricing {
  text-align: center;
  border-color: #c7d2fe;
}

.landing-pricing-section {
  padding: 28px;
  background:
    radial-gradient(circle at 50% 0%, rgba(79, 70, 229, 0.1), transparent 28%),
    #fff;
}

.landing-pricing-header {
  max-width: 680px;
  margin: 0 auto 26px;
  text-align: center;
}

.landing-pricing-header h2 {
  margin-bottom: 10px;
}

.landing-pricing-grid .card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.landing-pricing-grid .button-link {
  margin-top: auto;
}

.landing-price-card {
  padding: 26px;
}

.landing-price-card h3 {
  margin: 0;
  color: #0f172a;
  font-size: 22px;
  letter-spacing: -0.03em;
}

.landing-price-label {
  margin: 0;
  color: #64748b;
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.landing-price {
  color: #0f172a;
  font-size: 42px;
  font-weight: 900;
  letter-spacing: -0.06em;
  line-height: 1;
}

.landing-price span {
  color: #64748b;
  font-size: 16px;
  font-weight: 800;
  letter-spacing: -0.02em;
}

.landing-price-features {
  display: grid;
  gap: 12px;
  margin: 4px 0 8px;
  padding: 0;
  color: #475569;
  list-style: none;
}

.landing-price-features li {
  position: relative;
  padding-left: 28px;
  line-height: 1.45;
}

.landing-price-features li::before {
  position: absolute;
  top: 1px;
  left: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: #eef2ff;
  color: #4f46e5;
  content: "✓";
  font-size: 12px;
  font-weight: 900;
}

.landing-pricing-highlight {
  border-color: #4f46e5;
  background:
    linear-gradient(#fff, #fff) padding-box,
    linear-gradient(135deg, #4f46e5, #a855f7) border-box;
  border: 1px solid transparent;
  box-shadow: 0 28px 70px rgba(79, 70, 229, 0.2);
  transform: scale(1.02);
}

.landing-pricing-highlight:hover {
  transform: translateY(-3px) scale(1.03);
}

.landing-popular-badge {
  align-self: flex-start;
  background: linear-gradient(135deg, #4f46e5, #7c3aed);
  color: #fff;
  box-shadow: 0 10px 24px rgba(79, 70, 229, 0.22);
}

.landing-pricing-note {
  margin: 24px 0 0;
  color: #64748b;
  font-size: 14px;
  font-weight: 800;
  text-align: center;
}

.landing-pricing-trust-note {
  margin: 10px 0 0;
  text-align: center;
  color: rgba(255, 255, 255, 0.76);
  font-size: 12px;
  line-height: 1.5;
}

.landing-pricing-billing-note {
  margin: 18px auto 0;
  max-width: 36rem;
  text-align: center;
  font-size: 14px;
  line-height: 1.6;
}

.landing-cta {
  text-align: center;
  background:
    radial-gradient(circle at top right, rgba(79, 70, 229, 0.36), transparent 34%),
    linear-gradient(135deg, #0f172a, #1e1b4b);
  border-color: rgba(129, 140, 248, 0.36);
  color: #fff;
}

.landing-cta .muted {
  color: #cbd5e1;
}

.landing-cta .button-link {
  background: #fff;
  color: #4f46e5;
  box-shadow: 0 18px 38px rgba(15, 23, 42, 0.24);
}

.landing-cta-row {
  justify-content: center;
  margin-top: 18px;
}

.landing-trust {
  text-align: center;
}

.landing-trust-list {
  max-width: 720px;
  margin: 14px auto 0;
  text-align: left;
}

.landing-roadmap-section {
  scroll-margin-top: 88px;
}

.landing-roadmap-header {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 22px;
}

.landing-roadmap-subtitle {
  margin: 12px 0 0;
}

.landing-roadmap-badge {
  display: inline-block;
  width: fit-content;
  margin-bottom: 10px;
  padding: 4px 9px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: #eef2ff;
  color: #4338ca;
  border: 1px solid #c7d2fe;
}

.landing-feature-grid .landing-roadmap-card .landing-roadmap-badge {
  color: #4338ca;
}

.landing-feature-grid .landing-roadmap-card .landing-roadmap-badge.landing-roadmap-badge--addon {
  background: #ecfdf5;
  color: #047857;
  border-color: #a7f3d0;
}

.landing-feature-grid .landing-roadmap-card .landing-roadmap-badge.landing-roadmap-badge--roadmap {
  background: #fff7ed;
  color: #c2410c;
  border-color: #fed7aa;
}

.landing-roadmap-card strong {
  margin-top: 0;
}

.landing-price-custom {
  font-size: 2rem;
  font-weight: 900;
  letter-spacing: -0.04em;
  line-height: 1.15;
  color: #0f172a;
}

.landing-safety-faq .landing-safety-lead {
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
}

.landing-safety-disclaimer {
  max-width: 640px;
  margin: 16px auto 0;
  font-size: 13px;
}

.landing-faq-block {
  margin-top: 32px;
  padding-top: 26px;
  border-top: 1px solid rgba(148, 163, 184, 0.22);
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
  text-align: left;
}

.landing-faq-title {
  text-align: center;
  margin: 0 0 18px;
  font-size: 1.1rem;
}

.landing-faq-item {
  margin-bottom: 18px;
}

.landing-faq-item:last-child {
  margin-bottom: 0;
}

.landing-faq-item strong {
  display: block;
  margin-bottom: 6px;
  font-size: 15px;
  color: #0f172a;
}

.landing-faq-item .muted {
  margin: 0;
}

#faq.landing-safety-faq {
  scroll-margin-top: 88px;
}

.landing-use-cases-section h2 {
  margin-bottom: 18px;
}

.landing-use-cases-section .landing-feature-grid {
  margin-top: 4px;
}

.landing-results {
  text-align: center;
}

.landing-result-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 20px;
}

.landing-result-grid strong {
  display: block;
  margin-bottom: 6px;
  color: #4f46e5;
  font-size: 34px;
  letter-spacing: -0.04em;
  line-height: 1;
}

#routeLanding .card,
#routeLanding .landing-grid {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 520ms ease, transform 520ms ease;
}

#routeLanding .card.is-visible,
#routeLanding .landing-grid.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.landing-pricing h2 {
  font-size: 36px;
  letter-spacing: -0.04em;
}

.landing-pricing .button-link,
.landing-cta .button-link {
  margin-top: 10px;
}

/* Premium dark landing refresh */
#routeLanding {
  display: grid;
  gap: 28px;
  max-width: 1180px;
  margin: 0 auto;
  padding: 4px 4px 8px;
}

#routeLanding .card {
  border: 1px solid rgba(148, 163, 184, 0.22);
  background: linear-gradient(165deg, rgba(15, 23, 42, 0.92), rgba(30, 41, 59, 0.88));
  box-shadow: 0 18px 50px rgba(2, 6, 23, 0.38);
  color: #e2e8f0;
  padding: 30px 30px;
}

.landing-hero {
  grid-template-columns: minmax(0, 1.08fr) minmax(360px, 0.92fr);
  align-items: center;
  gap: 42px;
  min-height: 0;
  padding: 86px 62px;
  background:
    radial-gradient(circle at top right, rgba(59, 130, 246, 0.35), transparent 35%),
    radial-gradient(circle at bottom left, rgba(168, 85, 247, 0.25), transparent 30%),
    linear-gradient(145deg, #0b1220, #1a1f3a 55%, #281b4f);
}

.landing-hero h1 {
  font-size: clamp(42px, 6.3vw, 72px);
  line-height: 1.12;
  letter-spacing: -0.035em;
  word-spacing: normal;
  word-break: normal;
  overflow-wrap: break-word;
  hyphens: manual;
  color: #f8fafc;
  max-width: 620px;
  margin-bottom: 16px;
}

.landing-description {
  color: #cbd5e1;
  max-width: 560px;
  font-size: 19px;
  line-height: 1.62;
}

.landing-eyebrow {
  color: #93c5fd;
}

.landing-hero .button-link {
  border-radius: 12px;
  box-shadow: 0 12px 30px rgba(59, 130, 246, 0.3);
}

.landing-hero .button-link.secondary {
  border-color: rgba(148, 163, 184, 0.35);
  background: rgba(15, 23, 42, 0.5);
  color: #e2e8f0;
}

.landing-demo-float {
  position: relative;
  border: 1px solid rgba(129, 140, 248, 0.35);
  background: linear-gradient(170deg, rgba(15, 23, 42, 0.82), rgba(30, 41, 59, 0.9));
  box-shadow: 0 30px 80px rgba(37, 99, 235, 0.22), 0 0 0 1px rgba(129, 140, 248, 0.18);
  transform: translateY(-6px);
}

.landing-demo-mini-card {
  margin-top: 14px;
  padding: 12px 14px;
  border-radius: 10px;
  border: 1px solid rgba(45, 212, 191, 0.25);
  background: rgba(15, 23, 42, 0.52);
}

.landing-demo-mini-card span {
  display: block;
  font-size: 12px;
  color: #94a3b8;
}

.landing-demo-mini-card strong {
  color: #34d399;
  font-size: 14px;
}

.landing-status-list {
  gap: 8px;
  margin-top: 14px;
}

.landing-status-list div {
  padding: 8px 10px;
  background: rgba(15, 23, 42, 0.42);
  border: 1px solid rgba(148, 163, 184, 0.18);
  border-radius: 9px;
}

.landing-flow span {
  background: rgba(30, 41, 59, 0.85);
  border: 1px solid rgba(125, 211, 252, 0.25);
  color: #dbeafe;
}

.landing-steps div,
.landing-feature-grid div,
.landing-pricing-grid .card {
  border-color: rgba(148, 163, 184, 0.26);
  background: rgba(15, 23, 42, 0.62);
}

.landing-steps div:hover,
.landing-feature-grid div:hover,
.landing-pricing-grid .card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 34px rgba(59, 130, 246, 0.24);
}

.landing-pricing-section {
  background:
    radial-gradient(circle at top right, rgba(59, 130, 246, 0.17), transparent 35%),
    radial-gradient(circle at bottom left, rgba(168, 85, 247, 0.16), transparent 35%),
    linear-gradient(160deg, rgba(15, 23, 42, 0.95), rgba(30, 41, 59, 0.92));
  padding: 36px;
}

.landing-pricing-grid {
  gap: 20px;
}

.landing-pricing-grid .landing-price-card {
  display: flex;
  flex-direction: column;
  min-height: 100%;
  padding: 30px 28px;
  border: 1px solid rgba(148, 163, 184, 0.36);
  background: rgba(255, 255, 255, 0.04);
  box-shadow: 0 16px 36px rgba(2, 6, 23, 0.34);
}

.landing-pricing-grid .landing-price-label {
  color: rgba(255, 255, 255, 0.86);
}

.landing-pricing-grid .landing-price-card h3 {
  color: #ffffff;
  font-size: 24px;
}

.landing-pricing-grid .landing-price {
  color: #ffffff;
  font-size: 54px;
  font-weight: 900;
  line-height: 0.95;
  letter-spacing: -0.06em;
  margin: 4px 0 10px;
}

.landing-pricing-grid .landing-price span {
  color: rgba(255, 255, 255, 0.86);
}

.landing-pricing-grid .landing-price-features {
  color: rgba(255, 255, 255, 0.9);
  gap: 14px;
  margin: 8px 0 14px;
  min-height: 242px;
}

.landing-pricing-grid .landing-price-features li {
  color: rgba(255, 255, 255, 0.88);
}

.landing-pricing-grid .landing-price-features li::before {
  background: rgba(196, 181, 253, 0.24);
  color: #e9d5ff;
}

.landing-pricing-grid .landing-price-card .button-link {
  margin-top: auto;
  min-height: 50px;
  font-weight: 800;
}

.landing-pricing-grid .landing-plan-free .button-link {
  background: #ffffff;
  color: #111827;
  border: 1px solid rgba(255, 255, 255, 0.8);
  box-shadow: 0 12px 28px rgba(255, 255, 255, 0.12);
}

.landing-pricing-grid .landing-plan-free .button-link:hover {
  background: #f8fafc;
}

.landing-pricing-highlight {
  border: 1px solid rgba(139, 92, 246, 0.5);
  background: rgba(99, 102, 241, 0.15) !important;
  box-shadow:
    0 0 0 1px rgba(139, 92, 246, 0.35),
    0 0 42px rgba(139, 92, 246, 0.34),
    0 20px 44px rgba(59, 130, 246, 0.22);
  transform: translateY(-8px) scale(1.04);
}

.landing-popular-badge {
  box-shadow: 0 0 22px rgba(168, 85, 247, 0.5);
}

.landing-pricing-highlight .landing-popular-badge {
  content: normal;
}

.landing-popular-badge {
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.landing-pricing-highlight .landing-popular-badge {
  background: linear-gradient(135deg, #4f46e5, #9333ea);
  color: #f8fafc;
  border: 1px solid rgba(255, 255, 255, 0.22);
}

.landing-pricing-highlight .landing-price {
  background: linear-gradient(90deg, #7c3aed, #22c55e);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.landing-pricing-highlight .button-link {
  background: linear-gradient(135deg, #4f46e5, #7c3aed) !important;
  color: #ffffff !important;
  border: 1px solid rgba(167, 139, 250, 0.6) !important;
  box-shadow: 0 14px 34px rgba(124, 58, 237, 0.42) !important;
}

.landing-pricing-highlight .button-link:hover {
  background: linear-gradient(135deg, #4338ca, #6d28d9) !important;
}

.landing-pricing-grid .landing-plan-enterprise .button-link {
  background: transparent;
  color: #e2e8f0;
  border: 1px solid rgba(148, 163, 184, 0.56);
  box-shadow: none;
}

.landing-pricing-grid .landing-plan-enterprise .button-link:hover {
  background: rgba(255, 255, 255, 0.08);
}

.landing-pricing-grid .landing-plan-business .button-link {
  background: rgba(255, 255, 255, 0.9);
  color: #111827;
  border: 1px solid rgba(255, 255, 255, 0.82);
}

.landing-pricing-grid .landing-plan-business .button-link:hover {
  background: #ffffff;
}

.landing-pricing-grid .landing-plan-enterprise .muted {
  color: rgba(255, 255, 255, 0.84);
  line-height: 1.5;
  margin: 4px 0 6px;
}

#routeLanding > .card h2 {
  font-size: clamp(30px, 3.1vw, 44px);
  letter-spacing: -0.03em;
  line-height: 1.15;
  margin-bottom: 12px;
}

#routeLanding > .card p.muted {
  max-width: 860px;
}

#routeLanding > .card.landing-problem p,
#routeLanding > .card.landing-trust p {
  max-width: 840px;
}

#routeLanding .landing-safety-faq .landing-faq-title,
#routeLanding .landing-safety-faq .landing-faq-item strong {
  color: #f8fafc;
}

html[data-public-auth="landing"] #routeLanding .landing-safety-faq .landing-faq-title {
  color: #0f172a;
  font-weight: 800;
  font-size: 1.25rem;
}

html[data-public-auth="landing"] #routeLanding .landing-safety-faq .landing-faq-item strong {
  color: #1e293b;
  font-weight: 700;
  margin-bottom: 8px;
}

html[data-public-auth="landing"] #routeLanding .landing-safety-faq .landing-faq-item p,
html[data-public-auth="landing"] #routeLanding .landing-safety-faq .landing-faq-item .muted {
  color: #475569;
  font-size: 15px;
  line-height: 1.6;
  overflow-wrap: anywhere;
}

html[data-public-auth="landing"] #routeLanding .landing-safety-faq > h2 {
  color: #0f172a;
}

html[data-public-auth="landing"] #routeLanding .landing-safety-faq .landing-safety-lead {
  color: #334155;
}

html[data-public-auth="landing"] #routeLanding .landing-safety-faq .landing-safety-disclaimer {
  color: #475569;
  font-size: 14px;
  line-height: 1.65;
  margin-top: 22px;
  padding-top: 18px;
  border-top: 1px solid #e2e8f0;
}

html[data-public-auth="landing"] #routeLanding .landing-safety-faq .landing-faq-block {
  margin-top: 28px;
  padding: 22px 22px 20px;
  background: #ffffff;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.05);
  max-width: 100%;
  box-sizing: border-box;
}

html[data-public-auth="landing"] #routeLanding > .card.landing-safety-faq {
  background: #f8fafc;
}

html[data-public-auth="landing"] #routeLanding .landing-safety-faq .landing-faq-item {
  padding: 4px 0;
  min-width: 0;
}

html[data-public-auth="landing"] .floating-support-btn {
  right: 16px;
  bottom: 16px;
  padding: 7px 11px;
  font-size: 12px;
  box-shadow: 0 6px 14px rgba(22, 163, 74, 0.16);
  opacity: 0.82;
}

#routeLanding .card,
.landing-hero-card,
.landing-pricing-highlight {
  animation: landingFadeIn 0.48s ease both;
}

@keyframes landingFadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

.muted {
  color: #64748b;
}

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

.import-data-row {
  align-items: center;
}

/* Step 1 import: sheet / namelist load status (teal success only when loaded) */
.import-sheet-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  max-width: 100%;
  min-width: 0;
  line-height: 1.35;
  font-size: 14px;
  border-radius: 8px;
  border: 1px solid transparent;
  padding: 0;
  box-sizing: border-box;
}

.import-sheet-status-text {
  min-width: 0;
  word-break: break-word;
}

.import-sheet-status-icon {
  display: none;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
}

.import-sheet-status-check {
  display: block;
  width: 1.125rem;
  height: 1.125rem;
  color: #14b8a6;
}

.import-sheet-status--idle.import-sheet-status,
.import-sheet-status--loading.import-sheet-status {
  padding: 0;
  background: transparent;
  border-color: transparent;
}

.import-sheet-status--success.import-sheet-status {
  color: #0f766e;
  background: rgba(20, 184, 166, 0.12);
  border-color: rgba(20, 184, 166, 0.4);
  padding: 8px 11px;
}

.import-sheet-status--success .import-sheet-status-icon {
  display: inline-flex;
}

.import-sheet-status--error.import-sheet-status {
  color: #991b1b;
  background: rgba(248, 113, 113, 0.12);
  border-color: rgba(220, 38, 38, 0.35);
  padding: 8px 11px;
}

@media (max-width: 640px) {
  .import-data-row {
    align-items: flex-start;
  }

  .import-sheet-status {
    flex: 1 1 100%;
    font-size: 13px;
  }
}

.project-name-clickable {
  cursor: pointer;
  text-decoration: underline;
  text-decoration-color: #cbd5e1;
  text-underline-offset: 3px;
}

.project-name-clickable:hover {
  color: #1d4ed8;
}

.project-name-edit-input {
  max-width: 280px;
}

.status-bar {
  margin-bottom: 12px;
  padding: 10px 14px;
  border-radius: 8px;
  background: #f1f5f9;
  font-size: 14px;
}

.preview-secondary {
  opacity: 0.6;
  transition: opacity 0.2s ease;
}

.active-campaign-primary {
  border-color: #93c5fd;
  box-shadow: 0 0 0 2px #dbeafe inset;
}

.active-campaign-completed {
  opacity: 0.72;
  border-color: #d1d5db;
  background: #f9fafb;
  transition: opacity 0.2s ease, background 0.2s ease;
}

.active-campaign-card-list {
  display: none;
}

.campaign-history-card-list {
  display: none;
}

.active-campaign-card,
.campaign-history-card {
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: 14px;
  background: #fff;
}

.active-campaign-card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
}

.active-campaign-card-progress {
  margin-top: 10px;
  color: #2563eb;
  font-size: 15px;
  font-weight: 700;
}

.active-campaign-card-filtered {
  border-color: #e5e7eb;
  background: #fff;
}

.active-campaign-card-filtered .active-campaign-card-progress {
  color: #166534;
}

.active-campaign-card-note {
  margin-top: 4px;
  color: #4b5563;
  font-size: 14px;
}

.active-campaign-card-counts {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px 10px;
  margin-top: 10px;
  color: #4b5563;
  font-size: 14px;
}

.active-campaign-card-actions {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.active-campaign-card-actions button {
  width: 100%;
}

.campaign-safe-sending-note {
  display: block;
  font-size: 14px;
  color: #4b5563;
  padding: 6px 0;
  font-style: italic;
}

.campaign-review-start-btn {
  margin-bottom: 2px;
}

button.is-attention {
  animation: campaignReviewStartPulse 1.2s ease;
}

@keyframes campaignReviewStartPulse {
  0% { box-shadow: 0 0 0 0 rgba(37, 99, 235, 0.5); }
  70% { box-shadow: 0 0 0 10px rgba(37, 99, 235, 0); }
  100% { box-shadow: 0 0 0 0 rgba(37, 99, 235, 0); }
}

.campaign-action-terminal-btn {
  opacity: 0.95;
}

.campaign-completed-row {
  color: #6b7280;
  background: #f9fafb;
}

.instance-onboarding {
  display: grid;
  gap: 8px;
  margin: 8px 0 12px;
  padding: 12px;
  border: 1px solid #bfdbfe;
  border-radius: 10px;
  background: #eff6ff;
}

.instance-onboarding strong {
  color: #1e3a8a;
}

.instance-onboarding span {
  color: #4b5563;
  font-size: 14px;
}

.instance-onboarding small {
  color: #6b7280;
  font-size: 13px;
}

.instance-onboarding button {
  margin-top: 2px;
  width: fit-content;
}

.instance-connect-form {
  align-items: stretch;
}

.instance-card-list {
  display: none;
}

.instance-card {
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: 14px;
  background: #fff;
}

.instance-card-needs-setup {
  border-color: #bfdbfe;
  background: #f8fbff;
}

.instance-card-header {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: flex-start;
}

.instance-card-phone {
  margin-top: 10px;
  color: #4b5563;
  font-size: 15px;
}

.instance-card-actions {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.instance-card-actions button {
  width: 100%;
}

.instance-status-pill {
  flex: 0 0 auto;
  border-radius: 999px;
  padding: 4px 8px;
  background: #f3f4f6;
  color: #374151;
  font-size: 12px;
  font-weight: 700;
}

.instance-status-pill.connected {
  background: #dcfce7;
  color: #166534;
}

.instance-status-pill.paused {
  background: #fef3c7;
  color: #92400e;
}

.instance-status-pill.disconnected {
  background: #fee2e2;
  color: #991b1b;
}

.instance-status-pill.health-healthy-accent.connected {
  box-shadow: inset 0 0 0 1px rgba(22, 101, 52, 0.45);
}

.instance-table-wrap {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin-top: 4px;
}

#instanceTable.instance-table {
  width: 100%;
  min-width: 640px;
  border-collapse: collapse;
  font-size: 14px;
}

#instanceTable.instance-table th,
#instanceTable.instance-table td {
  padding: 10px 12px;
  vertical-align: middle;
  text-align: left;
  border-bottom: 1px solid #e5e7eb;
}

#instanceTable.instance-table th {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #64748b;
  background: #f8fafc;
}

.instance-name-stack {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  min-width: 0;
}

.instance-name-strong {
  font-weight: 700;
  color: #0f172a;
}

.instance-queue-pair {
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  color: #334155;
  white-space: nowrap;
}

.instance-queue-sep {
  margin: 0 4px;
  color: #94a3b8;
  font-weight: 500;
}

.instance-health-cell {
  font-size: 13px;
  color: #475569;
}

.instance-health-cell.health-healthy-accent {
  color: #166534;
  font-weight: 600;
}

.instance-health-cell.health-offline-accent {
  color: #64748b;
  font-weight: 500;
}

.instance-health-cell.health-warning-accent {
  color: #b45309;
  font-weight: 600;
}

.instance-card-metric span.health-healthy-accent {
  color: #166534;
  font-weight: 600;
}

.instance-card-metric span.health-offline-accent {
  color: #64748b;
  font-weight: 600;
}

.instance-card-metric span.health-warning-accent {
  color: #b45309;
  font-weight: 600;
}

.instance-actions-cell {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 8px;
}

.instance-actions-table-cell {
  white-space: normal;
}

.instance-manage-dropdown {
  position: relative;
}

.instance-manage-dropdown > summary {
  list-style: none;
  cursor: pointer;
}

.instance-manage-dropdown > summary::-webkit-details-marker {
  display: none;
}

.instance-manage-menu {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 8px;
  padding: 10px;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 6px 16px rgba(15, 23, 42, 0.08);
  min-width: 196px;
}

.instance-manage-menu button {
  width: 100%;
}

.instance-detail-row.hidden {
  display: none;
}

.instance-detail-panel {
  padding: 4px 0 8px;
}

.instance-detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px 20px;
}

.instance-detail-field--wide {
  grid-column: 1 / -1;
}

.instance-detail-label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #64748b;
  margin-bottom: 4px;
}

.instance-detail-value {
  font-size: 13px;
  color: #0f172a;
  word-break: break-word;
}

.instance-detail-api-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.instance-detail-api-row code {
  font-size: 12px;
  background: #f1f5f9;
  padding: 4px 8px;
  border-radius: 6px;
}

.instance-detail-error {
  color: #991b1b;
  white-space: pre-wrap;
}

.instance-card-metrics {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px 12px;
  margin-top: 10px;
  font-size: 13px;
  color: #334155;
}

.instance-card-metric-label {
  display: block;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #64748b;
  margin-bottom: 2px;
}

.instance-card-details-block {
  margin-top: 12px;
  padding: 10px 12px;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  background: #fafafa;
}

.instance-card-details-block summary {
  cursor: pointer;
  font-weight: 600;
  font-size: 14px;
  color: #1d4ed8;
}

.instance-card-details-body {
  margin-top: 10px;
  font-size: 13px;
  color: #334155;
}

.instance-card-detail-line {
  margin: 0 0 10px;
  line-height: 1.45;
}

.instance-card-actions-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: 12px;
}

.instance-manage-dropdown--block {
  width: 100%;
}

.instance-manage-dropdown--block > summary {
  width: 100%;
  text-align: center;
}

@media (min-width: 761px) {
  #instancesSection.card {
    max-width: min(100%, 1420px);
    margin-left: auto;
    margin-right: auto;
  }

  #instanceTable.instance-table {
    min-width: 0;
  }
}

.campaign-onboarding-card {
  margin: 14px 0 16px;
  padding: 16px;
  border: 1px solid #bfdbfe;
  border-radius: 12px;
  background: #eff6ff;
}

.campaign-onboarding-card h2 {
  margin-bottom: 6px;
}

.onboarding-flow-card {
  margin-bottom: 18px;
  border: 1px solid #bfdbfe;
  background:
    radial-gradient(circle at top right, rgba(59, 130, 246, 0.16), transparent 34%),
    linear-gradient(135deg, #f8fbff 0%, #eef6ff 100%);
}

.onboarding-flow-card h2 {
  margin-bottom: 6px;
}

.onboarding-steps {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 16px;
}

.onboarding-step {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px;
  border: 1px solid #dbeafe;
  border-radius: 14px;
  background: #fff;
}

.onboarding-step-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: #dbeafe;
  color: #1d4ed8;
  font-weight: 800;
}

.onboarding-step strong,
.onboarding-step span {
  display: block;
}

.onboarding-step span {
  margin-top: 2px;
  color: #64748b;
  font-size: 13px;
}

.onboarding-step button {
  margin-left: auto;
  white-space: nowrap;
}

.onboarding-step-completed {
  border-color: #bbf7d0;
  background: #f0fdf4;
}

.onboarding-step-completed .onboarding-step-icon {
  background: #16a34a;
  color: #fff;
}

.onboarding-step-current {
  border-color: #2563eb;
  box-shadow: 0 14px 30px rgba(37, 99, 235, 0.14);
  background: linear-gradient(135deg, #ffffff 0%, #eff6ff 100%);
  transform: translateY(-2px);
}

.onboarding-step-current .onboarding-step-icon {
  background: #2563eb;
  color: #fff;
}

.onboarding-step-locked {
  opacity: 0.62;
  background: #f8fafc;
}

.onboarding-help-banner {
  margin-top: 14px;
  padding: 10px 12px;
  border: 1px solid #e0e7ff;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.72);
  color: #334155;
  font-weight: 600;
}

/* Dashboard one-click onboarding (dark glass hero) */
.onboarding-oneclick-hero.dashboard-onboarding-hero {
  margin-bottom: 22px;
  padding: 0;
  border: 1px solid rgba(139, 92, 246, 0.38);
  border-radius: 20px;
  background: linear-gradient(148deg, #0f172a 0%, #1e1b4b 45%, #312e81 100%);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.06) inset,
    0 24px 56px rgba(15, 23, 42, 0.55),
    0 0 100px rgba(99, 102, 241, 0.12);
}

.dashboard-onboarding-glass {
  padding: 24px 22px 20px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.045);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.onboarding-oneclick-eyebrow {
  margin: 0 0 8px;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(196, 181, 253, 0.88);
  font-weight: 700;
}

.onboarding-oneclick-hero #dashboardOnboardingTitle,
.onboarding-oneclick-hero h2 {
  margin: 0 0 8px;
  color: #f8fafc;
  font-size: clamp(1.35rem, 3.5vw, 1.78rem);
  font-weight: 800;
  letter-spacing: -0.02em;
}

.onboarding-oneclick-subtitle {
  margin: 0 0 4px;
  color: rgba(226, 232, 240, 0.9);
  font-size: 1rem;
  line-height: 1.55;
}

.onboarding-macro-rail {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  gap: 6px;
  margin: 18px 0 16px;
  flex-wrap: wrap;
}

.onboarding-macro-step {
  flex: 1 1 88px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 10px;
  border-radius: 14px;
  background: rgba(15, 23, 42, 0.45);
  border: 1px solid rgba(148, 163, 184, 0.2);
  transition: border-color 0.25s ease, box-shadow 0.25s ease, background 0.25s ease, opacity 0.25s ease;
}

.onboarding-macro-step.is-upcoming {
  opacity: 0.52;
}

.onboarding-macro-step.is-current {
  opacity: 1;
  border-color: rgba(129, 140, 248, 0.78);
  box-shadow:
    0 0 0 1px rgba(129, 140, 248, 0.35),
    0 0 32px rgba(99, 102, 241, 0.42);
  background: rgba(79, 70, 229, 0.24);
}

.onboarding-macro-step.is-done {
  border-color: rgba(52, 211, 153, 0.48);
  background: rgba(16, 185, 129, 0.16);
}

.onboarding-macro-num,
.onboarding-macro-check {
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 800;
  background: rgba(255, 255, 255, 0.1);
  color: #e2e8f0;
}

.onboarding-macro-check {
  background: rgba(16, 185, 129, 0.38);
  color: #ecfdf5;
}

.onboarding-macro-label {
  font-size: 11px;
  font-weight: 700;
  color: rgba(248, 250, 252, 0.94);
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

.onboarding-macro-connector {
  flex: 0 0 14px;
  align-self: center;
  height: 3px;
  min-width: 10px;
  border-radius: 99px;
  background: linear-gradient(90deg, rgba(59, 130, 246, 0.15), rgba(139, 92, 246, 0.85), rgba(59, 130, 246, 0.15));
}

.dashboard-onboarding-progress.onboarding-oneclick-progress {
  margin: 8px 0 16px;
}

.onboarding-oneclick-hero .dashboard-onboarding-progress-track {
  height: 10px;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.65);
  border: 1px solid rgba(148, 163, 184, 0.14);
  overflow: hidden;
  box-shadow: inset 0 1px 8px rgba(0, 0, 0, 0.4);
}

.onboarding-oneclick-hero .dashboard-onboarding-progress-fill {
  height: 100%;
  min-width: 0;
  border-radius: 999px;
  background: linear-gradient(90deg, #3b82f6, #6366f1, #8b5cf6, #a855f7);
  background-size: 220% 100%;
  animation: onboarding-progress-flow 2.5s ease-in-out infinite;
  box-shadow: 0 0 18px rgba(139, 92, 246, 0.7);
  transition: width 0.55s cubic-bezier(0.22, 1, 0.36, 1);
}

@keyframes onboarding-progress-flow {
  0%,
  100% {
    background-position: 0% 50%;
  }

  50% {
    background-position: 100% 50%;
  }
}

.onboarding-oneclick-hero .dashboard-onboarding-progress-label {
  font-size: 13px;
  margin-top: 10px;
  font-weight: 600;
  color: rgba(203, 213, 225, 0.95);
}

.onboarding-main-continue-btn {
  width: 100%;
  margin: 0 0 18px;
  padding: 14px 22px;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  border: none;
  border-radius: 14px;
  cursor: pointer;
  color: #f8fafc;
  background: linear-gradient(135deg, #3b82f6 0%, #6366f1 42%, #7c3aed 100%);
  box-shadow:
    0 10px 36px rgba(79, 70, 229, 0.48),
    0 0 0 1px rgba(255, 255, 255, 0.1) inset;
  transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}

.onboarding-main-continue-btn:hover {
  transform: translateY(-1px);
  filter: brightness(1.07);
  box-shadow: 0 14px 40px rgba(99, 102, 241, 0.52);
}

.onboarding-main-continue-btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
  transform: none;
}

.onboarding-dynamic-card {
  margin-top: 2px;
}

.onboarding-dynamic-card-inner {
  padding: 16px 18px;
  border-radius: 16px;
  background: rgba(15, 23, 42, 0.38);
  border: 1px solid rgba(148, 163, 184, 0.16);
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.onboarding-dynamic-title {
  margin: 0 0 8px;
  font-size: 1.06rem;
  color: #f1f5f9;
}

.onboarding-dynamic-desc {
  margin: 0;
  font-size: 14px;
  line-height: 1.55;
  color: rgba(203, 213, 225, 0.92);
}

.onboarding-dynamic-example {
  margin: 12px 0 0;
  font-size: 13px;
  font-style: italic;
  color: rgba(165, 180, 252, 0.95);
}

.onboarding-sheet-warning--glass {
  margin-top: 12px;
  border-color: rgba(251, 191, 36, 0.45) !important;
  background: rgba(120, 53, 15, 0.28) !important;
  color: #fde68a !important;
}

.onboarding-dynamic-help-btn {
  margin-top: 12px;
  width: 100%;
}

.onboarding-oneclick-hero button.secondary {
  background: rgba(255, 255, 255, 0.08);
  color: #e2e8f0;
  border: 1px solid rgba(148, 163, 184, 0.35);
}

.onboarding-oneclick-hero button.secondary:hover {
  background: rgba(255, 255, 255, 0.12);
}

.onboarding-oneclick-help {
  margin-top: 16px;
  border-color: rgba(129, 140, 248, 0.28);
  background: rgba(255, 255, 255, 0.06);
  color: rgba(226, 232, 240, 0.9);
}

.onboarding-oneclick-success {
  padding: 32px 24px 28px;
}

.onboarding-oneclick-success h2 {
  color: #f8fafc;
  margin-bottom: 8px;
}

.onboarding-oneclick-success-sub {
  color: rgba(203, 213, 225, 0.92);
  margin: 0 0 20px;
}

.onboarding-success-cta {
  max-width: 340px;
  margin: 0 auto;
  display: block;
}

@keyframes onboarding-highlight-pulse {
  0%,
  100% {
    box-shadow: 0 0 0 0 rgba(129, 140, 248, 0.45), 0 0 0 0 rgba(168, 85, 247, 0.15);
  }

  50% {
    box-shadow: 0 0 0 7px rgba(129, 140, 248, 0.22), 0 0 42px rgba(139, 92, 246, 0.4);
  }
}

.onboarding-highlight-target {
  outline: 2px solid rgba(165, 180, 252, 0.95) !important;
  outline-offset: 4px;
  animation: onboarding-highlight-pulse 1.08s ease-in-out 2;
  position: relative;
  z-index: 2;
}

.dashboard-onboarding-steps {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 18px;
}

.onboarding-step-v2 {
  flex-direction: column;
  align-items: stretch;
  gap: 12px;
  padding: 16px 16px 14px;
}

.onboarding-step-v2-inner {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.onboarding-step-v2 .onboarding-step-body {
  flex: 1;
  min-width: 0;
}

.onboarding-step-v2 .onboarding-step-body strong {
  display: block;
  font-size: 1.02rem;
  color: #0f172a;
}

.onboarding-step-desc {
  display: block;
  margin-top: 4px;
  line-height: 1.45;
}

.onboarding-step-example {
  margin: 8px 0 0;
  font-size: 13px;
  font-style: italic;
}

.onboarding-sheet-warning {
  margin: 10px 0 0;
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid #fcd34d;
  background: #fffbeb;
  color: #92400e;
  font-size: 13px;
  line-height: 1.4;
}

.onboarding-step-inline-actions {
  margin-top: 10px;
}

.onboarding-step-footer {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

.onboarding-step-footer button {
  margin-left: 0;
  width: 100%;
}

.onboarding-cta-bright {
  background: linear-gradient(180deg, #fbbf24 0%, #f59e0b 100%) !important;
  color: #1c1917 !important;
  border: none !important;
  font-weight: 700;
  box-shadow: 0 8px 20px rgba(245, 158, 11, 0.35);
}

.onboarding-cta-bright:hover:not(:disabled) {
  filter: brightness(1.05);
}

.dashboard-onboarding-success {
  text-align: center;
  padding: 28px 20px 24px;
}

.dashboard-onboarding-success h2 {
  margin-bottom: 8px;
}

.onboarding-oneclick-hero .dashboard-onboarding-success.onboarding-oneclick-success {
  text-align: center;
  padding: 36px 28px 32px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.05);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  margin: 0;
}

.import-csv-share-warning {
  margin: 0 0 10px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid #fcd34d;
  background: #fffbeb;
  color: #92400e;
  font-size: 13px;
  font-weight: 600;
  line-height: 1.45;
}

.import-namelist-block {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.import-namelist-block select#contactSourceSelect {
  width: 100%;
  max-width: 100%;
}

.import-namelist-privacy {
  margin: 0;
  font-size: 13px;
  line-height: 1.45;
}

.import-namelist-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.import-namelist-block--grouped {
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid #e2e8f0;
  background: #f8fafc;
}

.import-namelist-actions--primary {
  padding-top: 10px;
  margin-top: 6px;
  border-top: 1px solid #e2e8f0;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

.import-csv-section--in-namelist {
  margin-top: 10px;
  padding-top: 12px;
  border-top: 1px solid #e2e8f0;
}

.import-csv-section--in-namelist label[for="importCsvUrl"] {
  display: block;
}

.import-csv-section--in-namelist input#importCsvUrl {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

.import-csv-section--in-namelist .import-data-row {
  flex-wrap: wrap;
  max-width: 100%;
  min-width: 0;
}

.import-csv-section--in-namelist #sheetConnectionStatus {
  flex: 1 1 180px;
  min-width: 0;
}

.import-step-heading {
  margin: 0 0 8px;
  font-size: 1rem;
  font-weight: 600;
  color: #475569;
  letter-spacing: 0.01em;
}

.dashboard-step-heading--with-action {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px 12px;
}

.dashboard-step-heading--with-action .dashboard-step-title {
  margin: 0;
}

/* Coming soon tab placeholders (Leads / Follow-ups) */
.coming-soon-tab-panel {
  padding: 4px 0 10px;
}

.coming-soon-card {
  max-width: 560px;
  margin: 0 auto;
  padding: 22px 20px 24px;
  border-radius: 14px;
  border: 1px solid #e2e8f0;
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 98%);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.05);
}

.coming-soon-card-header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 14px;
  margin-bottom: 12px;
}

.coming-soon-card-title {
  margin: 0;
  font-size: clamp(1.25rem, 3vw, 1.45rem);
  font-weight: 700;
  color: #0f172a;
  letter-spacing: -0.02em;
}

.coming-soon-badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  background: #eef2ff;
  color: #4338ca;
  border: 1px solid #c7d2fe;
}

.coming-soon-card-lead {
  margin: 0 0 16px;
  line-height: 1.55;
  color: #475569;
  font-size: 0.98rem;
}

.coming-soon-features {
  margin: 0 0 20px;
  padding-left: 1.15rem;
  color: #334155;
  font-size: 0.94rem;
  line-height: 1.55;
}

.coming-soon-features li {
  margin-bottom: 8px;
}

.coming-soon-features li:last-child {
  margin-bottom: 0;
}

.coming-soon-back-btn {
  width: 100%;
  max-width: 280px;
}

.dashboard-usage-summary {
  margin-bottom: 20px;
  padding: 1.1rem 1.25rem 1.15rem;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: linear-gradient(180deg, #fafbfc 0%, #ffffff 100%);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.dashboard-usage-summary-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 0.35rem;
}

.dashboard-usage-summary-title {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 650;
  letter-spacing: -0.01em;
  color: #0f172a;
}

.dashboard-usage-plan-line {
  margin: 0 0 0.35rem;
  font-size: 0.95rem;
  color: #475569;
}

.dashboard-usage-plan-line strong {
  color: #0f172a;
  font-weight: 650;
}

.dashboard-usage-meter-line {
  margin: 0 0 0.2rem;
  font-size: 1.02rem;
  font-weight: 600;
  color: #0f172a;
  letter-spacing: -0.01em;
}

.dashboard-usage-remaining-line {
  margin: 0 0 0.85rem;
  font-size: 0.95rem;
  color: #64748b;
}

.dashboard-usage-bar-track {
  width: 100%;
  max-width: 520px;
  height: 12px;
  background: #e2e8f0;
  border-radius: 999px;
  overflow: hidden;
  box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.06);
}

.dashboard-usage-bar-track--near .dashboard-usage-bar-fill {
  background: linear-gradient(90deg, #f59e0b, #fbbf24);
}

.dashboard-usage-bar-track--full .dashboard-usage-bar-fill {
  background: linear-gradient(90deg, #dc2626, #f87171);
}

.dashboard-usage-bar-fill {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, #1d4ed8, #3b82f6);
  border-radius: 999px;
  transition: width 0.35s ease;
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.25) inset;
}

.usage-warn-banner {
  margin-top: 12px;
  padding: 10px 12px;
  border-radius: 10px;
  background: #fffbeb;
  border: 1px solid #fde68a;
  color: #92400e;
  font-size: 0.9rem;
  line-height: 1.4;
}

.usage-blocked-banner {
  margin-top: 12px;
  padding: 10px 12px;
  border-radius: 10px;
  background: #fef2f2;
  border: 1px solid #fecaca;
  color: #991b1b;
  font-size: 0.9rem;
  line-height: 1.45;
  font-weight: 500;
}

.billing-restriction-slot {
  margin-bottom: 12px;
}

.billing-restriction-slot .billing-restriction-cta {
  margin-left: 6px;
  padding: 0;
  border: none;
  background: none;
  color: inherit;
  font: inherit;
  font-weight: 600;
  text-decoration: underline;
  cursor: pointer;
}

.billing-restriction-slot .billing-restriction-cta:hover {
  opacity: 0.85;
}

@media (min-width: 480px) {
  .coming-soon-back-btn {
    width: auto;
  }
}

.dashboard-onboarding-main--compact .campaign-readiness-grid,
.campaign-readiness-grid.campaign-readiness-grid--compact {
  gap: 6px;
  margin-top: 10px;
}

.dashboard-onboarding-main--compact .campaign-readiness-row,
.campaign-readiness-grid.campaign-readiness-grid--compact .campaign-readiness-row {
  padding: 8px 10px;
  font-size: 0.93rem;
}

.dashboard-onboarding-main--compact .dashboard-onboarding-progress,
.dashboard-onboarding-main--compact .onboarding-oneclick-progress {
  margin-top: 10px;
}

.contact-source-detail-notes {
  white-space: pre-wrap;
  word-break: break-word;
}

.campaign-readiness-grid {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}

.campaign-readiness-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  flex-wrap: wrap;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid #e2e8f0;
  background: #f8fafc;
}

.campaign-readiness-row.is-ready {
  border-color: #86efac;
  background: #f0fdf4;
}

.campaign-readiness-row.is-pending {
  border-color: #e2e8f0;
}

.campaign-readiness-label {
  font-weight: 600;
  color: #0f172a;
}

.campaign-readiness-value {
  text-align: right;
  color: #334155;
  font-size: 0.95rem;
  max-width: 100%;
  word-break: break-word;
}

/* Returning users: compact readiness summary (pills instead of 4-row grid) */
.campaign-readiness-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
  padding: 0;
  list-style: none;
}

.dashboard-onboarding-main--compact .campaign-readiness-chips {
  margin-top: 10px;
}

.campaign-readiness-chip {
  display: inline-flex;
  align-items: center;
  padding: 5px 11px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.02em;
  border: 1px solid rgba(226, 232, 240, 0.95);
  background: rgba(248, 250, 252, 0.96);
  color: #475569;
}

.campaign-readiness-chip.is-ready {
  border-color: rgba(52, 211, 153, 0.65);
  background: rgba(240, 253, 244, 0.98);
  color: #166534;
}

.campaign-readiness-chip.is-pending {
  border-color: rgba(251, 191, 36, 0.65);
  background: rgba(254, 252, 232, 0.98);
  color: #92400e;
}

.dashboard-onboarding-main--compact .dashboard-onboarding-glass {
  padding: 18px 18px 16px;
}

.dashboard-onboarding-main--compact .onboarding-oneclick-eyebrow {
  margin-bottom: 6px;
}

.dashboard-onboarding-main--compact .onboarding-oneclick-hero #dashboardOnboardingTitle,
.dashboard-onboarding-main--compact .onboarding-oneclick-hero h2 {
  font-size: clamp(1.15rem, 3vw, 1.42rem);
  margin-bottom: 6px;
}

.dashboard-onboarding-main--compact .onboarding-oneclick-subtitle {
  font-size: 0.94rem;
  line-height: 1.45;
  margin-bottom: 0;
}

.dashboard-onboarding-main--compact .dashboard-onboarding-progress-track {
  display: none;
}

.dashboard-onboarding-main--compact .dashboard-onboarding-progress-label,
.dashboard-onboarding-main--compact .onboarding-oneclick-hero .dashboard-onboarding-progress-label {
  margin-top: 10px;
  font-size: 0.88rem;
  opacity: 0.95;
}

.dashboard-onboarding-main--compact .onboarding-main-continue-btn {
  margin-top: 12px;
}

.dashboard-onboarding-main--compact .onboarding-help-banner,
.dashboard-onboarding-main--compact .onboarding-oneclick-help {
  display: none !important;
}

.dashboard-onboarding-main--compact #onboardingSupportBtn {
  display: none;
}

@media (max-width: 560px) {
  .dashboard-onboarding-main--compact .onboarding-main-continue-btn {
    width: 100%;
    box-sizing: border-box;
    padding: 11px 16px;
    min-height: 46px;
    max-height: 52px;
    font-size: 0.92rem;
    border-radius: 10px;
    margin-top: 10px;
    margin-bottom: 12px;
    box-shadow:
      0 6px 22px rgba(79, 70, 229, 0.38),
      0 0 0 1px rgba(255, 255, 255, 0.08) inset;
  }

  .nav-coming-soon-badge {
    font-size: 8px;
    padding: 2px 6px;
    letter-spacing: 0.04em;
  }

  .campaign-readiness-chips {
    gap: 6px;
  }
}

.main-operation-one-liner {
  margin-top: 0;
  margin-bottom: 12px;
}

.campaign-mini-guide-wrap {
  margin-top: 4px;
}

.campaign-preview-pre-import {
  padding: 14px 16px;
  border-radius: 12px;
  border: 1px solid #e2e8f0;
  background: #fafafa;
}

.campaign-preview-pre-import-lead {
  margin: 0 0 10px;
  line-height: 1.5;
  color: #1e293b;
}

.campaign-preview-pre-import-safe {
  margin: 0;
  font-size: 0.92rem;
  line-height: 1.45;
}

.active-campaign-empty-state {
  padding: 16px 4px 8px;
}

.active-campaign-empty-title {
  margin: 0 0 8px;
  font-size: 1.05rem;
}

.active-campaign-empty-text {
  margin: 0;
  line-height: 1.5;
}

.message-sequence-preview-unready {
  opacity: 0.55;
  cursor: not-allowed;
}

@media (max-width: 640px) {
  .import-namelist-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .import-namelist-actions button {
    width: 100%;
  }

  .campaign-readiness-value {
    text-align: left;
    width: 100%;
  }

  .onboarding-main-continue-btn {
    width: 100%;
    min-height: 44px;
  }
}

.google-sheet-help-modal {
  display: none;
}

.google-sheet-help-modal:not(.hidden) {
  display: flex;
}

.google-sheet-help-modal-card {
  width: min(440px, 92vw);
  max-height: 85vh;
  overflow: auto;
  border-radius: 14px;
  padding: 18px;
  background: #fff;
  box-shadow: 0 24px 70px rgba(15, 23, 42, 0.24);
}

.google-sheet-help-steps {
  margin: 0;
  padding-left: 1.2rem;
  line-height: 1.6;
}

.google-sheet-help-steps li {
  margin-bottom: 6px;
}

.campaign-create-modal-card {
  width: min(520px, 92vw);
  max-height: 85vh;
  overflow: auto;
  border-radius: 16px;
  padding: 18px;
  background: #fff;
  box-shadow: 0 24px 70px rgba(15, 23, 42, 0.24);
}

.campaign-create-modal-card h3 {
  margin: 0;
}

.campaign-create-modal-steps {
  display: grid;
  gap: 8px;
  margin-top: 14px;
}

.campaign-create-modal-steps span {
  padding: 10px 12px;
  border: 1px solid #dbeafe;
  border-radius: 10px;
  background: #f8fbff;
  color: #1e3a8a;
  font-weight: 700;
}

.first-campaign-success-card {
  width: min(520px, 92vw);
  max-height: 85vh;
  overflow: auto;
  border: 1px solid #bbf7d0;
  border-radius: 20px;
  padding: 24px;
  background:
    radial-gradient(circle at top right, rgba(34, 197, 94, 0.14), transparent 34%),
    #ffffff;
  box-shadow: 0 28px 80px rgba(15, 23, 42, 0.28);
  animation: firstCampaignSuccessIn 0.24s ease-out;
  text-align: center;
}

.first-campaign-success-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: 999px;
  background: #16a34a;
  color: #fff;
  font-size: 28px;
  font-weight: 900;
}

.first-campaign-success-card h3 {
  margin: 14px 0 8px;
  color: #14532d;
  font-size: 24px;
}

.first-campaign-success-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 18px;
}

.first-campaign-success-stats div {
  padding: 12px;
  border: 1px solid #dcfce7;
  border-radius: 14px;
  background: #f0fdf4;
}

.first-campaign-success-stats span,
.first-campaign-success-stats strong {
  display: block;
}

.first-campaign-success-stats span {
  color: #166534;
  font-size: 13px;
  font-weight: 700;
}

.first-campaign-success-stats strong {
  margin-top: 4px;
  color: #052e16;
  font-size: 20px;
}

.first-campaign-upsell {
  margin-top: 16px;
  color: #166534;
  font-weight: 700;
}

.first-campaign-success-actions {
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-top: 18px;
}

@keyframes firstCampaignSuccessIn {
  from {
    opacity: 0;
    transform: translateY(10px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.campaign-mini-guide {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: 14px;
}

.campaign-mini-guide div {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px;
  border: 1px solid #dbeafe;
  border-radius: 10px;
  background: #fff;
}

.campaign-mini-guide strong {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  background: #2563eb;
  color: #fff;
  font-size: 13px;
}

.campaign-mini-guide span {
  font-size: 14px;
  font-weight: 600;
}

.campaign-warning {
  padding: 10px 12px;
  border: 1px solid #fed7aa;
  border-radius: 8px;
  background: #fff7ed;
  color: #9a3412;
}

.instance-dup-warning {
  margin: 0 0 12px;
  padding: 12px 14px;
  border-radius: 10px;
  border: 1px solid #fecaca;
  background: #fef2f2;
  color: #7f1d1d;
  font-size: 14px;
  line-height: 1.45;
}

.instance-dup-warning strong {
  display: block;
  margin-bottom: 8px;
  font-size: 15px;
  color: #991b1b;
}

.instance-dup-warning ul {
  margin: 10px 0 0;
  padding-left: 18px;
}

.instance-dup-warning li {
  margin: 6px 0;
}

.support-inline-link {
  margin: 6px 0 10px;
  padding: 0;
  border: none;
  background: transparent;
  color: #0ea5e9;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
  cursor: pointer;
}

.support-inline-link:hover {
  color: #0284c7;
}

.campaign-safety-hint {
  margin-top: 6px;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.82);
}

.campaign-safety-tooltip {
  cursor: help;
  font-weight: 700;
  color: #93c5fd;
}

.safe-sending-trust-panel {
  border: 1px solid #bfdbfe;
  border-radius: 12px;
  background: #eff6ff;
  padding: 12px;
}

.safe-sending-trust-panel h3 {
  margin: 0 0 6px;
  color: #1e3a8a;
}

.safe-sending-trust-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(180px, 1fr));
  gap: 8px 14px;
  margin-top: 8px;
}

/* Campaign review: lead source + safety level */
.campaign-safety-controls {
  border: 1px solid rgba(226, 232, 240, 0.95);
  border-radius: 12px;
  padding: 14px 16px;
  background: #fafafa;
}

.campaign-safety-heading {
  margin: 0 0 12px;
  font-size: 1rem;
}

.campaign-safety-field {
  margin-bottom: 14px;
}

.campaign-lead-source-hint {
  margin-top: 6px;
  margin-bottom: 0;
  font-size: 13px;
  line-height: 1.4;
}

.campaign-safety-field label[for="campaignLeadSourceSelect"] {
  display: block;
  font-weight: 600;
  margin-bottom: 6px;
  font-size: 0.9rem;
}

.campaign-safety-field select {
  width: 100%;
  max-width: 360px;
  padding: 8px 10px;
  border-radius: 8px;
  border: 1px solid #e5e7eb;
  font-size: 0.95rem;
}

.campaign-safety-slider-head label {
  font-weight: 600;
  font-size: 0.9rem;
}

.campaign-safety-slider-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 8px;
}

.campaign-safety-slider-edge {
  font-size: 0.82rem;
  color: #64748b;
  flex: 0 0 auto;
}

.campaign-safety-slider-row input[type="range"] {
  flex: 1;
  min-width: 0;
}

.campaign-safety-warning {
  margin: 8px 0 0;
  font-size: 0.88rem;
  color: #b45309;
}

.campaign-safety-policy-preview {
  font-size: 0.88rem;
  line-height: 1.45;
  color: #334155;
  margin-bottom: 12px;
}

.campaign-safety-policy-preview h4 {
  margin: 0 0 6px;
  font-size: 0.92rem;
}

.campaign-safety-policy-preview ul {
  margin: 0 0 8px;
  padding-left: 1.2em;
}

.campaign-safety-policy-preview .campaign-safety-advisory {
  margin-top: 8px;
  font-size: 0.82rem;
  color: #64748b;
}

.campaign-optin-confirmation {
  text-align: left;
  width: 100%;
  max-width: 100%;
  margin-top: 4px;
  padding: 12px 14px;
  border-radius: 10px;
  border: 1px solid #fecaca;
  background: linear-gradient(to bottom, #fffbeb 0%, #fff7ed 100%);
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
}

.campaign-daily-risk-warning {
  margin: 8px 0 10px;
  padding: 12px 14px;
  border-radius: 10px;
  border: 1px solid #f59e0b;
  background: linear-gradient(to bottom, #fffbeb 0%, #fff7ed 100%);
  color: #78350f;
}

.campaign-daily-risk-warning h4 {
  margin: 0 0 6px;
  font-size: 0.95rem;
}

.campaign-daily-risk-warning p {
  margin: 0 0 10px;
  font-size: 0.9rem;
  line-height: 1.45;
}

.campaign-required-star {
  color: #dc2626;
  font-weight: 700;
  margin-right: 4px;
}

.campaign-opt-in-label {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 0.95rem;
  font-weight: 600;
  color: #1e293b;
  cursor: pointer;
  line-height: 1.45;
  margin: 0;
  text-align: left;
}

.campaign-optin-label-text {
  flex: 1;
  min-width: 0;
}

.campaign-opt-in-label input {
  margin-top: 4px;
  flex-shrink: 0;
  width: 18px;
  height: 18px;
}

.register-responsibility-note {
  margin-top: 8px;
  max-width: 760px;
}

.floating-support-btn {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 9998;
  border: none;
  border-radius: 999px;
  padding: 12px 16px;
  background: linear-gradient(135deg, #25d366, #16a34a);
  color: #ffffff;
  font-weight: 700;
  box-shadow: 0 10px 24px rgba(22, 163, 74, 0.34);
  cursor: pointer;
  transition: transform 0.18s ease, box-shadow 0.18s ease, filter 0.18s ease;
}

.floating-support-btn:hover {
  transform: scale(1.04);
  filter: brightness(1.03);
  box-shadow: 0 12px 30px rgba(22, 163, 74, 0.4);
}

.super-admin-system-banner {
  margin: 0 0 14px;
  padding: 10px 12px;
  border-radius: 8px;
  border: 1px solid #e2e8f0;
  background: #f8fafc;
  color: #475569;
  font-weight: 600;
  font-size: 0.9rem;
  letter-spacing: 0.01em;
}

.progress-track {
  width: 100%;
  max-width: 420px;
  height: 10px;
  background: #e5e7eb;
  border-radius: 999px;
  overflow: hidden;
}

.progress-fill {
  height: 100%;
  width: 0%;
  background: #2563eb;
  transition: width 0.2s ease;
}

.active-campaign-all-filtered .progress-track {
  display: none;
}

.active-campaign-all-filtered #activeCampaignProgressText {
  color: #166534;
  font-weight: 700;
}

.grid.two {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.grid.three {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 12px;
}

#stepUploadProgressWrap {
  width: 100%;
  max-width: 420px;
  height: 8px;
  background: #e5e7eb;
  border-radius: 999px;
  overflow: hidden;
}

#stepUploadProgressBar {
  width: 0%;
  height: 100%;
  background: #3b82f6;
  transition: width 0.15s linear;
}

#stepMediaPreview img {
  max-width: 240px;
  border-radius: 8px;
  border: 1px solid #d1d5db;
}

label {
  font-size: 14px;
  color: #374151;
}

input {
  width: 100%;
  max-width: 420px;
  padding: 8px 10px;
  border: 1px solid #d1d5db;
  border-radius: 8px;
  font-size: 14px;
}

input[readonly] {
  background: #f3f4f6;
  color: #4b5563;
}

textarea {
  width: 100%;
  max-width: 100%;
  padding: 8px 10px;
  border: 1px solid #d1d5db;
  border-radius: 8px;
  font-size: 14px;
  font-family: inherit;
}

select {
  width: 100%;
  max-width: 420px;
  padding: 8px 10px;
  border: 1px solid #d1d5db;
  border-radius: 8px;
  font-size: 14px;
  background: #fff;
}

button {
  border: 0;
  background: #2563eb;
  color: #fff;
  padding: 9px 12px;
  border-radius: 8px;
  font-size: 14px;
  cursor: pointer;
}

button:hover {
  background: #1d4ed8;
}

button.secondary {
  background: #374151;
}

button.secondary:hover {
  background: #1f2937;
}

button.danger {
  background: #dc2626;
}

button.danger:hover {
  background: #b91c1c;
}

button:disabled {
  cursor: not-allowed;
  opacity: 0.6;
}

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

.dashboard-step-heading {
  margin: 12px 0 8px;
}

.dashboard-step-title {
  margin: 0;
  font-size: 14px;
  font-weight: 700;
  color: #1e3a8a;
}

.dashboard-step-subtitle {
  margin: 4px 0 0;
  font-size: 13px;
}

.message-sequence-card {
  scroll-margin-top: 12px;
}

.message-sequence-compact-panel {
  scroll-margin-top: 12px;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid #e5e7eb;
}

.message-sequence-compact-panel .message-sequence-summary-dl {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.message-sequence-details.message-sequence-details--editor > summary.message-sequence-editor-summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  gap: 10px;
  align-items: center;
  padding: 10px 4px;
  margin: 0 -4px;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 600;
  color: #1e3a8a;
}

.message-sequence-details.message-sequence-details--editor > summary.message-sequence-editor-summary::-webkit-details-marker {
  display: none;
}

.message-sequence-editor-summary-text {
  flex: 1 1 auto;
  min-width: 0;
}

.active-campaign-compact-line {
  margin: 6px 0 12px;
  font-size: 13px;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.active-campaign-step-details {
  margin-top: 4px;
}

.active-campaign-step-details > summary.active-campaign-step-summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  gap: 10px;
  align-items: center;
  padding: 8px 4px;
  margin: 0 -4px;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 600;
  color: #1e3a8a;
}

.active-campaign-step-details > summary.active-campaign-step-summary::-webkit-details-marker {
  display: none;
}

.active-campaign-step-summary-label {
  flex: 1 1 auto;
  min-width: 0;
}

.active-campaign-step-details-body {
  padding-top: 8px;
  border-top: 1px solid #e5e7eb;
  margin-top: 8px;
}

.message-sequence-details summary.message-sequence-summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 4px 2px 8px;
  border-radius: 8px;
}

.message-sequence-details summary.message-sequence-summary::-webkit-details-marker {
  display: none;
}

.message-sequence-summary-chevron {
  flex: 0 0 auto;
  font-size: 12px;
  line-height: 1.6;
  color: #64748b;
  margin-top: 4px;
}

.message-sequence-summary-inner {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.message-sequence-summary-header-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.message-sequence-summary-title {
  font-size: 16px;
  font-weight: 700;
  color: #1e3a8a;
}

.message-sequence-status {
  font-size: 12px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 999px;
  white-space: nowrap;
}

.message-sequence-status-needs-setup {
  background: #fef3c7;
  color: #92400e;
}

.message-sequence-status-check-sequence {
  background: #e0f2fe;
  color: #0c4a6e;
}

.message-sequence-status-select-project {
  background: #f1f5f9;
  color: #475569;
}

.message-sequence-status-ready {
  background: #dcfce7;
  color: #166534;
}

.message-sequence-summary-dl {
  margin: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px 16px;
  font-size: 13px;
}

.message-sequence-summary-dl-item {
  margin: 0;
  min-width: 0;
}

.message-sequence-summary-dl dt {
  margin: 0;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: #64748b;
}

.message-sequence-summary-dl dd {
  margin: 2px 0 0;
  font-weight: 600;
  color: #0f172a;
  overflow-wrap: anywhere;
}

.message-sequence-summary-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-top: 0;
  width: 100%;
}

.message-sequence-summary-actions .secondary {
  flex: 1 1 200px;
  min-width: min(100%, 160px);
  max-width: 100%;
}

.message-sequence-details-body {
  padding-top: 4px;
  border-top: 1px solid #e5e7eb;
  margin-top: 8px;
}

.message-sequence-builder-block {
  margin-top: 8px;
}

.message-sequence-builder-card.card {
  margin: 0;
  box-shadow: none;
  border: 1px solid #e2e8f0;
  background: #fff;
}

@media (min-width: 640px) {
  .message-sequence-summary-actions {
    flex-wrap: nowrap;
  }

  .message-sequence-summary-actions .secondary {
    flex: 1 1 0;
    min-width: 0;
    max-width: none;
  }
}

.admin-company-filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 10px 0 12px;
  align-items: center;
}

.admin-company-filter-btn.active {
  box-shadow: 0 0 0 2px #1d4ed8;
}

.admin-console-header {
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: 14px;
  margin-bottom: 12px;
  background: linear-gradient(180deg, #ffffff, #f8fafc);
}

.admin-console-header h2 {
  margin-bottom: 6px;
}

.admin-ops-status-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 12px 0 10px;
}

.admin-ops-chip {
  display: inline-flex;
  align-items: center;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid #dbeafe;
  background: #eff6ff;
  color: #1e3a8a;
  font-size: 12px;
  font-weight: 700;
}

.admin-console-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.admin-subtab-strip {
  flex-wrap: nowrap;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-gutter: stable;
  max-width: 100%;
  padding-bottom: 2px;
  gap: 6px;
}

/* Admin subtabs: explicit colors so active never inherits white text on a light bg (global `button` uses white). */
#adminSection .admin-subtab-strip .admin-subtab-btn {
  flex: 0 0 auto;
  white-space: nowrap;
  background: #f3f4f6;
  color: #1f2937;
  border: 1px solid #d1d5db;
  box-shadow: none;
}

#adminSection .admin-subtab-strip .admin-subtab-btn:hover {
  background: #e5e7eb;
  color: #111827;
  border-color: #9ca3af;
}

#adminSection .admin-subtab-strip .admin-subtab-btn:focus-visible {
  outline: 2px solid #3b82f6;
  outline-offset: 2px;
}

#adminSection .admin-subtab-strip .admin-subtab-btn.admin-subtab-btn--active,
#adminSection .admin-subtab-strip .admin-subtab-btn[aria-selected="true"] {
  background: linear-gradient(180deg, #2563eb 0%, #1e3a8a 100%);
  color: #fff;
  border: 1px solid #1d4ed8;
  box-shadow: 0 0 0 1px rgba(37, 99, 235, 0.35), 0 1px 2px rgba(15, 23, 42, 0.12);
}

#adminSection .admin-subtab-strip .admin-subtab-btn.admin-subtab-btn--active:hover,
#adminSection .admin-subtab-strip .admin-subtab-btn[aria-selected="true"]:hover {
  background: linear-gradient(180deg, #1d4ed8 0%, #172554 100%);
  color: #fff;
  border-color: #1e40af;
}

#adminSection .admin-subtab-strip .admin-subtab-btn.admin-subtab-btn--active:focus-visible,
#adminSection .admin-subtab-strip .admin-subtab-btn[aria-selected="true"]:focus-visible {
  outline: 2px solid #dbeafe;
  outline-offset: 2px;
}

/* Super Admin sub-tab panels: only one visible; class + hidden kept in sync in app.js */
#adminSection .admin-subtab-panel:not(.admin-subtab-panel--active) {
  display: none !important;
}

#adminSection .admin-subtab-panel.admin-subtab-panel--active {
  display: block !important;
  max-width: 100%;
  overflow-x: auto;
}

@media print {
  #adminSection .admin-subtab-panel:not(.admin-subtab-panel--active) {
    display: none !important;
  }

  #adminSection .admin-subtab-panel.admin-subtab-panel--active {
    display: block !important;
  }
}

.admin-overview-attention-preview .admin-overview-attention-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 10px 0 12px;
  max-width: 100%;
}

.admin-overview-issue-chip {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  max-width: 100%;
  word-break: break-word;
}

.admin-overview-issue-chip--critical {
  border: 1px solid #fecaca;
  background: #fef2f2;
  color: #991b1b;
}

.admin-overview-issue-chip--warning {
  border: 1px solid #fcd34d;
  background: #fffbeb;
  color: #92400e;
}

.admin-focus-highlight {
  box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.45), 0 0 0 5px rgba(191, 219, 254, 0.8);
  border-radius: 10px;
}

.admin-company-summary-row-line {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px 8px;
}

.admin-company-summary-sep {
  user-select: none;
}

.admin-summary-usage-strip {
  flex: 0 1 220px;
  min-width: 180px;
  max-width: 260px;
}

.admin-summary-usage-strip .admin-usage > div:first-child {
  font-size: 0.82rem;
}

.admin-summary-usage-strip .admin-usage-track {
  height: 7px;
}

.admin-health-badge,
.admin-usage-warn-badge {
  flex-shrink: 0;
}

.admin-company-card-one-line {
  font-size: 0.88rem;
  color: var(--muted-text, #6b7280);
}

.admin-company-card-one-line .admin-company-card-name-strong {
  color: #111827;
}

.admin-company-card-badges-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.admin-company-actions-cell .admin-plan-select {
  display: block;
  width: 100%;
  max-width: 220px;
  margin-bottom: 8px;
}

.admin-needs-attention-empty.hidden {
  display: none;
}

.admin-needs-attention-empty {
  margin: 8px 0 0;
}

.admin-attention-chip {
  margin: 2px 4px 2px 0;
}

.admin-attention-reasons {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 10px 0 4px;
}

.admin-needs-attention-h4 {
  margin: 16px 0 8px;
  font-size: 0.95rem;
}

.admin-needs-attention-subempty {
  margin: -2px 0 10px;
}

.admin-needs-attention-table-wrap {
  overflow-x: auto;
}

/* Admin: company-centric Business view */
.admin-companies-centric-table .admin-company-summary-row td {
  vertical-align: top;
}

.admin-company-summary-sub {
  font-size: 0.82rem;
  margin-top: 4px;
  line-height: 1.3;
}

.admin-company-detail-row td {
  padding: 0;
}

.admin-company-nested-shell {
  padding: 12px 12px 14px 20px;
  background: #f9fafb;
  border-top: 1px solid #e5e7eb;
  border-bottom: 1px solid #e5e7eb;
}

.admin-company-nested-inner .admin-nested-meta {
  margin: 0 0 12px;
  font-size: 0.85rem;
}

.admin-nested-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

@media (max-width: 900px) {
  .admin-nested-cols {
    grid-template-columns: 1fr;
  }
}

.admin-nested-panel {
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  padding: 10px 12px;
  background: #fff;
}

.admin-nested-label {
  display: block;
  margin-bottom: 8px;
  font-size: 0.9rem;
}

.admin-nested-ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.admin-nested-li {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  padding: 8px 0;
  border-bottom: 1px solid #f3f4f6;
}

.admin-nested-li:last-child {
  border-bottom: none;
}

.admin-nested-li-main {
  flex: 1 1 160px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.admin-nested-li-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.admin-nested-footer {
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px dashed #e5e7eb;
}

.admin-nested-hint {
  font-size: 0.78rem;
  margin: 0 0 8px;
}

.admin-nested-empty {
  margin: 4px 0 0;
  font-size: 0.85rem;
}

.admin-company-card-title-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 8px;
  flex-wrap: wrap;
}

.admin-company-card-meta-line {
  margin: 6px 0 10px;
  font-size: 0.88rem;
}

.admin-company-card-toolbar {
  margin-top: 8px;
}

.admin-company-card-details {
  margin-top: 12px;
  padding: 12px;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  background: #f9fafb;
}

.admin-companies-centric-cards {
  gap: 12px;
}

.admin-company-actions-cell {
  white-space: normal;
}

.admin-company-actions-cell .admin-save-plan-btn,
.admin-company-actions-cell .admin-company-status-btn {
  display: inline-block;
  margin: 2px 4px 2px 0;
}

.admin-flat-users-details summary {
  cursor: pointer;
  font-weight: 600;
  padding: 4px 0;
}

.admin-flat-users-details > .muted {
  margin: 8px 0 10px;
  font-size: 0.88rem;
}

.sub-card {
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  padding: 12px;
  margin-top: 12px;
}

.import-step-card h3 {
  margin-bottom: 6px;
}

.sub-card h3 {
  margin: 0 0 10px;
}

.settings-mode-label {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  background: #eff6ff;
  color: #1d4ed8;
  font-weight: 700;
  padding: 6px 10px;
  margin: 4px 0 8px;
}

.selected-project-row {
  background: #eff6ff;
}

.top-gap {
  margin-top: 12px;
}

details {
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  padding: 10px 12px;
  background: #f9fafb;
}

/* Advanced logs: single disclosure cue (arrow in label; hide duplicate native marker) */
#logsDetails > summary {
  list-style: none;
  cursor: pointer;
  user-select: none;
}

#logsDetails > summary::-webkit-details-marker {
  display: none;
}

details > summary {
  cursor: pointer;
  font-weight: 600;
  color: #111827;
}

.steps-card-list {
  display: grid;
  gap: 18px;
  margin-top: 12px;
  justify-items: center;
}

.step-flow-item {
  position: relative;
  width: 100%;
  max-width: 760px;
  padding-bottom: 8px;
}

.step-flow-item.with-connector {
  padding-bottom: 34px;
}

.step-flow-item.with-connector::after {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: calc(100% - 8px);
  width: 4px;
  height: 24px;
  background: #94a3b8;
  border-radius: 999px;
}

.step-flow-item.with-connector::before {
  content: "↓";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: calc(100% + 16px);
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  color: #475569;
  background: #e2e8f0;
  border-radius: 999px;
  border: 1px solid #cbd5e1;
}

.step-card {
  border: 1px solid #dbeafe;
  border-radius: 10px;
  padding: 12px;
  background: #f8fbff;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.03);
}

.step-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}

.step-card-number {
  font-weight: 700;
}

#stepsTitle {
  margin-bottom: 4px;
}

.step-card-preview {
  font-size: 14px;
  color: #374151;
  margin-bottom: 10px;
  white-space: pre-wrap;
}

.step-card-delay {
  font-size: 13px;
  color: #6b7280;
  margin-bottom: 10px;
}

.step-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

/* Message flow (Step 2): image step thumbnails + lightbox */
.step-image-flow-preview {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  max-width: 100%;
}

.step-image-thumb-btn {
  display: block;
  padding: 0;
  margin: 0;
  border: none;
  background: transparent;
  border-radius: 10px;
  cursor: pointer;
  max-width: 100%;
  line-height: 0;
}

.step-image-thumb-btn:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
}

.step-image-thumb {
  display: block;
  width: 100%;
  max-width: 220px;
  max-height: 160px;
  height: auto;
  object-fit: cover;
  border-radius: 10px;
  border: 1px solid #e5e7eb;
  background: #f8fafc;
}

.step-image-thumb-caption {
  font-size: 13px;
  word-break: break-word;
  max-width: min(220px, 100%);
}

.step-image-flow-preview.step-image-load-failed .step-image-thumb-btn {
  display: none;
}

.step-image-thumb-fallback {
  display: none;
  font-size: 13px;
  word-break: break-word;
}

.step-image-flow-preview.step-image-load-failed .step-image-thumb-fallback {
  display: block;
}

.step-image-preview-modal-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 10000;
  align-items: center;
  justify-content: center;
  padding: 16px;
  background: rgba(15, 23, 42, 0.55);
}

.step-image-preview-modal-backdrop:not(.hidden) {
  display: flex;
}

.step-image-preview-modal-dialog {
  width: min(720px, 100%);
  max-height: min(92vh, 900px);
  overflow: auto;
  border-radius: 14px;
  padding: 18px;
  background: #fff;
  box-shadow: 0 24px 70px rgba(15, 23, 42, 0.28);
}

.step-image-preview-modal-header {
  margin-bottom: 12px;
  align-items: flex-start;
}

.step-image-preview-modal-header h3 {
  margin: 0;
  font-size: 1.1rem;
}

.step-image-preview-modal-body {
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: center;
}

.step-image-preview-modal-img {
  display: block;
  max-width: 100%;
  max-height: min(70vh, 640px);
  width: auto;
  height: auto;
  object-fit: contain;
  border-radius: 10px;
}

.step-image-preview-modal-meta {
  font-size: 13px;
  text-align: center;
  word-break: break-word;
  max-width: 100%;
}

.step-current-saved-image-wrap {
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: 12px;
  background: #fafafa;
}

.step-current-saved-image-heading {
  font-size: 13px;
  font-weight: 700;
  color: #1e3a8a;
  margin-bottom: 8px;
}

.step-current-saved-image-inner {
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: flex-start;
}

.step-current-saved-image-thumb-wrap {
  max-width: 100%;
}

.step-current-saved-image-thumb-btn {
  display: block;
  padding: 0;
  margin: 0;
  border: none;
  background: transparent;
  border-radius: 10px;
  cursor: pointer;
  max-width: 100%;
  line-height: 0;
}

.step-current-saved-image-thumb {
  display: block;
  width: 100%;
  max-width: 220px;
  max-height: 160px;
  height: auto;
  object-fit: cover;
  border-radius: 10px;
  border: 1px solid #e5e7eb;
}

.step-current-saved-image-url {
  font-size: 12px;
  word-break: break-all;
  max-width: 100%;
}

.step-current-saved-image-hint {
  margin: 10px 0 0;
  font-size: 12px;
  line-height: 1.45;
}

.step-product-link-flow {
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: flex-start;
}

.step-product-link-heading {
  font-weight: 700;
  font-size: 14px;
  color: #9a3412;
}

.step-product-link-format {
  font-size: 12px;
  line-height: 1.4;
}

.step-product-link-block-gap {
  min-height: 8px;
}

.step-product-link-text {
  font-size: 14px;
  white-space: pre-wrap;
  word-break: break-word;
  color: #0f172a;
}

.step-product-link-text-empty {
  font-size: 13px;
}

.step-product-link-url a {
  word-break: break-all;
  font-size: 13px;
}

.step-product-link-flow-hint {
  margin: 4px 0 0;
  font-size: 11px;
  line-height: 1.4;
}

.step-current-saved-image-inner.is-load-failed .step-current-saved-image-thumb-wrap {
  display: none;
}

.carousel-card-preview {
  border: 1px dashed #cbd5e1;
  border-radius: 8px;
  padding: 10px;
  margin-top: 8px;
  background: #f8fafc;
}

.carousel-card-title {
  font-weight: 700;
  margin-bottom: 4px;
}

.carousel-card-buttons {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 6px;
}

table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 12px;
}

th, td {
  border-bottom: 1px solid #e5e7eb;
  text-align: left;
  padding: 10px 8px;
  font-size: 14px;
  vertical-align: top;
}

th {
  background: #f9fafb;
  white-space: nowrap;
}

.message-log-failed-row {
  background: #fff1f2;
}

.message-log-failed-row td {
  border-bottom-color: #fecdd3;
}

.message-log-card-list {
  display: none;
}

.message-log-card {
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: 14px;
  background: #fff;
}

.message-log-card-attention {
  background: #f9fafb;
}

.message-log-card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
}

.message-log-card-phone {
  margin-top: 8px;
  color: #4b5563;
  font-size: 14px;
}

.message-log-card-counts {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}

.message-log-card-counts span {
  border-radius: 999px;
  padding: 4px 8px;
  background: #f3f4f6;
  color: #374151;
  font-size: 12px;
  font-weight: 700;
}

.admin-plan-modal-card {
  background: #fff;
  border-radius: 14px;
  padding: 18px;
  width: min(560px, calc(100vw - 32px));
  max-height: calc(100vh - 48px);
  overflow: auto;
  box-shadow: 0 20px 50px rgba(15, 23, 42, 0.24);
}

.admin-plan-modal-card label {
  display: grid;
  gap: 6px;
  margin-top: 10px;
}

.message-log-card-reason {
  margin-top: 10px;
  color: #6b7280;
  font-size: 13px;
}

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

.admin-summary-card {
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  padding: 14px;
  background: #f9fafb;
}

.admin-summary-card span {
  display: block;
  color: #6b7280;
  font-size: 13px;
}

.admin-summary-card strong {
  display: block;
  margin-top: 6px;
  color: #111827;
  font-size: 26px;
}

.admin-card-list {
  display: none;
}

.admin-mobile-card {
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: 14px;
  background: #fff;
  color: #4b5563;
  font-size: 14px;
}

.admin-mobile-card-header {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
  color: #111827;
}

.admin-detail-panel {
  margin: 12px 0;
}

.admin-detail-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 6px 14px;
  margin: 8px 0 10px;
}

.admin-advanced-json {
  margin-top: 8px;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  background: #f9fafb;
  padding: 6px 10px;
}

.admin-advanced-json > summary {
  cursor: pointer;
  color: #334155;
  font-size: 0.92rem;
  font-weight: 600;
  user-select: none;
}

.admin-advanced-json > summary:hover {
  color: #1e40af;
}

.admin-advanced-json pre.result-box {
  margin-top: 8px;
  max-width: 100%;
  overflow-x: auto;
  white-space: pre;
}

.admin-action-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.admin-action-row button {
  flex: 1 1 120px;
}

.admin-setting-field,
.admin-setting-check {
  display: flex;
  align-items: center;
  gap: 8px;
}

.admin-setting-field {
  justify-content: space-between;
  margin: 8px 0;
}

.admin-setting-field input[type="number"] {
  max-width: 120px;
}

.admin-setting-check {
  margin: 8px 0;
}

.settings-invite-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-width: 440px;
}

.settings-invite-form select {
  max-width: 220px;
}

.admin-usage {
  min-width: 120px;
}

.admin-usage-topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  font-size: 0.82rem;
  line-height: 1.25;
}

.admin-usage-messages {
  color: #111827;
  font-weight: 600;
}

.admin-usage-percent {
  color: #334155;
  font-weight: 700;
  white-space: nowrap;
}

.admin-usage-track {
  height: 8px;
  margin-top: 5px;
  border-radius: 999px;
  background: #cbd5e1;
  overflow: hidden;
}

.admin-usage-track span {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, #2563eb, #1d4ed8);
}

.admin-usage-near .admin-usage-track span {
  background: linear-gradient(90deg, #f59e0b, #d97706);
}

.admin-usage-reached .admin-usage-track span {
  background: linear-gradient(90deg, #ef4444, #b91c1c);
}

.admin-usage-threshold {
  margin-top: 6px;
}

.admin-company-card-badges-row .admin-usage {
  width: 100%;
  max-width: 100%;
}

.admin-risk-badge {
  border-radius: 999px;
  padding: 4px 8px;
  font-size: 12px;
  font-weight: 700;
  background: #f3f4f6;
  color: #374151;
  white-space: nowrap;
}

.admin-risk-badge.ok {
  background: #dcfce7;
  color: #166534;
}

.admin-risk-badge.warning {
  background: #fef3c7;
  color: #92400e;
  border: 1px solid #fbbf24;
  font-weight: 700;
}

.admin-risk-badge.danger {
  background: #fee2e2;
  color: #991b1b;
  border: 1px solid #f87171;
  font-weight: 800;
}

.admin-card-list.always-visible {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

.admin-recommended-action {
  background: #1d4ed8;
  border-color: #1d4ed8;
  color: #ffffff;
  font-weight: 700;
}

.admin-recommended-action:hover {
  background: #1e40af;
  border-color: #1e40af;
}

.admin-secondary-action {
  opacity: 0.86;
}

.hidden {
  display: none;
}

.impersonation-banner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 14px;
  margin-bottom: 12px;
  border-radius: 8px;
  background: linear-gradient(90deg, #451a03 0%, #b45309 100%);
  color: #fffbeb;
  border: 1px solid rgba(253, 230, 138, 0.5);
  font-size: 0.95rem;
}

.impersonation-banner.hidden {
  display: none;
}

.impersonation-banner .secondary {
  background: #fffbeb;
  color: #7c2d12;
}

.impersonate-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
}

.impersonate-modal-backdrop.hidden {
  display: none;
}

.impersonate-modal-card {
  max-width: 420px;
  width: 100%;
}

.result-box {
  margin-top: 12px;
  background: #111827;
  color: #e5e7eb;
  border-radius: 8px;
  padding: 10px;
  min-height: 40px;
  overflow-x: auto;
}

#detailsTitle {
  margin: 4px 0 10px;
}

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

.preview-summary-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(180px, 1fr));
  gap: 10px;
}

.preview-summary-card {
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  background: #f9fafb;
  padding: 12px;
}

.preview-summary-label {
  color: #6b7280;
  font-size: 13px;
  margin-bottom: 6px;
}

.preview-summary-value {
  font-size: 22px;
  font-weight: 700;
  color: #111827;
}

.campaign-msg-preview {
  max-width: 280px;
  white-space: normal;
  word-break: break-word;
  font-size: 13px;
  color: #374151;
}

.label {
  font-weight: 600;
}

.skipped-list {
  margin: 8px 0 0;
  padding-left: 20px;
}

.skipped-list li {
  margin: 4px 0;
  color: #4b5563;
  font-size: 14px;
}

.badge {
  display: inline-block;
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  line-height: 1.4;
  text-transform: none;
}

.badge-green {
  background: #dcfce7;
  color: #166534;
}

.badge-yellow {
  background: #fef9c3;
  color: #854d0e;
}

.badge-red {
  background: #fee2e2;
  color: #991b1b;
}

.badge-blue {
  background: #dbeafe;
  color: #1e40af;
}

.badge-gray {
  background: #e5e7eb;
  color: #374151;
}

/* Project list: shorter action labels on small screens only */
.project-list-table .project-list-label-mobile {
  display: none;
}

.type-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  border: 1px solid transparent;
}

.type-badge-text {
  background: #dbeafe;
  color: #1e3a8a;
  border-color: #bfdbfe;
}

.type-badge-image {
  background: #f3e8ff;
  color: #6b21a8;
  border-color: #e9d5ff;
}

.type-badge-document {
  background: #ffedd5;
  color: #9a3412;
  border-color: #fed7aa;
}

.type-badge-carousel {
  background: #ecfeff;
  color: #155e75;
  border-color: #a5f3fc;
}

.type-badge-product-link {
  background: #fff7ed;
  color: #9a3412;
  border-color: #fed7aa;
}

#messageBox.success {
  border-color: #10b981;
  background: #ecfdf5;
  color: #065f46;
}

#messageBox.error {
  border-color: #ef4444;
  background: #fef2f2;
  color: #991b1b;
}

#authScreen.verify-email-only > :not(#phoneLoginCard):not(#authMessage) {
  display: none;
}

#phoneLoginCard.email-verify-only > :not(#emailVerifyPanel) {
  display: none;
}

#phoneLoginCard.email-verify-only #emailVerifyPanel {
  display: block;
}

.email-verify-nav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px 20px;
  margin: 0 0 14px;
  padding-bottom: 14px;
  border-bottom: 1px solid #e2e8f0;
}

.email-verify-back-link,
.email-verify-login-link {
  font-size: 14px;
  font-weight: 600;
  line-height: 1.4;
  color: #1d4ed8;
  text-decoration: none;
}

.email-verify-back-link:hover,
.email-verify-back-link:focus-visible,
.email-verify-login-link:hover,
.email-verify-login-link:focus-visible {
  text-decoration: underline;
  color: #1e40af;
}

@media (max-width: 520px) {
  .email-verify-nav {
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
  }
}

.toast {
  position: fixed;
  top: 20px;
  right: 20px;
  z-index: 9999;
  background: #16a34a;
  color: white;
  padding: 12px 16px;
  border-radius: 8px;
  font-size: 14px;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15);
  opacity: 0;
  transform: translateY(-10px);
  transition: all 0.3s ease;
  pointer-events: none;
}

.toast.show {
  opacity: 1;
  transform: translateY(0);
}

.toast.error {
  background: #dc2626;
}

.toast.warning {
  background: #f59e0b;
}

@media (min-width: 761px) {
  .landing-hero {
    grid-template-columns: minmax(0, 1.08fr) minmax(360px, 0.92fr);
    gap: 42px;
    padding: 86px 62px;
  }

  .landing-actions {
    align-items: center;
    flex-direction: row;
  }

  .landing-actions.landing-actions--hero {
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: stretch;
  }

  .landing-actions.landing-actions--hero .button-link {
    flex: 1 1 200px;
    min-width: min(100%, 180px);
    max-width: 100%;
  }

  .button-link {
    width: auto;
    min-width: 150px;
  }

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

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

  .landing-steps {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .landing-feature-grid:not(.landing-roadmap-grid) {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .landing-roadmap-grid {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  }

  .landing-pricing-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    align-items: stretch;
  }

  .landing-price-card {
    min-height: 100%;
  }

  .landing-price-features {
    min-height: 250px;
  }

  .landing-result-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (min-width: 761px) and (max-width: 1200px) {
  .landing-pricing-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  #routeLanding {
    max-width: 100%;
    overflow-x: hidden;
  }

  .container {
    margin: 12px auto;
    padding: 0 12px 28px;
  }

  #routeLanding .card,
  #routeLanding .landing-grid {
    margin-bottom: 24px;
  }

  .landing-hero,
  .landing-grid,
  .landing-steps,
  .landing-feature-grid,
  .campaign-mini-guide,
  .onboarding-steps,
  .dashboard-onboarding-steps,
  .grid.two,
  .grid.three,
  .preview-grid,
  .preview-summary-grid,
  .safe-sending-trust-grid {
    grid-template-columns: 1fr;
  }

  .landing-hero {
    min-height: auto;
    padding: 38px 22px;
    text-align: center;
  }

  .landing-hero h1 {
    font-size: clamp(46px, 16vw, 64px);
    word-break: normal;
    overflow-wrap: break-word;
  }

  .landing-subtitle {
    font-size: 22px;
  }

  .landing-description {
    font-size: 16px;
  }

  .landing-hero-card {
    width: 100%;
    max-width: 420px;
    margin: 0 auto;
    text-align: left;
  }

  .landing-campaign-progress {
    grid-template-columns: 1fr;
  }

  .landing-status-list div {
    font-size: 12px;
  }

  .landing-pricing-highlight {
    transform: none;
  }

  .landing-pricing-highlight:hover {
    transform: translateY(-3px);
  }

  .landing-pricing-section {
    padding: 22px;
  }

  .landing-price-card {
    padding: 22px;
  }

  .landing-price {
    font-size: 38px;
  }

  .landing-price-card .button-link {
    width: 100%;
  }

  .landing-flow {
    gap: 14px;
  }

  .landing-steps {
    gap: 18px;
  }

  .campaign-onboarding-card {
    margin-top: 12px;
    padding: 14px;
  }

  .onboarding-step {
    align-items: flex-start;
    flex-wrap: wrap;
  }

  .dashboard-onboarding-steps {
    grid-template-columns: 1fr;
  }

  .onboarding-macro-rail {
    flex-direction: column;
    align-items: stretch;
  }

  .onboarding-macro-connector {
    display: none;
  }

  .onboarding-macro-step {
    flex-direction: row;
    justify-content: flex-start;
    gap: 14px;
    min-height: 52px;
  }

  .onboarding-macro-label {
    text-align: left;
  }

  .onboarding-step button {
    width: 100%;
    margin-left: 42px;
  }

  .onboarding-step-v2 .onboarding-step-footer button {
    margin-left: 0;
  }

  .first-campaign-success-stats,
  .first-campaign-success-actions {
    grid-template-columns: 1fr;
    flex-direction: column;
  }

  .first-campaign-success-actions button {
    width: 100%;
  }

  .campaign-mini-guide {
    gap: 8px;
  }

  .campaign-mini-guide div {
    padding: 9px;
  }

  /* Dashboard mobile polish: improve wizard readability and tap comfort. */
  .dashboard-step-heading {
    margin: 16px 0 10px;
  }

  .dashboard-step-title {
    font-size: 15px;
    line-height: 1.35;
  }

  .dashboard-step-subtitle {
    line-height: 1.45;
  }

  .project-list-table .project-list-label-desktop {
    display: none;
  }

  .project-list-table .project-list-label-mobile {
    display: inline;
  }

  /* Project List: card rows on mobile */
  #projectsTable.project-list-table {
    display: block;
    width: 100%;
    border: none;
    border-collapse: separate;
    border-spacing: 0;
  }

  #projectsTable.project-list-table thead {
    display: none;
  }

  #projectsTable.project-list-table tbody {
    display: block;
    width: 100%;
  }

  #projectsTable.project-list-table tbody tr {
    display: block;
    width: 100%;
    margin-bottom: 12px;
    padding: 14px 14px 12px;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    background: #fff;
    box-sizing: border-box;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
  }

  #projectsTable.project-list-table tbody tr.selected-project-row {
    border-color: #2563eb;
    box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.25);
  }

  #projectsTable.project-list-table tbody tr td {
    display: block;
    width: 100%;
    padding: 0;
    border: none;
    vertical-align: top;
  }

  #projectsTable.project-list-table tbody tr td:first-child {
    font-weight: 700;
    font-size: 15px;
    color: #0f172a;
    margin-bottom: 6px;
    line-height: 1.35;
  }

  #projectsTable.project-list-table tbody tr td:nth-child(2) {
    font-size: 13px;
    color: #64748b;
    margin-bottom: 12px;
    line-height: 1.45;
  }

  #projectsTable.project-list-table tbody tr td:nth-child(2):empty {
    display: none;
    margin-bottom: 0;
  }

  #projectsTable.project-list-table tbody tr td:last-child {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    margin: 0;
    padding-top: 2px;
  }

  #projectsTable.project-list-table tbody tr td:last-child .manage-steps-btn {
    order: 1;
  }

  #projectsTable.project-list-table tbody tr td:last-child .project-preview-sequence-btn {
    order: 2;
  }

  #projectsTable.project-list-table tbody tr td:last-child .project-list-btn-edit {
    order: 3;
  }

  #projectsTable.project-list-table tbody tr td:last-child .delete-project-btn {
    order: 4;
  }

  #projectsTable.project-list-table tbody tr td:last-child button {
    width: 100%;
    min-height: 44px;
    touch-action: manipulation;
    box-sizing: border-box;
    margin: 0;
  }

  #projectsTable.project-list-table tbody tr td:last-child .project-list-btn-edit {
    background: #334155;
    color: #fff;
    border-color: #334155;
  }

  #projectsTable.project-list-table tbody tr td:last-child .project-list-btn-edit:hover {
    background: #1e293b;
    border-color: #1e293b;
  }

  .message-sequence-summary-dl {
    grid-template-columns: 1fr;
  }

  .message-sequence-compact-panel .message-sequence-summary-dl {
    grid-template-columns: 1fr;
  }

  .message-sequence-summary-actions {
    flex-direction: column;
  }

  .message-sequence-summary-actions .secondary {
    width: 100%;
    min-height: 46px;
    max-height: 52px;
    min-width: 0;
    padding: 10px 14px;
    font-size: 13px;
    box-sizing: border-box;
    line-height: 1.25;
  }

  .message-sequence-summary-actions #messageSequenceManageBtn {
    background: #1e293b;
    color: #f8fafc;
    border-color: #334155;
    font-weight: 700;
  }

  .message-sequence-summary-actions #messageSequenceManageBtn:hover {
    background: #0f172a;
    border-color: #1e293b;
    color: #fff;
    filter: brightness(1.03);
  }

  .message-sequence-summary-header-row {
    flex-direction: column;
    align-items: flex-start;
  }

  #campaignPreviewSection,
  #activeCampaignSection {
    padding: 14px;
  }

  .campaign-optin-confirmation {
    padding: 10px 12px;
    margin-top: 6px;
  }

  .campaign-opt-in-label {
    font-size: 0.92rem;
    gap: 8px;
  }

  #campaignPreviewSection button,
  #activeCampaignSection button,
  #importForm button {
    min-height: 44px;
  }

  .safe-sending-trust-panel {
    padding: 14px;
  }

  .safe-sending-trust-grid {
    gap: 8px;
  }

  #activeCampaignProgressText {
    font-size: 14px;
    line-height: 1.4;
  }

  #activeCampaignTable {
    display: none;
  }

  .active-campaign-card-list {
    display: grid;
    gap: 10px;
    margin-top: 12px;
  }

  #activeCampaignSection {
    overflow: hidden;
  }

  #activeCampaignSection .section-title-row {
    align-items: stretch;
    flex-direction: column;
  }

  #activeCampaignSection button {
    width: 100%;
  }

  #activeCampaignProgressCount {
    display: grid;
    gap: 4px;
    margin-top: 8px;
  }

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

  #messageLogsTable {
    display: none;
  }

  #campaignsTable {
    display: none;
  }

  .campaign-history-card-list {
    display: grid;
    gap: 10px;
    margin-top: 12px;
  }

  .campaign-history-card button {
    width: 100%;
  }

  .message-log-card-list {
    display: grid;
    gap: 10px;
    margin-top: 12px;
  }

  #deliveryLogsDetails {
    overflow-x: auto;
  }

  .admin-summary-grid {
    grid-template-columns: 1fr 1fr;
  }

  #adminUsersTable,
  #adminCompaniesTable,
  #adminPlansTable,
  #adminInstancesTable {
    display: none;
  }

  .admin-card-list {
    display: grid;
    gap: 10px;
    margin-top: 12px;
  }

  .admin-action-row {
    display: grid;
  }

  .admin-action-row button,
  .admin-mobile-card button {
    width: 100%;
  }

  .landing-actions .button-link {
    width: 100%;
  }

  .landing-pricing-grid .button-link,
  .landing-cta .button-link {
    width: 100%;
  }

  .landing-pricing h2 {
    font-size: 38px;
  }

  .landing-pricing-grid .landing-price-features {
    min-height: 0;
  }

  .landing-pricing-highlight {
    transform: none;
  }

  #instancesSection,
  #instancesTab {
    padding: 14px;
  }

  .instance-connect-form {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
    margin-top: 8px;
  }

  .instance-connect-form input,
  .instance-connect-form button {
    width: 100%;
    max-width: none;
  }

  #instanceName {
    display: none;
  }

  .instance-onboarding button {
    width: 100%;
  }

  #instanceTable {
    display: none;
  }

  .instance-card-list {
    display: grid;
    gap: 10px;
    margin-top: 12px;
  }

  #instancesSection button {
    width: 100%;
  }

  .floating-support-btn {
    right: 12px;
    bottom: 12px;
    padding: 10px 14px;
    font-size: 14px;
  }
}

@media (max-width: 420px) {
  /* Dashboard mobile polish: prevent squeezed dense stats at ~390px width. */
  .dashboard-step-heading {
    margin: 18px 0 10px;
  }

  .safe-sending-trust-panel h3 {
    font-size: 16px;
  }

  #activeCampaignProgressCount {
    gap: 6px;
  }
}

/* Public pages light redesign (landing/login/register only) */
html[data-public-auth="landing"] body,
html[data-public-auth="login"] body,
html[data-public-auth="register"] body {
  background: #f8fafc;
}

html[data-public-auth="landing"] #authScreen,
html[data-public-auth="login"] #authScreen,
html[data-public-auth="register"] #authScreen {
  max-width: 1180px;
}

html[data-public-auth="landing"] #routeLanding {
  max-width: 1180px;
  margin: 0 auto;
  gap: 30px;
}

html[data-public-auth="landing"] #routeLanding .card {
  background: #ffffff;
  color: #0f172a;
  border: 1px solid #e2e8f0;
  box-shadow: 0 12px 32px rgba(15, 23, 42, 0.06);
  padding: 30px;
}

html[data-public-auth="landing"] .landing-hero {
  grid-template-columns: minmax(0, 1.05fr) minmax(340px, 0.95fr);
  gap: 44px;
  padding: 72px 58px;
  border: 1px solid #e2e8f0;
  background:
    radial-gradient(circle at top right, rgba(99, 102, 241, 0.12), transparent 35%),
    linear-gradient(180deg, #ffffff, #f8fafc);
  min-height: 0;
}

html[data-public-auth="landing"] .landing-hero::after {
  display: none;
}

html[data-public-auth="landing"] .landing-hero h1 {
  color: #0f172a;
  max-width: min(620px, 100%);
  min-width: 0;
  font-size: clamp(44px, 6vw, 70px);
  line-height: 1.12;
  letter-spacing: -0.035em;
  word-spacing: normal;
  word-break: normal;
  overflow-wrap: break-word;
  hyphens: manual;
}

@media print {
  .landing-hero h1,
  html[data-public-auth="landing"] .landing-hero h1 {
    max-width: 100%;
    line-height: 1.18;
    letter-spacing: -0.02em;
    word-spacing: normal;
    word-break: normal;
    overflow-wrap: break-word;
    hyphens: manual;
  }
}

html[data-public-auth="landing"] .landing-eyebrow {
  color: #4338ca;
}

html[data-public-auth="landing"] .landing-description {
  color: #334155;
  font-size: 19px;
  line-height: 1.6;
  max-width: 560px;
}

html[data-public-auth="landing"] .landing-trust-text {
  color: #64748b;
}

html[data-public-auth="landing"] .landing-hero .button-link {
  background: linear-gradient(135deg, #4f46e5, #7c3aed);
  color: #ffffff;
  box-shadow: 0 14px 30px rgba(79, 70, 229, 0.22), 0 0 0 1px rgba(99, 102, 241, 0.08);
  transition: transform 160ms ease, box-shadow 160ms ease, filter 160ms ease;
}

html[data-public-auth="landing"] .landing-hero .button-link:hover {
  transform: translateY(-2px);
  filter: brightness(1.02);
  box-shadow: 0 18px 36px rgba(79, 70, 229, 0.3), 0 0 0 1px rgba(99, 102, 241, 0.14);
}

html[data-public-auth="landing"] .landing-hero .button-link.secondary {
  background: #ffffff;
  color: #312e81;
  border: 1px solid #c7d2fe;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.07);
}

html[data-public-auth="landing"] .landing-demo-float {
  border-color: rgba(99, 102, 241, 0.26);
  background: #ffffff;
  box-shadow: 0 28px 60px rgba(15, 23, 42, 0.14), 0 0 0 1px rgba(129, 140, 248, 0.08), 0 0 28px rgba(99, 102, 241, 0.08);
  transform: translateY(-2px);
}

html[data-public-auth="landing"] .landing-mock-header strong,
html[data-public-auth="landing"] .landing-progress-panel strong,
html[data-public-auth="landing"] .landing-chat-bubble,
html[data-public-auth="landing"] .landing-chat-status,
html[data-public-auth="landing"] .landing-campaign-progress strong {
  color: #0f172a;
}

html[data-public-auth="landing"] .landing-chat-status {
  border-top: 1px solid #e2e8f0;
  padding-top: 10px;
}

html[data-public-auth="landing"] .landing-mock-header span,
html[data-public-auth="landing"] .landing-progress-panel span,
html[data-public-auth="landing"] .landing-campaign-progress span,
html[data-public-auth="landing"] .landing-chat-bubble span {
  color: #64748b;
}

html[data-public-auth="landing"] .landing-chat-bubble,
html[data-public-auth="landing"] .landing-status-list div,
html[data-public-auth="landing"] .landing-demo-mini-card {
  background: #f8fafc;
  border-color: #e2e8f0;
}

html[data-public-auth="landing"] .landing-demo-mini-card strong {
  color: #2563eb;
}

html[data-public-auth="landing"] .landing-live-pill {
  background: linear-gradient(135deg, #dcfce7, #dbeafe);
  color: #1e3a8a;
}

html[data-public-auth="landing"] .landing-flow span,
html[data-public-auth="landing"] .landing-steps div,
html[data-public-auth="landing"] .landing-feature-grid div {
  background: #f8fafc;
  border-color: #e2e8f0;
  color: #0f172a;
}

html[data-public-auth="landing"] .landing-steps span,
html[data-public-auth="landing"] .landing-feature-grid span {
  color: #475569;
}

html[data-public-auth="landing"] .landing-mock-chip {
  background: #f1f5f9;
  border-color: #e2e8f0;
  color: #475569;
}

html[data-public-auth="landing"] .landing-faq-item strong {
  color: #1e293b;
}

html[data-public-auth="landing"] .landing-faq-block {
  border-top: none;
}

html[data-public-auth="landing"] .landing-pricing-section {
  background: #ffffff;
}

html[data-public-auth="landing"] .landing-pricing-header .muted {
  color: #64748b;
}

html[data-public-auth="landing"] .landing-pricing-billing-note {
  color: #475569;
}

html[data-public-auth="landing"] .landing-pricing-grid {
  gap: 16px;
}

html[data-public-auth="landing"] .landing-pricing-grid .landing-price-card {
  background: #ffffff;
  border: 1px solid #e2e8f0;
  box-shadow: 0 14px 30px rgba(15, 23, 42, 0.06);
}

html[data-public-auth="landing"] .landing-pricing-grid .landing-price-features {
  flex: 1 1 auto;
  min-height: 0 !important;
}

html[data-public-auth="landing"] .landing-pricing-grid .landing-price-card h3,
html[data-public-auth="landing"] .landing-pricing-grid .landing-price {
  color: #0f172a;
}

html[data-public-auth="landing"] .landing-pricing-grid .landing-price span,
html[data-public-auth="landing"] .landing-pricing-grid .landing-price-label,
html[data-public-auth="landing"] .landing-pricing-grid .landing-price-features,
html[data-public-auth="landing"] .landing-pricing-grid .landing-price-features li {
  color: #475569;
}

html[data-public-auth="landing"] .landing-pricing-highlight {
  border: 1px solid rgba(79, 70, 229, 0.45);
  background: linear-gradient(180deg, #ffffff, #f5f3ff) !important;
  box-shadow: 0 0 0 1px rgba(79, 70, 229, 0.16), 0 16px 34px rgba(79, 70, 229, 0.18), 0 0 22px rgba(124, 58, 237, 0.15);
}

html[data-public-auth="landing"] .landing-popular-badge {
  background: linear-gradient(135deg, #4f46e5, #7c3aed);
  color: #ffffff;
  box-shadow: 0 8px 18px rgba(99, 102, 241, 0.24);
}

html[data-public-auth="landing"] .landing-pricing-highlight .landing-price {
  background: linear-gradient(90deg, #4f46e5, #7c3aed);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

html[data-public-auth="landing"] .landing-pricing-note {
  color: #64748b;
}

html[data-public-auth="landing"] .landing-pricing-trust-note {
  color: rgba(15, 23, 42, 0.72);
}

html[data-public-auth="landing"] .landing-trust-list {
  color: #334155;
}

html[data-public-auth="landing"] .landing-flow strong,
html[data-public-auth="landing"] .landing-status-dot.sent {
  color: #4f46e5;
}

html[data-public-auth="landing"] .landing-status-dot.failed {
  color: #dc2626;
}

html[data-public-auth="landing"] .floating-support-btn {
  right: 14px;
  bottom: 14px;
  padding: 6px 10px;
  font-size: 12px;
  opacity: 0.52;
  box-shadow: 0 6px 14px rgba(22, 163, 74, 0.14);
}

html[data-public-auth="landing"] .floating-support-btn:hover {
  opacity: 1;
  box-shadow: 0 10px 20px rgba(22, 163, 74, 0.24);
}

html[data-public-auth="login"] #phoneLoginCard,
html[data-public-auth="register"] #registerCard {
  max-width: 560px;
  margin: 24px auto 0;
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  background: #ffffff;
  box-shadow: 0 20px 46px rgba(15, 23, 42, 0.08);
  padding: 28px 26px;
}

html[data-public-auth="login"] #phoneLoginCard h2,
html[data-public-auth="register"] #registerCard h2 {
  color: #0f172a;
}

html[data-public-auth="login"] #phoneLoginCard .muted,
html[data-public-auth="register"] #registerCard .muted {
  color: #64748b;
}

html[data-public-auth="register"] .register-trust-note {
  margin: 6px 0 12px;
  padding: 10px 12px;
  border: 1px solid #dbeafe;
  border-radius: 10px;
  background: #f8fafc;
  color: #1e3a8a;
  font-weight: 600;
}

html[data-public-auth="register"] .register-responsibility-notice {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  margin-top: 16px;
  padding: 14px 16px;
  border: 1px solid #cbd5e1;
  border-radius: 12px;
  background: #f8fafc;
  transition: border-color 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}

html[data-public-auth="register"] .register-responsibility-notice.register-responsibility-notice--error {
  border-color: #dc2626;
  background: #fef2f2;
  box-shadow: 0 0 0 2px rgba(220, 38, 38, 0.22);
}

html[data-public-auth="register"] .register-responsibility-check-label {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  cursor: pointer;
  margin: 0;
  color: #0f172a;
  font-size: 15px;
  line-height: 1.5;
  font-weight: 600;
}

html[data-public-auth="register"] .register-responsibility-check-label input[type="checkbox"] {
  margin-top: 4px;
  width: 18px;
  height: 18px;
  min-width: 18px;
  flex-shrink: 0;
  accent-color: #16a34a;
}

html[data-public-auth="register"] .register-responsibility-inline-error {
  margin: 12px 0 0;
  padding: 0;
  font-size: 14px;
  font-weight: 600;
  color: #b91c1c;
  line-height: 1.45;
}

html[data-public-auth="register"] .register-responsibility-inline-error.hidden {
  display: none;
}

html[data-public-auth="register"] .register-responsibility-note {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

/*
 * Public homepage visual upgrade v1 — landing only (narrowed selectors; dashboard #appShell unchanged).
 */
html[data-public-auth="landing"] body {
  background: #eef2f6;
}

html[data-public-auth="landing"] #authScreen {
  max-width: 1240px;
  padding-bottom: 128px;
  box-sizing: border-box;
}

html[data-public-auth="landing"] #routeLanding {
  max-width: 1240px;
  gap: 40px;
  padding: 12px 16px 0;
}

html[data-public-auth="landing"] #routeLanding > .card:not(.landing-hero) {
  border-radius: 18px;
  padding: 34px 32px;
  border: 1px solid #e2e8f0;
  box-shadow: 0 4px 24px rgba(15, 23, 42, 0.06);
  transition: box-shadow 0.2s ease, transform 0.2s ease, border-color 0.2s ease;
}

html[data-public-auth="landing"] #routeLanding > .card:not(.landing-hero):hover {
  box-shadow: 0 12px 36px rgba(15, 23, 42, 0.1);
  border-color: #cbd5e1;
}

html[data-public-auth="landing"] #routeLanding > .card.landing-problem {
  background: linear-gradient(165deg, #ffffff 0%, #f8fafc 50%, #eef2ff 100%);
}

html[data-public-auth="landing"] #routeLanding > .card.landing-how-it-works {
  background: #ffffff;
}

html[data-public-auth="landing"] #routeLanding > .card#features {
  background: linear-gradient(180deg, #f8fafc 0%, #ffffff 48%);
}

html[data-public-auth="landing"] #routeLanding > .card.landing-use-cases-section {
  background: #ffffff;
}

html[data-public-auth="landing"] #routeLanding > .card.landing-results {
  background: linear-gradient(165deg, #faf5ff 0%, #ffffff 55%);
}

html[data-public-auth="landing"] #routeLanding > .card.landing-pricing-section {
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 55%, #eef2ff 100%);
}

html[data-public-auth="landing"] #routeLanding > .card.landing-safety-faq {
  background: #f1f5f9;
}

html[data-public-auth="landing"] #routeLanding > .card.landing-roadmap-section {
  background: #ffffff;
}

html[data-public-auth="landing"] #routeLanding > .card.landing-cta {
  background: linear-gradient(135deg, #1e1b4b 0%, #3730a3 40%, #5b21b6 100%);
  color: #f8fafc;
  border-color: rgba(165, 180, 252, 0.35);
  box-shadow: 0 16px 40px rgba(30, 27, 75, 0.35);
}

html[data-public-auth="landing"] #routeLanding > .card.landing-cta h2 {
  color: #f8fafc;
}

html[data-public-auth="landing"] #routeLanding > .card.landing-cta .muted {
  color: rgba(248, 250, 252, 0.9);
}

html[data-public-auth="landing"] #routeLanding > .card.landing-cta .button-link {
  background: #ffffff;
  color: #3730a3;
  border: 1px solid rgba(255, 255, 255, 0.85);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.2);
}

html[data-public-auth="landing"] #routeLanding > .card.landing-cta .button-link.secondary {
  background: rgba(255, 255, 255, 0.12);
  color: #f8fafc;
  border: 1px solid rgba(255, 255, 255, 0.35);
  box-shadow: none;
}

html[data-public-auth="landing"] #routeLanding > .card.landing-cta .button-link.secondary:hover {
  background: rgba(255, 255, 255, 0.2);
}

html[data-public-auth="landing"] #routeLanding > .card h2 {
  margin-bottom: 16px;
}

/* Hero layout & trust list */
html[data-public-auth="landing"] .landing-hero.card {
  border-radius: 20px;
  overflow: hidden;
  padding: 64px 56px;
  border: 1px solid #e2e8f0;
  background:
    radial-gradient(ellipse 90% 70% at 100% 0%, rgba(99, 102, 241, 0.16), transparent 55%),
    radial-gradient(ellipse 80% 55% at 0% 100%, rgba(14, 165, 233, 0.11), transparent 50%),
    linear-gradient(165deg, #ffffff 0%, #f8fafc 100%);
  box-shadow: 0 20px 48px rgba(15, 23, 42, 0.08);
}

html[data-public-auth="landing"] .landing-hero-copy {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

html[data-public-auth="landing"] .landing-hero-trust {
  list-style: none;
  margin: 22px 0 0;
  padding: 0;
  max-width: 36rem;
  text-align: left;
}

html[data-public-auth="landing"] .landing-hero-trust li {
  position: relative;
  padding: 10px 0 10px 30px;
  color: #475569;
  font-size: 15px;
  line-height: 1.55;
  border-bottom: 1px solid rgba(226, 232, 240, 0.95);
}

html[data-public-auth="landing"] .landing-hero-trust li:last-child {
  border-bottom: none;
}

html[data-public-auth="landing"] .landing-hero-trust li::before {
  content: "";
  position: absolute;
  left: 2px;
  top: 50%;
  transform: translateY(-50%);
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: linear-gradient(135deg, #6366f1, #8b5cf6);
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.22);
}

html[data-public-auth="landing"] .landing-hero .landing-hero-cta--primary {
  background: linear-gradient(135deg, #4f46e5, #7c3aed);
  color: #ffffff;
  border: none;
  font-weight: 800;
}

html[data-public-auth="landing"] .landing-hero .landing-hero-cta--secondary {
  background: #ffffff;
  color: #3730a3;
  border: 1px solid #c7d2fe;
  font-weight: 700;
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.06);
}

html[data-public-auth="landing"] .landing-hero .landing-hero-cta--secondary:hover {
  background: #f8fafc;
  border-color: #a5b4fc;
}

html[data-public-auth="landing"] .landing-hero .landing-hero-cta--outline {
  background: rgba(255, 255, 255, 0.6);
  color: #4338ca;
  border: 2px solid rgba(99, 102, 241, 0.4);
  font-weight: 700;
  box-shadow: none;
}

html[data-public-auth="landing"] .landing-hero .landing-hero-cta--outline:hover {
  background: #ffffff;
  border-color: #6366f1;
}

/* Product mockup */
html[data-public-auth="landing"] .landing-demo-float {
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid #e2e8f0;
  box-shadow:
    0 24px 56px rgba(15, 23, 42, 0.12),
    0 0 0 1px rgba(99, 102, 241, 0.07);
  background: #ffffff;
  transform: translateY(0);
}

html[data-public-auth="landing"] .landing-mock-header {
  margin: 0;
  padding: 18px 20px;
  background: linear-gradient(105deg, #eef2ff 0%, #f8fafc 45%, #e0e7ff 100%);
  border-bottom: 1px solid #e2e8f0;
}

html[data-public-auth="landing"] .landing-mock-readiness {
  padding: 14px 18px 8px;
}

html[data-public-auth="landing"] .landing-hero-card .landing-campaign-progress div {
  border: 1px solid #e2e8f0;
  background: #f8fafc;
}

html[data-public-auth="landing"] .landing-chat-bubble {
  border-radius: 14px;
  border: 1px solid #e2e8f0;
  background: linear-gradient(180deg, #fafafa 0%, #ffffff 100%);
}

/* Section cards — how it works, features, industries, roadmap */
html[data-public-auth="landing"] .landing-steps div,
html[data-public-auth="landing"] .landing-feature-grid div {
  border-radius: 14px;
  padding: 20px 20px;
  border: 1px solid #e2e8f0;
  background: #ffffff;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.04);
}

html[data-public-auth="landing"] .landing-steps div:hover,
html[data-public-auth="landing"] .landing-feature-grid div:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.08);
}

html[data-public-auth="landing"] .landing-roadmap-card {
  border-radius: 14px;
}

html[data-public-auth="landing"] .landing-result-grid div {
  border-radius: 14px;
  border: 1px solid #e2e8f0;
  background: #ffffff;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.04);
}

/* FAQ / safety — extra card shells (contrast rules elsewhere) */
html[data-public-auth="landing"] #routeLanding .landing-safety-faq .landing-safety-lead {
  background: #ffffff;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  padding: 18px 20px;
  margin-left: auto;
  margin-right: auto;
}

html[data-public-auth="landing"] #routeLanding .landing-safety-faq .landing-trust-list {
  background: #ffffff;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  padding: 18px 20px 18px 36px;
  margin-top: 18px;
}

html[data-public-auth="landing"] #routeLanding .landing-safety-faq .landing-faq-block {
  background: #ffffff;
}

/* Pricing */
html[data-public-auth="landing"] .landing-pricing-billing-note {
  font-size: 13px;
  max-width: 34rem;
  color: #64748b;
}

html[data-public-auth="landing"] .landing-pricing-cta-note {
  margin: 8px 0 0;
  font-size: 14px;
  text-align: center;
  max-width: 38rem;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.55;
  color: #475569;
}

html[data-public-auth="landing"] .landing-pricing-addon-note {
  scroll-margin-top: 88px;
  font-size: 14px;
  max-width: 40rem;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  line-height: 1.55;
  color: #475569;
}

html[data-public-auth="landing"] .landing-pricing-grid .landing-price-card {
  position: relative;
  border-radius: 16px;
  padding: 28px 24px 24px;
}

html[data-public-auth="landing"] .landing-plan-business--accent .landing-plan-side-badge {
  position: absolute;
  top: 14px;
  right: 14px;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 4px 8px;
  border-radius: 6px;
  background: #eef2ff;
  color: #4338ca;
  border: 1px solid #c7d2fe;
}

html[data-public-auth="landing"] .landing-plan-business--accent {
  padding-top: 38px;
}

/* Logged-in homepage: single-line WhatsApp status in public nav */
html[data-public-auth="landing"] .public-nav-wa-status {
  font-size: 12px;
  font-weight: 700;
  color: #166534;
  background: #ecfdf5;
  border: 1px solid #bbf7d0;
  border-radius: 999px;
  padding: 6px 12px;
  margin: 0;
  flex: 1 1 100%;
  text-align: center;
  box-sizing: border-box;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

html[data-public-auth="landing"] .public-nav-wa-status.hidden {
  display: none;
}

@media (min-width: 761px) {
  html[data-public-auth="landing"] .public-nav-wa-status:not(.hidden) {
    flex: 0 1 auto;
    max-width: min(240px, 32vw);
    text-align: left;
  }
}

/* Floating support: keep above page chrome but below modals; landing bottom inset */
html[data-public-auth="landing"] .floating-support-btn {
  bottom: 28px;
  right: 20px;
  z-index: 90;
}

/* --- Public homepage footer v1 --- */
html[data-public-auth="landing"] #routeLanding .landing-footer {
  position: relative;
  margin: 48px 0 0;
  padding: 52px 0 32px;
  background: linear-gradient(165deg, #0b1224 0%, #0f172a 42%, #111827 100%);
  color: #e2e8f0;
  border: none;
  border-radius: 0;
  box-shadow: none;
  clip-path: polygon(0 28px, 100% 0, 100% 100%, 0 100%);
  overflow: hidden;
}

html[data-public-auth="landing"] #routeLanding .landing-footer-slope {
  display: none;
}

html[data-public-auth="landing"] #routeLanding .landing-footer-inner {
  max-width: 1120px;
  margin: 0 auto;
  padding: 0 24px;
  box-sizing: border-box;
}

html[data-public-auth="landing"] #routeLanding .landing-footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px 40px;
}

html[data-public-auth="landing"] #routeLanding .landing-footer-brand-title {
  margin: 0 0 12px;
  font-size: 1.35rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #f8fafc;
  background: linear-gradient(90deg, #38bdf8, #a78bfa, #818cf8);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

html[data-public-auth="landing"] #routeLanding .landing-footer-brand-lead {
  margin: 0 0 10px;
  font-size: 15px;
  line-height: 1.55;
  color: #cbd5e1;
  font-weight: 600;
}

html[data-public-auth="landing"] #routeLanding .landing-footer-contact {
  margin: 16px 0 0;
  font-size: 14px;
  line-height: 1.55;
  color: rgba(148, 163, 184, 0.95);
}

html[data-public-auth="landing"] #routeLanding .landing-footer-contact a {
  color: #e2e8f0;
  font-weight: 600;
  text-decoration: none;
}

html[data-public-auth="landing"] #routeLanding .landing-footer-contact a:hover,
html[data-public-auth="landing"] #routeLanding .landing-footer-contact a:focus-visible {
  text-decoration: underline;
}

html[data-public-auth="landing"] #routeLanding .landing-footer-brand-sub {
  margin: 0;
  font-size: 14px;
  line-height: 1.6;
  color: #94a3b8;
}

html[data-public-auth="landing"] #routeLanding .landing-footer-heading {
  margin: 0 0 14px;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #f8fafc;
}

html[data-public-auth="landing"] #routeLanding .landing-footer-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
}

html[data-public-auth="landing"] #routeLanding .landing-footer-link {
  color: #94a3b8;
  text-decoration: none;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.45;
  transition: color 0.15s ease;
}

html[data-public-auth="landing"] #routeLanding .landing-footer-link:hover,
html[data-public-auth="landing"] #routeLanding .landing-footer-link:focus-visible {
  color: #7dd3fc;
  outline: none;
}

html[data-public-auth="landing"] #routeLanding .landing-footer-link--btn {
  display: inline;
  padding: 0;
  margin: 0;
  border: none;
  background: none;
  font: inherit;
  cursor: pointer;
  text-align: left;
}

html[data-public-auth="landing"] #routeLanding .landing-footer-bottom {
  margin-top: 40px;
  padding-top: 24px;
  border-top: 1px solid rgba(148, 163, 184, 0.25);
}

html[data-public-auth="landing"] #routeLanding .landing-footer-copy {
  margin: 0 0 8px;
  font-size: 14px;
  font-weight: 600;
  color: #cbd5e1;
}

html[data-public-auth="landing"] #routeLanding .landing-footer-disclaimer {
  margin: 0;
  font-size: 12px;
  line-height: 1.55;
  color: #64748b;
}

@media (min-width: 760px) {
  html[data-public-auth="landing"] #routeLanding .landing-footer-grid {
    grid-template-columns: 1.15fr repeat(3, minmax(0, 1fr));
    gap: 28px 36px;
    align-items: start;
  }

  html[data-public-auth="landing"] #routeLanding .landing-footer-brand {
    padding-right: 12px;
  }
}

@media (max-width: 759px) {
  html[data-public-auth="landing"] #routeLanding .landing-footer {
    clip-path: polygon(0 18px, 100% 0, 100% 100%, 0 100%);
    margin-top: 32px;
    padding-top: 40px;
  }

  html[data-public-auth="landing"] #routeLanding .landing-footer-inner {
    padding: 0 16px;
  }
}

@media print {
  .floating-support-btn,
  #toast,
  .toast {
    display: none !important;
  }

  html[data-public-auth="landing"] #publicNav {
    position: static !important;
  }

  html[data-public-auth="landing"] #authScreen {
    padding-bottom: 0 !important;
  }

  html[data-public-auth="landing"] #routeLanding .landing-footer {
    clip-path: none !important;
    background: #f8fafc !important;
    color: #0f172a !important;
    margin-top: 24px !important;
    padding: 20px 16px 16px !important;
    border-top: 2px solid #e2e8f0 !important;
    break-inside: avoid;
  }

  html[data-public-auth="landing"] #routeLanding .landing-footer-brand-title {
    background: none !important;
    -webkit-text-fill-color: #0f172a !important;
    color: #0f172a !important;
  }

  html[data-public-auth="landing"] #routeLanding .landing-footer-brand-lead,
  html[data-public-auth="landing"] #routeLanding .landing-footer-brand-sub,
  html[data-public-auth="landing"] #routeLanding .landing-footer-copy {
    color: #334155 !important;
  }

  html[data-public-auth="landing"] #routeLanding .landing-footer-heading {
    color: #0f172a !important;
  }

  html[data-public-auth="landing"] #routeLanding .landing-footer-link,
  html[data-public-auth="landing"] #routeLanding .landing-footer-link--btn {
    color: #1d4ed8 !important;
  }

  html[data-public-auth="landing"] #routeLanding .landing-footer-disclaimer {
    color: #64748b !important;
  }

  html[data-public-auth="landing"] #routeLanding .landing-footer-bottom {
    border-top-color: #e2e8f0 !important;
  }
}

/* --- Landing homepage mobile (overrides light-theme two-column hero at all widths) --- */
@media (max-width: 768px) {
  html[data-public-auth="landing"] #authScreen.container {
    padding-left: 12px;
    padding-right: 12px;
  }

  html[data-public-auth="landing"] .landing-hero.card {
    grid-template-columns: minmax(0, 1fr);
    gap: 24px;
    padding: 28px 16px;
    min-height: 0;
    align-items: stretch;
    overflow-x: hidden;
  }

  html[data-public-auth="landing"] .landing-hero-copy {
    min-width: 0;
    width: 100%;
  }

  html[data-public-auth="landing"] .landing-hero h1 {
    font-size: clamp(28px, 8.5vw, 44px);
    line-height: 1.14;
    letter-spacing: -0.03em;
    word-break: normal;
    overflow-wrap: break-word;
    margin-left: auto;
    margin-right: auto;
    max-width: 100%;
  }

  html[data-public-auth="landing"] .landing-description {
    font-size: 17px;
    max-width: 100%;
  }

  html[data-public-auth="landing"] .landing-hero-trust li {
    white-space: normal;
  }

  html[data-public-auth="landing"] .landing-hero .landing-hero-card {
    width: 100%;
    max-width: 360px;
    margin: 8px auto 0;
    padding: 18px;
    transform: none;
    position: relative;
    left: auto;
    right: auto;
    top: auto;
    justify-self: center;
    box-sizing: border-box;
  }

  html[data-public-auth="landing"] .landing-hero .landing-hero-card:hover {
    transform: none;
  }

  html[data-public-auth="landing"] .landing-demo-float {
    transform: none;
  }

  html[data-public-auth="landing"] .landing-hero .landing-actions.row {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    gap: 12px;
    width: 100%;
    max-width: 100%;
    margin-top: 20px;
  }

  html[data-public-auth="landing"] .landing-hero .landing-actions .button-link {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    flex: 0 0 auto;
    white-space: normal;
    word-break: normal;
    overflow-wrap: anywhere;
    text-align: center;
  }

  html[data-public-auth="landing"] .landing-mock-header {
    flex-wrap: wrap;
  }

  html[data-public-auth="landing"] .landing-chat-bubble {
    font-size: 14px;
    line-height: 1.45;
  }

  html[data-public-auth="landing"] .landing-status-list div {
    overflow-wrap: anywhere;
  }

  html[data-public-auth="landing"] .public-nav {
    gap: 8px;
    padding: 8px 10px;
    height: auto;
    min-height: 56px;
  }

  html[data-public-auth="landing"] .public-nav-logo {
    height: 28px;
  }

  html[data-public-auth="landing"] .public-nav-actions {
    gap: 6px;
    flex-shrink: 0;
  }

  html[data-public-auth="landing"] .public-nav-link,
  html[data-public-auth="landing"] .public-nav-cta {
    font-size: 13px;
    padding: 8px 10px;
    white-space: nowrap;
  }

  html[data-public-auth="landing"] .public-nav-cta {
    padding: 8px 12px;
  }

  .floating-support-btn {
    right: 12px;
    bottom: 12px;
    max-width: calc(100vw - 24px);
    padding: 10px 14px;
    font-size: 13px;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  html[data-public-auth="landing"] .floating-support-btn {
    opacity: 1;
  }
}

/* Campaign completion popup (session-scoped; frontend-only) */
.campaign-completion-modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 10050;
  align-items: center;
  justify-content: center;
  background: rgba(15, 23, 42, 0.45);
  padding: 16px;
  box-sizing: border-box;
}

.campaign-completion-modal {
  position: relative;
  width: min(420px, 100%);
  max-height: min(520px, 90vh);
  overflow: auto;
  border-radius: 14px;
  padding: 20px 20px 18px;
  background: #ffffff;
  box-shadow: 0 22px 48px rgba(15, 23, 42, 0.16);
  border: 1px solid rgba(226, 232, 240, 0.95);
}

.campaign-completion-modal--success {
  border-color: rgba(34, 197, 94, 0.35);
  background: linear-gradient(160deg, #f0fdf4 0%, #ffffff 42%, #ffffff 100%);
}

.campaign-completion-modal--warning {
  border-color: rgba(245, 158, 11, 0.45);
  background: linear-gradient(160deg, #fffbeb 0%, #ffffff 46%, #ffffff 100%);
  box-shadow: 0 18px 40px rgba(180, 83, 9, 0.12);
}

.campaign-completion-modal h3 {
  margin: 0 0 8px;
  font-size: 1.2rem;
  line-height: 1.35;
  color: #0f172a;
}

.campaign-completion-modal-name {
  margin: 0 0 12px;
  font-weight: 600;
  color: #334155;
}

.campaign-completion-modal-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 18px;
  margin: 0 0 12px;
  font-size: 0.95rem;
  color: #475569;
}

.campaign-completion-modal-stats strong {
  color: #0f172a;
}

.campaign-completion-modal-message {
  margin: 0 0 16px;
  font-size: 0.92rem;
  line-height: 1.45;
  color: #475569;
}

.campaign-completion-modal-auto-close-hint {
  margin: -8px 0 14px;
  font-size: 0.82rem;
  line-height: 1.35;
}

.campaign-completion-modal-actions {
  margin-top: 4px;
  justify-content: flex-end;
  gap: 10px;
}

.campaign-completion-confetti-host {
  pointer-events: none;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 120px;
  overflow: hidden;
  border-radius: 14px 14px 0 0;
}

.campaign-completion-modal--warning .campaign-completion-confetti-host {
  display: none;
}

.campaign-completion-confetti-piece {
  position: absolute;
  top: -12px;
  width: 6px;
  height: 10px;
  border-radius: 2px;
  opacity: 0.92;
  animation: campaignCompletionConfettiFall 2.1s ease-out forwards;
  transform: translate3d(0, 0, 0);
}

@keyframes campaignCompletionConfettiFall {
  0% {
    transform: translate3d(0, 0, 0) rotate(0deg);
    opacity: 1;
  }
  100% {
    transform: translate3d(var(--confetti-drift, 0px), 130px, 0) rotate(520deg);
    opacity: 0;
  }
}

/* Phase 2.2 — shared Messages internal pages (Reusable + Sequences) */
.delochat-messages-page,
#dashboardSection.dashboard-focus-message-flows .message-sequence-card.layer-card {
  max-width: 960px;
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
  overflow-x: hidden;
}

#templatesSection.delochat-messages-page {
  border: 1px solid rgba(226, 232, 240, 0.95);
}

.delochat-messages-page-header,
.templates-page-header,
.message-flows-page-header {
  margin-bottom: 20px;
}

.delochat-messages-page-back,
.templates-page-back,
.message-flows-page-back {
  margin-bottom: 12px;
}

.delochat-messages-page-title,
.templates-page-title,
.message-flows-page-title {
  margin: 0 0 0.35rem;
  font-size: 1.5rem;
  font-weight: 800;
  color: #0f172a;
  line-height: 1.25;
}

.delochat-messages-page-subtitle,
.templates-page-subtitle,
.message-flows-page-subtitle {
  margin: 0;
  max-width: 42rem;
  font-size: 0.95rem;
  line-height: 1.5;
}

.delochat-messages-page-stack,
.templates-page-stack,
.message-flows-page-stack {
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-width: 0;
}

.delochat-messages-page-card.sub-card,
#templatesSection .templates-page-card.sub-card,
#dashboardSection.dashboard-focus-message-flows .message-flows-section-card.sub-card {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  padding: 18px 16px;
  margin: 0;
  min-width: 0;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
}

.delochat-messages-page-card-head,
.templates-page-card-head,
.message-flows-section-card-head {
  margin-bottom: 12px;
}

.delochat-messages-page-card-head-row,
.templates-page-card-head-row,
.message-flows-section-card-head-row {
  align-items: flex-start;
  gap: 12px;
}

.delochat-messages-page-card-head-text,
.templates-page-card-head-text,
.message-flows-section-card-head-text {
  flex: 1;
  min-width: 0;
}

.delochat-messages-page-card-title,
.templates-page-card-title,
.message-flows-section-card-title,
.message-flows-sequence-details-title {
  margin: 0 0 0.25rem;
  font-size: 1rem;
  font-weight: 700;
  color: #0f172a;
}

.delochat-messages-page-card-subtitle,
.templates-page-card-subtitle,
.message-flows-section-card-subtitle,
.message-flows-sequence-details-subtitle {
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.45;
}

.delochat-messages-primary-submit,
#templatesSection #templateSubmitBtn,
#dashboardSection.dashboard-focus-message-flows #createProjectForm button[type="submit"] {
  background: #2563eb;
  border-color: #2563eb;
  color: #fff;
  font-weight: 600;
}

.delochat-messages-primary-submit:hover,
#templatesSection #templateSubmitBtn:hover,
#dashboardSection.dashboard-focus-message-flows #createProjectForm button[type="submit"]:hover {
  background: #1d4ed8;
  border-color: #1d4ed8;
}

/* Reusable Messages (templates) page — Phase 2.2A */

.templates-variables-hint {
  margin: 0 0 14px;
  font-size: 0.88rem;
  line-height: 1.45;
}

.templates-form-actions {
  flex-wrap: wrap;
  gap: 10px;
}

.templates-page-preview {
  min-width: 0;
}

.delochat-messages-page-preview-label,
.templates-page-preview-label {
  margin: 0 0 8px;
  font-size: 0.95rem;
  font-weight: 700;
  color: #0f172a;
}

#templatesSection .templates-preview-panel {
  margin: 0;
  background: #f8fafc;
  color: #334155;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  padding: 12px 14px;
  min-height: 48px;
  font-family: inherit;
  font-size: 0.9rem;
  line-height: 1.5;
  white-space: pre-wrap;
  word-break: break-word;
  overflow-x: auto;
  max-width: 100%;
  box-sizing: border-box;
}

.templates-saved-empty {
  margin: 0;
  padding: 8px 0 4px;
}

.templates-table-wrap {
  margin-top: 8px;
  overflow-x: auto;
  max-width: 100%;
  -webkit-overflow-scrolling: touch;
}

#templatesSection #templatesTable {
  width: 100%;
  min-width: 0;
}

.templates-flow-hint .support-inline-link {
  vertical-align: baseline;
}

@media (max-width: 640px) {
  #templatesSection.delochat-messages-page {
    padding: 16px;
  }

  #templatesSection .delochat-messages-page-card.sub-card,
  #dashboardSection.dashboard-focus-message-flows .delochat-messages-page-card.sub-card {
    padding: 14px 12px;
  }

  .delochat-messages-page-card-head-row.section-title-row,
  .templates-page-card-head-row.section-title-row {
    flex-direction: column;
    align-items: stretch;
  }

  .delochat-messages-page-card-head-row .secondary,
  .templates-page-card-head-row .secondary,
  #templatesSection .templates-form-actions button,
  #templatesSection .templates-form-actions .secondary,
  #dashboardSection.dashboard-focus-message-flows .message-flows-setup-form button.delochat-messages-primary-submit {
    width: 100%;
  }

  #templatesSection .grid.two {
    grid-template-columns: 1fr;
  }
}

/* --- Message Sequences workspace (Phase 2.2B) --- */
.message-flows-page-header {
  display: none;
  margin-bottom: 20px;
}

.message-flows-section-card-head {
  display: none;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  margin-bottom: 12px;
}

.message-flows-section-card-head-row {
  display: none;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.message-flows-section-card-head-text {
  flex: 1 1 12rem;
  min-width: 0;
}

.message-flows-editor-summary-flows {
  display: none;
}

.message-flows-summary-dt-flows {
  display: none;
}

.message-flows-current-sequence-panel {
  margin-bottom: 0;
}

.message-flows-current-sequence-head {
  display: none;
}

.message-flows-current-sequence-title {
  margin: 0 0 4px;
  font-size: 1rem;
  font-weight: 700;
  color: #0f172a;
}

.message-flows-current-sequence-subtitle {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.45;
}

.message-flows-current-sequence-empty {
  margin: 0 0 10px;
  font-size: 0.9rem;
  line-height: 1.45;
}

.message-flows-sequence-details-block {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid #e2e8f0;
}

.message-flows-sequence-details-head {
  display: none;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  margin-bottom: 12px;
}

.message-flows-sequence-details-title {
  margin: 0 0 4px;
  font-size: 1rem;
  font-weight: 700;
  color: #0f172a;
}

.message-flows-sequence-details-subtitle {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.45;
}

.message-sequence-compact-campaign-only {
  display: block;
}

#dashboardSection.dashboard-focus-message-flows .message-flows-summary-dt-campaign {
  display: none;
}

#dashboardSection.dashboard-focus-message-flows .message-flows-summary-dt-flows {
  display: block;
}

#dashboardSection.dashboard-focus-campaign-builder .message-flows-summary-dt-flows {
  display: none !important;
}

#dashboardSection.dashboard-focus-campaign-builder .message-flows-summary-dt-campaign {
  display: block;
}

.message-flows-steps-card-head {
  display: none;
}

.message-flows-steps-title-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

#dashboardSection.dashboard-focus-message-flows #newUserOnboardingCard,
#dashboardSection.dashboard-focus-message-flows .onboarding-flow-card,
#dashboardSection.dashboard-focus-message-flows #dashboardStep1Region,
#dashboardSection.dashboard-focus-message-flows .dashboard-step-heading.dashboard-builder-skip-flows,
#dashboardSection.dashboard-focus-message-flows .dashboard-builder-skip-flows,
#dashboardSection.dashboard-focus-message-flows .main-operation-card,
#dashboardSection.dashboard-focus-message-flows #campaignPreviewSection,
#dashboardSection.dashboard-focus-message-flows #activeCampaignSection {
  display: none !important;
}

#dashboardSection.dashboard-focus-message-flows .dashboard-workspace-toolbar {
  display: none !important;
}

#dashboardSection.dashboard-focus-message-flows .message-flows-page-header {
  display: block;
}

#dashboardSection.dashboard-focus-message-flows .message-flows-section-card-head,
#dashboardSection.dashboard-focus-message-flows .message-flows-section-card-head-row {
  display: flex;
}

#dashboardSection.dashboard-focus-message-flows .message-flows-steps-card-head {
  display: none;
}

#dashboardSection.dashboard-focus-message-flows .message-flows-editor-summary-campaign {
  display: none;
}

#dashboardSection.dashboard-focus-message-flows .message-flows-editor-summary-flows {
  display: inline;
}

#dashboardSection.dashboard-focus-message-flows .dashboard-step-heading.dashboard-builder-flow-block,
#dashboardSection.dashboard-focus-message-flows #dashboardStep1Region,
#dashboardSection.dashboard-focus-message-flows .message-flows-campaign-hint {
  display: none !important;
}

#dashboardSection.dashboard-focus-message-flows .message-sequence-card.layer-card {
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
}

#dashboardSection.dashboard-focus-message-flows .message-flows-current-sequence-panel {
  display: none !important;
}

#dashboardSection.dashboard-focus-message-flows .message-flows-current-sequence-head {
  display: block;
  grid-area: head;
  margin: 0;
}

#dashboardSection.dashboard-focus-message-flows .message-flows-current-sequence-empty {
  grid-area: empty;
  grid-column: 1 / -1;
}

#dashboardSection.dashboard-focus-message-flows .message-sequence-compact-status-slot {
  grid-area: status;
  align-self: start;
}

#dashboardSection.dashboard-focus-message-flows .message-sequence-compact-status-row {
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
  margin: 0;
  gap: 0;
}

#dashboardSection.dashboard-focus-message-flows .message-sequence-compact-status-row .message-flows-compact-summary-title-campaign,
#dashboardSection.dashboard-focus-message-flows .message-sequence-compact-campaign-only {
  display: none !important;
}

#dashboardSection.dashboard-focus-message-flows #messageSequenceCompactPanel {
  grid-area: panel;
  grid-column: 1 / -1;
}

#dashboardSection.dashboard-focus-message-flows .message-sequence-compact-panel {
  margin-bottom: 0;
  padding: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  border-bottom: none;
}

#dashboardSection.dashboard-focus-message-flows .message-flows-current-sequence-actions .secondary {
  flex: 0 1 auto;
  min-width: 0;
  width: auto;
  max-width: none;
  padding: 8px 14px;
  font-size: 0.875rem;
}

#dashboardSection.dashboard-focus-message-flows .message-flows-sequence-details-head {
  display: flex;
}

#dashboardSection.dashboard-focus-message-flows .message-flows-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

#dashboardSection.dashboard-focus-message-flows .message-flows-card-steps-details > summary.message-sequence-editor-summary {
  padding: 14px 16px;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  background: #fff;
  font-weight: 700;
  color: #0f172a;
}

#dashboardSection.dashboard-focus-message-flows .message-flows-card-steps-details[open] > summary {
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  border-bottom: none;
}

#dashboardSection.dashboard-focus-message-flows .message-flows-card-steps-details .message-sequence-details-body {
  padding: 0 0 4px;
}

#dashboardSection.dashboard-focus-message-flows .message-flows-card-steps.sub-card {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  border-top: none;
  margin-top: 0;
}

@media (max-width: 640px) {
  #dashboardSection.dashboard-focus-message-flows .message-flows-section-card-head-row {
    flex-direction: column;
    align-items: stretch;
  }

  #dashboardSection.dashboard-focus-message-flows .message-flows-section-card-head-row .secondary,
  #dashboardSection.dashboard-focus-message-flows .message-flows-setup-form button,
  #dashboardSection.dashboard-focus-message-flows .message-sequence-summary-actions .secondary,
  #dashboardSection.dashboard-focus-message-flows #addStepForm .row button,
  #dashboardSection.dashboard-focus-message-flows #addStepSubmitBtn {
    width: 100%;
  }

  #dashboardSection.dashboard-focus-message-flows .message-sequence-summary-actions {
    flex-direction: column;
    align-items: stretch;
  }

  #dashboardSection.dashboard-focus-message-flows .message-flows-current-sequence-panel {
    grid-template-columns: 1fr;
    grid-template-areas:
      "head"
      "status"
      "empty"
      "panel";
  }

  #dashboardSection.dashboard-focus-message-flows .message-sequence-compact-status-slot {
    justify-self: start;
  }

  #dashboardSection.dashboard-focus-message-flows .message-sequence-compact-status-row {
    justify-content: flex-start;
  }

  #dashboardSection.dashboard-focus-message-flows .message-flows-current-sequence-actions .secondary {
    width: 100%;
  }
}

/* Campaign builder: compact summary + collapsible editor only (not full flows workspace) */
#dashboardSection.dashboard-focus-campaign-builder .message-flows-page-header {
  display: none !important;
}

#dashboardSection.dashboard-focus-campaign-builder .message-flows-page-stack > .message-flows-card-setup .message-flows-section-card-head,
#dashboardSection.dashboard-focus-campaign-builder .message-flows-page-stack > .message-flows-card-setup .message-flows-sequence-details-block,
#dashboardSection.dashboard-focus-campaign-builder .message-flows-page-stack > .message-flows-card-setup .message-flows-current-sequence-head,
#dashboardSection.dashboard-focus-campaign-builder .message-flows-page-stack > .message-flows-card-setup .message-flows-current-sequence-empty {
  display: none !important;
}

#dashboardSection.dashboard-focus-campaign-builder .message-flows-current-sequence-panel {
  display: block;
  margin-bottom: 0;
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
}

#dashboardSection.dashboard-focus-campaign-builder .message-sequence-compact-status-slot {
  display: block;
}

#dashboardSection.dashboard-focus-campaign-builder .message-sequence-compact-status-row {
  margin-bottom: 6px;
}

#dashboardSection.dashboard-focus-campaign-builder .message-flows-page-stack > .message-flows-card-saved {
  display: none !important;
}

#dashboardSection.dashboard-focus-campaign-builder .message-flows-editor-summary-flows {
  display: none !important;
}

#dashboardSection.dashboard-focus-campaign-builder .message-flows-compact-summary-title-campaign {
  display: inline;
}

#dashboardSection.dashboard-focus-campaign-builder .message-flows-compact-summary-desc-campaign {
  display: block;
}

#dashboardSection.dashboard-focus-campaign-builder .message-flows-editor-summary-campaign {
  display: inline;
}

#dashboardSection.dashboard-focus-campaign-builder .message-flows-card-steps-details .message-flows-section-card-head,
#dashboardSection.dashboard-focus-campaign-builder .message-flows-card-steps-details .message-flows-steps-card-head {
  display: none !important;
}

/* Send Campaign Phase 2.3A — primary flow cleanup (campaign-builder focus only) */
#dashboardSection.dashboard-focus-campaign-builder .dashboard-campaign-setup-path-wrap {
  display: none !important;
}

#dashboardSection.dashboard-focus-campaign-builder
  #newUserOnboardingCard:not(.hidden):has(#dashboardOnboardingMain:not(.hidden))
  ~ #dashboardStep1Region {
  display: none !important;
}

#dashboardSection.dashboard-focus-campaign-builder #newUserOnboardingCard:not(.hidden) {
  margin-bottom: 16px;
}

#dashboardSection.dashboard-focus-campaign-builder .dashboard-campaign-builder-header {
  margin-bottom: 12px;
}

#dashboardSection.dashboard-focus-campaign-builder #campaignPreviewSection {
  padding: 14px 16px;
  margin-bottom: 14px;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.04);
}

#dashboardSection.dashboard-focus-campaign-builder #campaignPreviewSection > h2 {
  margin: 0 0 6px;
  font-size: 1.1rem;
}

#dashboardSection.dashboard-focus-campaign-builder #campaignPreviewSection .campaign-safety-hint,
#dashboardSection.dashboard-focus-campaign-builder #campaignPreviewSection .support-inline-link {
  margin-top: 4px;
  margin-bottom: 6px;
}

#dashboardSection.dashboard-focus-campaign-builder #campaignPreviewSection .campaign-preview-pre-import {
  padding: 10px 12px;
  margin-top: 8px;
}

#dashboardSection.dashboard-focus-campaign-builder #campaignPreviewSection .campaign-preview-pre-import-lead {
  margin-bottom: 6px;
  font-size: 0.92rem;
}

#dashboardSection.dashboard-focus-campaign-builder #campaignPreviewSection .campaign-preview-pre-import-safe {
  font-size: 0.88rem;
}

#dashboardSection.dashboard-focus-campaign-builder
  #activeCampaignSection.active-campaign-dashboard-card--empty {
  padding: 12px 14px;
  margin-bottom: 12px;
  box-shadow: 0 6px 18px rgba(15, 23, 42, 0.04);
}

#dashboardSection.dashboard-focus-campaign-builder
  #activeCampaignSection.active-campaign-dashboard-card--empty
  .active-campaign-section-heading {
  font-size: 1.05rem;
}

#dashboardSection.dashboard-focus-campaign-builder
  #activeCampaignSection.active-campaign-dashboard-card--empty
  .active-campaign-neutral-empty {
  padding: 10px 12px;
  margin-bottom: 8px;
}

#dashboardSection.dashboard-focus-campaign-builder
  #activeCampaignSection.active-campaign-dashboard-card--empty
  .active-campaign-neutral-empty-title {
  margin-bottom: 4px;
  font-size: 0.95rem;
}

#dashboardSection.dashboard-focus-campaign-builder
  #activeCampaignSection.active-campaign-dashboard-card--empty
  .active-campaign-neutral-empty-text {
  font-size: 0.88rem;
  line-height: 1.4;
}

#dashboardSection.dashboard-focus-campaign-builder
  #activeCampaignSection.active-campaign-dashboard-card--empty
  .active-campaign-step-summary {
  font-size: 0.9rem;
}

#dashboardSection.dashboard-focus-campaign-builder #logsDetails {
  margin-bottom: 12px;
  padding: 8px 10px;
  border-color: #e2e8f0;
  background: #fff;
  box-shadow: none;
}

#dashboardSection.dashboard-focus-campaign-builder #logsDetails > summary {
  font-size: 0.92rem;
  font-weight: 600;
  color: #475569;
}

#dashboardSection.dashboard-focus-campaign-builder #logsDetails > .muted.top-gap {
  margin-top: 8px;
  font-size: 0.88rem;
  line-height: 1.4;
}

#dashboardSection.dashboard-focus-campaign-builder #logsDetails .card {
  padding: 12px 14px;
  margin-bottom: 12px;
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.04);
}

#dashboardSection.dashboard-focus-campaign-builder #logsDetails .section-title-row h2 {
  font-size: 1rem;
  margin: 0;
}

#dashboardSection.dashboard-focus-campaign-builder #logsDetails .campaign-reports-list-helper {
  margin: 0 0 10px;
  font-size: 0.88rem;
}

#dashboardSection.dashboard-focus-campaign-builder #logsDetails .campaign-reports-empty-hint {
  margin-top: 4px;
  font-size: 0.86rem;
}

#dashboardSection.dashboard-focus-campaign-builder #logsDetails .campaign-report-summary-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(88px, 1fr));
  gap: 8px;
}

#dashboardSection.dashboard-focus-campaign-builder #logsDetails .campaign-report-summary-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  padding: 10px 8px;
  border-radius: 10px;
  border: 1px solid #e2e8f0;
  background: #f8fafc;
  min-width: 0;
}

#dashboardSection.dashboard-focus-campaign-builder #logsDetails .campaign-report-summary-card-value {
  font-size: 1.15rem;
  font-weight: 700;
  color: #0f172a;
  line-height: 1.1;
}

#dashboardSection.dashboard-focus-campaign-builder #logsDetails .campaign-report-summary-card-label {
  font-size: 0.72rem;
  font-weight: 600;
  color: #64748b;
  text-align: center;
  line-height: 1.2;
}

#dashboardSection.dashboard-focus-campaign-builder #logsDetails .campaign-report-summary-card--sent {
  border-color: #bbf7d0;
  background: #f0fdf4;
}

#dashboardSection.dashboard-focus-campaign-builder #logsDetails .campaign-report-summary-card--failed,
#dashboardSection.dashboard-focus-campaign-builder #logsDetails .campaign-report-summary-card--attention {
  border-color: #fecaca;
  background: #fef2f2;
}

#dashboardSection.dashboard-focus-campaign-builder #logsDetails .campaign-report-summary-card--pending {
  border-color: #fde68a;
  background: #fffbeb;
}

#dashboardSection.dashboard-focus-campaign-builder #logsDetails .campaign-report-summary-card--filtered {
  border-color: #e2e8f0;
  background: #f1f5f9;
}

#dashboardSection.dashboard-focus-campaign-builder #logsDetails .campaign-report-bucket-sections {
  display: grid;
  gap: 8px;
}

#dashboardSection.dashboard-focus-campaign-builder #logsDetails .campaign-report-bucket-details {
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  padding: 8px 10px;
  background: #fff;
}

#dashboardSection.dashboard-focus-campaign-builder #logsDetails .campaign-report-bucket-details > summary {
  cursor: pointer;
  font-weight: 600;
  color: #334155;
}

#dashboardSection.dashboard-focus-campaign-builder #logsDetails .campaign-report-bucket-card-list {
  display: none;
}

#dashboardSection.dashboard-focus-campaign-builder #logsDetails .campaign-report-advanced-log {
  margin-top: 10px;
}

#dashboardSection.dashboard-focus-campaign-builder #logsDetails .campaign-report-advanced-log:not([open]) {
  overflow: hidden;
}

#dashboardSection.dashboard-focus-campaign-builder #logsStatusContent .campaign-report-technical-panel,
#dashboardSection.dashboard-focus-campaign-builder #logsDetails .campaign-report-technical-panel {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  max-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  border: 0 !important;
}

#dashboardSection.dashboard-focus-campaign-builder #logsStatusContent .campaign-report-technical-only,
#dashboardSection.dashboard-focus-campaign-builder #logsDetails .campaign-report-technical-only {
  display: none !important;
}

#dashboardSection.dashboard-focus-campaign-builder .dashboard-step-heading.dashboard-builder-skip-flows {
  margin-top: 8px;
  margin-bottom: 6px;
}

#dashboardSection.dashboard-focus-campaign-builder .dashboard-campaign-builder-workspace,
#dashboardSection.dashboard-focus-campaign-builder .dashboard-campaign-builder {
  max-width: 100%;
  min-width: 0;
  overflow-x: clip;
}

@media (max-width: 640px) {
  #dashboardSection.dashboard-focus-campaign-builder #newUserOnboardingCard:not(.hidden) {
    margin-bottom: 12px;
  }

  #dashboardSection.dashboard-focus-campaign-builder .dashboard-step-heading.dashboard-builder-skip-flows {
    margin-top: 6px;
    margin-bottom: 4px;
  }

  #dashboardSection.dashboard-focus-campaign-builder #campaignPreviewSection,
  #dashboardSection.dashboard-focus-campaign-builder #activeCampaignSection {
    padding: 12px;
    margin-bottom: 10px;
  }

  #dashboardSection.dashboard-focus-campaign-builder .card.layer-card.message-sequence-card {
    margin-bottom: 12px;
  }

  #dashboardSection.dashboard-focus-campaign-builder .main-operation-card {
    margin-bottom: 12px;
  }

  #dashboardSection.dashboard-focus-campaign-builder #logsDetails {
    padding: 8px;
  }

  #dashboardSection.dashboard-focus-campaign-builder #logsDetails .campaign-report-summary-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  #dashboardSection.dashboard-focus-campaign-builder #logsDetails .campaign-report-bucket-table {
    display: none;
  }

  #dashboardSection.dashboard-focus-campaign-builder #logsDetails .campaign-report-bucket-card-list {
    display: grid;
    gap: 8px;
    margin-top: 8px;
  }

  #dashboardSection.dashboard-focus-campaign-builder #logsDetails .campaign-report-bucket-card {
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    padding: 10px;
    background: #f8fafc;
  }

  #dashboardSection.dashboard-focus-campaign-builder #logsDetails .campaign-report-bucket-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 4px;
  }

  #dashboardSection.dashboard-focus-campaign-builder #logsDetails .view-logs-btn {
    width: 100%;
    margin-top: 4px;
  }

  #dashboardSection.dashboard-focus-campaign-builder #logsDetails #campaignsTable {
    display: none;
  }

  #dashboardSection.dashboard-focus-campaign-builder #logsDetails #deliveryLogsDetails:not([open]) #logsTable {
    display: none;
  }
}

/* Send Campaign Phase 2.3C — mobile sticky CTA, history link, subtitle de-dupe */
#dashboardSection.dashboard-focus-campaign-builder
  #newUserOnboardingCard:not(.hidden):has(#dashboardOnboardingMain:not(.hidden))
  ~ .dashboard-campaign-builder
  #dashboardBuilderHeaderSubtitle,
#dashboardSection.dashboard-focus-campaign-builder
  #newUserOnboardingCard:not(.hidden):has(#dashboardOnboardingMain:not(.hidden))
  ~ .dashboard-campaign-builder
  #dashboardBuilderHeaderTitle {
  display: none;
}

#dashboardSection.dashboard-focus-campaign-builder .dashboard-delivery-history-step-heading {
  display: none;
}

#dashboardSection.dashboard-focus-campaign-builder .active-campaign-delivery-history-link-wrap {
  margin: 0 0 10px;
}

#dashboardSection.dashboard-focus-campaign-builder .active-campaign-delivery-history-link-wrap .support-inline-link {
  margin: 0;
  padding: 0;
  font-size: 0.92rem;
}

#dashboardSection.dashboard-focus-campaign-builder .dashboard-campaign-builder-mobile-sticky-cta {
  display: none;
}

@media (max-width: 640px) {
  #dashboardSection.dashboard-focus-campaign-builder.dashboard-campaign-builder-mobile-sticky-active
    #dashboardCampaignBuilderWorkspace {
    padding-bottom: calc(76px + env(safe-area-inset-bottom, 0px));
  }

  #dashboardSection.dashboard-focus-campaign-builder.dashboard-campaign-builder-mobile-sticky-active
    #dashboardOnboardingMain:not(.hidden)
    #onboardingMainContinueBtn {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }

  #dashboardSection.dashboard-focus-campaign-builder
    .dashboard-campaign-builder-mobile-sticky-cta:not(.hidden) {
    display: flex;
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 60;
    justify-content: center;
    padding: 10px 14px calc(10px + env(safe-area-inset-bottom, 0px));
    background: linear-gradient(180deg, rgba(248, 250, 252, 0) 0%, rgba(248, 250, 252, 0.92) 28%, #f8fafc 100%);
    border-top: 1px solid #e2e8f0;
    box-shadow: 0 -10px 28px rgba(15, 23, 42, 0.1);
    pointer-events: none;
  }

  #dashboardSection.dashboard-focus-campaign-builder
    .dashboard-campaign-builder-mobile-sticky-cta:not(.hidden)
    .onboarding-main-continue-btn {
    pointer-events: auto;
    width: 100%;
    max-width: 520px;
    margin: 0;
    box-sizing: border-box;
  }
}

/* Send Campaign Phase 2.3B — customer list & sending setup copy/layout */
#dashboardSection.dashboard-focus-campaign-builder .main-operation-card > h2 {
  margin-bottom: 4px;
  font-size: 1.15rem;
}

#dashboardSection.dashboard-focus-campaign-builder .main-operation-card .main-operation-one-liner {
  margin-bottom: 10px;
  font-size: 0.92rem;
  line-height: 1.45;
}

#dashboardSection.dashboard-focus-campaign-builder .import-contacts-card {
  min-width: 0;
  max-width: 100%;
  overflow-x: clip;
}

#dashboardSection.dashboard-focus-campaign-builder .import-message-source-summary {
  padding: 10px 12px;
}

#dashboardSection.dashboard-focus-campaign-builder .import-message-source-summary-title {
  font-size: 14px;
  margin-bottom: 2px;
}

#dashboardSection.dashboard-focus-campaign-builder .import-message-source-summary-detail {
  margin-bottom: 8px;
  font-size: 13px;
}

#dashboardSection.dashboard-focus-campaign-builder
  .import-message-source-summary:has(#importMessageSettingsPanel.hidden):has(#useTemplateCheckbox:not(:checked))
  .import-message-source-summary-title,
#dashboardSection.dashboard-focus-campaign-builder
  .import-message-source-summary:has(#importMessageSettingsPanel.hidden):has(#useTemplateCheckbox:not(:checked))
  .import-message-source-summary-detail {
  display: none;
}

#dashboardSection.dashboard-focus-campaign-builder
  .import-message-source-summary:has(#importMessageSettingsPanel.hidden):has(#useTemplateCheckbox:not(:checked)) {
  padding: 0;
  border: none;
  background: transparent;
}

#dashboardSection.dashboard-focus-campaign-builder
  .import-message-source-summary:has(#importMessageSettingsPanel.hidden):has(#useTemplateCheckbox:not(:checked))
  .import-message-settings-open-btn {
  margin: 0;
  min-height: 40px;
}

@media (max-width: 640px) {
  #dashboardSection.dashboard-focus-campaign-builder .dashboard-step-heading--with-action {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }

  #dashboardSection.dashboard-focus-campaign-builder .dashboard-step-heading--with-action .support-inline-link {
    position: static;
    margin: 0;
    align-self: flex-start;
  }

  #dashboardSection.dashboard-focus-campaign-builder .import-contacts-card .row,
  #dashboardSection.dashboard-focus-campaign-builder .import-data-row {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }

  #dashboardSection.dashboard-focus-campaign-builder .import-contacts-card .row button,
  #dashboardSection.dashboard-focus-campaign-builder .import-data-row button,
  #dashboardSection.dashboard-focus-campaign-builder .import-message-settings-open-btn,
  #dashboardSection.dashboard-focus-campaign-builder .import-namelist-actions button {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
  }

  #dashboardSection.dashboard-focus-campaign-builder .import-step-import-actions {
    padding-top: 12px;
    position: relative;
    z-index: 2;
  }

  #dashboardSection.dashboard-focus-campaign-builder .import-campaign-primary-btn {
    width: 100%;
    min-height: 48px;
  }

  #dashboardSection.dashboard-focus-campaign-builder .campaign-safety-hint {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 4px 6px;
  }

  #dashboardSection.dashboard-focus-campaign-builder .campaign-safety-tooltip {
    flex-shrink: 0;
    position: static;
    margin: 0;
    line-height: 1.4;
  }
}

/* --- App shell: sidebar + main (DeloChat dashboard) --- */
.app-shell {
  display: flex;
  align-items: flex-start;
  gap: 0;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  position: relative;
}

.app-sidebar-backdrop {
  display: none;
}

.app-sidebar {
  flex: 0 0 260px;
  width: 260px;
  box-sizing: border-box;
  background: #f8fafc;
  border-right: 1px solid #e2e8f0;
  min-height: 100vh;
  position: sticky;
  top: 0;
  align-self: flex-start;
  z-index: 40;
  overflow-y: auto;
  overflow-x: hidden;
}

.app-sidebar-inner {
  padding: 16px 12px 24px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.app-sidebar-brand {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 6px 12px;
  margin-bottom: 2px;
  text-decoration: none;
  color: #0f172a;
  border-bottom: 1px solid #e2e8f0;
  background: transparent;
}

.app-sidebar-brand:hover {
  color: #1d4ed8;
}

.app-sidebar-brand:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
  border-radius: 8px;
}

.app-sidebar-logo {
  display: block;
  height: 24px;
  width: auto;
  max-width: 112px;
  object-fit: contain;
  object-position: left center;
}

.app-sidebar-brand-text {
  display: none;
}

.app-sidebar-nav {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.app-sidebar-group {
  margin: 0;
}

.app-sidebar-group-label {
  margin: 0 0 6px;
  padding: 0 10px;
  font-size: 9px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #94a3b8;
}

.app-sidebar-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.app-sidebar-link {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 8px 10px;
  border: none;
  border-radius: 8px;
  background: transparent;
  color: #475569;
  font-size: 13px;
  font-weight: 500;
  text-align: left;
  cursor: pointer;
  font-family: inherit;
  line-height: 1.25;
  min-height: 40px;
  box-sizing: border-box;
  touch-action: manipulation;
  transition: background 0.12s ease, color 0.12s ease;
  user-select: none;
  -webkit-user-select: none;
  -webkit-tap-highlight-color: transparent;
}

.app-sidebar-link:hover {
  background: #e2e8f0;
  color: #0f172a;
}

.app-sidebar-link:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
}

.app-sidebar-link--active {
  background: rgba(99, 102, 241, 0.12);
  color: #4338ca;
  box-shadow: none;
  border-left: 3px solid #6366f1;
  padding-left: 7px;
}

.app-sidebar-link--active:hover {
  color: #4338ca;
  background: rgba(99, 102, 241, 0.16);
}

.app-sidebar-link--active .app-sidebar-badge {
  background: rgba(99, 102, 241, 0.14);
  color: #4338ca;
  border-color: rgba(99, 102, 241, 0.28);
}

.app-sidebar-link--aux {
  font-weight: 500;
  color: #475569;
}

.app-sidebar-link--soon .app-sidebar-link-label {
  flex: 1 1 auto;
  min-width: 0;
}

.app-sidebar-badge {
  flex-shrink: 0;
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 3px 7px;
  border-radius: 999px;
  background: #eef2ff;
  color: #4338ca;
  border: 1px solid #c7d2fe;
}

.app-sidebar-badge--addon {
  font-size: 8px;
  font-weight: 600;
  letter-spacing: 0.03em;
  padding: 2px 6px;
  background: #fff7ed;
  color: #c2410c;
  border-color: #fed7aa;
}

.app-main {
  flex: 1 1 auto;
  min-width: 0;
  max-width: 100%;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.app-content {
  min-width: 0;
  max-width: 100%;
}

.app-header-brand-row {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  min-width: 0;
  flex: 1 1 auto;
}

.app-header-brand-row .app-header-brand {
  min-width: 0;
  flex: 1 1 auto;
}

.app-sidebar-toggle {
  display: none;
  flex-shrink: 0;
  padding: 8px 12px;
  min-width: 44px;
  min-height: 44px;
  align-items: center;
  justify-content: center;
}

@media (max-width: 760px) {
  .app-shell {
    flex-direction: column;
  }

  .app-sidebar-backdrop {
    display: block;
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.45);
    z-index: 998;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease;
  }

  .app-sidebar-backdrop.is-visible {
    opacity: 1;
    pointer-events: auto;
  }

  .app-sidebar {
    position: fixed;
    left: 0;
    top: 0;
    bottom: 0;
    width: min(280px, 88vw);
    max-width: 280px;
    z-index: 999;
    transform: translateX(-100%);
    transition: transform 0.22s ease;
    box-shadow: 8px 0 32px rgba(15, 23, 42, 0.12);
    min-height: 100vh;
    max-height: 100dvh;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    touch-action: pan-y;
    border-right: 1px solid #e2e8f0;
  }

  .app-shell--sidebar-open .app-sidebar {
    transform: translateX(0);
  }

  html.app-shell-sidebar-open-mobile,
  html.app-shell-sidebar-open-mobile body {
    overflow: hidden;
    overscroll-behavior: none;
    height: 100%;
  }

  .app-sidebar-toggle {
    display: inline-flex;
    width: 44px;
    height: 44px;
    min-width: 44px;
    min-height: 44px;
    max-width: 48px;
    max-height: 48px;
    padding: 0;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    line-height: 1;
    border-radius: 10px;
    flex-shrink: 0;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
  }

  .app-header-brand .app-header-title {
    font-size: 1.25rem;
  }

  #appContainer .app-main .app-dashboard-header.card {
    border-radius: 0;
  }
}

/* Desktop: wider main column with sidebar (DeloChat app shell) */
@media (min-width: 761px) {
  #appContainer.container {
    max-width: 1580px;
    padding-left: 20px;
    padding-right: 20px;
  }

  #appContainer .app-main {
    flex: 1 1 0%;
    min-width: 0;
  }

  #appContainer .app-content {
    width: 100%;
    max-width: none;
  }

  .app-dashboard-header .app-header-subtitle {
    max-width: 52rem;
  }

  .dashboard-usage-summary .dashboard-usage-bar-track {
    max-width: none;
  }

  .onboarding-oneclick-hero .campaign-readiness-grid:not(.campaign-readiness-grid--compact) {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .safe-sending-trust-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px 18px;
  }

  .admin-summary-grid {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  }

  #dashboardSection .progress-track {
    max-width: none;
  }
}

/* Dashboard header (SaaS shell) */
.app-dashboard-header.card {
  padding: 18px 20px 16px;
}

@media (max-width: 760px) {
  .app-dashboard-header.card {
    padding: 10px 12px 10px;
  }

  .app-dashboard-header .app-header-top {
    gap: 8px 12px;
  }

  .app-header-brand-row {
    gap: 8px;
    align-items: center;
  }

  .app-dashboard-header .app-header-title {
    margin: 0 0 2px;
    font-size: clamp(22px, 5.5vw, 26px);
    line-height: 1.15;
  }

  .app-dashboard-header .app-header-subtitle {
    font-size: 14px;
    line-height: 1.4;
  }

  .app-dashboard-header .app-header-wa-chip {
    margin-top: 6px;
  }

  .app-header-wa-chip:not(.hidden) {
    min-height: 28px;
    font-weight: 700;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .app-header-user-area {
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 6px;
    width: 100%;
    margin-top: 2px;
    padding-top: 8px;
    border-top: 1px solid #e2e8f0;
  }

  .app-header-user-cluster {
    justify-content: flex-start;
    width: 100%;
    flex-wrap: nowrap;
  }

  .app-header-user-identity {
    flex-wrap: nowrap;
    max-width: 100%;
    gap: 6px;
  }

  .app-header-user-name {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
  }

  .app-header-role-badge {
    font-size: 9px;
    padding: 2px 6px;
    flex-shrink: 0;
  }

  .app-header-user-area > a.app-header-homepage-link,
  .app-header-user-area > button.app-header-logout-btn.secondary {
    font-size: 11px;
    padding: 4px 8px;
    min-height: 0;
    align-self: flex-start;
  }

  .app-dashboard-header .app-api-key-details {
    border-radius: 8px;
  }

  .app-dashboard-header .app-api-key-details > summary.app-api-key-summary {
    padding: 7px 10px;
    font-size: 11px;
    font-weight: 700;
  }

  .app-dashboard-header .app-api-key-details > p.muted {
    font-size: 0.8125rem !important;
    line-height: 1.35 !important;
    padding: 6px 10px 0 !important;
    margin-top: 0 !important;
  }

  .app-dashboard-header .app-api-key-inner.row {
    padding: 8px 10px 10px;
    gap: 8px;
  }

  .app-dashboard-header .app-main-tab-toolbar.top-gap {
    margin-top: 8px;
  }

  .app-dashboard-header .app-api-key-details.top-gap {
    margin-top: 6px;
  }

  .app-dashboard-header .app-main-tab-nav.top-gap {
    margin-top: 6px;
  }

  .app-content {
    padding-bottom: 96px;
    max-width: 100%;
    overflow-x: hidden;
    box-sizing: border-box;
  }

  .floating-support-btn.floating-support-btn--admin-context {
    bottom: 88px;
    right: 12px;
    padding: 8px 12px;
    font-size: 12px;
    max-width: min(240px, calc(100vw - 56px));
  }

  #adminSection.card {
    max-width: 100%;
    overflow-x: hidden;
    box-sizing: border-box;
  }

  #adminSection .admin-subtab-panel.admin-subtab-panel--active {
    overflow-x: hidden;
    max-width: 100%;
  }

  #adminSection .admin-mobile-table-scroll {
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    margin-bottom: 10px;
  }

  #adminSection .admin-mobile-table-scroll table {
    margin-bottom: 0;
  }

  #adminSection .admin-needs-attention-table-wrap {
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  #adminSection .admin-subtab-strip {
    padding-right: 16px;
    padding-left: 2px;
    scroll-padding-inline: 4px 16px;
    gap: 8px;
  }

  #adminSection .admin-subtab-strip .admin-subtab-btn {
    min-height: 42px;
    padding: 8px 12px;
    font-size: 13px;
    user-select: none;
    -webkit-user-select: none;
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
  }

  #adminSection .admin-company-filter-btn {
    user-select: none;
    -webkit-user-select: none;
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
  }

  #adminSendingRulesRoot {
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}

.app-header-top {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px 20px;
}

.app-header-brand {
  flex: 1 1 240px;
  min-width: 0;
}

.app-header-title {
  margin: 0 0 6px;
  font-size: clamp(1.2rem, 2.6vw, 1.35rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: #0f172a;
  line-height: 1.2;
}

.app-header-subtitle {
  margin: 0;
  font-size: 14px;
  line-height: 1.45;
  max-width: 36rem;
}

.app-header-wa-chip {
  display: inline-flex;
  align-items: center;
  margin-top: 10px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  color: #047857;
  background: rgba(16, 185, 129, 0.12);
  border: 1px solid rgba(16, 185, 129, 0.35);
}

.app-header-user-area {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 10px 12px;
  flex: 0 1 auto;
}

.app-header-user-cluster {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 10px;
  justify-content: flex-end;
}

.app-header-user-identity {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0 6px;
  max-width: min(100%, 22rem);
  line-height: 1.35;
}

.app-header-user-sep {
  display: none;
  color: #94a3b8;
  font-weight: 500;
  font-size: 13px;
  line-height: 1;
}

.app-header-user-identity:has(.app-header-role-badge:not(.hidden)) .app-header-user-sep {
  display: inline;
}

.app-header-user-name {
  font-size: 13px;
  font-weight: 600;
  color: #334155;
}

.app-header-role-badge {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.045em;
  padding: 2px 7px;
  border-radius: 999px;
  color: #4338ca;
  background: rgba(99, 102, 241, 0.1);
  border: 1px solid rgba(99, 102, 241, 0.22);
}

button.app-header-logout-btn.secondary {
  padding: 5px 10px;
  font-size: 12px;
  font-weight: 600;
  border-radius: 6px;
  background: transparent;
  color: #64748b;
  border: 1px solid transparent;
  box-shadow: none;
}

a.app-header-homepage-link {
  font-size: 12px;
  font-weight: 600;
  color: #64748b;
  text-decoration: none;
  padding: 5px 10px;
  border-radius: 6px;
  border: 1px solid transparent;
  line-height: 1.2;
  white-space: nowrap;
  flex: 0 0 auto;
}

a.app-header-homepage-link:hover {
  color: #475569;
  background: rgba(148, 163, 184, 0.12);
  border-color: rgba(148, 163, 184, 0.35);
}

a.app-header-homepage-link:focus-visible {
  outline: 2px solid rgba(99, 102, 241, 0.45);
  outline-offset: 2px;
}

button.app-header-logout-btn.secondary:hover {
  background: rgba(148, 163, 184, 0.14);
  color: #475569;
  border-color: rgba(148, 163, 184, 0.4);
}

.app-api-key-details {
  border: 1px solid rgba(226, 232, 240, 0.95);
  border-radius: 12px;
  background: rgba(248, 250, 252, 0.75);
  padding: 0;
  overflow: hidden;
}

.app-api-key-details > summary.app-api-key-summary {
  cursor: pointer;
  list-style: none;
  padding: 10px 14px;
  font-size: 13px;
  font-weight: 600;
  color: #475569;
  user-select: none;
}

.app-api-key-details > summary.app-api-key-summary::-webkit-details-marker {
  display: none;
}

.app-api-key-details[open] > summary.app-api-key-summary {
  border-bottom: 1px solid rgba(226, 232, 240, 0.95);
  color: #334155;
}

.app-api-key-inner.row {
  padding: 12px 14px 14px;
  margin-top: 0;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  max-width: 100%;
}

.app-api-key-inner.row label {
  flex: 0 0 auto;
}

.app-api-key-inner.row input#apiKey {
  flex: 1 1 180px;
  min-width: 0;
  max-width: 100%;
}

@media (max-width: 560px) {
  .app-header-top {
    flex-direction: column;
    align-items: stretch;
  }

  .app-header-user-area {
    justify-content: flex-start;
    align-items: flex-start;
  }

  a.app-header-homepage-link {
    white-space: normal;
    text-align: left;
  }

  button.app-header-logout-btn.secondary {
    min-height: 0;
  }
}

/* App shell: main tabs (pills; desktop wrap, mobile menu + horizontal scroll) */
.app-main-tab-toolbar {
  width: 100%;
}

.app-mobile-nav-toggle {
  display: none;
  width: 100%;
  min-height: 44px;
  align-items: center;
  justify-content: center;
  touch-action: manipulation;
  user-select: none;
  -webkit-user-select: none;
  -webkit-tap-highlight-color: transparent;
}

.app-main-tab-nav {
  gap: 8px;
}

/* Two-row layout: available features vs roadmap (coming soon) */
.app-main-tab-nav--grouped {
  flex-direction: column;
  align-items: stretch;
  gap: 12px;
}

.app-main-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  max-width: 100%;
  min-width: 0;
}

.app-roadmap-nav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 10px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid #e2e8f0;
  background: linear-gradient(180deg, #fafafa 0%, #f1f5f9 100%);
  max-width: 100%;
  box-sizing: border-box;
  min-width: 0;
}

.roadmap-nav-label {
  flex: 0 0 100%;
  margin: 0;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: #64748b;
  line-height: 1.2;
}

@media (min-width: 640px) {
  .roadmap-nav-label {
    flex: 0 0 auto;
    width: auto;
  }
}

.app-roadmap-nav-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  min-width: 0;
  flex: 1 1 160px;
  max-width: 100%;
}

.app-main-tab-nav .app-tab-pill {
  margin: 0;
  background: #f1f5f9;
  color: #475569;
  border: 1px solid rgba(226, 232, 240, 0.95);
  font-weight: 600;
  font-size: 13px;
  padding: 8px 14px;
  border-radius: 999px;
  box-shadow: none;
  flex: 0 0 auto;
}

.app-main-tab-nav .app-tab-pill--roadmap {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  background: #eef2f6;
  color: #64748b;
  border-color: #e2e8f0;
  font-weight: 600;
}

.app-main-tab-nav .app-tab-pill--roadmap .app-tab-pill-label {
  line-height: 1.25;
}

.app-main-tab-nav .app-tab-pill--roadmap:hover {
  background: #e2e8f0;
  color: #475569;
}

.nav-coming-soon-badge {
  display: inline-flex;
  align-items: center;
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 3px 7px;
  border-radius: 999px;
  background: #eef2ff;
  color: #4338ca;
  border: 1px solid #c7d2fe;
  flex-shrink: 0;
  line-height: 1.2;
}

.app-main-tab-nav .app-tab-pill:hover {
  background: #e2e8f0;
  color: #334155;
}

.app-main-tab-nav .app-tab-pill--roadmap:hover .nav-coming-soon-badge {
  background: #e0e7ff;
  border-color: #a5b4fc;
}

.app-main-tab-nav .app-tab-pill.app-tab-pill--active {
  scroll-margin: 8px;
  background: linear-gradient(135deg, #2563eb 0%, #4f46e5 100%);
  color: #fff;
  border-color: rgba(37, 99, 235, 0.35);
}

.app-main-tab-nav .app-tab-pill.app-tab-pill--roadmap.app-tab-pill--active {
  background: linear-gradient(135deg, #2563eb 0%, #4f46e5 100%);
  color: #fff;
  border-color: rgba(37, 99, 235, 0.35);
}

.app-main-tab-nav .app-tab-pill.app-tab-pill--roadmap.app-tab-pill--active .nav-coming-soon-badge {
  background: rgba(255, 255, 255, 0.22);
  color: #fff;
  border-color: rgba(255, 255, 255, 0.38);
}

.app-main-tab-nav .app-tab-pill.app-tab-pill--active:hover {
  background: linear-gradient(135deg, #1d4ed8 0%, #4338ca 100%);
  color: #fff;
}

.app-main-tab-nav .app-tab-pill.app-tab-pill--roadmap.app-tab-pill--active:hover .nav-coming-soon-badge {
  background: rgba(255, 255, 255, 0.28);
  color: #fff;
  border-color: rgba(255, 255, 255, 0.45);
}

@media (max-width: 760px) {
  .app-mobile-nav-toggle {
    display: flex;
  }

  .app-main-tab-nav:not(.is-open) {
    display: none !important;
  }

  .app-main-tab-nav.is-open {
    display: flex !important;
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: stretch;
    gap: 12px;
    width: 100%;
    max-width: 100%;
    overflow-x: visible;
    overflow-y: visible;
    padding-bottom: 4px;
    box-sizing: border-box;
  }

  .app-main-nav {
    flex-wrap: wrap;
    overflow-x: visible;
  }

  .app-roadmap-nav {
    flex-direction: column;
    align-items: stretch;
  }

  .app-roadmap-nav-pills {
    flex-wrap: wrap;
    overflow-x: visible;
  }

  .app-main-tab-nav.is-open .app-tab-pill {
    min-height: 40px;
    touch-action: manipulation;
  }
}

@media (min-width: 761px) {
  .app-main-tab-nav {
    display: flex !important;
    flex-wrap: nowrap;
    flex-direction: column;
    align-items: stretch;
  }

  .app-mobile-nav-toggle {
    display: none !important;
  }
}

/* Import — Step 3 message source summary + collapsible settings */
.import-message-source-summary {
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid rgba(226, 232, 240, 0.95);
  background: #f8fafc;
}

.import-message-source-summary-title {
  margin: 0 0 4px;
  font-size: 15px;
  font-weight: 700;
  color: #0f172a;
  line-height: 1.35;
}

.import-message-source-summary-detail {
  margin: 0 0 10px;
  font-size: 14px;
  line-height: 1.45;
}

.import-message-settings-panel {
  padding: 14px;
  border-radius: 12px;
  border: 1px solid rgba(226, 232, 240, 0.95);
  background: #ffffff;
}

.import-message-settings-panel .row {
  flex-wrap: wrap;
}

.import-message-settings-templates-hint {
  font-size: 14px;
  line-height: 1.45;
}

@media (max-width: 760px) {
  .import-message-source-summary {
    padding: 10px 12px;
  }

  .import-message-source-summary-title {
    font-size: 14px;
  }

  .import-message-source-summary-detail {
    margin-bottom: 8px;
    font-size: 13px;
  }

  .import-message-settings-open-btn,
  .import-message-settings-close-btn {
    width: 100%;
    min-height: 44px;
    touch-action: manipulation;
  }

  .import-message-settings-panel .secondary {
    width: 100%;
  }
}

/* Safe Sending Rules admin tables */
.table-scroll-wrap {
  overflow-x: auto;
  max-width: 100%;
}

.admin-send-rules-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}

.admin-send-rules-table th,
.admin-send-rules-table td {
  border: 1px solid #e2e8f0;
  padding: 6px 8px;
  vertical-align: middle;
}

.admin-send-rules-table th {
  text-align: left;
  background: #f8fafc;
}

.admin-send-rules-table .input {
  min-width: 4rem;
  width: 100%;
  max-width: 10rem;
  box-sizing: border-box;
}

.admin-inline-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

.admin-inline-field .small {
  font-size: 12px;
}

.admin-sending-rule-summary {
  padding: 10px 12px;
  border-radius: 10px;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  margin: 10px 0 12px;
}

.admin-sending-rule-summary-line {
  margin: 0 0 6px;
  font-size: 14px;
  line-height: 1.45;
}

.admin-sending-rule-summary-line:last-child {
  margin-bottom: 0;
}

.admin-sending-rule-field-label {
  margin: 10px 0 4px;
}

/* Source rules — compact chips (Safe Sending admin only) */
.admin-source-rule-chip-group {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 8px;
  margin: 6px 0 12px;
  max-width: 100%;
}

.admin-source-rule-chip {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid #cbd5e1;
  background: #f8fafc;
  cursor: pointer;
  box-sizing: border-box;
  font-size: 14px;
  font-weight: 600;
  color: #334155;
  max-width: 100%;
  user-select: none;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  transition: background 0.12s ease, border-color 0.12s ease, box-shadow 0.12s ease;
}

.admin-source-rule-chip:focus-within {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
}

.admin-source-rule-chip-input {
  position: absolute;
  opacity: 0;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.admin-source-rule-chip-body {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  pointer-events: none;
  min-width: 0;
}

.admin-source-rule-chip-main {
  white-space: nowrap;
  line-height: 1.2;
}

.admin-source-rule-chip--inactive {
  opacity: 0.55;
  border-style: dashed;
  font-weight: 500;
  color: #64748b;
}

.admin-source-rule-chip--allowed:has(.admin-source-rule-chip-input:checked) {
  background: #dbeafe;
  border-color: #3b82f6;
  color: #1e40af;
  box-shadow: inset 0 0 0 1px rgba(37, 99, 235, 0.2);
}

.admin-source-rule-chip--allowed:has(.admin-source-rule-chip-input:checked) .admin-source-rule-chip-main::before {
  content: "✓ ";
  font-weight: 800;
  margin-right: 1px;
}

.admin-source-rule-chip--default:has(.admin-source-rule-chip-input:checked) {
  background: #eff6ff;
  border-color: #1d4ed8;
  color: #1e3a8a;
  box-shadow: inset 0 0 0 2px rgba(29, 78, 216, 0.35);
}

.admin-source-rule-chip--default:has(.admin-source-rule-chip-input:checked) .admin-source-rule-chip-body::before {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #1d4ed8;
  flex-shrink: 0;
}

.admin-source-rule-chip--default:has(.admin-source-rule-chip-input:checked) .admin-source-rule-chip-main::after {
  content: "Default";
  margin-left: 6px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #1d4ed8;
  vertical-align: middle;
}

@media (max-width: 380px) {
  .admin-source-rule-chip--default:has(.admin-source-rule-chip-input:checked) .admin-source-rule-chip-main::after {
    content: "";
    margin: 0;
  }
}

.admin-safety-levels-table .input.admin-sending-sl-title,
.admin-safety-levels-table .input.admin-sending-sl-risk {
  max-width: none;
  min-width: 9rem;
}

.admin-safety-levels-table {
  min-width: 880px;
}

.admin-safety-levels-scroll-hint {
  display: none;
}

@media (min-width: 761px) {
  #adminPlansTable,
  #adminCompaniesTable,
  #adminUsersTable,
  #adminCustomerInstancesTable,
  #adminInstancesTable {
    display: table !important;
  }

  #adminSystemInstancesTable:not(.hidden) {
    display: table !important;
  }

  #adminSection .admin-card-list:not(.always-visible) {
    display: none !important;
  }
}

@media (max-width: 760px) {
  .admin-safety-levels-scroll-hint {
    display: block;
    margin: 0 0 8px;
    line-height: 1.4;
  }

  .admin-safety-levels-section .admin-safety-levels-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .admin-safety-levels-section .admin-safety-levels-table {
    min-width: 0;
    width: 100%;
  }

  .admin-safety-levels-section .admin-safety-levels-table thead {
    display: none;
  }

  .admin-safety-levels-section .admin-safety-levels-table tbody {
    display: block;
    width: 100%;
  }

  .admin-safety-levels-section .admin-safety-levels-table tbody tr {
    display: block;
    width: 100%;
    margin-bottom: 14px;
    padding: 12px 12px 10px;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    background: #fff;
    box-sizing: border-box;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
  }

  .admin-safety-levels-section .admin-safety-levels-table tbody tr td {
    display: block;
    width: 100%;
    border: none;
    padding: 8px 0;
    vertical-align: top;
  }

  .admin-safety-levels-section .admin-safety-levels-table tbody tr td::before {
    content: attr(data-label);
    display: block;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: #64748b;
    margin-bottom: 4px;
  }

  .admin-safety-levels-section .admin-safety-levels-table tbody tr td[data-label="Actions"]::before {
    content: "";
    display: none;
  }

  .admin-safety-levels-section .admin-safety-levels-table tbody tr td[data-label="Actions"] {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding-top: 12px;
    margin-top: 4px;
    border-top: 1px solid #f1f5f9;
  }

  .admin-safety-levels-section .admin-safety-levels-table tbody tr td[data-label="Actions"] button {
    flex: 1 1 140px;
    min-height: 44px;
  }

  .admin-safety-levels-section .admin-safety-levels-table .input {
    max-width: none;
    width: 100%;
    min-width: 0;
  }
}

/* Manual billing v1: customer Billing tab shows only subscription bundle */
#settingsSection.settings-billing-only .settings-full-only {
  display: none !important;
}

/* Phase 3.5A — Settings/Billing separation: hide the billing bundle when the
   user is on the Settings tab (i.e. settingsSection is rendered without the
   .settings-billing-only flag). The DOM nodes stay in place so loadBilling /
   renderBilling can still find every required ID when the Billing tab is
   opened. */
#settingsSection:not(.settings-billing-only) .settings-billing-bundle {
  display: none !important;
}

.billing-upgrade-list {
  margin: 8px 0 0;
  padding-left: 1.25rem;
  line-height: 1.5;
}

.billing-subscription-warning {
  padding: 10px 12px;
  border-radius: 8px;
  background: #fff7ed;
  border: 1px solid #fdba74;
  color: #9a3412;
  font-size: 0.95rem;
}

/* Phase 3.1B: customer manual payment (Billing tab) */
.billing-manual-payment-card {
  border-color: #e2e8f0;
  border-radius: 12px;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
  max-width: 100%;
  overflow-x: hidden;
  box-sizing: border-box;
}

.billing-manual-payment-subtitle {
  margin: 0 0 12px;
  font-size: 0.95rem;
  line-height: 1.45;
}

.billing-manual-payment-section-title {
  margin: 16px 0 8px;
  font-size: 1rem;
  font-weight: 600;
  color: #0f172a;
}

.billing-manual-payment-bank-heading {
  margin-top: 0;
}

.billing-manual-payment-how {
  margin: 0 0 14px;
  padding: 12px 14px;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  background: #fff;
}

.billing-manual-payment-how .billing-manual-payment-section-title {
  margin-top: 0;
}

.billing-manual-payment-steps {
  margin: 0;
  padding-left: 1.15rem;
  display: grid;
  gap: 6px;
  font-size: 0.9rem;
  line-height: 1.4;
  color: #334155;
}

.billing-manual-payment-steps li {
  padding-left: 2px;
}

.billing-manual-payment-method-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 12px;
}

.billing-manual-payment-method-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 4px 10px;
  background: #eef2ff;
  color: #3730a3;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  white-space: nowrap;
}

.billing-manual-payment-bank-block {
  padding: 12px;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  background: #f8fafc;
  max-width: 100%;
  box-sizing: border-box;
}

.billing-manual-payment-bank-layout {
  display: grid;
  grid-template-columns: minmax(160px, 220px) 1fr;
  gap: 16px;
  align-items: start;
}

.billing-manual-payment-bank-qr-col {
  min-width: 0;
}

.billing-manual-payment-bank-details-col {
  min-width: 0;
}

.billing-manual-payment-qr-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 120px;
  height: 100%;
  margin: 0;
  padding: 12px;
  border: 1px dashed #cbd5e1;
  border-radius: 10px;
  background: #fff;
}

.billing-manual-payment-qr-img {
  display: block;
  width: 100%;
  max-width: min(200px, 100%);
  height: auto;
  border-radius: 8px;
}

.billing-manual-payment-qr-placeholder {
  margin: 0;
  text-align: center;
  font-size: 0.9rem;
  max-width: 280px;
}

.billing-manual-payment-bank-dl {
  margin: 0;
  display: grid;
  gap: 8px;
}

.billing-manual-payment-bank-row {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 8px;
  font-size: 0.92rem;
}

.billing-manual-payment-bank-row dt {
  margin: 0;
  color: #64748b;
  font-weight: 500;
}

.billing-manual-payment-bank-row dd {
  margin: 0;
  font-weight: 600;
  color: #0f172a;
  word-break: break-word;
}

.billing-manual-payment-instructions {
  margin: 10px 0 0;
  font-size: 0.9rem;
  line-height: 1.45;
  white-space: pre-wrap;
}

.billing-manual-payment-plans {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(148px, 1fr));
  gap: 10px;
  margin-top: 8px;
  max-width: 100%;
}

.billing-manual-payment-plan-card {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 12px;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  background: #fff;
  cursor: pointer;
  text-align: left;
  transition: border-color 0.15s, box-shadow 0.15s, background 0.15s, color 0.15s;
  min-width: 0;
  box-sizing: border-box;
}

.billing-manual-payment-plan-card:hover {
  border-color: #93c5fd;
}

.billing-manual-payment-plan-card.billing-manual-payment-plan-card--selected {
  border-color: #4f46e5;
  box-shadow: 0 0 0 2px rgba(79, 70, 229, 0.2);
  background: linear-gradient(145deg, #4f46e5 0%, #2563eb 100%);
  color: #fff;
}

.billing-manual-payment-subscription-summary {
  margin: 16px 0 8px;
  padding: 12px 14px;
  border-radius: 8px;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
}

.billing-manual-payment-subscription-summary-text {
  margin: 4px 0 0;
  font-size: 0.9rem;
}

.billing-manual-payment-renewal-guard {
  margin: 12px 0 0;
  padding: 12px 14px;
  border-radius: 8px;
  background: #fffbeb;
  border: 1px solid #fde68a;
}

.billing-manual-payment-renewal-warning {
  margin: 0 0 8px;
  font-size: 0.875rem;
}

.billing-manual-payment-renewal-confirm {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 0.875rem;
  font-weight: 500;
}

.billing-manual-payment-plan-projected {
  display: block;
  font-size: 0.75rem;
  margin-top: 4px;
}

.billing-manual-payment-plan-card.billing-manual-payment-plan-card--disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.billing-manual-payment-plan-card.billing-manual-payment-plan-card--disabled:hover {
  border-color: var(--border, #e2e8f0);
  box-shadow: none;
}

.billing-manual-payment-plan-card.billing-manual-payment-plan-card--selected:hover {
  border-color: #4338ca;
}

.billing-manual-payment-plan-name {
  font-weight: 700;
  color: #0f172a;
  font-size: 0.95rem;
}

.billing-manual-payment-plan-card--selected .billing-manual-payment-plan-name,
.billing-manual-payment-plan-card--selected .billing-manual-payment-plan-price,
.billing-manual-payment-plan-card--selected .billing-manual-payment-plan-limit {
  color: #fff;
}

.billing-manual-payment-plan-price {
  font-size: 0.88rem;
  color: #475569;
}

.billing-manual-payment-plan-limit {
  font-size: 0.8rem;
  color: #64748b;
}

.billing-manual-payment-plan-selected-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: flex-start;
  margin-top: 6px;
  padding: 3px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.22);
  color: #fff;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.billing-manual-payment-plan-select-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: flex-start;
  margin-top: 6px;
  padding: 5px 10px;
  border-radius: 8px;
  border: 1px solid #cbd5e1;
  background: #f8fafc;
  color: #334155;
  font-size: 0.78rem;
  font-weight: 600;
  line-height: 1.2;
}

.billing-manual-payment-plan-card:hover .billing-manual-payment-plan-select-btn {
  border-color: #93c5fd;
  background: #eff6ff;
  color: #1d4ed8;
}

.billing-manual-payment-actions {
  margin-top: 14px;
}

.billing-manual-payment-primary-btn {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

.billing-custom-plan-copy {
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.45;
}

.billing-manual-payment-upload-section {
  margin-top: 8px;
  padding-top: 4px;
  border-top: 1px solid #e2e8f0;
}

.billing-manual-payment-upload-hint {
  margin: 0 0 10px;
  font-size: 0.88rem;
}

.billing-manual-payment-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 12px;
  font-size: 0.92rem;
  font-weight: 500;
}

.billing-manual-payment-field input[type="file"],
.billing-manual-payment-field textarea {
  font-weight: 400;
  width: 100%;
  box-sizing: border-box;
}

.billing-manual-payment-status-section {
  margin-top: 12px;
  padding: 12px;
  border-radius: 10px;
  background: #f1f5f9;
  border: 1px solid #e2e8f0;
}

.billing-manual-payment-status-badge {
  display: inline-block;
  margin: 0 0 8px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.billing-manual-payment-status-badge--draft {
  background: #e0e7ff;
  color: #3730a3;
}

.billing-manual-payment-status-badge--pending {
  background: #fef3c7;
  color: #92400e;
}

.billing-manual-payment-status-badge--approved {
  background: #dcfce7;
  color: #166534;
}

.billing-manual-payment-status-badge--rejected {
  background: #fee2e2;
  color: #991b1b;
}

.billing-manual-payment-status-badge--cancelled {
  background: #f1f5f9;
  color: #475569;
}

.billing-manual-payment-status-message {
  margin: 0 0 6px;
  font-size: 0.94rem;
  line-height: 1.45;
  color: #0f172a;
}

.billing-manual-payment-status-meta {
  margin: 0 0 8px;
  font-size: 0.85rem;
}

.billing-manual-payment-view-receipt {
  margin-top: 4px;
}

.billing-manual-payment-banner {
  padding: 10px 12px;
  border-radius: 8px;
  font-size: 0.9rem;
  margin: 0 0 10px;
}

.billing-manual-payment-banner--error {
  background: #fef2f2;
  border: 1px solid #fecaca;
  color: #991b1b;
}

.billing-manual-payment-loading {
  margin: 0 0 8px;
  font-size: 0.9rem;
}

@media (max-width: 640px) {
  .billing-manual-payment-bank-layout {
    grid-template-columns: 1fr;
  }

  .billing-manual-payment-qr-wrap {
    max-width: 100%;
  }

  .billing-manual-payment-qr-img {
    max-width: min(180px, 100%);
    margin: 0 auto;
  }

  .billing-manual-payment-method-badges {
    gap: 6px;
  }

  .billing-manual-payment-method-pill {
    font-size: 0.72rem;
    padding: 3px 8px;
  }

  .billing-manual-payment-plans {
    grid-template-columns: 1fr;
  }

  .billing-manual-payment-bank-row {
    grid-template-columns: 1fr;
    gap: 2px;
  }

  .billing-manual-payment-primary-btn {
    width: 100%;
  }

  .billing-manual-payment-steps {
    font-size: 0.86rem;
  }
}

.admin-billing-panel .admin-billing-payments-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  max-width: 100%;
}

.admin-billing-payments-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
}

.admin-billing-payments-table th,
.admin-billing-payments-table td {
  border: 1px solid #e2e8f0;
  padding: 6px 8px;
  text-align: left;
  vertical-align: top;
}

.admin-billing-payments-table th {
  background: #f8fafc;
  font-weight: 600;
}

/* Phase 3.1C: admin billing verification */
.admin-billing-verification-section {
  max-width: 100%;
  overflow-x: hidden;
}

.admin-billing-verify-section-title {
  margin: 18px 0 8px;
  font-size: 1rem;
  font-weight: 600;
}

.admin-billing-verify-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  max-width: 100%;
}

.admin-billing-verify-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
  min-width: 640px;
}

.admin-billing-verify-table th,
.admin-billing-verify-table td {
  border: 1px solid #e2e8f0;
  padding: 8px 10px;
  text-align: left;
  vertical-align: top;
}

.admin-billing-verify-table th {
  background: #f8fafc;
  font-weight: 600;
}

.admin-billing-verify-note-cell {
  max-width: 220px;
  word-break: break-word;
}

.admin-billing-verify-action-badge {
  display: inline-block;
  margin-left: 4px;
  padding: 2px 6px;
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  border-radius: 4px;
  background: #e0f2fe;
  color: #0369a1;
  vertical-align: middle;
}

.admin-billing-verify-expiry {
  margin-top: 4px;
  line-height: 1.35;
}

.admin-billing-verify-downgrade-badge {
  display: inline-block;
  margin-left: 6px;
  padding: 2px 6px;
  font-size: 0.7rem;
  font-weight: 600;
  border-radius: 4px;
  background: #fef3c7;
  color: #92400e;
  vertical-align: middle;
}

.admin-billing-verify-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.admin-billing-verify-actions button {
  font-size: 0.78rem;
  padding: 4px 8px;
}

.admin-billing-verify-banner {
  padding: 10px 12px;
  border-radius: 8px;
  font-size: 0.9rem;
  margin: 0 0 10px;
}

.admin-billing-verify-banner--error {
  background: #fef2f2;
  border: 1px solid #fecaca;
  color: #991b1b;
}

.admin-billing-verify-loading {
  margin: 0 0 8px;
}

.admin-billing-settings-section {
  max-width: 720px;
}

.admin-billing-settings-banner {
  margin: 8px 0;
  padding: 10px 12px;
  border-radius: 8px;
  font-size: 0.9rem;
}

.admin-billing-settings-banner--error {
  background: #fef2f2;
  border: 1px solid #fecaca;
  color: #991b1b;
}

.admin-billing-settings-loading {
  margin: 0 0 8px;
}

.admin-billing-settings-block {
  padding-top: 4px;
}

.admin-billing-settings-block-title {
  margin: 0 0 6px;
  font-size: 1rem;
}

.admin-billing-settings-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin: 12px 0 0;
  font-weight: 500;
}

.admin-billing-settings-field--narrow {
  max-width: 200px;
}

.admin-billing-settings-field span:first-child {
  font-size: 0.875rem;
}

.admin-billing-settings-input,
.admin-billing-settings-textarea {
  font-weight: 400;
  width: 100%;
  box-sizing: border-box;
}

.admin-billing-settings-textarea {
  resize: vertical;
  min-height: 72px;
}

.admin-billing-settings-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0 12px;
}

.admin-billing-settings-check {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
  font-weight: 500;
}

.admin-billing-settings-hint {
  font-weight: 400;
  font-size: 0.8125rem;
}

.admin-billing-settings-otp-status {
  margin: 8px 0 0;
  font-size: 0.9rem;
}

.admin-billing-settings-system-otp code {
  font-size: 0.85em;
}

.admin-billing-verify-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  z-index: 9999;
  align-items: center;
  justify-content: center;
  padding: 16px;
  box-sizing: border-box;
}

.admin-billing-verify-modal-card {
  width: min(520px, 100%);
  max-height: calc(100vh - 32px);
  overflow: auto;
  background: #fff;
  border-radius: 12px;
  padding: 16px;
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.18);
}

.admin-billing-verify-modal-summary {
  margin: 0 0 12px;
  line-height: 1.45;
}

.admin-billing-verify-modal-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 10px;
  font-weight: 500;
}

.admin-billing-verify-modal-field textarea {
  font-weight: 400;
  width: 100%;
  box-sizing: border-box;
}

.admin-billing-verify-modal-hint {
  margin: 0 0 12px;
  font-size: 0.88rem;
  line-height: 1.4;
}

.admin-billing-verify-modal-actions {
  flex-wrap: wrap;
}

@media (max-width: 640px) {
  .admin-billing-verify-table {
    min-width: 560px;
  }
}

/* Dashboard overview polish v1 */
.dashboard-overview-section {
  margin-bottom: 18px;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

.dashboard-overview-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 14px;
  width: 100%;
  box-sizing: border-box;
}

@media (min-width: 1100px) {
  .dashboard-overview-grid {
    grid-template-columns: repeat(4, 1fr);
  }

  .dashboard-overview-grid--no-plan-usage {
    grid-template-columns: repeat(3, 1fr);
  }
}

.dashboard-overview-card-title {
  margin: 0 0 10px;
  font-size: 1rem;
  font-weight: 700;
  color: #0f172a;
}

.dashboard-overview-wa-status {
  margin: 0 0 6px;
  font-weight: 600;
  color: #0f172a;
}

.dashboard-overview-wa-detail {
  margin: 0 0 12px;
  font-size: 0.9rem;
  line-height: 1.4;
  word-break: break-word;
}

.dashboard-overview-card-action {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

.dashboard-overview-active-summary {
  margin: 0 0 8px;
  font-weight: 600;
  color: #0f172a;
  line-height: 1.35;
  word-break: break-word;
}

.dashboard-overview-active-meta {
  margin: 0 0 12px;
  font-size: 0.88rem;
  line-height: 1.4;
}

.dashboard-overview-active-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.dashboard-overview-active-actions button {
  flex: 1 1 auto;
  min-height: 42px;
  min-width: 0;
}

.dashboard-quick-actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.dashboard-quick-actions button {
  width: 100%;
  min-height: 44px;
  box-sizing: border-box;
  text-align: center;
}

.dashboard-quick-actions button.dashboard-quick-action--blocked {
  opacity: 0.55;
  cursor: not-allowed;
}

.dashboard-next-step-card {
  margin-bottom: 18px;
  padding: 16px 18px;
  border: 1px solid rgba(99, 102, 241, 0.25);
  background: linear-gradient(135deg, rgba(238, 242, 255, 0.95), rgba(255, 255, 255, 0.98));
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.06);
}

.dashboard-next-step-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}

.dashboard-next-step-copy-block {
  flex: 1 1 220px;
  min-width: 0;
}

.dashboard-next-step-eyebrow {
  margin: 0 0 6px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #4338ca;
}

.dashboard-next-step-title {
  margin: 0 0 8px;
  font-size: 1.15rem;
  font-weight: 700;
  color: #0f172a;
  line-height: 1.25;
}

.dashboard-next-step-body {
  margin: 0;
  font-size: 0.92rem;
  line-height: 1.5;
  max-width: 40rem;
}

.dashboard-next-step-cta {
  flex: 0 0 auto;
  min-height: 44px;
  padding-left: 18px;
  padding-right: 18px;
}

.dashboard-campaign-setup-path-wrap {
  margin-bottom: 18px;
  padding: 14px 16px;
}

.dashboard-campaign-setup-path-heading {
  margin: 0 0 10px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #64748b;
}

.dashboard-campaign-setup-path {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 10px;
  align-items: stretch;
  list-style: none;
  margin: 0;
  padding: 0;
}

.dashboard-campaign-setup-step {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid #e2e8f0;
  background: #f8fafc;
  font-size: 13px;
  font-weight: 600;
  color: #64748b;
  min-height: 40px;
  box-sizing: border-box;
}

.dashboard-campaign-setup-step .dashboard-campaign-setup-index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: #e2e8f0;
  color: #475569;
  font-size: 12px;
  font-weight: 800;
}

.dashboard-campaign-setup-step.is-done {
  border-color: rgba(34, 197, 94, 0.35);
  background: rgba(240, 253, 244, 0.9);
  color: #166534;
}

.dashboard-campaign-setup-step.is-done .dashboard-campaign-setup-index {
  background: #22c55e;
  color: #fff;
}

.dashboard-campaign-setup-step.is-current {
  border-color: rgba(99, 102, 241, 0.45);
  background: #eef2ff;
  color: #312e81;
  box-shadow: 0 0 0 1px rgba(99, 102, 241, 0.12);
}

.dashboard-campaign-setup-step.is-current .dashboard-campaign-setup-index {
  background: #4f46e5;
  color: #fff;
}

.dashboard-campaign-setup-step.is-upcoming.is-disabled {
  opacity: 0.45;
}

.message-sequence-compact-desc {
  margin: 0 0 12px;
  font-size: 0.9rem;
  line-height: 1.45;
}

.import-dashboard-group--source {
  border-left: 3px solid #38bdf8;
}

.import-dashboard-group--campaign {
  border-left: 3px solid #a78bfa;
}

.import-dashboard-group--actions {
  border-left: 3px solid #4f46e5;
}

.import-subheading {
  margin: 0 0 8px;
  font-size: 0.95rem;
  font-weight: 700;
  color: #0f172a;
}

.import-namelist-privacy-inline {
  margin: 4px 0 0;
  font-size: 0.88rem;
}

.import-step-import-actions {
  padding: 18px 16px;
}

.import-campaign-primary-btn {
  width: 100%;
  min-height: 46px;
  font-weight: 700;
}

.import-advanced-details {
  margin-top: 4px;
}

.import-advanced-details-summary {
  cursor: pointer;
  font-weight: 600;
  color: #334155;
}

.import-advanced-details-body {
  margin-top: 10px;
}

.active-campaign-dashboard-card--empty .section-title-row,
.active-campaign-dashboard-card--empty .active-campaign-section-title-row {
  margin-bottom: 8px;
}

.active-campaign-section-heading {
  margin: 0;
  font-size: 1.2rem;
}

.active-campaign-neutral-empty {
  padding: 14px 16px;
  border-radius: 12px;
  background: #f8fafc;
  border: 1px dashed #cbd5e1;
  margin-bottom: 12px;
}

.active-campaign-neutral-empty-title {
  margin: 0 0 6px;
  font-weight: 700;
  color: #0f172a;
}

.active-campaign-neutral-empty-text {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.45;
}

.app-sidebar-group--soon {
  opacity: 0.92;
}

.app-sidebar-group-label--soon {
  font-size: 11px;
  color: #94a3b8;
}

.app-sidebar-list--soon .app-sidebar-link--soon {
  padding-top: 6px;
  padding-bottom: 6px;
}

.app-sidebar-link--addon-quiet {
  font-weight: 500;
}

.app-sidebar-link--addon-quiet .app-sidebar-badge {
  opacity: 0.9;
}

.dashboard-campaign-builder {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
  margin-bottom: 8px;
}

.dashboard-campaign-builder-header {
  margin: 0 0 16px;
}

.dashboard-campaign-builder-title {
  margin: 0 0 6px;
  font-size: 1.35rem;
  font-weight: 700;
  color: #0f172a;
}

.dashboard-campaign-builder-subtitle {
  margin: 0;
  max-width: 52rem;
  line-height: 1.45;
}

.dashboard-step-1-region .dashboard-step-1-title {
  margin: 0 0 8px;
  font-size: 1.05rem;
}

.dashboard-step-1-region .muted {
  margin: 0 0 12px;
}

@media (max-width: 760px) {
  .dashboard-overview-active-actions {
    flex-direction: column;
  }

  .dashboard-overview-active-actions button {
    width: 100%;
  }

  .dashboard-next-step-cta {
    width: 100%;
  }

  .dashboard-campaign-setup-step {
    flex: 1 1 auto;
    min-width: calc(50% - 10px);
  }

  .dashboard-campaign-setup-path {
    gap: 8px;
  }

  .dashboard-entry-card-inner,
  .dashboard-message-flow-home-inner {
    flex-direction: column;
    align-items: stretch;
  }

  .dashboard-entry-card-cta {
    width: 100%;
  }
}

/* Dashboard focus mode v1 — home vs builder vs message flows */
#dashboardSection.dashboard-focus-home #dashboardCampaignBuilderWorkspace {
  display: none !important;
}

#dashboardSection.dashboard-focus-home #newUserOnboardingCard {
  display: none !important;
}

#dashboardSection.dashboard-focus-home #dashboardStep1Region {
  display: none !important;
}

.dashboard-home-panel {
  display: block;
}

.dashboard-campaign-builder-workspace {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

.dashboard-workspace-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}

.dashboard-workspace-back-btn {
  flex: 0 0 auto;
}

.dashboard-workspace-title {
  margin: 0;
  font-size: 1.15rem;
  font-weight: 700;
  color: #0f172a;
}

.dashboard-entry-card {
  margin-bottom: 14px;
}

.dashboard-entry-card-inner,
.dashboard-message-flow-home-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.dashboard-entry-card-title {
  margin: 0 0 6px;
  font-size: 1rem;
  font-weight: 700;
}

.dashboard-entry-card-body {
  margin: 0;
  font-size: 0.92rem;
}

.dashboard-entry-card-cta {
  flex: 0 0 auto;
  min-height: 44px;
}

.dashboard-message-flow-home-status {
  margin: 0 0 4px;
  font-weight: 600;
  color: #b45309;
}

.dashboard-message-flow-home-status--ready {
  color: #047857;
}

.dashboard-message-flow-home-meta {
  margin: 0;
  font-size: 0.88rem;
}

.dashboard-home-active-section {
  margin-bottom: 14px;
}

.dashboard-home-active-line {
  margin: 0 0 12px;
}

#dashboardSection.dashboard-focus-message-flows .dashboard-builder-skip-flows {
  display: none !important;
}

#dashboardSection.dashboard-focus-message-flows .dashboard-campaign-builder-header,
#dashboardSection.dashboard-focus-message-flows .dashboard-campaign-setup-path-wrap {
  display: none !important;
}

/* First-time customer guided dashboard v1 */
.dashboard-first-time-hero {
  margin-bottom: 18px;
  padding: 20px 22px;
  border: 1px solid rgba(16, 185, 129, 0.35);
  background: linear-gradient(145deg, rgba(236, 253, 245, 0.95), rgba(255, 255, 255, 0.98));
  box-shadow: 0 12px 32px rgba(15, 23, 42, 0.07);
}

.dashboard-first-time-hero-eyebrow {
  margin: 0 0 8px;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #047857;
}

.dashboard-first-time-hero-title {
  margin: 0 0 10px;
  font-size: 1.35rem;
  font-weight: 800;
  color: #0f172a;
  line-height: 1.25;
}

.dashboard-first-time-hero-subtitle {
  margin: 0 0 16px;
  font-size: 0.95rem;
  line-height: 1.5;
  max-width: 52rem;
}

.dashboard-first-time-checklist {
  list-style: none;
  margin: 0 0 18px;
  padding: 0;
  display: grid;
  gap: 10px;
}

.dashboard-first-time-checklist-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid #e2e8f0;
  background: rgba(255, 255, 255, 0.85);
}

.dashboard-first-time-checklist-item.is-done {
  border-color: rgba(16, 185, 129, 0.35);
  background: rgba(236, 253, 245, 0.7);
}

.dashboard-first-time-checklist-item.is-current {
  border-color: rgba(99, 102, 241, 0.45);
  background: rgba(238, 242, 255, 0.85);
  box-shadow: 0 0 0 1px rgba(99, 102, 241, 0.15);
}

.dashboard-first-time-checklist-item.is-pending {
  opacity: 0.88;
}

.dashboard-first-time-checklist-marker {
  flex: 0 0 auto;
  width: 1.35rem;
  height: 1.35rem;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  font-weight: 700;
  background: #e2e8f0;
  color: #475569;
}

.dashboard-first-time-checklist-item.is-done .dashboard-first-time-checklist-marker {
  background: #10b981;
  color: #fff;
}

.dashboard-first-time-checklist-item.is-current .dashboard-first-time-checklist-marker {
  background: #6366f1;
  color: #fff;
}

.dashboard-first-time-checklist-label {
  margin: 0;
  font-weight: 600;
  color: #0f172a;
  line-height: 1.35;
}

.dashboard-first-time-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.dashboard-first-time-primary-cta {
  min-height: 44px;
  font-weight: 700;
}

#dashboardSection.dashboard-first-time-customer .dashboard-next-step-card {
  display: none !important;
}

#dashboardSection.dashboard-first-time-customer .dashboard-overview-cell--quick {
  display: none !important;
}

#dashboardSection.dashboard-first-time-customer .dashboard-overview-cell--usage {
  opacity: 0.92;
}

#dashboardSection.dashboard-first-time-customer #dashboardCampaignBuilderEntryCard {
  display: none !important;
}

.dashboard-builder-beginner-hint {
  margin: 8px 0 0;
  font-size: 0.9rem;
}

@media (max-width: 760px) {
  .dashboard-first-time-hero-actions {
    flex-direction: column;
  }

  .dashboard-first-time-primary-cta,
  .dashboard-first-time-hero-actions .secondary {
    width: 100%;
  }
}

/* Dashboard Ultra Simple v2 — Phase 1.1 visual cleanup */
body.dashboard-ultra-home-chrome #appShell #appSidebar,
body.dashboard-ultra-home-chrome #appShell .app-sidebar,
body.dashboard-ultra-home-chrome #appShell #appSidebarBackdrop,
body.dashboard-ultra-home-chrome #appShell .app-sidebar-backdrop {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

body.dashboard-ultra-home-chrome #appContainer .app-main > header.app-dashboard-header,
body.dashboard-ultra-home-chrome #appContainer .app-dashboard-header {
  display: none !important;
}

body.dashboard-ultra-home-chrome #appShellSidebarToggle {
  display: none !important;
}

body.dashboard-ultra-home-chrome .app-shell {
  display: block;
}

body.dashboard-ultra-home-chrome #appContainer .app-main {
  flex: 1 1 100%;
  width: 100%;
  max-width: 100%;
  min-width: 0;
}

#dashboardSection.dashboard-focus-campaign-builder #dashboardHomePanel .dash-ultra-home-only,
#dashboardSection.dashboard-focus-message-flows #dashboardHomePanel .dash-ultra-home-only,
#dashboardSection.dashboard-focus-messages-hub #dashboardHomePanel .dash-ultra-home-only,
#dashboardSection.dashboard-focus-customer-lists #dashboardHomePanel .dash-ultra-home-only,
#dashboardSection:not(.dashboard-focus-home) #dashboardHomePanel .dash-ultra-home-only {
  display: none !important;
}

#dashboardSection.dashboard-focus-campaign-builder #dashboardHomePanel,
#dashboardSection.dashboard-focus-message-flows #dashboardHomePanel,
#dashboardSection.dashboard-focus-messages-hub #dashboardHomePanel,
#dashboardSection.dashboard-focus-customer-lists #dashboardHomePanel,
#dashboardSection:not(.dashboard-focus-home) #dashboardHomePanel,
#dashboardHomePanel.hidden {
  display: none !important;
  height: 0 !important;
  overflow: hidden !important;
  margin: 0 !important;
  padding: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

#dashboardSection.dashboard-focus-messages-hub #dashboardCampaignBuilderWorkspace,
#dashboardSection.dashboard-focus-messages-hub #dashboardCampaignBuilderWorkspace.hidden,
#dashboardSection.dashboard-focus-customer-lists #dashboardCampaignBuilderWorkspace,
#dashboardSection.dashboard-focus-customer-lists #dashboardCampaignBuilderWorkspace.hidden {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

#messagesHubPanel.hidden,
#customerListsPanel.hidden {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

#dashboardSection.dashboard-focus-messages-hub #messagesHubPanel {
  display: block !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

#dashboardSection.dashboard-focus-customer-lists #customerListsPanel {
  display: block !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

#dashboardSection.dashboard-focus-customer-lists #messagesHubPanel,
#dashboardSection.dashboard-focus-customer-lists #messagesHubPanel.hidden,
#dashboardSection.dashboard-focus-messages-hub #customerListsPanel,
#dashboardSection.dashboard-focus-messages-hub #customerListsPanel.hidden {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

.messages-hub-panel {
  max-width: 960px;
  margin: 0 auto;
  padding: 0 0 40px;
}

.messages-hub-shell {
  padding: 0 4px;
}

.messages-hub-page-header {
  margin-bottom: 24px;
}

.messages-hub-title {
  margin: 0 0 8px;
  font-size: 1.5rem;
  font-weight: 800;
  color: #0f172a;
  line-height: 1.25;
}

.messages-hub-subtitle {
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.5;
  max-width: 40rem;
}

.messages-hub-cards-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.messages-hub-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 20px 18px;
  margin-bottom: 0;
  height: 100%;
}

.messages-hub-card-head {
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
  padding-right: 6.5rem;
}

.messages-hub-card-badge {
  position: absolute;
  top: 0;
  right: 0;
  font-size: 0.65rem;
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: 0.02em;
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(99, 102, 241, 0.1);
  color: #5b21b6;
  border: 1px solid rgba(99, 102, 241, 0.22);
  white-space: nowrap;
}

.messages-hub-card-title {
  margin: 0;
  font-size: 1rem;
  font-weight: 700;
}

.messages-hub-card-desc {
  margin: 0;
  flex: 1;
  font-size: 0.88rem;
  color: #64748b;
  line-height: 1.45;
}

.messages-hub-card-note {
  margin: 0;
  font-size: 0.8rem;
  line-height: 1.4;
}

@media (max-width: 720px) {
  .messages-hub-cards-grid {
    grid-template-columns: 1fr;
  }
}

.customer-lists-panel {
  max-width: 960px;
  margin: 0 auto;
  padding: 0 0 40px;
}

.customer-lists-shell {
  padding: 0 4px;
}

.customer-lists-page-header {
  margin-bottom: 24px;
}

.customer-lists-title {
  margin: 0 0 8px;
  font-size: 1.5rem;
  font-weight: 800;
  color: #0f172a;
  line-height: 1.25;
}

.customer-lists-subtitle {
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.5;
  max-width: 40rem;
}

.customer-lists-privacy {
  margin: 0 0 4px;
  font-size: 0.85rem;
}

.customer-lists-form-actions {
  flex-wrap: wrap;
  gap: 10px;
}

.customer-lists-table-wrap {
  overflow-x: auto;
  margin-top: 8px;
}

.customer-lists-table-wrap table td:nth-child(2) {
  max-width: 280px;
  word-break: break-all;
  font-size: 0.85rem;
}

.customer-lists-table-wrap .customer-lists-sheet-link {
  color: #2563eb;
  text-decoration: none;
}

.customer-lists-table-wrap .customer-lists-sheet-link:hover {
  text-decoration: underline;
}

.customer-lists-saved-empty {
  margin-top: 8px;
}

@media (max-width: 640px) {
  .customer-lists-page-card-head-row {
    flex-direction: column;
    align-items: stretch;
  }

  .customer-lists-page-card-head-row #loadCustomerListsBtn {
    width: 100%;
  }
}

/* Dashboard Ultra Simple v2 — home focus only */
#dashboardSection.dashboard-focus-home .dashboard-ultra-simple-v2 {
  max-width: 960px;
  margin: 0 auto;
}

.dashboard-home-shell {
  padding: 0 0 40px;
}

.dashboard-home-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 28px;
  padding: 12px 16px;
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  position: sticky;
  top: 12px;
  z-index: 40;
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.08);
}

.dashboard-home-brand {
  display: flex;
  align-items: center;
  text-decoration: none;
  flex-shrink: 0;
}

.dashboard-home-logo {
  display: block;
  height: 32px;
  width: auto;
  max-width: 160px;
  object-fit: contain;
}

.dashboard-home-nav-toggle {
  display: none;
}

.dashboard-home-nav-menu {
  display: flex;
  align-items: center;
  gap: 2px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.dashboard-home-nav-link {
  padding: 8px 10px;
  border: 0;
  border-radius: 8px;
  font-size: 0.8125rem;
  font-weight: 600;
  color: #475569;
  text-decoration: none;
  white-space: nowrap;
  background: transparent;
  cursor: pointer;
  font-family: inherit;
}

.dashboard-home-nav-link:hover {
  background: #f1f5f9;
  color: #0f172a;
}

.dashboard-home-nav-link.is-active {
  background: #eef2ff;
  color: #4338ca;
}

.dashboard-home-page-header {
  margin-bottom: 24px;
}

.dashboard-home-page-header h1 {
  margin: 0 0 8px;
  font-size: clamp(1.5rem, 4vw, 1.85rem);
  font-weight: 800;
  letter-spacing: -0.03em;
}

.dashboard-home-subtitle {
  margin: 0;
  color: #64748b;
  font-size: 1.05rem;
  max-width: 36rem;
}

.dashboard-home-setup-card {
  padding: 28px 24px 32px;
  margin-bottom: 20px;
}

.dashboard-home-setup-title {
  margin: 0 0 10px;
  font-size: 1.35rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.35;
}

.dashboard-home-setup-lead {
  margin: 0 0 32px;
  color: #64748b;
  font-size: 0.98rem;
  max-width: 40rem;
}

.dashboard-home-steps-rail {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  margin: 0 0 36px;
  padding: 0;
  list-style: none;
}

.dashboard-home-step-pill {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 10px;
  padding: 20px 14px;
  border-radius: 12px;
  border: 1px solid #e2e8f0;
  background: #fafafa;
  min-height: 100%;
}

.dashboard-home-step-pill .num {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  font-weight: 800;
  background: #e2e8f0;
  color: #475569;
  flex-shrink: 0;
}

.dashboard-home-step-pill .step-index {
  margin: 0;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #64748b;
  line-height: 1.2;
}

.dashboard-home-step-pill .step-title {
  margin: 0;
  font-size: 0.82rem;
  font-weight: 700;
  color: #334155;
  line-height: 1.35;
}

.dashboard-home-step-pill .status {
  margin: 0;
  font-size: 0.8rem;
  font-weight: 600;
  color: #64748b;
  line-height: 1.3;
}

.dashboard-home-step-pill.is-done {
  border-color: #bbf7d0;
  background: #f0fdf4;
}

.dashboard-home-step-pill.is-done .num {
  background: #16a34a;
  color: #fff;
}

.dashboard-home-step-pill.is-done .status {
  color: #15803d;
}

.dashboard-home-step-pill.is-ready {
  border-color: #a7f3d0;
  background: #ecfdf5;
}

.dashboard-home-step-pill.is-ready .num {
  background: #059669;
  color: #fff;
}

.dashboard-home-step-pill.is-ready .status {
  color: #047857;
}

.dashboard-home-step-pill.is-current {
  border: 2px solid #6366f1;
  background: #fff;
  padding: 22px 14px;
}

.dashboard-home-step-pill.is-current .num {
  background: #4f46e5;
  color: #fff;
}

.dashboard-home-step-pill.is-current .step-title {
  color: #312e81;
}

.dashboard-home-step-pill.is-current .status {
  color: #4338ca;
  font-weight: 700;
}

.dashboard-home-step-pill.is-locked {
  opacity: 0.55;
}

.dashboard-home-step-pill.is-locked .num {
  background: #cbd5e1;
  color: #94a3b8;
}

.dashboard-home-onboarding-cta {
  padding-top: 28px;
  border-top: 1px solid #e2e8f0;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 12px;
}

.dashboard-home-cta-helper {
  margin: 0;
  font-size: 0.9rem;
  font-weight: 600;
  color: #475569;
  text-align: center;
}

.dashboard-home-cta-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 48px;
  padding: 12px 20px;
  border: 0;
  border-radius: 10px;
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
  background: #4f46e5;
  cursor: pointer;
  font-family: inherit;
}

.dashboard-home-cta-btn:hover {
  background: #4338ca;
}

.dashboard-home-section-heading {
  margin: 0 0 14px;
  font-size: 1rem;
  font-weight: 700;
  color: #334155;
}

.dashboard-home-section-heading-secondary {
  margin: 8px 0 10px;
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: #94a3b8;
}

.dashboard-home-tools-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin: 0 0 28px;
  padding: 0;
  list-style: none;
}

.dashboard-home-tool-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 20px 18px;
  margin-bottom: 0;
  height: 100%;
}

.dashboard-home-tool-card-head {
  display: flex;
  align-items: center;
  gap: 10px;
}

.dashboard-home-tool-card h3 {
  margin: 0;
  font-size: 1rem;
  font-weight: 700;
}

.dashboard-home-tool-card p {
  margin: 0;
  flex: 1;
  font-size: 0.88rem;
  color: #64748b;
  line-height: 1.45;
}

.dashboard-home-icon {
  flex-shrink: 0;
  display: block;
}

.dashboard-home-icon-tool {
  width: 28px;
  height: 28px;
  color: #4f46e5;
}

.dashboard-home-icon-stat {
  width: 18px;
  height: 18px;
  color: #6366f1;
  opacity: 0.9;
}

.dashboard-home-tool-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: flex-start;
  min-height: 38px;
  padding: 8px 16px;
  border: 1px solid #c7d2fe;
  border-radius: 8px;
  font-size: 0.875rem;
  font-weight: 600;
  color: #4338ca;
  background: #fff;
  cursor: pointer;
  font-family: inherit;
}

.dashboard-home-tool-btn:hover {
  background: #eef2ff;
}

.dashboard-home-stats-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 0;
}

.dashboard-home-stat-card {
  padding: 14px 12px;
  margin-bottom: 0;
  background: #fafbfc;
  border-color: #e8edf3;
  border-radius: 10px;
}

.dashboard-home-stat-card-head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}

.dashboard-home-stat-card h3 {
  margin: 0;
  font-size: 0.78rem;
  font-weight: 600;
  color: #94a3b8;
  letter-spacing: 0.01em;
}

.dashboard-home-stat-value {
  margin: 0 0 3px;
  font-size: 0.88rem;
  font-weight: 700;
  color: #334155;
}

.dashboard-home-stat-value.is-connected {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #15803d;
}

.dashboard-home-stat-value.is-connected::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: #22c55e;
}

.dashboard-home-stat-detail {
  margin: 0 0 6px;
  font-size: 0.8rem;
  color: #64748b;
  line-height: 1.4;
}

.dashboard-home-stat-link {
  padding: 0;
  border: 0;
  background: none;
  font-size: 0.8rem;
  font-weight: 600;
  color: #4f46e5;
  cursor: pointer;
  font-family: inherit;
  text-decoration: none;
}

.dashboard-home-stat-link:hover {
  color: #4338ca;
  text-decoration: underline;
}

.dashboard-home-usage-bar-track {
  height: 5px;
  border-radius: 99px;
  background: #e2e8f0;
  overflow: hidden;
  margin: 6px 0 4px;
}

.dashboard-home-usage-bar-fill {
  height: 100%;
  min-width: 4px;
  border-radius: 99px;
  background: #6366f1;
  width: 0%;
}

.dashboard-home-usage-meta {
  margin: 0;
  font-size: 0.75rem;
  color: #94a3b8;
  line-height: 1.45;
}

.app-sidebar-customer-hidden {
  display: none !important;
}

@media (max-width: 900px) and (min-width: 721px) {
  .dashboard-home-nav-link {
    padding: 7px 8px;
    font-size: 0.75rem;
  }
}

@media (max-width: 720px) {
  .dashboard-home-steps-rail {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .dashboard-home-step-pill {
    flex-direction: row;
    align-items: flex-start;
    text-align: left;
    padding: 16px 14px;
    gap: 12px;
  }

  .dashboard-home-step-pill.is-current {
    padding: 18px 14px;
  }

  .dashboard-home-step-pill .step-body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
  }

  .dashboard-home-tools-grid,
  .dashboard-home-stats-grid {
    grid-template-columns: 1fr;
  }

  .dashboard-home-nav-toggle-label {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    background: #fff;
    cursor: pointer;
    font-size: 1.2rem;
    line-height: 1;
  }

  .dashboard-home-nav-toggle {
    display: block;
    position: absolute;
    opacity: 0;
    pointer-events: none;
  }

  .dashboard-home-nav-menu {
    display: none;
    position: absolute;
    top: calc(100% + 8px);
    right: 16px;
    left: 16px;
    flex-direction: column;
    align-items: stretch;
    padding: 8px;
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    z-index: 50;
    max-height: min(70vh, 420px);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  .dashboard-home-topbar {
    flex-wrap: wrap;
    position: sticky;
  }

  .dashboard-home-logo {
    height: 28px;
    max-width: 140px;
  }

  .dashboard-home-nav-toggle:checked ~ .dashboard-home-nav-menu {
    display: flex;
  }

  .dashboard-home-nav-link {
    padding: 10px 12px;
    font-size: 0.875rem;
    white-space: normal;
    text-align: left;
  }
}

@media (min-width: 721px) {
  .dashboard-home-nav-toggle-label {
    display: none;
  }

  .dashboard-home-step-pill .step-body {
    display: contents;
  }
}

/* Dashboard Ultra Simple Phase 1.1 — end-of-cascade enforcement */
@media (max-width: 760px) {
  body.dashboard-ultra-home-chrome #appContainer .app-main > header.app-dashboard-header,
  body.dashboard-ultra-home-chrome #appContainer .app-dashboard-header.card {
    display: none !important;
  }

  body.dashboard-ultra-home-chrome #appShell #appSidebar,
  body.dashboard-ultra-home-chrome #appShell .app-sidebar {
    transform: translateX(-100%) !important;
  }
}

.dev-api-docs {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 18px;
}

.dev-api-docs-h {
  margin: 0 0 4px;
  font-size: 1rem;
}

.dev-api-docs-section {
  border: 1px solid rgba(226, 232, 240, 0.95);
  border-radius: 10px;
  background: rgba(248, 250, 252, 0.6);
  padding: 0;
  overflow: hidden;
}

.dev-api-docs-section > summary {
  cursor: pointer;
  list-style: none;
  padding: 10px 14px;
  font-weight: 600;
  color: #334155;
  font-size: 0.92rem;
  user-select: none;
}

.dev-api-docs-section > summary::-webkit-details-marker {
  display: none;
}

.dev-api-docs-section[open] > summary {
  border-bottom: 1px solid rgba(226, 232, 240, 0.95);
}

.dev-api-docs-body {
  padding: 12px 14px 16px;
  font-size: 0.92rem;
  line-height: 1.45;
}

.dev-api-docs-body ul,
.dev-api-docs-body ol {
  padding-left: 20px;
  margin: 6px 0;
}

.dev-api-docs-body code {
  background: rgba(15, 23, 42, 0.06);
  padding: 1px 4px;
  border-radius: 4px;
  font-size: 0.85rem;
}

.dev-api-code-block {
  background: #0f172a;
  color: #e2e8f0;
  padding: 12px 14px;
  border-radius: 8px;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 0.8rem;
  line-height: 1.45;
  overflow-x: auto;
  margin: 8px 0;
  white-space: pre;
}

.dev-api-code-block code {
  background: transparent;
  color: inherit;
  padding: 0;
  font-size: inherit;
}

.dev-api-error-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.88rem;
  margin-top: 8px;
}

.dev-api-error-table th,
.dev-api-error-table td {
  border-bottom: 1px solid rgba(226, 232, 240, 0.95);
  padding: 6px 8px;
  text-align: left;
  vertical-align: top;
}

.dev-api-error-table th {
  background: rgba(241, 245, 249, 0.8);
  font-weight: 600;
}

.dev-api-status-card {
  display: flex;
  flex-direction: column;
  gap: 8px;
  border: 1px solid rgba(226, 232, 240, 0.95);
  background: rgba(248, 250, 252, 0.6);
  border-radius: 10px;
  padding: 12px 14px;
}

.dev-api-status-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.dev-api-status-label {
  font-weight: 600;
  min-width: 120px;
  color: #475569;
  font-size: 0.88rem;
}

.dev-api-status-endpoint {
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  background: rgba(241, 245, 249, 0.9);
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 0.88rem;
}

.dev-api-status-tinybtn {
  padding: 2px 8px;
  font-size: 0.8rem;
}

.dev-api-status-rate,
.dev-api-status-lastused {
  font-size: 0.9rem;
}

.dev-api-regen-modal-card {
  font-family: inherit;
}

.dev-api-regen-modal-card h3 {
  font-size: 1.05rem;
}

/* Phase 3.6 — WhatsApp Number Health & Queue Dashboard */

.workspace-sending-status {
  background: #f8fafc;
  border: 1px solid #e5e7eb;
}

.workspace-sending-status-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.workspace-sending-status-header h3 {
  margin: 0;
}

.workspace-sending-status-summary {
  margin: 6px 0 8px;
  font-size: 0.95rem;
  color: #0f172a;
}

.workspace-sending-status-bar {
  position: relative;
  height: 8px;
  border-radius: 999px;
  background: #e5e7eb;
  overflow: hidden;
  margin: 0 0 8px;
}

.workspace-sending-status-bar-fill {
  position: absolute;
  inset: 0 auto 0 0;
  width: 0%;
  background: linear-gradient(90deg, #10b981 0%, #22c55e 100%);
  transition: width 240ms ease;
}

.workspace-sending-status.is-warning .workspace-sending-status-bar-fill {
  background: linear-gradient(90deg, #f59e0b, #f97316);
}

.workspace-sending-status.is-blocked .workspace-sending-status-bar-fill {
  background: linear-gradient(90deg, #ef4444, #dc2626);
}

.workspace-sending-status-restriction {
  margin: 6px 0 8px;
  padding: 8px 10px;
  border-radius: 6px;
  background: #fef2f2;
  color: #991b1b;
  font-size: 0.92rem;
}

.workspace-sending-status-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.instance-health-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 12px;
}

.instance-health-card {
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  background: #ffffff;
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.instance-health-card.is-blocked {
  border-color: #fecaca;
  background: #fef2f2;
}

.instance-health-card.is-warning {
  border-color: #fde68a;
  background: #fffbeb;
}

.instance-health-card.is-ready {
  border-color: #bbf7d0;
}

.instance-health-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}

.instance-health-card-title {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.instance-health-card-name {
  font-weight: 700;
  font-size: 1rem;
  color: #0f172a;
}

.instance-health-card-phone {
  font-size: 0.85rem;
  color: #475569;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
}

.instance-health-card-badges {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.instance-health-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 2px 8px;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  background: #e2e8f0;
  color: #0f172a;
}

.instance-health-badge.connected {
  background: #dcfce7;
  color: #166534;
}

.instance-health-badge.disconnected,
.instance-health-badge.notconnected {
  background: #fee2e2;
  color: #991b1b;
}

.instance-health-badge.paused {
  background: #e0e7ff;
  color: #3730a3;
}

.instance-health-badge.duplicatephone,
.instance-health-badge.blocked {
  background: #fecaca;
  color: #7f1d1d;
}

.instance-health-badge.healthy {
  background: #dcfce7;
  color: #166534;
}

.instance-health-badge.warning {
  background: #fef3c7;
  color: #854d0e;
}

.instance-health-badge.offline {
  background: #fee2e2;
  color: #991b1b;
}

.instance-health-message {
  margin: 0;
  font-size: 0.9rem;
  color: #1e293b;
}

.instance-health-queue-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 6px;
}

.instance-health-queue-cell {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 8px 6px;
  border-radius: 6px;
  background: #f1f5f9;
  min-height: 52px;
}

.instance-health-queue-cell-value {
  font-weight: 700;
  font-size: 1.05rem;
  color: #0f172a;
}

.instance-health-queue-cell-label {
  font-size: 0.72rem;
  color: #475569;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.instance-health-queue-cell.has-failed .instance-health-queue-cell-value {
  color: #b91c1c;
}

.instance-health-queue-cell.has-cancelled .instance-health-queue-cell-value {
  color: #6b7280;
}

.instance-health-card-actions,
.instance-health-action-row {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  align-items: center;
}

.instance-health-card-actions button,
.instance-health-action-row button {
  flex: 0 1 auto;
  padding: 4px 10px;
  font-size: 0.85rem;
  line-height: 1.3;
  min-height: 30px;
  white-space: nowrap;
}

@media (max-width: 640px) {
  .instance-health-queue-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .instance-health-card {
    padding: 12px;
  }
  .instance-health-card-actions,
  .instance-health-action-row {
    flex-direction: column;
    align-items: stretch;
  }
  .instance-health-card-actions button,
  .instance-health-action-row button {
    flex: 1 1 100%;
    width: 100%;
  }
}

/* Phase 3.6A — Workspace Sending Status helper + Advanced number details */

.workspace-sending-status-helper {
  margin: 6px 0 8px;
  font-size: 0.85rem;
  color: #475569;
}

.instance-advanced-details {
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  background: #ffffff;
  padding: 0;
  overflow: hidden;
}

.instance-advanced-details > summary {
  cursor: pointer;
  list-style: none;
  padding: 10px 14px;
  font-weight: 600;
  color: #0f172a;
  background: #f8fafc;
  border-bottom: 1px solid transparent;
  display: flex;
  align-items: center;
  gap: 8px;
  user-select: none;
}

.instance-advanced-details > summary::-webkit-details-marker {
  display: none;
}

.instance-advanced-details > summary::before {
  content: "▸";
  color: #64748b;
  font-size: 0.85rem;
  transition: transform 120ms ease;
  display: inline-block;
}

.instance-advanced-details[open] > summary::before {
  transform: rotate(90deg);
}

.instance-advanced-details[open] > summary {
  border-bottom-color: #e5e7eb;
}

.instance-advanced-details > *:not(summary) {
  padding: 0 14px;
}

.instance-advanced-details > .instance-advanced-details-helper {
  padding: 10px 14px 0;
}

.instance-advanced-details > .instance-table-wrap,
.instance-advanced-details > #instanceCards {
  padding: 0 14px 14px;
}

.instance-advanced-details-helper {
  font-size: 0.85rem;
  color: #475569;
}

/* Phase 3.8 — Settings → Developer API docs preview banner */

.dev-api-docs-preview-banner {
  display: flex;
  flex-direction: column;
  gap: 4px;
  border: 1px dashed #fbbf24;
  background: #fffbeb;
  color: #92400e;
  border-radius: 8px;
  padding: 10px 12px;
  margin: 0 0 12px;
}

.dev-api-docs-preview-banner strong {
  font-size: 0.95rem;
}

.dev-api-docs-preview-banner span {
  font-size: 0.88rem;
  line-height: 1.45;
}

/* Phase 3.7 — Public Homepage Refresh */

.landing-hero-status-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 12px;
  background: #f8fafc;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  padding: 12px;
  margin: 12px 0;
}

.landing-hero-status-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  font-size: 0.9rem;
}

.landing-hero-status-label {
  color: #475569;
  font-weight: 500;
}

.landing-hero-status-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 2px 10px;
  font-size: 0.8rem;
  font-weight: 600;
  background: #e2e8f0;
  color: #0f172a;
  white-space: nowrap;
}

.landing-hero-status-pill--good {
  background: #dcfce7;
  color: #166534;
}

.landing-hero-status-pill--warn {
  background: #fef3c7;
  color: #854d0e;
}

.landing-hero-status-pill--neutral {
  background: #e0e7ff;
  color: #3730a3;
}

.landing-section-heading {
  text-align: center;
  margin-bottom: 18px;
}

.landing-section-heading h2 {
  margin: 6px 0 8px;
}

.landing-section-lead {
  max-width: 720px;
  margin: 0 auto;
  font-size: 0.95rem;
}

.landing-section-disclaimer {
  margin-top: 14px;
  font-size: 0.85rem;
  color: #64748b;
  text-align: center;
}

.landing-health-section,
.landing-api-section {
  padding: 28px 24px;
}

.landing-health-grid,
.landing-api-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 14px;
  margin-top: 12px;
}

.landing-health-card,
.landing-api-card {
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  background: #ffffff;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.landing-health-card strong,
.landing-api-card strong {
  font-size: 1rem;
  color: #0f172a;
}

.landing-health-card span,
.landing-api-card span {
  font-size: 0.92rem;
  color: #334155;
  line-height: 1.45;
}

.landing-api-card code {
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  background: #f1f5f9;
  padding: 1px 6px;
  border-radius: 4px;
  font-size: 0.85rem;
}

.landing-health-section {
  background: #f0fdf4;
}

.landing-api-section {
  background: #eff6ff;
}

.landing-api-disclaimer {
  margin-top: 14px;
  font-size: 0.88rem;
  color: #475569;
  text-align: center;
}

.landing-api-cta-row {
  display: flex;
  justify-content: center;
  margin-top: 14px;
}

.landing-pricing-addon-cta {
  display: flex;
  justify-content: center;
  margin: 8px 0 4px;
}

/* Roadmap "Available add-on" badge variant */
.landing-roadmap-badge--addon {
  background: #dcfce7;
  color: #166534;
}

.landing-roadmap-badge--roadmap {
  background: #e0e7ff;
  color: #3730a3;
}

@media (max-width: 640px) {
  .landing-hero-status-grid {
    grid-template-columns: 1fr;
  }
  .landing-health-section,
  .landing-api-section {
    padding: 22px 16px;
  }
  .landing-health-grid,
  .landing-api-grid {
    grid-template-columns: 1fr;
  }
}

/* === Phase 3.8A: Send Campaign UX simplification === */
.phase38a-legacy-hidden {
  display: none !important;
}

.campaign-builder-intro {
  padding: 20px 22px;
  margin-bottom: 18px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.campaign-builder-intro-title {
  margin: 0;
  font-size: 1.45rem;
  line-height: 1.25;
}
.campaign-builder-intro-subtitle {
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.45;
}

.campaign-workflow-steps {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.campaign-workflow-step {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--border, #e2e6ee);
  border-radius: 10px;
  background: var(--surface, #fbfbfd);
  min-width: 0;
}
.campaign-workflow-step .campaign-step-number {
  width: 28px;
  height: 28px;
  flex: 0 0 28px;
  border-radius: 999px;
  background: var(--badge-bg, #eef1f7);
  color: var(--badge-text, #4a5568);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 0.9rem;
}
.campaign-workflow-step .campaign-step-label {
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--text, #1a202c);
  line-height: 1.2;
  min-width: 0;
}
.campaign-workflow-step.is-active {
  border-color: #4f7cff;
  background: #eef3ff;
}
.campaign-workflow-step.is-active .campaign-step-number {
  background: #4f7cff;
  color: #fff;
}
.campaign-workflow-step.is-done .campaign-step-number {
  background: #2ea36b;
  color: #fff;
}
.campaign-workflow-step.is-done .campaign-step-label::after {
  content: " ✓";
  color: #2ea36b;
}

.campaign-step-card {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 14px 16px;
  margin: 18px 0 10px;
  border: 1px solid var(--border, #e2e6ee);
  border-radius: 12px;
  background: var(--surface, #fbfbfd);
}
.campaign-step-card .campaign-step-card-number {
  width: 36px;
  height: 36px;
  flex: 0 0 36px;
  border-radius: 999px;
  background: var(--badge-bg, #eef1f7);
  color: var(--text, #1a202c);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 1rem;
}
.campaign-step-card-body {
  flex: 1 1 auto;
  min-width: 0;
}
.campaign-step-card-title {
  margin: 0;
  font-size: 1.05rem;
  line-height: 1.25;
}
.campaign-step-card-subtitle {
  margin: 4px 0 0;
  font-size: 0.9rem;
  line-height: 1.4;
}
.campaign-step-card-link {
  display: inline-block;
  margin-top: 6px;
  font-size: 0.88rem;
}
.campaign-step-status {
  flex: 0 0 auto;
  padding: 4px 10px;
  border-radius: 999px;
  background: var(--badge-bg, #eef1f7);
  color: var(--badge-text, #4a5568);
  font-size: 0.78rem;
  font-weight: 600;
  white-space: nowrap;
  align-self: center;
}
.campaign-step-status[data-step-status="done"] {
  background: #d8f1e3;
  color: #1c6b41;
}
.campaign-step-status[data-step-status="active"] {
  background: #dbe6ff;
  color: #2746a8;
}
.campaign-step-status[data-step-status="warn"] {
  background: #fff2cc;
  color: #8a5a00;
}
.campaign-step-status[data-step-status="blocked"] {
  background: #fde2e2;
  color: #a02323;
}

.campaign-advanced-editor {
  display: block;
  margin-top: 8px;
}

.campaign-checklist-card {
  padding: 16px 18px;
  margin: 18px 0;
}
.campaign-checklist-card-head {
  margin-bottom: 10px;
}
.campaign-checklist-card-title {
  margin: 0;
  font-size: 1rem;
}
.campaign-checklist-card-subtitle {
  margin: 4px 0 0;
  font-size: 0.88rem;
}
.campaign-checklist-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px 16px;
}
.campaign-checklist-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;
  border-radius: 8px;
  background: var(--surface, #fbfbfd);
  border: 1px solid var(--border, #e2e6ee);
  min-width: 0;
}
.campaign-checklist-icon {
  flex: 0 0 16px;
  width: 16px;
  height: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  color: #94a3b8;
}
.campaign-checklist-text {
  flex: 1 1 auto;
  font-size: 0.9rem;
  font-weight: 600;
  min-width: 0;
}
.campaign-checklist-state {
  flex: 0 0 auto;
  font-size: 0.8rem;
  color: var(--muted, #64748b);
  white-space: nowrap;
}
.campaign-checklist-item[data-checklist-status="ok"] {
  border-color: #b9e3cd;
  background: #f0faf5;
}
.campaign-checklist-item[data-checklist-status="ok"] .campaign-checklist-icon {
  color: #2ea36b;
}
.campaign-checklist-item[data-checklist-status="ok"] .campaign-checklist-icon::before {
  content: "✓";
}
.campaign-checklist-item[data-checklist-status="ok"] .campaign-checklist-state {
  color: #1c6b41;
  font-weight: 600;
}
.campaign-checklist-item[data-checklist-status="warn"] {
  border-color: #ffe6a8;
  background: #fff8e6;
}
.campaign-checklist-item[data-checklist-status="warn"] .campaign-checklist-icon {
  color: #b88500;
}
.campaign-checklist-item[data-checklist-status="warn"] .campaign-checklist-state {
  color: #8a5a00;
  font-weight: 600;
}
.campaign-checklist-item[data-checklist-status="blocked"] {
  border-color: #f5c1c1;
  background: #fdecec;
}
.campaign-checklist-item[data-checklist-status="blocked"] .campaign-checklist-icon {
  color: #a02323;
}
.campaign-checklist-item[data-checklist-status="blocked"] .campaign-checklist-state {
  color: #a02323;
  font-weight: 600;
}

.campaign-empty-state {
  padding: 14px 16px;
  border: 1px dashed var(--border, #d6dbe6);
  border-radius: 12px;
  background: var(--surface, #fafbfd);
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 10px;
}
.campaign-empty-state-title {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 600;
}
.campaign-empty-state-text {
  margin: 0;
  font-size: 0.88rem;
  color: var(--muted, #64748b);
  line-height: 1.4;
}
.campaign-empty-state-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 4px;
}

.campaign-send-ready-card {
  padding: 14px 16px;
  margin-top: 14px;
  border-radius: 12px;
  border: 1px solid var(--border, #e2e6ee);
  background: var(--surface, #fbfbfd);
}

@media (max-width: 720px) {
  .campaign-workflow-steps {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .campaign-step-card {
    flex-wrap: wrap;
    padding: 12px 14px;
  }
  .campaign-step-card .campaign-step-card-number {
    width: 32px;
    height: 32px;
    flex: 0 0 32px;
  }
  .campaign-step-status {
    order: 3;
    align-self: flex-start;
    margin-left: 46px;
  }
  .campaign-checklist-list {
    grid-template-columns: 1fr;
  }
  .campaign-empty-state-actions > * {
    width: 100%;
  }
}

@media (max-width: 480px) {
  .campaign-workflow-steps {
    grid-template-columns: 1fr;
  }
}

/* ---------------------------------------------------------------- */
/* Phase 4.0A — Compliance & Responsible Messaging Copy              */
/* Public legal/policy sections, compliance disclaimers, responsible */
/* business-number guidance, public footer legal nav.                */
/* Additive only — no retargeting of existing global selectors.      */
/* ---------------------------------------------------------------- */

.legal-page {
  display: block;
  width: 100%;
  max-width: 100%;
  margin: 32px auto 24px;
  padding: 32px 20px;
  background: #ffffff;
  border-radius: 14px;
  border: 1px solid #e2e8f0;
  box-shadow: 0 6px 24px rgba(15, 23, 42, 0.04);
  color: #0f172a;
  line-height: 1.65;
}

.legal-page[hidden] {
  display: none !important;
}

.legal-page-inner {
  max-width: 760px;
  margin: 0 auto;
}

.legal-page h1 {
  margin: 0 0 4px;
  font-size: 1.6rem;
  line-height: 1.25;
  color: #0f172a;
}

.legal-page h2 {
  margin-top: 24px;
  margin-bottom: 8px;
  font-size: 1.05rem;
  color: #1e293b;
}

.legal-page p {
  margin: 8px 0;
}

.legal-page a {
  color: #1d4ed8;
  text-decoration: underline;
}

.legal-page a:hover {
  color: #1e40af;
}

.legal-section {
  margin-bottom: 12px;
}

.legal-section + .legal-section {
  margin-top: 16px;
}

.legal-updated {
  margin: 2px 0 12px;
  font-size: 0.9rem;
}

.legal-disclaimer {
  margin: 12px 0 16px;
}

.legal-back-link {
  display: inline-block;
  margin-bottom: 12px;
  font-size: 0.9rem;
  color: #1d4ed8;
  text-decoration: none;
}

.legal-back-link:hover {
  text-decoration: underline;
}

.legal-list {
  margin: 8px 0 12px;
  padding-left: 22px;
}

.legal-list > li {
  margin: 6px 0;
}

.policy-badge {
  display: inline-block;
  padding: 1px 8px;
  border-radius: 999px;
  background: #eef2ff;
  color: #3730a3;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  vertical-align: 1px;
}

.compliance-note {
  margin: 12px 0 0;
  padding: 10px 12px;
  border-left: 3px solid #f59e0b;
  background: #fffbeb;
  color: #78350f;
  font-size: 0.9rem;
  border-radius: 0 8px 8px 0;
}

.compliance-note strong {
  color: #78350f;
}

.safe-sending-compliance-note {
  margin-top: 12px;
}

.responsible-sending-card {
  display: block;
  margin: 16px 0;
  padding: 14px 16px;
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  border-left: 4px solid #2563eb;
  border-radius: 10px;
  color: #0f172a;
}

.responsible-sending-card-title {
  display: block;
  font-size: 0.95rem;
  color: #1e3a8a;
  margin-bottom: 4px;
}

.responsible-sending-card-body {
  margin: 4px 0;
  font-size: 0.92rem;
  line-height: 1.55;
}

.responsible-sending-card a {
  color: #1d4ed8;
  text-decoration: underline;
}

.public-footer-legal {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 18px;
  justify-content: center;
  align-items: center;
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.public-footer-legal a {
  color: rgba(255, 255, 255, 0.85);
  text-decoration: none;
  font-size: 0.88rem;
  padding: 2px 4px;
  border-radius: 4px;
}

.public-footer-legal a:hover,
.public-footer-legal a:focus-visible {
  color: #ffffff;
  text-decoration: underline;
}

@media (max-width: 720px) {
  .legal-page {
    padding: 22px 16px;
    margin: 20px auto 16px;
  }
  .legal-page h1 {
    font-size: 1.35rem;
  }
  .legal-page h2 {
    font-size: 1rem;
  }
  .responsible-sending-card {
    padding: 12px 14px;
  }
  .public-footer-legal {
    gap: 6px 14px;
  }
}

@media (max-width: 480px) {
  .legal-page {
    padding: 18px 14px;
    border-radius: 10px;
  }
  .legal-page h1 {
    font-size: 1.2rem;
  }
  .legal-list {
    padding-left: 18px;
  }
  .public-footer-legal {
    flex-direction: column;
    gap: 4px;
  }
}

/* ---------------------------------------------------------------- */
/* Phase 4.0A — Operator identity (2026-05-27)                       */
/* Additive only — no retargeting of existing global selectors.      */
/* ---------------------------------------------------------------- */

.public-footer-operator {
  margin: 8px 0 0;
  padding: 0 8px;
  color: rgba(255, 255, 255, 0.7);
  font-size: 0.8rem;
  line-height: 1.45;
  text-align: center;
}

.legal-intro {
  margin: 0 0 16px;
  padding: 10px 14px;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  color: #334155;
  font-size: 0.95rem;
  line-height: 1.55;
}

.billing-operator-note {
  margin: 10px 0 0;
  font-size: 0.8rem;
  line-height: 1.45;
  color: #64748b;
}

@media (max-width: 720px) {
  .public-footer-operator {
    font-size: 0.78rem;
  }
  .legal-intro {
    padding: 9px 12px;
    font-size: 0.92rem;
  }
}

@media (max-width: 480px) {
  .public-footer-operator {
    font-size: 0.76rem;
    line-height: 1.5;
  }
  .legal-intro {
    padding: 8px 11px;
    border-radius: 6px;
  }
}

/* ==========================================================================
   Phase 4.0C — Pricing section UI polish (additive)
   Cards are split into "core bullets" + "additional features" with a divider,
   inheritance callouts on Pro/Business/Enterprise, inline SVG checks,
   and a featured top-strip + flex-aligned CTAs.
   ========================================================================== */

.landing-pricing-grid.pricing-grid {
  align-items: stretch;
}

.landing-pricing-grid .pricing-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 12px;
  overflow: visible;
}

.pricing-card-eyebrow {
  text-transform: uppercase;
  letter-spacing: 0.09em;
  font-weight: 800;
}

.pricing-card-title {
  margin: 0;
}

.pricing-card-price {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 4px;
}

.pricing-card-price-period {
  margin-left: 4px;
}

.pricing-inheritance-callout {
  margin: 4px 0 6px;
  padding: 9px 12px;
  font-size: 13px;
  font-weight: 600;
  color: #4338ca;
  background: linear-gradient(180deg, #eef2ff 0%, #ede9fe 100%);
  border: 1px solid rgba(99, 102, 241, 0.22);
  border-radius: 10px;
  line-height: 1.45;
}

.pricing-inheritance-callout strong {
  color: #312e81;
  font-weight: 800;
}

.pricing-card-divider {
  height: 1px;
  margin: 4px 0 2px;
  border: 0;
  background: linear-gradient(90deg, transparent 0%, rgba(99, 102, 241, 0.22) 50%, transparent 100%);
}

.landing-pricing-grid .pricing-feature-list {
  display: grid;
  gap: 10px;
  margin: 4px 0;
  padding: 0;
  list-style: none;
  min-height: 0;
  flex: 0 0 auto;
}

.landing-pricing-grid .pricing-feature-list--core {
  gap: 8px;
}

.landing-pricing-grid .pricing-feature-list--addons {
  gap: 10px;
}

.landing-pricing-grid .pricing-feature {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding-left: 0;
  color: inherit;
  line-height: 1.45;
}

.landing-pricing-grid .pricing-feature::before {
  content: none !important;
  display: none !important;
}

.pricing-feature-check {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  margin-top: 2px;
  color: #4f46e5;
}

.pricing-cta {
  display: flex;
  flex-direction: column;
  margin-top: auto;
  padding-top: 10px;
}

.landing-pricing-grid .pricing-cta .button-link {
  width: 100%;
  margin-top: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.pricing-cta-icon {
  flex-shrink: 0;
}

.pricing-card-featured {
  z-index: 1;
}

html[data-public-auth="landing"] .pricing-card-featured {
  box-shadow:
    0 0 0 1px rgba(79, 70, 229, 0.18),
    0 22px 44px rgba(79, 70, 229, 0.22),
    0 0 28px rgba(124, 58, 237, 0.18);
}

html[data-public-auth="landing"] .pricing-card-featured::before {
  content: "";
  position: absolute;
  top: -1px;
  left: -1px;
  right: -1px;
  height: 5px;
  background: linear-gradient(90deg, #4f46e5 0%, #7c3aed 50%, #a855f7 100%);
  border-top-left-radius: 16px;
  border-top-right-radius: 16px;
  pointer-events: none;
  z-index: 2;
}

html[data-public-auth="landing"] .pricing-card-featured .pricing-card-badge--top {
  position: relative;
  z-index: 3;
  margin-top: 4px;
  align-self: flex-start;
}

html[data-public-auth="landing"] .pricing-card-featured .pricing-inheritance-callout {
  background: linear-gradient(180deg, #ede9fe 0%, #ddd6fe 100%);
  border-color: rgba(124, 58, 237, 0.32);
  color: #4c1d95;
}

html[data-public-auth="landing"] .pricing-card-featured .pricing-feature-check {
  color: #7c3aed;
}

html[data-public-auth="landing"] .landing-plan-business--accent .pricing-feature-check {
  color: #4338ca;
}

html[data-public-auth="landing"] .landing-plan-enterprise .pricing-feature-check {
  color: #4f46e5;
}

html[data-public-auth="landing"] .landing-plan-free .pricing-feature-check {
  color: #6366f1;
}

/* Dark-mode (logged-in) pricing fallbacks — keep new structure readable */
.landing-pricing-grid .pricing-feature {
  color: inherit;
}

.landing-pricing-highlight .pricing-feature-check {
  color: #c4b5fd;
}

@media (max-width: 1200px) {
  .pricing-card-featured {
    transform: none;
  }
}

@media (max-width: 760px) {
  .landing-pricing-grid.pricing-grid {
    grid-template-columns: 1fr;
  }
  .pricing-card-featured {
    transform: none;
  }
  html[data-public-auth="landing"] .pricing-card-featured::before {
    height: 4px;
  }
  .pricing-card-price {
    font-size: 38px;
  }
  .pricing-inheritance-callout {
    font-size: 12.5px;
  }
}

@media (max-width: 480px) {
  .pricing-card-price {
    font-size: 32px;
  }
  .pricing-card-price-period {
    font-size: 14px;
  }
  .pricing-inheritance-callout {
    padding: 8px 10px;
    font-size: 12.5px;
  }
  .landing-pricing-grid .pricing-feature {
    font-size: 14px;
  }
}

