/*
 * Formsies UI — scoped styles for Command Center, Workflow Board,
 * and Edit Studio layouts. Inspired by formsies_mockup_v2.html.
 *
 * Everything here is namespaced under .formsies-* / .fs-* prefixes
 * so it can't leak into other Pegasus pages.
 */

/* ---------------------------------------------------------------------
 * Shared tokens (scoped to .formsies-scope so they don't leak globally)
 * ------------------------------------------------------------------ */
.formsies-scope {
  /* -------------------------------------------------------------------
   * Dark "command surface" palette (design handoff: Formsies redesign).
   * The authenticated app is its own dark product surface, so these
   * tokens are unconditionally dark and do NOT track the global Pegasus
   * light/dark theme.
   * ---------------------------------------------------------------- */
  --fs-page: #0e1217;          /* app background, top bar */
  --fs-page-2: #11161d;        /* rails, list panes */
  --fs-panel: #161b22;         /* metric cards, form rows, detail card */
  --fs-panel-soft: #11161d;    /* secondary panel */
  --fs-panel-muted: #0e131a;   /* inputs, selects, code blocks, insets */
  --fs-inset: #0e131a;         /* input / inset background */
  --fs-inset-2: #0c1015;       /* darkest inset (preview pane) */
  --fs-popover: #1a212a;       /* dropdown menus */

  --fs-line: rgba(255, 255, 255, 0.06);        /* hairline / card border */
  --fs-line-strong: rgba(255, 255, 255, 0.10); /* input border */
  --fs-hover: rgba(255, 255, 255, 0.05);       /* hover fill */
  --fs-subtle: rgba(255, 255, 255, 0.02);      /* subtle fill */

  --fs-heading: #f3f7fa;       /* primary text / headings */
  --fs-text: #e7edf3;          /* default body text, input values */
  --fs-text-2: #c7d0d9;        /* secondary text, list names */
  --fs-muted: #9aa7b4;         /* sub-labels, descriptions */
  --fs-muted-2: #8b97a4;       /* muted */
  --fs-dim: #7a8794;           /* helper / description text */
  --fs-faint: #6b7785;         /* uppercase labels, faint */
  --fs-faint-2: #5d6873;       /* timestamps, faint-er */
  --fs-placeholder: #4d5863;   /* placeholders */

  --fs-primary: #35d0bd;       /* accent teal */
  --fs-primary-2: #5fe0d0;     /* bright teal text on dark */
  --fs-primary-hover: #43dccb; /* teal button hover */
  --fs-accent-deep: #06201d;   /* text on teal buttons */
  --fs-accent-dark: #1c9d8e;   /* gradient end */
  --fs-primary-soft: rgba(53, 208, 189, 0.10); /* accent tint fill */
  --fs-primary-border: rgba(53, 208, 189, 0.28);
  --fs-focus: rgba(53, 208, 189, 0.45);        /* focus border */

  --fs-warn: #e0a13c;
  --fs-warn-2: #e8be78;
  --fs-warn-soft: rgba(224, 161, 60, 0.16);
  --fs-danger: #e08a6a;
  --fs-danger-2: #e8a48a;
  --fs-danger-soft: rgba(224, 138, 106, 0.10);
  --fs-success: #35d0bd;
  --fs-purple: #6366f1;        /* indigo (data) */
  --fs-purple-2: #a5a8f5;
  --fs-green: #1f9d57;
  --fs-green-2: #6cd49a;

  --fs-shadow-sm: 0 6px 18px rgba(0, 0, 0, 0.35);
  --fs-shadow: 0 16px 40px rgba(0, 0, 0, 0.5);

  --fs-font-display: 'Space Grotesk', system-ui, sans-serif;
  --fs-font-body: 'Public Sans', system-ui, -apple-system, sans-serif;
  --fs-font-mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, monospace;

  /* -------------------------------------------------------------------
   * DaisyUI v5 / Tailwind v4 token overrides, scoped to the Formsies app.
   * The screen templates use raw DaisyUI utilities (bg-base-100,
   * text-primary, .btn, …) which resolve to these CSS variables. By
   * overriding them only inside .formsies-scope, every utility on a
   * Formsies surface picks up the dark palette without touching the rest
   * of the Pegasus app or rewriting every template.
   * ---------------------------------------------------------------- */
  --color-base-100: #161b22;
  --color-base-200: #11161d;
  --color-base-300: rgba(255, 255, 255, 0.10);
  --color-base-content: #e7edf3;
  --color-primary: #35d0bd;
  --color-primary-content: #06201d;
  --color-secondary: #5fe0d0;
  --color-secondary-content: #06201d;
  --color-accent: #35d0bd;
  --color-accent-content: #06201d;
  --color-neutral: #1a212a;
  --color-neutral-content: #e7edf3;
  --color-info: #5fe0d0;
  --color-info-content: #06201d;
  --color-success: #35d0bd;
  --color-success-content: #06201d;
  --color-warning: #e0a13c;
  --color-warning-content: #0e1217;
  --color-error: #e08a6a;
  --color-error-content: #0e1217;

  color: var(--fs-text);
  font-family: var(--fs-font-body);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ---------------------------------------------------------------------
 * Force the ENTIRE authenticated Formsies app surface dark — including the
 * shared Pegasus top bar and the page body — regardless of the user's global
 * light/dark theme toggle. The handoff app is its own dark product surface,
 * so a light top bar over a dark workspace (the bug) must never happen.
 *
 * `formsies_app_base.html` adds `.formsies-app-page` to <html> very early in
 * <head>. Overriding the DaisyUI v5 `--color-*` tokens here re-skins every
 * utility on the page (nav, body, toasts) to the dark palette. We key on the
 * html class (specificity 0,1,1) so it beats DaisyUI's `[data-theme=...]`
 * (0,1,0) even after the theme-sync script flips the attribute to "light".
 * ------------------------------------------------------------------ */
html.formsies-app-page {
  --color-base-100: #161b22;
  --color-base-200: #11161d;
  --color-base-300: rgba(255, 255, 255, 0.10);
  --color-base-content: #e7edf3;
  --color-primary: #35d0bd;
  --color-primary-content: #06201d;
  --color-secondary: #5fe0d0;
  --color-secondary-content: #06201d;
  --color-accent: #35d0bd;
  --color-accent-content: #06201d;
  --color-neutral: #1a212a;
  --color-neutral-content: #e7edf3;
  --color-info: #5fe0d0;
  --color-info-content: #06201d;
  --color-success: #35d0bd;
  --color-success-content: #06201d;
  --color-warning: #e0a13c;
  --color-warning-content: #0e1217;
  --color-error: #e08a6a;
  --color-error-content: #0e1217;
  color-scheme: dark;
}
html.formsies-app-page body {
  background: #0e1217;
  background-image: none;
  color: #e7edf3;
}

/* Base typography for the dark app surface. Headings and big metric
 * numbers use Space Grotesk; monospace (numbers, timestamps, slugs, hex,
 * embed snippets) uses JetBrains Mono via the .font-mono utility. */
.formsies-scope h1,
.formsies-scope h2,
.formsies-scope h3,
.formsies-command__title,
.formsies-kpi__value,
.formsies-studio__section-title,
.formsies-hero__metric,
.formsies-statcard__value {
  font-family: var(--fs-font-display);
  letter-spacing: -0.02em;
}
.formsies-scope .font-mono,
.formsies-scope code,
.formsies-scope kbd,
.formsies-scope .formsies-mono {
  font-family: var(--fs-font-mono);
}

/* Workspace background — make sure the dark surface fills the column even
 * where a component hasn't set its own background. */
.formsies-workspace,
.formsies-app-shell {
  background: var(--fs-page);
}

/* Teal text-selection + custom thin scrollbars from the handoff. */
.formsies-scope ::selection { background: rgba(53, 208, 189, 0.28); }
.fs-scroll::-webkit-scrollbar { width: 10px; height: 10px; }
.fs-scroll::-webkit-scrollbar-track { background: transparent; }
.fs-scroll::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  border: 3px solid transparent;
  background-clip: padding-box;
}
.fs-scroll::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.16);
  background-clip: padding-box;
}

/* ---------------------------------------------------------------------
 * Command Center (button detail)
 * ------------------------------------------------------------------ */
/* The Command Center is an app surface, not a framed card: the header and
 * tabs sit directly on the workspace background and the KPI / tab panels are
 * the cards. So no outer border, panel fill, radius, or shadow here. */
.formsies-command {
  position: relative;
  border: 0;
  background: transparent;
  box-shadow: none;
  /* Fill the app-shell content box (which is itself max-width 1480px, centered
     with equal 24px gutters), so the command center has balanced left/right
     margins that match the All-workflows page on both edges. The previous
     max-width:1080px cap left a large unused right margin and squished the Edit
     preview; the app-shell cap already keeps line lengths reasonable. */
  padding: 12px 0 44px;
  margin: 0;
  min-width: 0;
  width: 100%;
}
@media (max-width: 640px) {
  .formsies-command {
    padding: 2px 0;
  }
}
/* The Command Center is a non-interactive, programmatically-focusable region
 * (tabindex="-1"): the range controls link to `#command-center`, and the
 * browser focuses that fragment target on load. Some browsers then draw a
 * focus ring around the whole section, which reads as a broken white outline
 * around the header/tabs/KPI grid. Suppress the ring on the *container* only.
 *
 * Accessibility-safe: the section is not keyboard-tabbable (tabindex -1), so
 * no keyboard user lands here by tabbing; it still receives programmatic focus
 * so screen readers announce the landing region. Real interactive controls
 * inside (the 7d/30d/90d buttons, the tabs) keep their own focus styles — this
 * rule matches the section element, not its children. */
.formsies-command:focus,
.formsies-command:focus-visible,
.formsies-command:target {
  outline: none;
}
.formsies-command__title {
  overflow-wrap: anywhere;
  word-break: break-word;
}
.formsies-command__subtitle {
  overflow-wrap: anywhere;
  word-break: break-word;
}

.formsies-submissions-preview {
  min-width: 0;
}
.formsies-submissions-preview__head {
  min-width: 0;
}
.formsies-submissions-preview__actions {
  min-width: 0;
  max-width: 100%;
}
.formsies-submissions-preview__actions > .btn {
  flex: 0 1 auto;
  min-width: 0;
  max-width: 100%;
}
@media (max-width: 480px) {
  .formsies-submissions-preview__actions {
    width: 100%;
  }
  .formsies-submissions-preview__actions > .btn {
    flex: 1 1 calc(50% - 8px);
  }
}
/* Submissions preview rows — handoff: dot | name + snippet | mono timestamp */
.formsies-submissions-preview__list {
  border: 1px solid var(--fs-line);
  background: var(--fs-inset);
  border-radius: 12px;
  overflow: hidden;
  margin-top: 12px;
}
.formsies-submissions-preview .formsies-inbox-row { align-items: center; }
.formsies-submissions-preview__rowmain { min-width: 0; }
.formsies-submissions-preview .formsies-unread {
  width: 7px;
  height: 7px;
  margin-top: 0;
}
.formsies-submissions-preview .snippet-line {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.formsies-submissions-preview .when {
  color: var(--fs-dim);
  font-family: var(--fs-font-mono);
}
.formsies-submissions-preview__empty {
  text-align: center;
  color: var(--fs-dim);
  font-size: 13px;
  padding: 28px 16px;
  margin-top: 12px;
}

.formsies-activity-panel {
  min-width: 0;
}
.formsies-activity-panel__head {
  min-width: 0;
}
/* Top line of the Command Center: "Selected workflow · Name" eyebrow on the
 * left, live status pill on the right — a compact app header strip. */
.formsies-command__topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 10px;
}
.formsies-command__status {
  flex: 0 0 auto;
}
.formsies-command-header {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  margin-top: 4px;
  margin-bottom: 12px;
  min-width: 0;
}
.formsies-command-header > .left {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  flex-wrap: wrap;
}
.formsies-command-header > .center {
  min-width: 0;
}
.formsies-command-header > .center h1 {
  margin: 0;
  letter-spacing: -0.01em;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.formsies-command-header > .right {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  justify-content: flex-end;
  min-width: 0;
  max-width: 100%;
}
.formsies-command__actions > .btn,
.formsies-command__actions > a.btn {
  flex: 0 1 auto;
  min-width: 0;
  max-width: 100%;
}
.formsies-command__actions .formsies-command__action-form {
  margin: 0;
  display: inline-flex;
  min-width: 0;
  max-width: 100%;
}
.formsies-command__actions .formsies-command__action-form > .btn {
  flex: 1 1 auto;
  min-width: 0;
  max-width: 100%;
}
@media (max-width: 960px) {
  .formsies-command-header {
    grid-template-columns: minmax(0, 1fr);
  }
  .formsies-command-header > .right {
    justify-content: flex-start;
  }
}
@media (max-width: 480px) {
  .formsies-command__actions {
    width: 100%;
  }
  .formsies-command__actions > .btn,
  .formsies-command__actions > a.btn,
  .formsies-command__actions .formsies-command__action-form,
  .formsies-command__actions .formsies-command__action-form > .btn {
    flex: 1 1 calc(50% - 8px);
  }
}
.formsies-range-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  padding: 0 0 14px;
  margin-bottom: 0;
  border: 0;
  background: transparent;
  min-width: 0;
}
.formsies-range-row__controls.join {
  background: var(--fs-subtle);
  border: 1px solid var(--fs-line-strong);
  border-radius: 8px;
  padding: 2px;
  gap: 2px;
}
.formsies-range-row__controls .btn {
  border: 0;
  background: transparent;
  color: var(--fs-muted-2);
  min-height: 26px;
  height: 26px;
  border-radius: 6px;
}
.formsies-range-row__controls .btn.btn-active {
  background: rgba(53, 208, 189, 0.16);
  color: var(--fs-primary-2);
}
.formsies-range-row__text {
  flex: 1 1 220px;
  min-width: 0;
  overflow-wrap: anywhere;
  line-height: 1.45;
}
.formsies-range-row__controls {
  flex: 0 0 auto;
  display: inline-flex;
  flex-wrap: nowrap;
  max-width: 100%;
}
.formsies-range-row .join .btn {
  font-weight: 700;
}
@media (max-width: 520px) {
  .formsies-range-row {
    flex-direction: column;
    align-items: stretch;
  }
  .formsies-range-row__controls {
    align-self: flex-start;
  }
}

.formsies-tabs-wrap {
  margin: 0 0 24px;
  padding: 0;
  min-width: 0;
  max-width: 100%;
  border-bottom: 1px solid rgba(255, 255, 255, 0.07);
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
}
/* Range segmented control — lives inside the Overview hint card (right side),
   so it only shows on Overview and adds no standalone row above the content. */
.formsies-overview-hint__range { margin-left: auto; padding-bottom: 0; }
.formsies-range { display: flex; align-items: center; gap: 8px; padding-bottom: 6px; flex: 0 0 auto; }
.formsies-range__label { font-size: 11px; text-transform: uppercase; letter-spacing: 0.07em; color: var(--fs-faint); }
.formsies-range__seg { display: inline-flex; border: 1px solid var(--fs-line); border-radius: 8px; overflow: hidden; }
.formsies-range__item {
  font-size: 12px;
  padding: 4px 10px;
  color: var(--fs-muted);
  text-decoration: none;
  border-right: 1px solid var(--fs-line);
}
.formsies-range__item:last-child { border-right: none; }
.formsies-range__item:hover { background: var(--fs-hover); color: var(--fs-text); }
.formsies-range__item.is-active { background: var(--fs-primary-soft); color: var(--fs-primary-2); font-weight: 600; }
@media (max-width: 640px) {
  .formsies-tabs-wrap { flex-direction: column; align-items: stretch; }
  .formsies-range { padding-bottom: 10px; }
}
.formsies-tabs {
  display: flex;
  flex-wrap: nowrap;
  gap: 2px;
  margin: 0 0 -1px;
  padding: 0;
  list-style: none;
  background: transparent;
  border: 0;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: none;
  -ms-overflow-style: none;
  max-width: 100%;
  min-width: 0;
}
.formsies-tabs::-webkit-scrollbar { display: none; }
.formsies-tab {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 11px 14px;
  border: 0;
  border-bottom: 2px solid transparent;
  background: transparent;
  color: var(--fs-dim);
  font-size: 13.5px;
  font-weight: 500;
  line-height: 1;
  white-space: nowrap;
  cursor: pointer;
  transition: color 0.18s ease, border-color 0.18s ease;
}
.formsies-tab__label { display: inline-block; }
.formsies-tab:hover { color: var(--fs-text); }
/* Mouse / hash navigation must not draw a box around the tab — only genuine
   keyboard focus shows a ring, and it's a soft inset ring (not the old full
   2px square outline) that reads cleanly on the dark theme. */
.formsies-tab:focus { outline: none; }
.formsies-tab:focus-visible {
  outline: none;
  border-radius: 7px;
  box-shadow: 0 0 0 2px var(--fs-primary-soft);
}
.formsies-tab.is-active {
  color: var(--fs-heading);
  font-weight: 600;
  border-bottom-color: var(--fs-primary);
}
.formsies-tab__badge {
  display: inline-grid;
  place-items: center;
  min-width: 18px;
  height: 16px;
  padding: 0 5px;
  border-radius: 5px;
  background: rgba(255, 255, 255, 0.08);
  color: var(--fs-muted);
  font-family: var(--fs-font-mono);
  font-size: 10px;
  font-weight: 600;
  line-height: 1;
}
.formsies-tab__badge.is-warn {
  background: var(--fs-warn-soft);
  color: var(--fs-warn);
}
@media (max-width: 640px) {
  .formsies-tabs-wrap {
    margin: 12px -14px 12px;
    padding: 8px 14px 10px;
  }
  .formsies-tab {
    padding: 8px 13px;
    font-size: 12px;
  }
}

.formsies-tabpanel { display: none; }
.formsies-tabpanel.is-active { display: block; }
.formsies-tabpanel:focus { outline: none; }

/* ---------------------------------------------------------------------
 * Overview hint row + KPI cards
 * ------------------------------------------------------------------ */
.formsies-overview-hint {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 14px;
  border: 1px solid var(--fs-line);
  background: var(--fs-panel-soft);
  font-size: 12.5px;
  color: var(--fs-text);
  margin-bottom: 14px;
  line-height: 1.4;
  flex-wrap: wrap;
}
.formsies-overview-hint__icon {
  flex-shrink: 0;
  font-size: 14px;
  line-height: 1.2;
}
.formsies-overview-hint__text {
  flex: 1 1 auto;
  min-width: 0;
}
.formsies-overview-hint__text strong {
  font-weight: 800;
  margin-right: 4px;
}
.formsies-overview-hint__cta {
  flex-shrink: 0;
  font-size: 11.5px;
  font-weight: 700;
  color: var(--fs-primary);
  text-decoration: none;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid rgba(53, 208, 189, 0.28);
  background: rgba(53, 208, 189, 0.08);
  transition: background 0.15s ease, border-color 0.15s ease;
}
.formsies-overview-hint__cta:hover {
  background: rgba(53, 208, 189, 0.14);
  border-color: rgba(53, 208, 189, 0.45);
}
.formsies-overview-hint.is-warn {
  background: var(--fs-warn-soft);
  border-color: rgba(224, 161, 60, 0.34);
  color: var(--fs-text);
}
.formsies-overview-hint.is-warn .formsies-overview-hint__cta {
  color: var(--fs-warn);
  background: rgba(224, 161, 60, 0.14);
  border-color: rgba(224, 161, 60, 0.4);
}
.formsies-overview-hint.is-warn .formsies-overview-hint__cta:hover {
  background: rgba(224, 161, 60, 0.22);
}
.formsies-overview-hint.is-info {
  background: rgba(20, 184, 166, 0.08);
  border-color: rgba(53, 208, 189, 0.22);
}
[data-theme="dark"] .formsies-overview-hint.is-info,
.dark .formsies-overview-hint.is-info {
  background: rgba(20, 184, 166, 0.12);
  border-color: rgba(94, 234, 212, 0.24);
}

.formsies-kpi-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 12px;
  min-width: 0;
}
@media (min-width: 520px) {
  .formsies-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (min-width: 768px) {
  .formsies-kpi-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (min-width: 1280px) {
  .formsies-kpi-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }
}
.formsies-kpi-grid > * {
  min-width: 0;
  max-width: 100%;
}
.formsies-kpi {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 138px;
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
  overflow-wrap: anywhere;
  word-break: break-word;
  box-sizing: border-box;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.formsies-kpi:hover {
  border-color: rgba(53, 208, 189, 0.28);
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.07);
}
.formsies-kpi--featured:hover {
  border-color: rgba(53, 208, 189, 0.55);
}
.formsies-kpi__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-height: 20px;
}
.formsies-kpi__label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fs-muted);
}
.formsies-kpi__label.is-strong {
  color: var(--fs-text);
}
.formsies-kpi__value {
  margin: 8px 0 0;
  font-size: 26px;
  line-height: 1.1;
  font-weight: 700;
  color: var(--fs-text);
  letter-spacing: -0.02em;
  overflow-wrap: anywhere;
  word-break: break-word;
  min-width: 0;
}
@media (min-width: 640px) {
  .formsies-kpi__value { font-size: 28px; }
}
.formsies-kpi__note {
  margin: 2px 0 0;
  font-size: 11px;
  color: var(--fs-muted);
}
.formsies-kpi__delta {
  margin: 4px 0 0;
  font-size: 11px;
  color: var(--fs-muted);
}
.formsies-kpi__foot {
  margin: 4px 0 0;
  font-size: 11px;
  color: var(--fs-muted-2);
}
.formsies-kpi.is-locked {
  background: linear-gradient(
    180deg,
    var(--fs-panel) 0%,
    color-mix(in oklab, var(--fs-panel-muted) 70%, transparent) 100%
  );
}
.formsies-kpi.is-locked .formsies-kpi__value {
  color: var(--fs-muted-2);
}
.formsies-kpi__lock-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 10px;
  min-width: 0;
  max-width: 100%;
}
.formsies-kpi__lock {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: 999px;
  background: var(--fs-warn-soft);
  border: 1px solid rgba(224, 161, 60, 0.35);
  color: var(--fs-warn);
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  width: max-content;
}
.formsies-kpi__upgrade {
  display: inline-flex;
  align-items: center;
  font-size: 11px;
  font-weight: 700;
  color: var(--fs-primary);
  text-decoration: none;
  max-width: 100%;
  overflow-wrap: anywhere;
}
.formsies-kpi__upgrade:hover {
  text-decoration: underline;
}

/* ---------------------------------------------------------------------
 * Workflow Board (button list)
 * ------------------------------------------------------------------ */
.formsies-board-tabs {
  display: inline-flex;
  background: var(--fs-panel-muted);
  border: 1px solid var(--fs-line);
  border-radius: 999px;
  padding: 3px;
  margin-bottom: 14px;
}
.formsies-board-tabs__btn {
  border: 0;
  background: transparent;
  padding: 7px 14px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 700;
  color: var(--fs-muted);
  cursor: pointer;
}
.formsies-board-tabs__btn.is-active {
  background: var(--fs-panel);
  color: var(--fs-primary);
  box-shadow: var(--fs-shadow-sm);
}
[data-theme="dark"] .formsies-board-tabs__btn.is-active,
.dark .formsies-board-tabs__btn.is-active {
  background: rgba(2, 6, 23, 0.85);
  color: rgb(94, 234, 212);
}

.formsies-board-panel { display: none; }
.formsies-board-panel.is-active { display: block; }

.formsies-board {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  align-items: flex-start;
}
@media (max-width: 1080px) {
  .formsies-board { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px) {
  .formsies-board { grid-template-columns: 1fr; }
}

.formsies-lane {
  border: 1px solid var(--fs-line);
  border-radius: 22px;
  background: var(--fs-panel-soft);
  padding: 14px;
  min-height: 240px;
  display: flex;
  flex-direction: column;
  min-width: 0;
  box-sizing: border-box;
  overflow: hidden;
}
.formsies-lane__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
  font-weight: 800;
  font-size: 14px;
}
.formsies-lane__count {
  min-width: 28px;
  height: 26px;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  background: var(--fs-panel);
  border: 1px solid var(--fs-line);
  color: var(--fs-muted);
  font-size: 12px;
  box-shadow: var(--fs-shadow-sm);
  padding: 0 8px;
}
[data-theme="dark"] .formsies-lane__count,
.dark .formsies-lane__count {
  background: rgba(2, 6, 23, 0.7);
}
.formsies-lane__items {
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
  min-width: 0;
}
.formsies-lane__items > * {
  min-width: 0;
  max-width: 100%;
}

.formsies-card {
  position: relative;
  display: block;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
  text-align: left;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid var(--fs-line);
  background: var(--fs-panel);
  box-shadow: var(--fs-shadow-sm);
  transition: transform 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
  overflow-wrap: anywhere;
}
.formsies-card:hover {
  transform: translateY(-1px);
  border-color: rgba(53, 208, 189, 0.34);
  box-shadow: 0 12px 24px rgba(15, 23, 42, 0.08);
}
.formsies-card__title {
  margin: 0 0 4px;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: -0.01em;
  padding-right: 80px;
}
.formsies-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  font-size: 11px;
  color: var(--fs-muted);
  margin-top: 4px;
}
.formsies-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 7px;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.04);
  border: 1px solid var(--fs-line);
  font-weight: 700;
  font-size: 11px;
}
.formsies-pill--warn {
  background: var(--fs-warn-soft);
  color: var(--fs-warn);
  border-color: rgba(224, 161, 60, 0.32);
}
.formsies-pill--danger {
  background: rgba(224, 138, 106, 0.08);
  color: var(--fs-danger);
  border-color: rgba(224, 138, 106, 0.22);
}
.formsies-pill--good {
  background: rgba(22, 163, 74, 0.10);
  color: var(--fs-success);
  border-color: rgba(22, 163, 74, 0.22);
}

.formsies-progress {
  height: 7px;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.08);
  overflow: hidden;
  margin-top: 10px;
}
.formsies-progress > i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--fs-primary), var(--fs-primary-2));
}
.formsies-progress > i.is-warn {
  background: linear-gradient(90deg, #e0a13c, #e08a6a);
}

.formsies-card__actions {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(92px, 1fr));
  gap: 6px;
  margin-top: 10px;
  min-width: 0;
  max-width: 100%;
}
.formsies-card__actions > * {
  min-width: 0;
  max-width: 100%;
  font-size: 12px;
}
.formsies-card__actions .btn {
  width: 100%;
  min-width: 0;
  max-width: 100%;
  padding-left: 8px;
  padding-right: 8px;
  font-size: 12px;
  line-height: 1.15;
  white-space: normal;
  text-align: center;
  overflow-wrap: anywhere;
  height: auto;
  min-height: 2rem;
}
@media (max-width: 640px) {
  .formsies-card__actions {
    grid-template-columns: 1fr;
  }
}

.formsies-card__status-pill {
  position: absolute;
  top: 12px;
  right: 12px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.formsies-card__status-pill.is-active {
  background: rgba(22, 163, 74, 0.14);
  color: var(--fs-success);
  border: 1px solid rgba(22, 163, 74, 0.28);
}
.formsies-card__status-pill.is-inactive {
  background: rgba(15, 23, 42, 0.05);
  color: var(--fs-muted);
  border: 1px solid var(--fs-line);
}
.formsies-card__status-pill.is-archived {
  background: rgba(124, 58, 237, 0.10);
  color: var(--fs-purple);
  border: 1px solid rgba(124, 58, 237, 0.28);
}
.formsies-card.is-archived {
  opacity: 0.78;
  background: var(--fs-panel-soft);
  border-style: dashed;
}
.formsies-card.is-archived:hover {
  opacity: 1;
}

/* Selected workflow card on the one-page dashboard. */
.formsies-card.is-selected {
  background: var(--fs-primary-soft);
  border-color: rgba(53, 208, 189, 0.45);
  box-shadow: 0 10px 24px rgba(53, 208, 189, 0.16);
}
.formsies-card.is-selected:hover {
  border-color: rgba(53, 208, 189, 0.55);
}
.formsies-card.is-selected .formsies-card__title a {
  color: var(--fs-primary);
}

.formsies-card__selected-marker {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: 8px;
  padding: 2px 8px;
  border-radius: 999px;
  background: rgba(53, 208, 189, 0.14);
  color: var(--fs-primary);
  border: 1px solid rgba(53, 208, 189, 0.32);
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  line-height: 1;
  width: max-content;
}
[data-theme="dark"] .formsies-card__selected-marker,
.dark .formsies-card__selected-marker {
  background: rgba(53, 208, 189, 0.20);
  color: rgb(94, 234, 212);
  border-color: rgba(94, 234, 212, 0.38);
}

.formsies-card__action-form {
  margin: 0;
  display: flex;
  min-width: 0;
  max-width: 100%;
}
.formsies-card__action-form > .btn {
  flex: 1 1 auto;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  font-size: 12px;
}
.formsies-card__archive-form {
  margin: 8px 0 0;
  display: flex;
  justify-content: flex-end;
}
.formsies-card__archive-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  font-weight: 700;
  color: var(--fs-muted);
  background: transparent;
  border: 0;
  cursor: pointer;
  padding: 4px 6px;
  border-radius: 8px;
}
.formsies-card__archive-btn:hover {
  color: var(--fs-danger);
  background: rgba(224, 138, 106, 0.06);
}

.formsies-empty-lane {
  border: 2px dashed var(--fs-line-strong);
  background: var(--fs-subtle);
  border-radius: 18px;
  padding: 22px;
  text-align: center;
  color: var(--fs-muted);
  font-size: 13px;
  line-height: 1.45;
}
[data-theme="dark"] .formsies-empty-lane,
.dark .formsies-empty-lane {
  background: rgba(2, 6, 23, 0.4);
}

/* ---------------------------------------------------------------------
 * Bulk-action toolbar (Workflow Board)
 *
 * Sits above the lanes. Buttons disable themselves until at least one
 * card is selected; the JS in formsies.js wires that + the live count.
 * ------------------------------------------------------------------ */
.formsies-bulk-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
  padding: 10px 12px;
  margin-bottom: 12px;
  border: 1px solid var(--fs-line);
  border-radius: 14px;
  background: var(--fs-panel-soft);
  box-shadow: var(--fs-shadow-sm);
}
.formsies-bulk-toolbar__left {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  font-size: 12px;
}
.formsies-bulk-toolbar__select-all {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  font-weight: 600;
  color: var(--fs-text);
}
.formsies-bulk-toolbar__select-all input {
  width: 16px;
  height: 16px;
  accent-color: var(--fs-primary);
}
.formsies-bulk-toolbar__count {
  display: inline-flex;
  align-items: center;
  padding: 2px 10px;
  border-radius: 999px;
  background: var(--fs-panel-muted);
  border: 1px solid var(--fs-line);
  color: var(--fs-muted);
  font-weight: 700;
  font-size: 11px;
}
.formsies-bulk-toolbar__count.is-active {
  background: var(--fs-primary-soft);
  color: var(--fs-primary);
  border-color: rgba(53, 208, 189, 0.3);
}
.formsies-bulk-toolbar__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.formsies-bulk-toolbar__actions .btn[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Card-level select checkbox. Anchored top-left so it doesn't overlap the
 * status pill on the right. */
.formsies-card__select {
  position: absolute;
  top: 12px;
  left: 12px;
  display: inline-flex;
  align-items: center;
  cursor: pointer;
  z-index: 1;
}
.formsies-card__select-input {
  width: 16px;
  height: 16px;
  accent-color: var(--fs-primary);
  cursor: pointer;
}
.formsies-card__title {
  /* Reserve room for the checkbox on the left + status pill on the right. */
  padding-left: 26px;
}

/* ---------------------------------------------------------------------
 * Edit Studio (button form sidebar)
 * ------------------------------------------------------------------ */
.formsies-studio {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 18px;
  align-items: flex-start;
}
@media (max-width: 900px) {
  .formsies-studio { grid-template-columns: 1fr; }
}

.formsies-studio__nav {
  position: sticky;
  top: 16px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 12px;
  border-radius: 18px;
  border: 1px solid var(--fs-line);
  background: var(--fs-panel);
  box-shadow: var(--fs-shadow-sm);
}
@media (max-width: 900px) {
  .formsies-studio__nav {
    position: static;
    flex-direction: row;
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: 6px;
  }
}
.formsies-studio__group {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  color: var(--fs-faint);
  padding: 10px 10px 4px;
  font-weight: 700;
}
@media (max-width: 900px) {
  .formsies-studio__group { display: none; }
}
.formsies-studio__nav-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 9px 12px;
  border-radius: 12px;
  background: transparent;
  border: 1px solid transparent;
  font-size: 13px;
  font-weight: 700;
  color: var(--fs-text);
  cursor: pointer;
  text-align: left;
  text-decoration: none;
  white-space: nowrap;
}
.formsies-studio__nav-item:hover {
  background: var(--fs-panel-muted);
}
.formsies-studio__nav-item.is-active {
  background: var(--fs-primary-soft);
  color: var(--fs-primary);
  border-color: rgba(53, 208, 189, 0.22);
}
.formsies-studio__nav-item--danger { color: var(--fs-danger); }

.formsies-studio__section {
  scroll-margin-top: 80px;
}
.formsies-studio__section-title {
  font-size: 18px;
  text-transform: none;
  letter-spacing: -0.02em;
  color: var(--fs-heading);
  font-weight: 600;
  margin: 0 0 4px;
}

/* ---------------------------------------------------------------------
 * Inbox layout (used in submission_list polish)
 * ------------------------------------------------------------------ */
.formsies-inbox-preview {
  display: grid;
  grid-template-columns: 1.05fr 1.4fr;
  gap: 14px;
  margin-top: 12px;
}
@media (max-width: 1080px) {
  .formsies-inbox-preview { grid-template-columns: 1fr; }
}
.formsies-inbox-row {
  display: grid;
  grid-template-columns: 14px 1fr auto;
  gap: 10px;
  align-items: start;
  padding: 12px 14px;
  border-bottom: 1px solid var(--fs-line);
  font-size: 13px;
}
.formsies-inbox-row:last-child { border-bottom: 0; }
.formsies-inbox-row .who { font-weight: 700; }
.formsies-inbox-row .snippet-line {
  color: var(--fs-muted);
  font-size: 12px;
  line-height: 1.35;
  margin-top: 2px;
  word-break: break-word;
}
.formsies-inbox-row .when {
  color: var(--fs-muted);
  font-size: 11px;
  white-space: nowrap;
}
.formsies-unread {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--fs-primary-2);
  margin-top: 6px;
}
.formsies-unread.is-read {
  background: transparent;
  border: 1px solid var(--fs-line);
}

/* ---------------------------------------------------------------------
 * Generic Formsies modal (used for Inbox preview)
 * ------------------------------------------------------------------ */
.formsies-modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: flex-start;
  justify-content: center;
  padding: 5vh 16px;
  background: rgba(15, 23, 42, 0.55);
  z-index: 1000;
  overflow-y: auto;
}
.formsies-modal.is-open {
  display: flex;
}
.formsies-modal__dialog {
  width: 100%;
  max-width: 960px;
  background: var(--fs-panel);
  border: 1px solid var(--fs-line);
  border-radius: 18px;
  box-shadow: var(--fs-shadow);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  max-height: 90vh;
}
.formsies-modal__close {
  position: absolute;
  top: 18px;
  right: 22px;
  width: 32px;
  height: 32px;
  border-radius: 999px;
  border: 1px solid var(--fs-line);
  background: var(--fs-panel);
  color: var(--fs-muted);
  font-size: 18px;
  font-weight: 800;
  line-height: 1;
  cursor: pointer;
  display: inline-grid;
  place-items: center;
  z-index: 2;
}
.formsies-modal__close:hover {
  color: var(--fs-text);
  background: var(--fs-hover);
}
.formsies-modal__body {
  position: relative;
  overflow-y: auto;
  flex: 1;
}
.formsies-modal__loading,
.formsies-modal__error {
  padding: 28px;
  text-align: center;
  color: var(--fs-muted);
  font-size: 13px;
}
.formsies-modal__error a {
  color: var(--fs-primary);
  font-weight: 700;
  text-decoration: underline;
}

/* ---------------------------------------------------------------------
 * Inbox modal partial (rendered inside .formsies-modal__body)
 * ------------------------------------------------------------------ */
.formsies-inbox-modal {
  padding: 18px 20px 20px;
}
.formsies-inbox-modal__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 12px;
  min-width: 0;
}
.formsies-inbox-modal__head > div {
  min-width: 0;
  flex: 1 1 220px;
}
.formsies-inbox-modal__head .formsies-inbox-modal__title {
  overflow-wrap: anywhere;
  word-break: break-word;
}
.formsies-inbox-modal__eyebrow {
  margin: 0;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  color: var(--fs-faint);
  font-weight: 700;
}
.formsies-inbox-modal__title {
  margin: 2px 0 0;
  font-size: 16px;
  font-weight: 800;
  letter-spacing: -0.01em;
}
.formsies-inbox-modal__head-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 12px;
  color: var(--fs-muted);
  flex-wrap: wrap;
  min-width: 0;
  max-width: 100%;
}
.formsies-inbox-modal__count { font-weight: 700; }
.formsies-inbox-modal__full-link {
  color: var(--fs-primary);
  font-weight: 700;
  text-decoration: none;
}
.formsies-inbox-modal__full-link:hover { text-decoration: underline; }

.formsies-inbox-modal__layout {
  display: grid;
  grid-template-columns: minmax(220px, 320px) 1fr;
  gap: 14px;
  margin-top: 6px;
}
@media (max-width: 720px) {
  .formsies-inbox-modal__layout { grid-template-columns: 1fr; }
}
.formsies-inbox-modal__list {
  list-style: none;
  margin: 0;
  padding: 0;
  border: 1px solid var(--fs-line);
  border-radius: 14px;
  background: var(--fs-panel-soft);
  max-height: 56vh;
  overflow-y: auto;
}
.formsies-inbox-modal__list li + li {
  border-top: 1px solid var(--fs-line);
}
.formsies-inbox-modal__row {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto auto;
  row-gap: 4px;
  column-gap: 10px;
  width: 100%;
  border: 0;
  background: transparent;
  text-align: left;
  cursor: pointer;
  padding: 10px 12px;
  font-size: 12px;
  color: var(--fs-text);
}
.formsies-inbox-modal__row:hover { background: rgba(15, 23, 42, 0.04); }
.formsies-inbox-modal__row.is-active {
  background: var(--fs-primary-soft);
  color: var(--fs-primary);
}
.formsies-inbox-modal__row-when {
  font-weight: 700;
  font-size: 11px;
  color: var(--fs-muted);
  grid-column: 1 / 2;
  grid-row: 1 / 2;
}
.formsies-inbox-modal__row-snippet {
  grid-column: 1 / 3;
  grid-row: 2 / 3;
  color: var(--fs-text);
  font-weight: 500;
  word-break: break-word;
}
.formsies-inbox-modal__row.is-active .formsies-inbox-modal__row-snippet {
  color: var(--fs-primary);
}
.formsies-inbox-modal__row-tags {
  grid-column: 2 / 3;
  grid-row: 1 / 2;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  justify-self: end;
}

.formsies-inbox-modal__detail {
  border: 1px solid var(--fs-line);
  border-radius: 14px;
  background: var(--fs-panel-soft);
  padding: 14px 16px;
  max-height: 56vh;
  overflow-y: auto;
}
.formsies-inbox-modal__detail-card { display: none; }
.formsies-inbox-modal__detail-card.is-active { display: block; }
.formsies-inbox-modal__detail-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.formsies-inbox-modal__detail-when {
  margin: 0;
  font-size: 12px;
  font-weight: 700;
}
.formsies-inbox-modal__detail-source {
  margin: 2px 0 0;
  font-size: 11px;
  color: var(--fs-muted);
  word-break: break-all;
}
.formsies-inbox-modal__detail-tags {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 4px;
}
.formsies-inbox-modal__fields {
  margin: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
.formsies-inbox-modal__fields > div {
  border-bottom: 1px dashed var(--fs-line);
  padding-bottom: 8px;
}
.formsies-inbox-modal__fields dt {
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--fs-muted-2);
  margin-bottom: 2px;
}
.formsies-inbox-modal__fields dd {
  margin: 0;
  font-size: 13px;
  color: var(--fs-text);
  word-break: break-word;
}
.formsies-inbox-modal__empty {
  padding: 28px 16px;
  text-align: center;
  color: var(--fs-muted);
  font-size: 13px;
}
.formsies-inbox-modal__empty-hint {
  font-size: 12px;
  color: var(--fs-muted-2);
  margin-top: 4px;
}

/* ---------------------------------------------------------------------
 * Workflow Board drag/drop affordances + lightweight banner toast.
 *
 * Drag/drop is enhancement-only — every card still has its own POST forms
 * for archive / toggle / unarchive, so the board works fully without JS.
 * These rules just style the in-flight states (grabbing card, drop target
 * highlight, refused drop) and the small status banner that surfaces
 * server messages without us having to reload the page on failure.
 * ------------------------------------------------------------------ */
.formsies-card[draggable="true"] {
  cursor: grab;
}
.formsies-card.is-dragging {
  opacity: 0.55;
  cursor: grabbing;
}
.formsies-card.is-busy {
  pointer-events: none;
  opacity: 0.7;
}
.formsies-lane.is-drop-target {
  outline: 2px dashed var(--fs-primary, #35d0bd);
  outline-offset: -6px;
  background: color-mix(in oklab, var(--fs-primary, #35d0bd) 10%, transparent);
}
.formsies-lane.is-drop-refused {
  outline: 2px dashed var(--fs-danger, #e08a6a);
  outline-offset: -6px;
}

.formsies-board-banner {
  margin: 0 0 12px;
  padding: 10px 12px;
  border-radius: 12px;
  font-size: 13px;
  font-weight: 600;
  border: 1px solid var(--fs-line);
  background: var(--fs-panel-soft);
  color: var(--fs-text);
  box-shadow: var(--fs-shadow-sm);
  display: none;
}
.formsies-board-banner.is-visible { display: block; }
.formsies-board-banner.is-error {
  border-color: rgba(185, 28, 28, 0.35);
  background: rgba(185, 28, 28, 0.08);
  color: #e08a6a;
}
.formsies-board-banner.is-success {
  border-color: rgba(53, 208, 189, 0.35);
  background: rgba(53, 208, 189, 0.10);
  color: var(--fs-primary);
}

/* Bulk toolbar mobile polish — wrap cleanly and stack actions on narrow
 * screens. */
@media (max-width: 640px) {
  .formsies-bulk-toolbar {
    flex-direction: column;
    align-items: stretch;
  }
  .formsies-bulk-toolbar__actions {
    justify-content: stretch;
  }
  .formsies-bulk-toolbar__actions .btn {
    flex: 1 1 calc(50% - 6px);
  }
}
.formsies-bulk-toolbar__hint {
  font-size: 11px;
  color: var(--fs-muted-2);
  font-weight: 500;
}

/* Lightweight modal-style confirm used in place of window.confirm() for
 * destructive bulk actions. Reuses the same backdrop/dialog pattern as the
 * inbox modal so we don't ship a new component. */
.formsies-confirm {
  position: fixed;
  inset: 0;
  background: rgba(2, 6, 23, 0.55);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 70;
  padding: 16px;
}
.formsies-confirm.is-open { display: flex; }
.formsies-confirm__dialog {
  background: var(--fs-panel, #fff);
  border: 1px solid var(--fs-line);
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(2, 6, 23, 0.35);
  max-width: 420px;
  width: 100%;
  padding: 18px 20px;
}
.formsies-confirm__title {
  font-weight: 800;
  font-size: 15px;
  margin: 0 0 6px;
  color: var(--fs-text);
}
.formsies-confirm__body {
  font-size: 13px;
  color: var(--fs-muted);
  margin: 0 0 14px;
  line-height: 1.4;
}
.formsies-confirm__actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

/* ---------------------------------------------------------------------
 * Full-width Formsies app shell.
 *
 * Wraps Command Center, Workflow Board, Edit Workspace, and the full
 * submissions inbox. Replaces the old `max-w-6xl mx-auto` containers so
 * Formsies pages occupy the working width like a real app surface,
 * without leaking to the rest of Pegasus.
 * ------------------------------------------------------------------ */
.formsies-app-shell {
  width: 100%;
  max-width: 1480px;
  margin: 0 auto;
  padding: 16px 24px 64px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
@media (max-width: 1024px) {
  .formsies-app-shell { padding: 14px 16px 56px; }
}
@media (max-width: 640px) {
  .formsies-app-shell { padding: 12px 12px 48px; gap: 14px; }
}

/* Inbox modal mockup-styled toolbar (search + filter chips). Sits inside
 * the modal between the head and the inbox body. */
.formsies-inbox-modal__toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  padding: 10px 16px;
  border-top: 1px solid var(--fs-line);
  border-bottom: 1px solid var(--fs-line);
  background: var(--fs-panel);
  min-width: 0;
  max-width: 100%;
}
[data-theme="dark"] .formsies-inbox-modal__toolbar,
.dark .formsies-inbox-modal__toolbar {
  background: rgba(2, 6, 23, 0.55);
}
.formsies-inbox-modal__search {
  position: relative;
  flex: 1 1 240px;
  max-width: 380px;
  min-width: 0;
}
@media (max-width: 520px) {
  .formsies-inbox-modal__search {
    flex: 1 1 100%;
    max-width: 100%;
  }
}
.formsies-inbox-modal__search input {
  width: 100%;
  padding: 8px 14px 8px 32px;
  border-radius: 999px;
  border: 1px solid var(--fs-line-strong);
  background: var(--fs-panel-muted);
  color: var(--fs-text);
  font-size: 13px;
  outline: none;
}
.formsies-inbox-modal__search::before {
  content: "🔍";
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 12px;
  opacity: 0.65;
  pointer-events: none;
}
.formsies-inbox-modal__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  min-width: 0;
  max-width: 100%;
}
@media (max-width: 520px) {
  .formsies-inbox-modal__chips {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
    padding-bottom: 2px;
    width: 100%;
    scroll-snap-type: x proximity;
  }
  .formsies-inbox-modal__chips::-webkit-scrollbar { display: none; }
  .formsies-inbox-modal__chip {
    scroll-snap-align: start;
    flex: 0 0 auto;
  }
}
.formsies-inbox-modal__chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid var(--fs-line);
  background: var(--fs-subtle);
  color: var(--fs-muted);
  font-size: 11px;
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
}
.formsies-inbox-modal__chip.is-active {
  background: var(--fs-primary-soft);
  color: var(--fs-primary);
  border-color: rgba(53, 208, 189, 0.28);
}
[data-theme="dark"] .formsies-inbox-modal__chip,
.dark .formsies-inbox-modal__chip {
  background: rgba(2, 6, 23, 0.55);
}

/* Mockup-style two-pane inbox layout */
.formsies-inbox-modal--full {
  padding: 0;
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 0;
}
.formsies-inbox-modal--full .formsies-inbox-modal__head {
  padding: 12px 18px;
  margin: 0;
  border-bottom: 1px solid var(--fs-line);
  background: var(--fs-panel);
}
[data-theme="dark"] .formsies-inbox-modal--full .formsies-inbox-modal__head,
.dark .formsies-inbox-modal--full .formsies-inbox-modal__head {
  background: rgba(2, 6, 23, 0.55);
}
.formsies-inbox-modal__grid {
  display: grid;
  grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
  flex: 1;
  min-height: 0;
  min-width: 0;
  background: var(--fs-panel-soft);
}
@media (max-width: 720px) {
  .formsies-inbox-modal__grid { grid-template-columns: 1fr; }
}
.formsies-inbox-modal__sidebar {
  border-right: 1px solid var(--fs-line);
  background: var(--fs-panel-soft);
  overflow-y: auto;
  list-style: none;
  margin: 0;
  padding: 0;
  min-width: 0;
}
@media (max-width: 720px) {
  .formsies-inbox-modal__sidebar {
    border-right: 0;
    border-bottom: 1px solid var(--fs-line);
    max-height: 40vh;
  }
}
[data-theme="dark"] .formsies-inbox-modal__sidebar,
.dark .formsies-inbox-modal__sidebar {
  background: rgba(2, 6, 23, 0.55);
}
.formsies-inbox-modal__sidebar > li + li {
  border-top: 1px solid var(--fs-line);
}
.formsies-inbox-modal__mailrow {
  display: grid;
  grid-template-columns: 14px minmax(0, 1fr) auto;
  gap: 8px 10px;
  align-items: start;
  width: 100%;
  border: 0;
  background: transparent;
  text-align: left;
  cursor: pointer;
  padding: 12px 14px;
  font-size: 13px;
  color: var(--fs-text);
  font-family: inherit;
  min-width: 0;
}
.formsies-inbox-modal__mailrow:hover {
  background: rgba(53, 208, 189, 0.04);
}
.formsies-inbox-modal__mailrow.is-active {
  background: var(--fs-primary-soft);
}
.formsies-inbox-modal__dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--fs-primary-2);
  margin-top: 6px;
  grid-column: 1 / 2;
  grid-row: 1 / 3;
}
.formsies-inbox-modal__dot.is-read {
  background: transparent;
  border: 1px solid var(--fs-line);
}
.formsies-inbox-modal__dot.is-spam {
  background: var(--fs-warn);
}
.formsies-inbox-modal__who {
  font-weight: 700;
  font-size: 13px;
  color: var(--fs-text);
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.formsies-inbox-modal__when {
  color: var(--fs-muted);
  font-size: 11px;
  white-space: nowrap;
  font-weight: 600;
}
.formsies-inbox-modal__email {
  color: var(--fs-muted);
  font-size: 12px;
  word-break: break-word;
  margin-top: 1px;
}
.formsies-inbox-modal__preview {
  color: var(--fs-text);
  font-size: 12px;
  line-height: 1.35;
  margin-top: 2px;
  word-break: break-word;
  opacity: 0.8;
}
.formsies-inbox-modal__rowtags {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 4px;
  grid-column: 2 / 4;
  margin-top: 4px;
}

.formsies-inbox-modal__detailpane {
  overflow-y: auto;
  padding: 22px 26px;
  background: var(--fs-panel-soft);
  min-width: 0;
}
@media (max-width: 720px) {
  .formsies-inbox-modal__detailpane {
    padding: 16px 14px;
  }
}
.formsies-inbox-modal__detailcard {
  display: none;
}
.formsies-inbox-modal__detailcard.is-active {
  display: block;
}
.formsies-inbox-modal__detail-title {
  margin: 0 0 4px;
  font-size: 18px;
  font-weight: 800;
  letter-spacing: -0.01em;
}
.formsies-inbox-modal__detail-from {
  color: var(--fs-muted);
  font-size: 13px;
  margin-bottom: 12px;
  overflow-wrap: anywhere;
  word-break: break-word;
}
[data-theme="dark"] .formsies-inbox-modal__detail-from,
.dark .formsies-inbox-modal__detail-from {
  color: var(--fs-muted-2);
}
.formsies-inbox-modal__detail-title {
  overflow-wrap: anywhere;
  word-break: break-word;
}
.formsies-inbox-modal__field-block {
  background: var(--fs-inset);
  border: 1px solid var(--fs-line);
  border-radius: 14px;
  padding: 10px 14px;
  margin-bottom: 10px;
}
[data-theme="dark"] .formsies-inbox-modal__field-block,
.dark .formsies-inbox-modal__field-block {
  background: rgba(2, 6, 23, 0.55);
}
.formsies-inbox-modal__field-block .lab {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--fs-muted);
  font-weight: 800;
  margin-bottom: 4px;
}
.formsies-inbox-modal__field-block p {
  margin: 0;
  font-size: 14px;
  line-height: 1.45;
  color: var(--fs-text);
  word-break: break-word;
}
.formsies-inbox-modal__meta {
  background: var(--fs-inset);
  border: 1px solid var(--fs-line);
  border-radius: 14px;
  padding: 10px 14px;
  margin-top: 12px;
  font-size: 12px;
  color: var(--fs-muted);
}
[data-theme="dark"] .formsies-inbox-modal__meta,
.dark .formsies-inbox-modal__meta {
  background: rgba(2, 6, 23, 0.55);
}
.formsies-inbox-modal__meta-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 4px 0;
  border-bottom: 1px dashed var(--fs-line);
  word-break: break-word;
  flex-wrap: wrap;
  min-width: 0;
}
.formsies-inbox-modal__meta-row > span {
  flex: 0 0 auto;
  color: var(--fs-muted);
}
.formsies-inbox-modal__meta-row > b {
  flex: 1 1 auto;
  min-width: 0;
  text-align: right;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.formsies-inbox-modal__meta-row:last-child { border-bottom: 0; }
.formsies-inbox-modal__meta-row b {
  color: var(--fs-text);
  font-weight: 700;
}
.formsies-inbox-modal__detail-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
  min-width: 0;
  max-width: 100%;
}
.formsies-inbox-modal__detail-actions form {
  margin: 0;
  display: inline-flex;
  min-width: 0;
  max-width: 100%;
}
.formsies-inbox-modal__detail-actions form > .btn,
.formsies-inbox-modal__detail-actions > a.btn,
.formsies-inbox-modal__detail-actions > .btn {
  flex: 0 1 auto;
  min-width: 0;
  max-width: 100%;
}
@media (max-width: 520px) {
  .formsies-inbox-modal__detail-actions {
    width: 100%;
  }
  .formsies-inbox-modal__detail-actions form,
  .formsies-inbox-modal__detail-actions form > .btn,
  .formsies-inbox-modal__detail-actions > a.btn,
  .formsies-inbox-modal__detail-actions > .btn {
    flex: 1 1 calc(50% - 8px);
  }
}

/* Generic full modal sizing tweaks for inbox/edit (wider). */
.formsies-modal--full .formsies-modal__dialog {
  max-width: 1280px;
  height: min(92vh, 900px);
  max-height: 92vh;
}

/* ---------------------------------------------------------------------
 * Edit workspace — full-screen split-screen edit experience.
 *
 * Used by button_form.html as the workflow editor. Layout:
 *   [   header (title, status, save)     ]
 *   [   top tabs                          ]
 *   [  editor (left)  |  preview (right) ]
 *   [   sticky save footer               ]
 * ------------------------------------------------------------------ */
.formsies-edit-workspace {
  display: flex;
  flex-direction: column;
  /* The element also carries the legacy `.formsies-studio` class, which sets
   * align-items: flex-start. Without this, the head / tab bar / footer shrink
   * to their content width instead of filling the card. Force stretch. */
  align-items: stretch;
  background: var(--fs-panel);
  border: 1px solid var(--fs-line);
  border-radius: 22px;
  box-shadow: var(--fs-shadow-sm);
  overflow: hidden;
}
.formsies-edit-workspace__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  padding: 14px 18px;
  border-bottom: 1px solid var(--fs-line);
  background: var(--fs-panel);
}
[data-theme="dark"] .formsies-edit-workspace__head,
.dark .formsies-edit-workspace__head {
  background: rgba(2, 6, 23, 0.55);
}
.formsies-edit-workspace__head h1 {
  margin: 0;
  font-size: 18px;
  letter-spacing: -0.02em;
  font-weight: 800;
}
.formsies-edit-workspace__eyebrow {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  color: var(--fs-faint);
  font-weight: 700;
  margin: 0 0 2px;
}
.formsies-edit-workspace__head-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

/* Section nav — vertical 216px rail (left column of the editor body). */
.formsies-edit-tabs {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 18px 12px;
  border-right: 1px solid var(--fs-line);
  background: var(--fs-page-2);
  min-width: 0;
}
.formsies-edit-tab {
  display: flex;
  align-items: center;
  gap: 9px;
  height: 38px;
  border: none;
  background: transparent;
  color: var(--fs-muted);
  font-size: 13px;
  font-weight: 500;
  padding: 0 12px;
  border-radius: 9px;
  cursor: pointer;
  text-align: left;
}
.formsies-edit-tab__dot {
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: var(--fs-faint);
  flex: 0 0 auto;
}
.formsies-edit-tab:hover { color: var(--fs-text); background: var(--fs-hover); }
.formsies-edit-tab.is-active {
  background: var(--fs-primary-soft);
  color: var(--fs-heading);
  font-weight: 600;
}
.formsies-edit-tab.is-active .formsies-edit-tab__dot { background: var(--fs-primary); }
.formsies-edit-tab__badge,
.formsies-tab-error-badge {
  display: inline-grid;
  place-items: center;
  min-width: 16px;
  height: 16px;
  padding: 0 5px;
  border-radius: 999px;
  background: var(--fs-danger);
  color: var(--fs-accent-deep);
  font-size: 10px;
  font-weight: 700;
  margin-left: auto;
}

.formsies-edit-workspace__body {
  display: grid;
  /* Preview column wide enough to show the real form/card at readable size
     (incl. desktop 2-column field layouts) without scaling. */
  grid-template-columns: 216px minmax(0, 1fr) 500px;
  align-items: stretch;
  min-height: 0;
}
@media (max-width: 1320px) {
  .formsies-edit-workspace__body { grid-template-columns: 200px minmax(0, 1fr) 440px; }
}
@media (max-width: 1080px) {
  .formsies-edit-workspace__body { grid-template-columns: 1fr; }
  .formsies-edit-tabs { flex-direction: row; flex-wrap: wrap; border-right: 0; border-bottom: 1px solid var(--fs-line); }
}

.formsies-edit-workspace__editor {
  padding: 28px 32px 60px;
  overflow-y: auto;
  background: var(--fs-panel);
  border-right: 1px solid var(--fs-line);
  min-width: 0;
}
.formsies-edit-workspace__editor > form { max-width: 640px; }
@media (max-width: 1080px) {
  .formsies-edit-workspace__editor {
    border-right: 0;
    border-bottom: 1px solid var(--fs-line);
    padding: 20px 18px 40px;
  }
}
.formsies-edit-workspace__preview {
  padding: 28px 24px 40px;
  overflow-y: auto;
  background: var(--fs-inset-2);            /* #0c1015 */
  border-left: 1px solid var(--fs-line);
  position: sticky;
  top: 0;
  align-self: stretch;
  min-width: 0;
}
@media (min-width: 1081px) {
  .formsies-edit-workspace__preview {
    max-height: calc(100vh - 80px);
  }
}

.formsies-edit-pane { display: none; }
.formsies-edit-pane.is-active { display: block; }
.formsies-edit-pane > * + * { margin-top: 14px; }

.formsies-edit-workspace__foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 12px 18px;
  border-top: 1px solid var(--fs-line);
  background: var(--fs-panel);
}
.formsies-edit-workspace__foot .actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

/* Dirty / saved indicators in the head. */
.formsies-edit__dirty { font-size: 11px; font-weight: 600; color: var(--fs-warn); }
.formsies-edit__saved { font-size: 11px; font-weight: 600; color: var(--fs-primary-2); }

/* Preview collapse (standalone editor): keep a slim preview rail so the
 * Show-preview toggle in the pane header stays reachable; the editor takes
 * the freed width. The detailed slim-rail styling lives in button_form.css. */
.formsies-edit-workspace.preview-collapsed .formsies-edit-workspace__body {
  grid-template-columns: 216px minmax(0, 1fr) max-content;
}

/* ---- 44×24 pill toggle ---- */
.formsies-toggle { display: inline-flex; flex: 0 0 auto; cursor: pointer; }
.formsies-toggle input { position: absolute; opacity: 0; width: 0; height: 0; }
.formsies-toggle__track {
  position: relative;
  width: 44px;
  height: 24px;
  border-radius: 999px;
  background: var(--fs-inset);
  border: 1px solid var(--fs-line-strong);
  transition: background 0.2s, border-color 0.2s;
}
.formsies-toggle__knob {
  position: absolute;
  top: 2px;
  left: 3px;
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: var(--fs-muted);
  transition: transform 0.2s, background 0.2s;
}
.formsies-toggle input:checked + .formsies-toggle__track {
  background: var(--fs-primary);
  border-color: var(--fs-primary);
}
.formsies-toggle input:checked + .formsies-toggle__track .formsies-toggle__knob {
  transform: translateX(20px);
  background: var(--fs-accent-deep);
}
.formsies-toggle input:disabled + .formsies-toggle__track { opacity: 0.5; }

/* ---- Toggle-row card ---- */
.formsies-toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 16px;
  border: 1px solid var(--fs-line);
  border-radius: 13px;
  background: var(--fs-panel);
  margin-bottom: 12px;
}
.formsies-toggle-row--plain { background: transparent; }
.formsies-toggle-row__label { font-size: 14px; font-weight: 600; color: var(--fs-heading); }
.formsies-toggle-row__desc { font-size: 12px; color: var(--fs-dim); margin-top: 2px; }

/* ---- Design swatch picker ---- */
.formsies-swatches { display: flex; gap: 10px; flex-wrap: wrap; }
.formsies-swatch {
  width: 34px;
  height: 34px;
  border-radius: 9px;
  background: var(--sw);
  border: 2px solid transparent;
  box-shadow: 0 0 0 1px var(--fs-line) inset;
  cursor: pointer;
}
.formsies-swatch.is-selected { border-color: #fff; }

/* ---- Danger zone ---- */
.formsies-danger-zone {
  border: 1px solid rgba(224,138,106,0.3);
  background: var(--fs-danger-soft);
  border-radius: 13px;
  padding: 16px;
}
.formsies-danger-zone__title { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: var(--fs-danger-2); margin: 0 0 4px; }
.formsies-danger-zone__desc { font-size: 12px; color: var(--fs-dim); margin: 0 0 10px; }
.formsies-studio__section-desc { font-size: 13px; color: var(--fs-dim); margin: 0 0 14px; }

/* ---------------------------------------------------------------------
 * Editor form sections (Messaging, Behavior) — design-handoff spec.
 * Scoped panel cards replacing the legacy rounded-2xl/base-300 styling.
 * ------------------------------------------------------------------ */
.formsies-form-section__title {
  font-family: var(--fs-font-display);
  font-size: 18px;
  font-weight: 600;
  color: var(--fs-heading);
  letter-spacing: -0.01em;
  margin: 0 0 4px;
}
.formsies-form-section__desc { font-size: 13px; color: var(--fs-dim); margin: 0 0 16px; }

.formsies-form-card {
  background: var(--fs-panel);
  border: 1px solid var(--fs-line);
  border-radius: 14px;
  padding: 16px 18px;
}
.formsies-form-card + .formsies-form-card { margin-top: 16px; }
.formsies-form-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}
.formsies-form-card__eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fs-muted);
}
/* Subtle text/outline "Clear availability" reset — deliberately not a destructive look. */
.formsies-form-card__clear {
  display: inline-flex;
  align-items: center;
  font-size: 11px;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 999px;
  background: transparent;
  color: var(--fs-muted);
  border: 1px solid var(--fs-line-strong);
  cursor: pointer;
  white-space: nowrap;
  transition: color 0.15s ease, border-color 0.15s ease;
}
.formsies-form-card__clear:hover {
  color: var(--fs-muted-2);
  border-color: var(--fs-muted);
}
.formsies-form-card__chip {
  display: inline-flex;
  align-items: center;
  font-size: 10px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 999px;
  background: var(--fs-primary-soft);
  color: var(--fs-primary-2);
  border: 1px solid var(--fs-primary-border);
  white-space: nowrap;
}
.formsies-form-card__label {
  display: block;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--fs-muted);
  margin-bottom: 6px;
}
.formsies-form-card__help { font-size: 11px; color: var(--fs-dim); margin: 8px 0 0; }
.formsies-form-card__grid {
  display: grid;
  gap: 16px;
}
@media (min-width: 640px) {
  .formsies-form-card__grid--split {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr);
  }
}

/* ---------------------------------------------------------------------
 * One-page dashboard layout.
 *
 * The Workflow Board page now also hosts the selected workflow's
 * Command Center pinned above the lanes. The dashboard wrapper just
 * tightens spacing so the two surfaces feel like one app.
 * ------------------------------------------------------------------ */
.formsies-dashboard {
  gap: 18px;
}
.formsies-dashboard__command {
  display: block;
  scroll-margin-top: 24px;
}
/* When the Command Center sits above the board, its outer panel already
 * brings its own border + radius via .formsies-command, so we don't need
 * extra wrapping chrome here. */
.formsies-dashboard__board-card {
  position: relative;
}

/* Highlight the selected card a little harder when sitting above its
 * Command Center. */
.formsies-dashboard .formsies-card.is-selected::before {
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  border: 2px solid rgba(53, 208, 189, 0.35);
  pointer-events: none;
}
.formsies-dashboard .formsies-card.is-selected::after {
  content: "";
  position: absolute;
  left: -1px;
  top: 14px;
  bottom: 14px;
  width: 4px;
  border-radius: 4px;
  background: linear-gradient(180deg, var(--fs-primary), var(--fs-primary-2));
  pointer-events: none;
}

.formsies-dashboard__command--placeholder { display: block; }
.formsies-dashboard__placeholder {
  border: 1px dashed var(--fs-line-strong);
  background: var(--fs-panel-soft);
  border-radius: 22px;
  padding: 18px 22px;
  text-align: center;
  color: var(--fs-muted);
  font-size: 13px;
}
.formsies-dashboard__placeholder-title {
  margin: 0 0 4px;
  font-size: 14px;
  font-weight: 800;
  color: var(--fs-text);
}
.formsies-dashboard__placeholder-body {
  margin: 0;
  font-size: 12px;
  line-height: 1.45;
}

.formsies-command.is-selected-anchor {
  border: 0;
  box-shadow: none;
}
.formsies-command__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  margin: 0;
  border-radius: 999px;
  background: var(--fs-primary-soft);
  border: 1px solid rgba(53, 208, 189, 0.28);
  color: var(--fs-primary);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  line-height: 1;
  max-width: 100%;
}
.formsies-command__eyebrow-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--fs-primary-2);
  flex-shrink: 0;
}
.formsies-command__eyebrow-sep {
  opacity: 0.55;
  font-weight: 700;
}
.formsies-command__eyebrow-name {
  text-transform: none;
  letter-spacing: 0;
  font-weight: 700;
  color: var(--fs-text);
  max-width: 60ch;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
[data-theme="dark"] .formsies-command__eyebrow,
.dark .formsies-command__eyebrow {
  background: rgba(53, 208, 189, 0.22);
  color: rgb(94, 234, 212);
  border-color: rgba(94, 234, 212, 0.38);
}
[data-theme="dark"] .formsies-command__eyebrow-name,
.dark .formsies-command__eyebrow-name {
  color: rgba(226, 232, 240, 0.96);
}

.formsies-empty-board {
  border: 1px dashed var(--fs-line-strong);
  background: var(--fs-panel-soft);
  border-radius: 22px;
  padding: 36px 24px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.formsies-empty-board__icon {
  font-size: 36px;
  line-height: 1;
  margin-bottom: 2px;
}
.formsies-empty-board__title {
  margin: 0;
  font-size: 15px;
  font-weight: 800;
  color: var(--fs-text);
}
.formsies-empty-board__body {
  margin: 0 auto 10px;
  max-width: 52ch;
  font-size: 12.5px;
  line-height: 1.5;
  color: var(--fs-muted);
}
.formsies-empty-board__hint {
  margin: 6px 0 0;
  font-size: 11px;
  color: var(--fs-muted-2);
}

@media (prefers-reduced-motion: reduce) {
  .formsies-dashboard__command { scroll-margin-top: 12px; }
}

/* Slim "switch workflow" hint shown over the lanes when a Command
 * Center is pinned above the board. Pure visual cue — no layout cost. */
.formsies-dashboard__switch-hint {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  color: var(--fs-muted);
  background: var(--fs-panel-muted);
  border: 1px solid var(--fs-line);
  border-radius: 999px;
  padding: 4px 10px;
  margin-bottom: 10px;
  font-weight: 700;
}

/* Inbox modal: prefer slightly more breathing room above by shrinking the
 * vertical padding so the head / toolbar / grid all share the visible
 * window. */
.formsies-modal--full .formsies-inbox-modal--full {
  height: 100%;
}

/* Dashboard inbox modal now reuses the full Inbox two-pane shell
 * (.formsies-inbox / _inbox_two_pane.html) so it matches the page exactly.
 * Fill the modal body and keep the header clear of the floating close (×). */
.formsies-modal--full .formsies-inbox--modal { height: 100%; }
.formsies-inbox--modal .formsies-inbox__head { padding-right: 64px; }

/* Inbox modal — webhook chip variant. */
.formsies-inbox-modal__chip[data-formsies-inbox-chip="webhook_failed"].is-active {
  background: rgba(224, 138, 106, 0.10);
  color: var(--fs-danger);
  border-color: rgba(224, 138, 106, 0.32);
}

/* Hide rows the chip filter has excluded. Keeps the layout calm and
 * avoids reflow flicker since we just toggle a class. */
.formsies-inbox-modal__sidebar > li.is-hidden { display: none; }

/* ---------------------------------------------------------------------
 * Full submission list — responsive polish for filter bar, bulk
 * toolbar, and card action rows. Scoped under .formsies-* wrappers so
 * the rules can't leak to other pages.
 * ------------------------------------------------------------------ */
.formsies-submission-filterbar,
.formsies-submission-bulkbar {
  min-width: 0;
  max-width: 100%;
}
.formsies-submission-filterbar .join {
  flex-wrap: wrap;
  max-width: 100%;
}
.formsies-submission-filterbar .join .btn {
  flex: 0 1 auto;
  min-width: 0;
}
@media (max-width: 640px) {
  .formsies-submission-filterbar .join { width: 100%; }
  .formsies-submission-filterbar .join .btn { flex: 1 1 calc(33% - 4px); }
}
.formsies-submission-bulkbar select,
.formsies-submission-bulkbar .btn {
  min-width: 0;
  max-width: 100%;
}
@media (max-width: 480px) {
  .formsies-submission-bulkbar select {
    flex: 1 1 100%;
    width: 100%;
  }
  .formsies-submission-bulkbar .btn {
    flex: 1 1 auto;
  }
}
.formsies-submission-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  min-width: 0;
  max-width: 100%;
}
.formsies-submission-card__actions form {
  margin: 0;
  display: inline-flex;
  min-width: 0;
  max-width: 100%;
}
.formsies-submission-card__actions form > .btn {
  flex: 0 1 auto;
  min-width: 0;
  max-width: 100%;
}
@media (max-width: 520px) {
  .formsies-submission-card__actions {
    width: 100%;
    justify-content: flex-start;
  }
  .formsies-submission-card__actions form,
  .formsies-submission-card__actions form > .btn {
    flex: 1 1 auto;
  }
}
.formsies-submission-card__source {
  overflow-wrap: anywhere;
  word-break: break-word;
  min-width: 0;
  max-width: 100%;
}

/* ---------------------------------------------------------------------
 * Edit Studio — responsive polish for head, tabs, body, foot.
 *
 * Top tabs scroll horizontally on narrow widths (instead of wrapping
 * into a tall block). Header and footer action rows wrap safely.
 * ------------------------------------------------------------------ */
.formsies-edit-workspace__head {
  min-width: 0;
}
.formsies-edit-workspace__head > div:first-child {
  flex: 1 1 240px;
  min-width: 0;
}
.formsies-edit-workspace__head h1 {
  overflow-wrap: anywhere;
  word-break: break-word;
}
.formsies-edit-workspace__head-actions {
  min-width: 0;
  max-width: 100%;
}
.formsies-edit-workspace__head-actions > .btn,
.formsies-edit-workspace__head-actions > a.btn {
  flex: 0 1 auto;
  min-width: 0;
  max-width: 100%;
}
@media (max-width: 520px) {
  .formsies-edit-workspace__head-actions {
    width: 100%;
  }
  .formsies-edit-workspace__head-actions > .btn,
  .formsies-edit-workspace__head-actions > a.btn {
    flex: 1 1 calc(50% - 8px);
  }
}

.formsies-edit-tabs {
  flex-wrap: nowrap;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  -ms-overflow-style: none;
  scroll-snap-type: x proximity;
  scroll-padding-inline: 12px;
  max-width: 100%;
  min-width: 0;
}
.formsies-edit-tabs::-webkit-scrollbar { display: none; }
.formsies-edit-tab {
  flex: 0 0 auto;
  scroll-snap-align: start;
  white-space: nowrap;
}

.formsies-edit-workspace__body {
  min-width: 0;
}
.formsies-edit-workspace__editor,
.formsies-edit-workspace__preview {
  min-width: 0;
  max-width: 100%;
}

.formsies-edit-workspace__foot {
  flex-wrap: wrap;
  min-width: 0;
}
.formsies-edit-workspace__foot > span {
  flex: 1 1 200px;
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.formsies-edit-workspace__foot .actions {
  min-width: 0;
  max-width: 100%;
}
.formsies-edit-workspace__foot .actions > .btn,
.formsies-edit-workspace__foot .actions > a.btn {
  flex: 0 1 auto;
  min-width: 0;
  max-width: 100%;
}
@media (max-width: 520px) {
  .formsies-edit-workspace__foot {
    flex-direction: column;
    align-items: stretch;
  }
  .formsies-edit-workspace__foot .actions {
    width: 100%;
  }
  .formsies-edit-workspace__foot .actions > .btn,
  .formsies-edit-workspace__foot .actions > a.btn {
    flex: 1 1 calc(50% - 8px);
  }
}

[data-theme="dark"] .formsies-edit-tabs,
.dark .formsies-edit-tabs {
  background: rgba(2, 6, 23, 0.4);
}
[data-theme="dark"] .formsies-edit-tab,
.dark .formsies-edit-tab {
  color: var(--fs-muted-2);
}
[data-theme="dark"] .formsies-edit-tab.is-active,
.dark .formsies-edit-tab.is-active {
  background: rgba(2, 6, 23, 0.6);
  color: rgb(94, 234, 212);
  border-color: rgba(94, 234, 212, 0.35);
  box-shadow: 0 -2px 0 rgba(94, 234, 212, 0.6) inset;
}

/* ---------------------------------------------------------------------
 * Webhook deliveries — responsive polish for header, summary, filters,
 * delivery table, and replay/retry action menus.
 * ------------------------------------------------------------------ */
.formsies-webhook-page {
  min-width: 0;
  max-width: 100%;
}
.formsies-webhook-header,
.formsies-webhook-header__row,
.formsies-webhook-header__text {
  min-width: 0;
}
.formsies-webhook-header__title {
  overflow-wrap: anywhere;
  word-break: break-word;
}
.formsies-webhook-summary {
  min-width: 0;
  max-width: 100%;
}
.formsies-webhook-summary__card {
  min-width: 0;
}
.formsies-webhook-health,
.formsies-webhook-health__grid {
  min-width: 0;
  max-width: 100%;
}
.formsies-webhook-filters {
  min-width: 0;
  max-width: 100%;
}
.formsies-webhook-filterbar {
  min-width: 0;
}
.formsies-webhook-filterbar__field {
  min-width: 0;
  max-width: 100%;
}
.formsies-webhook-filterbar__actions {
  min-width: 0;
  max-width: 100%;
}
.formsies-webhook-filterbar__actions > .btn,
.formsies-webhook-filterbar__actions > a.btn {
  flex: 0 1 auto;
  min-width: 0;
  max-width: 100%;
}
@media (max-width: 640px) {
  .formsies-webhook-filterbar {
    grid-template-columns: minmax(0, 1fr);
  }
  .formsies-webhook-filterbar__actions {
    width: 100%;
    justify-content: flex-start;
  }
  .formsies-webhook-filterbar__actions > .btn,
  .formsies-webhook-filterbar__actions > a.btn {
    flex: 1 1 auto;
  }
}

.formsies-webhook-deliveries {
  min-width: 0;
  max-width: 100%;
}
.formsies-webhook-table-wrap {
  -webkit-overflow-scrolling: touch;
  max-width: 100%;
}
.formsies-webhook-table {
  width: 100%;
  min-width: 860px;
}
/* Give delivery rows more vertical breathing room than table-sm so the
 * status badges + row actions don't feel cramped. */
.formsies-webhook-table > thead > tr > th {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  white-space: nowrap;
}
.formsies-webhook-table > tbody > tr.formsies-webhook-row > td {
  padding-top: 0.85rem;
  padding-bottom: 0.85rem;
  vertical-align: middle;
}
/* The expandable details row spans the full table width and carries no
 * default cell padding (the inner panel owns its own spacing). */
.formsies-webhook-detailrow > td {
  border-top: 0;
}
.formsies-webhook-detailpanel {
  min-width: 0;
  max-width: 100%;
}
.formsies-webhook-deflist {
  min-width: 0;
}
.formsies-webhook-deflist__row {
  overflow-wrap: anywhere;
  word-break: break-word;
}
.formsies-webhook-errorblock {
  min-width: 0;
  max-width: 100%;
  overflow-x: auto;
}
.formsies-webhook-rowactions {
  min-width: 0;
  max-width: 100%;
}
.formsies-webhook-cell--wrap {
  overflow-wrap: anywhere;
  word-break: break-word;
  max-width: 14rem;
}
.formsies-webhook-cell--error {
  overflow-wrap: anywhere;
  word-break: break-word;
}
.formsies-webhook-actions {
  display: inline-block;
  min-width: 0;
  max-width: 100%;
}
.formsies-webhook-actions__menu {
  max-width: calc(100vw - 32px);
}
.formsies-webhook-actions__meta {
  overflow-wrap: anywhere;
  word-break: break-word;
}
.formsies-webhook-actions__preview {
  overflow-wrap: anywhere;
  word-break: break-word;
}
.formsies-webhook-actions__forms > form {
  margin: 0;
  min-width: 0;
}
.formsies-webhook-docs {
  min-width: 0;
  max-width: 100%;
}
.formsies-webhook-docs__example {
  min-width: 0;
  max-width: 100%;
  overflow-x: auto;
}
.formsies-webhook-docs__example > pre {
  min-width: 0;
  max-width: 100%;
}
.formsies-webhook-empty {
  min-width: 0;
}

[data-theme="dark"] .formsies-webhook-actions__menu,
.dark .formsies-webhook-actions__menu {
  background: rgba(2, 6, 23, 0.95);
  border-color: rgba(148, 163, 184, 0.25);
}
[data-theme="dark"] .formsies-webhook-actions__preview,
.dark .formsies-webhook-actions__preview {
  background: rgba(15, 23, 42, 0.6);
  color: rgba(226, 232, 240, 0.92);
}

/* ---------------------------------------------------------------------
 * Notes section — wrap-safe form and note cards.
 * ------------------------------------------------------------------ */
.formsies-notes {
  min-width: 0;
  max-width: 100%;
}
.formsies-notes__head {
  min-width: 0;
}
.formsies-notes__form {
  min-width: 0;
}
.formsies-notes__field {
  min-width: 0;
  max-width: 100%;
}
.formsies-notes__field textarea,
.formsies-notes__field input[type="text"] {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
}
/* Notes composer — dark scoped textarea (the .fs-field stylesheet is only
 * loaded inside the Edit Studio, so the dashboard Notes tab styles its own). */
.formsies-notes__textarea {
  min-height: 140px;
  resize: vertical;
  background: var(--fs-inset);
  border: 1px solid var(--fs-line-strong);
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.35);
  color: var(--fs-text);
}
.formsies-notes__textarea::placeholder { color: var(--fs-placeholder); }
.formsies-notes__textarea:focus,
.formsies-notes__textarea:focus-visible {
  outline: none;
  border-color: var(--fs-focus);
  box-shadow:
    inset 0 1px 2px rgba(0, 0, 0, 0.35),
    0 0 0 3px rgba(53, 208, 189, 0.18);
}
.formsies-notes__form-actions {
  min-width: 0;
  max-width: 100%;
}
.formsies-notes__form-actions > .btn,
.formsies-notes__form-actions > .formsies-btn {
  flex: 0 1 auto;
  min-width: 0;
  max-width: 100%;
}
@media (max-width: 480px) {
  .formsies-notes__form-actions {
    justify-content: stretch;
  }
  .formsies-notes__form-actions > .btn,
  .formsies-notes__form-actions > .formsies-btn {
    flex: 1 1 auto;
  }
}
.formsies-notes__list {
  min-width: 0;
  max-width: 100%;
}
.formsies-notes__card {
  min-width: 0;
  max-width: 100%;
}
.formsies-notes__meta {
  min-width: 0;
}
.formsies-notes__author {
  overflow-wrap: anywhere;
  word-break: break-word;
  max-width: 100%;
}
.formsies-notes__body {
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* ---------------------------------------------------------------------
 * Activity panel rows — stack cleanly on phones, wrap long diffs.
 * ------------------------------------------------------------------ */
.formsies-activity-list {
  min-width: 0;
  max-width: 100%;
}
.formsies-activity-row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 6px 12px;
  padding: 8px 0;
  min-width: 0;
}
.formsies-activity-row__time {
  flex: 0 0 auto;
  color: var(--fs-muted);
  white-space: nowrap;
}
.formsies-activity-row__badge {
  flex: 0 0 auto;
  max-width: 100%;
  background: var(--fs-panel-muted);
  color: var(--fs-text-2);
  border: 1px solid var(--fs-line);
}
/* Activated reads as a positive/live change → teal tint. Other actions
 * (Deactivated, Updated, …) stay neutral. */
.formsies-activity-row__badge.is-activated {
  background: var(--fs-primary-soft);
  color: var(--fs-primary-2);
  border-color: var(--fs-primary-border);
}
.formsies-activity-row__body {
  flex: 1 1 220px;
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}
@media (max-width: 480px) {
  .formsies-activity-row {
    gap: 4px 8px;
  }
  .formsies-activity-row__body {
    flex-basis: 100%;
  }
}

/* ---------------------------------------------------------------------
 * Analytics chart cards — quick wrap-safe pass.
 * ------------------------------------------------------------------ */
.formsies-analytics-card {
  min-width: 0;
  max-width: 100%;
}
.formsies-analytics-card__head {
  min-width: 0;
}
.formsies-analytics-card__head h2 {
  overflow-wrap: anywhere;
  word-break: break-word;
}
.formsies-analytics-card__body {
  min-width: 0;
  max-width: 100%;
}
.formsies-analytics-card__body canvas {
  max-width: 100%;
}


/* =====================================================================
 * Full-screen app shell: persistent workflow rail + main content column.
 *
 * The authenticated Formsies app is a two-column workspace. The rail on the
 * left is the persistent workflow selector (always shows which workflow is
 * selected and lets you jump between them). On desktop it is a sticky
 * column; on mobile it collapses into an off-canvas drawer opened from the
 * rail bar. Everything is namespaced so it cannot leak to other pages.
 * ===================================================================== */
/* ---------------------------------------------------------------------
 * Branded top bar (56px) — replaces the generic Pegasus nav.
 * ------------------------------------------------------------------ */
.formsies-topbar {
  position: sticky;
  top: 0;
  z-index: 40;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 18px;
  background: var(--fs-page);
  border-bottom: 1px solid var(--fs-line);
}
.formsies-topbar__brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
}
.formsies-topbar__logo {
  width: 22px;
  height: 22px;
  border-radius: 7px;
  background: linear-gradient(140deg, #35d0bd, #1c9d8e);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.formsies-topbar__logo::after {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 2px;
  background: var(--fs-page);
}
.formsies-topbar__wordmark {
  font-family: var(--fs-font-display);
  font-weight: 600;
  font-size: 16px;
  letter-spacing: -0.01em;
  color: var(--fs-heading);
}
.formsies-topbar__right {
  display: flex;
  align-items: center;
  gap: 12px;
}
.formsies-topbar__switcher {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 34px;
  padding: 0 10px;
  border-radius: 9px;
  border: 1px solid var(--fs-line);
  background: var(--fs-panel);
  color: var(--fs-text-2);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}
.formsies-topbar__switcher:hover {
  background: var(--fs-hover);
  border-color: var(--fs-line-strong);
}
.formsies-topbar__ws-avatar {
  width: 20px;
  height: 20px;
  border-radius: 6px;
  background: linear-gradient(140deg, #35d0bd, #1c9d8e);
  color: var(--fs-accent-deep);
  font-size: 11px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.formsies-topbar__ws-name {
  max-width: 160px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.formsies-topbar__caret {
  color: var(--fs-faint);
  font-size: 11px;
}
.formsies-topbar__divider {
  width: 1px;
  height: 24px;
  background: var(--fs-line);
}
.formsies-topbar__avatar {
  width: 30px;
  height: 30px;
  border-radius: 999px;
  border: none;
  background: linear-gradient(135deg, #f0a868, #c5683a);
  color: #2a140a;
  font-size: 12px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.formsies-topbar__avatar:hover {
  filter: brightness(1.06);
}
/* Dark-surface dropdown menus opened from the top bar */
.formsies-topbar__menu {
  background: var(--fs-popover);
  border: 1px solid var(--fs-line);
  box-shadow: var(--fs-shadow);
}
.formsies-topbar__menu li > a,
.formsies-topbar__menu li > button {
  color: var(--fs-text-2);
}
.formsies-topbar__menu li > a:hover,
.formsies-topbar__menu li > button:hover {
  background: var(--fs-hover);
  color: var(--fs-heading);
}
.formsies-topbar__menu .menu-title > span {
  color: var(--fs-faint);
}

.formsies-workspace--no-rail {
  grid-template-columns: 1fr !important;
}
.formsies-workspace {
  --fs-nav-h: 56px;
  --fs-rail-w: 288px;
  display: grid;
  grid-template-columns: var(--fs-rail-w) minmax(0, 1fr);
  width: 100%;
  min-height: calc(100vh - var(--fs-nav-h));
  background: linear-gradient(180deg, var(--fs-page), var(--fs-page-2));
}
[data-theme="dark"] .formsies-workspace,
.dark .formsies-workspace {
  background: transparent;
}
.formsies-workspace__main {
  min-width: 0;
  display: flex;
  flex-direction: column;
}

/* ---- Rail (desktop sticky column) ---- */
.formsies-rail {
  position: sticky;
  top: var(--fs-nav-h);
  align-self: start;
  height: calc(100vh - var(--fs-nav-h));
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 16px 12px;
  border-right: 1px solid var(--fs-line);
  background: var(--fs-panel-soft);
  overflow-y: auto;
  z-index: 20;
}
.formsies-rail__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 4px;
}
.formsies-rail__heading {
  display: flex;
  align-items: center;
  gap: 8px;
}
.formsies-rail__title {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--fs-faint);
}
.formsies-rail__count {
  font-family: var(--fs-font-mono);
  font-size: 11px;
  color: var(--fs-faint-2);
}
.formsies-rail__close {
  display: none;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 9px;
  border: 1px solid var(--fs-line);
  background: var(--fs-panel-muted);
  color: var(--fs-muted);
  font-size: 14px;
  cursor: pointer;
}
.formsies-rail__create {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  height: 38px;
  padding: 0 12px;
  border-radius: 10px;
  background: var(--fs-primary-soft);
  color: var(--fs-primary-2);
  border: 1px dashed var(--fs-primary-border);
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
}
.formsies-rail__create:hover {
  background: rgba(53, 208, 189, 0.16);
}
.formsies-rail__create.is-disabled {
  opacity: 0.5;
  cursor: not-allowed;
  filter: none;
}
.formsies-rail__filter {
  position: relative;
  padding: 2px 0;
}
.formsies-rail__filter-icon {
  position: absolute;
  left: 11px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--fs-placeholder);
  font-size: 13px;
  pointer-events: none;
}
.formsies-rail__filter-input {
  width: 100%;
  height: 36px;
  padding: 0 12px 0 30px;
  border-radius: 9px;
  border: 1px solid var(--fs-line-strong);
  background: var(--fs-subtle);
  color: var(--fs-text);
  font-size: 13px;
  outline: none;
}
.formsies-rail__filter-input::placeholder { color: var(--fs-placeholder); }
.formsies-rail__filter-input:focus {
  border-color: var(--fs-focus);
  background: var(--fs-hover);
}
.formsies-rail__list {
  display: flex;
  flex-direction: column;
  gap: 0;
  min-height: 0;
}
.formsies-rail__group {
  margin-bottom: 18px;
}
.formsies-rail__group-head {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 6px 8px;
}
.formsies-rail__group-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.formsies-rail__group-count {
  font-family: var(--fs-font-mono);
  font-size: 10px;
  color: var(--fs-placeholder);
}
.formsies-rail__group-rule {
  flex: 1;
  height: 1px;
  background: rgba(255, 255, 255, 0.05);
}
.formsies-rail__group-items {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.formsies-rail__item {
  display: flex;
  align-items: center;
  gap: 10px;
  height: 38px;
  padding: 0 12px;
  border-radius: 9px;
  text-decoration: none;
  color: var(--fs-text-2);
  border: 1px solid transparent;
  min-width: 0;
  transition: background 0.12s ease, border-color 0.12s ease;
}
.formsies-rail__item:hover {
  background: var(--fs-hover);
}
.formsies-rail__item.is-selected {
  background: var(--fs-primary-soft);
  border-color: var(--fs-primary-border);
}
.formsies-rail__item.is-selected .formsies-rail__name {
  color: var(--fs-heading);
  font-weight: 600;
}
.formsies-rail__item.is-archived .formsies-rail__name {
  color: var(--fs-dim);
}
.formsies-rail__dot {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  flex: 0 0 7px;
}
/* Live toggle on, but public access expired/scheduled/closed: muted amber, never green. */
.formsies-rail__dot.is-unavailable {
  background: var(--fs-warn);
}
.formsies-rail__dot.is-status-expired {
  background: var(--fs-danger);
}
.formsies-rail__name {
  flex: 1 1 auto;
  min-width: 0;
  font-size: 13.5px;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.formsies-rail__badges {
  display: flex;
  align-items: center;
  gap: 6px;
  flex: 0 0 auto;
}
.formsies-rail__count-mono {
  font-family: var(--fs-font-mono);
  font-size: 11px;
  color: var(--fs-faint-2);
}
.formsies-rail__flag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
}
.formsies-rail__flag.is-warn {
  background: var(--fs-warn-soft);
  color: var(--fs-warn);
}
.formsies-rail__flag.is-setup {
  background: var(--fs-panel-muted);
  color: var(--fs-muted);
}
.formsies-rail__empty {
  padding: 18px 10px;
  text-align: center;
}
.formsies-rail__empty-title {
  font-weight: 700;
  font-size: 13px;
}
.formsies-rail__empty-body {
  font-size: 12px;
  color: var(--fs-muted);
  margin-top: 4px;
}
.formsies-rail__no-matches {
  padding: 14px 10px;
  text-align: center;
  font-size: 12px;
  color: var(--fs-muted);
}

/* ---- Rail bar (mobile-only header that opens the drawer) ---- */
.formsies-railbar {
  display: none;
}
.formsies-railbar__toggle {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 10px 14px;
  background: var(--fs-panel);
  border: 0;
  border-bottom: 1px solid var(--fs-line);
  cursor: pointer;
  text-align: left;
}
.formsies-railbar__toggle-icon {
  font-size: 18px;
  line-height: 1;
  color: var(--fs-muted);
}
.formsies-railbar__labels {
  display: flex;
  flex-direction: column;
  min-width: 0;
  flex: 1 1 auto;
}
.formsies-railbar__eyebrow {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--fs-muted-2);
}
.formsies-railbar__current {
  font-size: 14px;
  font-weight: 700;
  color: var(--fs-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.formsies-railbar__chevron {
  color: var(--fs-muted);
  font-size: 12px;
}

/* ---- Mobile drawer behavior ---- */
.formsies-workspace__backdrop {
  display: none;
}
@media (max-width: 1024px) {
  .formsies-workspace {
    grid-template-columns: minmax(0, 1fr);
  }
  .formsies-railbar {
    display: flex;
    position: sticky;
    top: 0;
    z-index: 30;
  }
  .formsies-rail {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    height: 100vh;
    width: min(86vw, 320px);
    transform: translateX(-100%);
    transition: transform 0.22s ease;
    box-shadow: var(--fs-shadow);
    z-index: 60;
    /* As an overlay drawer the rail must be opaque so page content behind it
     * doesn't bleed through (the sticky desktop column can stay translucent). */
    background: var(--fs-page-2);
  }
  [data-theme="dark"] .formsies-rail,
  .dark .formsies-rail {
    background: #0b1220;
  }
  .formsies-workspace.rail-open .formsies-rail {
    transform: translateX(0);
  }
  .formsies-rail__close {
    display: inline-flex;
  }
  .formsies-workspace.rail-open .formsies-workspace__backdrop {
    display: block;
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.45);
    z-index: 50;
  }
}

/* ---------------------------------------------------------------------
 * Shared helpers previously inlined per-template (now centralized so every
 * Formsies app-shell page picks them up identically).
 * ------------------------------------------------------------------ */
.formsies-scope .fs-info {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  border-radius: 9999px;
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  transition: all 0.15s ease;
}
.formsies-scope .fs-info--glass {
  background: hsl(var(--b1) / 0.55);
  border: 1px solid hsl(var(--bc) / 0.18);
  color: hsl(var(--bc) / 0.7);
  backdrop-filter: blur(10px);
}
.formsies-scope .fs-info--glass:hover {
  background: hsl(var(--b1) / 0.75);
  transform: translateY(-1px);
}
.formsies-scope .fs-panel {
  background: var(--fs-panel);
  border: 1px solid var(--fs-line);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
}
[data-theme="dark"] .formsies-scope .fs-panel,
.dark .formsies-scope .fs-panel {
  background: rgba(2, 6, 23, 0.55);
  border-color: rgba(148, 163, 184, 0.2);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
}
.formsies-scope .fs-muted {
  color: color-mix(in oklab, currentColor 65%, transparent);
}
.formsies-scope .fs-divider {
  border-top: 1px solid color-mix(in oklab, currentColor 12%, transparent);
}

/* =====================================================================
 * Command Center — redesign (dark "command surface" handoff)
 * Header, status pill, buttons, overflow menu, hero metrics, funnel,
 * share strip. Mirrors prototypes/Formsies Dashboard.dc.html.
 * ================================================================== */

/* ---- Command header ----
 * One compact band: workflow title + status (left), main tabs (middle),
 * overflow actions (far right). The tabs used to live in a separate
 * full-width row below; they now sit inline here so the editor starts
 * much higher. */
.formsies-cmd {
  display: flex;
  align-items: center;
  gap: 10px 20px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}
.formsies-cmd__titlewrap { min-width: 0; flex: 0 1 auto; }
.formsies-cmd__titlerow {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.formsies-cmd__title {
  font-family: var(--fs-font-display);
  font-weight: 600;
  font-size: 21px;
  letter-spacing: -0.02em;
  margin: 0;
  color: var(--fs-heading);
  overflow-wrap: anywhere;
}
/* Tabs sit inline in the header band — drop the standalone row's border,
 * bottom margin, and grow them to fill the space between title and actions. */
.formsies-cmd .formsies-tabs-wrap {
  flex: 1 1 auto;
  align-items: center;
  margin: 0;
  border-bottom: 0;
}
@media (max-width: 640px) {
  /* Tablet/mobile: tabs wrap to their own line under the title, compactly. */
  .formsies-cmd .formsies-tabs-wrap {
    flex-basis: 100%;
    margin: 2px 0 0;
  }
}
.formsies-cmd__meta {
  display: flex;
  align-items: center;
  gap: 10px;
  row-gap: 4px;
  flex-wrap: wrap;
  font-size: 12.5px;
  color: var(--fs-dim);
}
.formsies-cmd__meta-sep { color: #3d4751; }
.formsies-cmd__slug { color: var(--fs-faint); font-family: var(--fs-font-mono); }
.formsies-cmd__color { display: inline-flex; align-items: center; gap: 5px; }
.formsies-cmd__swatch {
  width: 9px; height: 9px; border-radius: 3px;
  border: 1px solid rgba(255, 255, 255, 0.15);
}
.formsies-cmd__actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 0 0 auto;
}

/* ---- Status pill ---- */
.formsies-statuspill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 24px;
  padding: 0 10px;
  border-radius: 7px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.02em;
  border: 1px solid transparent;
}
.formsies-statuspill__dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.formsies-statuspill.is-live {
  background: rgba(53, 208, 189, 0.12);
  color: var(--fs-primary);
  border-color: var(--fs-primary-border);
}
.formsies-statuspill.is-draft {
  background: rgba(255, 255, 255, 0.05);
  color: var(--fs-muted);
  border-color: rgba(255, 255, 255, 0.1);
}
.formsies-statuspill.is-archived {
  background: rgba(255, 255, 255, 0.04);
  color: var(--fs-dim);
  border-color: rgba(255, 255, 255, 0.08);
}
.formsies-statuspill.is-scheduled {
  background: rgba(99, 102, 241, 0.12);
  color: #a5b4fc;
  border-color: rgba(99, 102, 241, 0.35);
}
.formsies-statuspill.is-expired {
  background: rgba(248, 113, 113, 0.1);
  color: #fca5a5;
  border-color: rgba(248, 113, 113, 0.3);
}
.formsies-statuspill.is-closed {
  background: rgba(251, 191, 36, 0.1);
  color: #fcd34d;
  border-color: rgba(251, 191, 36, 0.3);
}

/* ---- Recurring schedule editor ---- */
.formsies-daypill {
  display: inline-flex;
  align-items: center;
  cursor: pointer;
  user-select: none;
  padding: 5px 11px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 600;
  color: var(--fs-muted);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.1);
}
.formsies-daypill input { position: absolute; opacity: 0; pointer-events: none; }
.formsies-daypill.is-on {
  color: var(--fs-primary);
  background: rgba(53, 208, 189, 0.12);
  border-color: var(--fs-primary-border);
}
.formsies-perday-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 2px;
}
.formsies-perday-row__day { width: 3.5rem; font-size: 13px; font-weight: 600; }
.formsies-perday-row__closed { display: none; }
.formsies-perday-row.is-closed input[type="time"] { opacity: 0.4; pointer-events: none; }
.formsies-perday-row.is-closed .formsies-perday-row__closed { display: inline; }
.formsies-toggle--sm { transform: scale(0.85); transform-origin: left center; }

/* ---- Basics availability summary ---- */
.formsies-basics-status {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 14px;
  margin-bottom: 16px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.03);
}
.formsies-basics-status__main {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
.formsies-basics-status__text {
  font-size: 12px;
  color: var(--fs-muted);
}

/* ---- Embed setup guide (help page) ---- */
.formsies-cmd__subtitle { margin: 2px 0 0; }
.fs-help-chip {
  display: inline-flex;
  align-items: center;
  padding: 6px 13px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  color: var(--fs-muted);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.1);
  transition: color .12s ease, border-color .12s ease, background .12s ease;
}
.fs-help-chip:hover {
  color: var(--fs-primary);
  background: rgba(53, 208, 189, 0.12);
  border-color: var(--fs-primary-border);
}
.fs-help-card {
  scroll-margin-top: 16px;
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.025);
  padding: 22px;
}
.fs-help-card__title {
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--fs-text, #f8fafc);
  margin: 0 0 12px;
}
.fs-help-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--fs-muted);
  margin: 16px 0 6px;
}
.fs-help-text { font-size: 13px; line-height: 1.55; color: var(--fs-muted); margin: 0 0 4px; }
.fs-help-steps, .fs-help-list { margin: 4px 0 4px; padding-left: 20px; }
.fs-help-steps { list-style: decimal; }
.fs-help-list { list-style: disc; }
.fs-help-steps > li, .fs-help-list > li {
  font-size: 13px;
  line-height: 1.55;
  color: var(--fs-muted);
  margin-bottom: 4px;
}
.fs-help-step {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  color: var(--fs-primary);
  background: rgba(53, 208, 189, 0.14);
  border: 1px solid var(--fs-primary-border);
}
.fs-help-note {
  margin: 12px 0 6px;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.03);
}
.fs-help-note--warn {
  border-color: rgba(251, 191, 36, 0.3);
  background: rgba(251, 191, 36, 0.08);
}
.fs-help-note__title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--fs-dim, #cbd5e1);
  margin: 0 0 6px;
}
.fs-help-note .fs-help-list { margin-bottom: 0; }
.fs-help-code {
  margin: 6px 0;
  padding: 12px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(0, 0, 0, 0.28);
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 12px;
  line-height: 1.55;
  white-space: pre;
  overflow-x: auto;
  max-height: 220px;
}

/* ---- Buttons (handoff style) ---- */
.formsies-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  height: 36px;
  padding: 0 16px;
  border-radius: 9px;
  border: 1px solid transparent;
  font-size: 13px;
  font-weight: 600;
  font-family: inherit;
  text-decoration: none;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}
.formsies-btn--sm { height: 30px; padding: 0 12px; font-size: 12px; border-radius: 8px; }
.formsies-btn--icon { width: 36px; padding: 0; font-size: 16px; line-height: 1; }
.formsies-btn--primary {
  background: var(--fs-primary);
  color: var(--fs-accent-deep);
  font-weight: 700;
}
.formsies-btn--primary:hover { background: var(--fs-primary-hover); }
.formsies-btn--accent {
  background: var(--fs-primary-soft);
  color: var(--fs-primary-2);
  border-color: var(--fs-primary-border);
}
.formsies-btn--accent:hover { background: rgba(53, 208, 189, 0.18); }
.formsies-btn--ghost {
  background: var(--fs-subtle);
  color: var(--fs-text-2);
  border-color: rgba(255, 255, 255, 0.09);
}
.formsies-btn--ghost:hover { background: var(--fs-hover); }
.formsies-btn__badge {
  background: var(--fs-primary);
  color: var(--fs-accent-deep);
  font-family: var(--fs-font-mono);
  font-size: 10px;
  font-weight: 700;
  border-radius: 5px;
  padding: 1px 5px;
}

/* ---- Overflow menu (details/summary) ---- */
.formsies-overflow { position: relative; }
.formsies-overflow > summary { list-style: none; }
.formsies-overflow > summary::-webkit-details-marker { display: none; }
.formsies-overflow__menu {
  position: absolute;
  right: 0;
  top: 42px;
  width: 210px;
  background: var(--fs-popover);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 12px;
  padding: 6px;
  box-shadow: var(--fs-shadow);
  z-index: 40;
}
.formsies-overflow__item {
  width: 100%;
  text-align: left;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 10px;
  border-radius: 8px;
  border: none;
  background: transparent;
  color: var(--fs-text-2);
  font-size: 13px;
  font-family: inherit;
  cursor: pointer;
  text-decoration: none;
}
.formsies-overflow__item:hover { background: rgba(255, 255, 255, 0.06); }
.formsies-overflow__item.is-danger { color: var(--fs-danger); }
.formsies-overflow__item.is-danger:hover { background: var(--fs-danger-soft); }
.formsies-overflow__item.is-accent { color: var(--fs-primary-2); }
.formsies-overflow__sep { height: 1px; background: rgba(255, 255, 255, 0.08); margin: 5px 6px; }
.formsies-overflow__count {
  font-family: var(--fs-font-mono);
  font-size: 10px;
  background: var(--fs-warn-soft);
  color: var(--fs-warn);
  border-radius: 5px;
  padding: 0 5px;
}

/* ---- Generic panels / insets ---- */
.formsies-panel {
  background: var(--fs-panel);
  border: 1px solid var(--fs-line);
  border-radius: 16px;
  padding: 22px 24px;
  margin-bottom: 16px;
}
.formsies-panel__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 18px;
}
.formsies-panel__title { font-size: 13px; font-weight: 600; color: var(--fs-text); }
.formsies-panel__sub { font-size: 12px; color: var(--fs-dim); margin-top: 2px; }
.formsies-inset {
  background: var(--fs-inset);
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: 10px;
}
.formsies-link-btn {
  font-size: 12px;
  color: var(--fs-primary-2);
  background: none;
  border: none;
  cursor: pointer;
  font-family: inherit;
  font-weight: 600;
}

/* ---- Hero metrics grid ---- */
.formsies-hero-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 16px;
  margin-bottom: 16px;
}
.formsies-hero-side { display: flex; flex-direction: column; gap: 16px; }
.formsies-statcard {
  background: var(--fs-panel);
  border: 1px solid var(--fs-line);
  border-radius: 16px;
  padding: 18px 20px;
}
.formsies-statcard--hero {
  padding: 22px 24px;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.formsies-hero-side .formsies-statcard { flex: 1; }
.formsies-statcard__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 4px;
}
.formsies-statcard__eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--fs-faint);
}
.formsies-statcard__range { font-size: 11px; color: var(--fs-faint-2); }
.formsies-statcard__value {
  font-family: var(--fs-font-display);
  font-weight: 600;
  font-size: 34px;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--fs-heading);
  margin-top: 8px;
}
.formsies-statcard__note { font-size: 12px; color: var(--fs-dim); margin-top: 6px; }
.formsies-statcard__lockrow { display: flex; align-items: center; gap: 10px; margin-top: 8px; }
.formsies-statcard__lock { font-size: 11px; color: var(--fs-faint); }
.formsies-statcard__upgrade { font-size: 11px; color: var(--fs-primary-2); text-decoration: none; }
.formsies-statcard.is-locked .formsies-statcard__value { color: var(--fs-faint); }

.formsies-hero__metricrow { display: flex; align-items: flex-end; gap: 14px; }
.formsies-hero__metric {
  font-family: var(--fs-font-display);
  font-weight: 600;
  font-size: 52px;
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--fs-heading);
}
.formsies-hero__delta {
  padding-bottom: 7px;
  font-size: 12px;
  font-weight: 600;
}
.formsies-hero__delta.is-up { color: var(--fs-primary); }
.formsies-hero__delta.is-down { color: var(--fs-danger); }
.formsies-hero__delta.is-flat { color: var(--fs-faint-2); }
.formsies-hero__sub {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-top: 14px;
  font-size: 12.5px;
  color: var(--fs-muted-2);
  flex-wrap: wrap;
}
.formsies-hero__sub-strong { color: var(--fs-text-2); font-weight: 600; }
.formsies-hero__sub-sep { color: #3d4751; }
.formsies-hero__spark { margin-top: auto; padding-top: 18px; height: 56px; min-height: 44px; }
.formsies-hero__spark canvas { width: 100%; height: 100%; display: block; }

/* ---- Engagement funnel ---- */
.formsies-funnel__rows { display: flex; flex-direction: column; gap: 14px; }
.formsies-funnel__row {
  display: grid;
  grid-template-columns: 108px 1fr 110px;
  align-items: center;
  gap: 14px;
}
.formsies-funnel__label { font-size: 12.5px; color: var(--fs-muted); font-weight: 500; }
.formsies-funnel__track {
  height: 26px;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 7px;
  overflow: hidden;
}
.formsies-funnel__bar {
  height: 100%;
  border-radius: 7px;
  transition: width 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.formsies-funnel__bar.is-neutral { background: rgba(255, 255, 255, 0.16); }
.formsies-funnel__bar.is-neutral2 { background: rgba(255, 255, 255, 0.22); }
.formsies-funnel__bar.is-tealsoft { background: rgba(53, 208, 189, 0.45); }
.formsies-funnel__bar.is-teal { background: var(--fs-primary); }
.formsies-funnel__val { text-align: right; font-size: 13px; color: var(--fs-text); }
.formsies-funnel__pct { font-size: 11px; color: var(--fs-faint-2); }
.formsies-funnel__locked {
  margin-top: 16px;
  padding: 12px 14px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--fs-line);
  border-radius: 10px;
  font-size: 12px;
  color: var(--fs-muted-2);
}
.formsies-funnel__locked a { color: var(--fs-primary-2); text-decoration: none; }

/* ---- Share & embed strip ---- */
.formsies-share { margin-bottom: 0; }
.formsies-share__row { display: flex; align-items: stretch; gap: 10px; flex-wrap: wrap; }
.formsies-share__snippet {
  flex: 1;
  min-width: 280px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
}
.formsies-share__snippet code {
  flex: 1;
  font-family: var(--fs-font-mono);
  font-size: 12px;
  color: #9fd9d0;
  overflow-x: auto;
  white-space: nowrap;
}
.formsies-share__link {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 6px 0 14px;
}
.formsies-share__link .formsies-mono { font-size: 12px; color: var(--fs-muted-2); }

@media (max-width: 760px) {
  .formsies-hero-grid { grid-template-columns: 1fr; }
}

/* =====================================================================
 * Inbox — full-page two-pane layout (list + detail). Design handoff.
 * ================================================================== */
/* Fill the main area so the panes scroll internally (overflow hidden body). */
.formsies-workspace--inbox .formsies-app-shell {
  height: calc(100vh - var(--fs-nav-h));
  max-width: none;
  margin: 0;
  padding: 0;
  gap: 0;
}
.formsies-inbox {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 0;
}

/* ---- Sub-header ---- */
.formsies-inbox__head {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 28px;
  border-bottom: 1px solid var(--fs-line);
  flex: 0 0 auto;
}
.formsies-inbox__back {
  width: 34px;
  height: 34px;
  border-radius: 9px;
  border: 1px solid var(--fs-line);
  background: var(--fs-panel);
  color: var(--fs-text-2);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  text-decoration: none;
  flex: 0 0 auto;
}
.formsies-inbox__back:hover { background: var(--fs-hover); color: var(--fs-heading); }
.formsies-inbox__heading { min-width: 0; }
.formsies-inbox__title-row { display: flex; align-items: center; gap: 10px; }
.formsies-inbox__title {
  font-family: var(--fs-font-display);
  font-weight: 600;
  font-size: 21px;
  letter-spacing: -0.02em;
  color: var(--fs-heading);
  margin: 0;
}
.formsies-inbox__count { font-size: 12px; color: var(--fs-faint); }
.formsies-inbox__head-actions { margin-left: auto; display: flex; gap: 8px; }

/* Mobile: the sub-header crams a 2-line title, status pill, count and two
   action buttons into one flex row, so they collide. Let it wrap and push
   the actions onto their own full-width row with comfortable tap targets. */
@media (max-width: 640px) {
  .formsies-inbox__head {
    flex-wrap: wrap;
    padding: 12px 16px;
    gap: 10px 12px;
  }
  .formsies-inbox__heading { flex: 1 1 auto; }
  .formsies-inbox__title-row { flex-wrap: wrap; gap: 8px; }
  .formsies-inbox__title { font-size: 18px; }
  .formsies-inbox__head-actions { margin-left: 0; width: 100%; flex-wrap: wrap; }
  .formsies-inbox__head-actions .formsies-btn { flex: 1 1 auto; justify-content: center; }
}

/* "Back to list" control — only meaningful in the mobile detail overlay. */
.formsies-inbox__detail-back {
  display: none;
  align-items: center;
  gap: 6px;
  margin-bottom: 18px;
  padding: 8px 12px;
  border-radius: 9px;
  border: 1px solid var(--fs-line);
  background: var(--fs-panel);
  color: var(--fs-text-2);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
}

/* ---- Body grid ---- */
.formsies-inbox__body {
  flex: 1 1 auto;
  min-height: 0;
  display: grid;
  grid-template-columns: 396px minmax(0, 1fr);
}

/* ---- List pane ---- */
.formsies-inbox__list {
  min-height: 0;
  overflow-y: auto;
  background: var(--fs-page-2);
  border-right: 1px solid var(--fs-line);
  display: flex;
  flex-direction: column;
}
.formsies-inbox__list-head {
  position: sticky;
  top: 0;
  z-index: 2;
  background: var(--fs-page-2);
  padding: 14px 14px 10px;
  border-bottom: 1px solid var(--fs-line);
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.formsies-inbox__search { position: relative; }
.formsies-inbox__search-icon {
  position: absolute;
  left: 11px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--fs-faint);
  font-size: 14px;
}
.formsies-inbox__search-input {
  width: 100%;
  height: 38px;
  border-radius: 9px;
  border: 1px solid var(--fs-line-strong);
  background: var(--fs-inset);
  color: var(--fs-text);
  padding: 0 12px 0 32px;
  font-size: 13px;
}
.formsies-inbox__search-input::placeholder { color: var(--fs-placeholder); }
.formsies-inbox__search-input:focus { outline: none; border-color: var(--fs-focus); }
.formsies-inbox__chips { display: flex; gap: 6px; flex-wrap: wrap; }
.formsies-inbox__chip-n { opacity: 0.7; font-variant-numeric: tabular-nums; }
.formsies-inbox__trash-link {
  font-size: 11px;
  color: var(--fs-faint);
  text-decoration: none;
  align-self: flex-start;
}
.formsies-inbox__trash-link:hover { color: var(--fs-text-2); }

.formsies-inbox__rows { display: flex; flex-direction: column; }
.formsies-inbox__row {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 13px;
  border: none;
  border-bottom: 1px solid var(--fs-line);
  border-left: 2px solid transparent;
  background: transparent;
  text-align: left;
  cursor: pointer;
  width: 100%;
}
.formsies-inbox__row:hover { background: var(--fs-hover); }
.formsies-inbox__row.is-active {
  background: var(--fs-primary-soft);
  border-left-color: var(--fs-primary);
}
.formsies-inbox__row-main { min-width: 0; flex: 1; }
.formsies-inbox__row-top { display: flex; align-items: baseline; justify-content: space-between; gap: 8px; }
.formsies-inbox__row-name {
  font-size: 13.5px;
  color: var(--fs-text-2);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.formsies-inbox__row-name.is-unread { color: var(--fs-heading); font-weight: 600; }
.formsies-inbox__row-time { font-size: 11px; color: var(--fs-faint); flex: 0 0 auto; }
.formsies-inbox__row-sub { display: flex; align-items: center; gap: 6px; margin-top: 2px; }
.formsies-inbox__row-email {
  font-size: 12px;
  color: var(--fs-muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
}
.formsies-inbox__row-star { color: var(--fs-warn); font-size: 12px; }
.formsies-inbox__no-matches,
.formsies-inbox__empty { padding: 24px 14px; color: var(--fs-faint); font-size: 13px; text-align: center; }

/* ---- Avatars (5-color tint palette) ---- */
.formsies-ibx-avatar {
  position: relative;
  width: 36px;
  height: 36px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  flex: 0 0 auto;
}
.formsies-ibx-avatar--lg { width: 48px; height: 48px; font-size: 15px; }
.formsies-ibx-avatar__dot {
  position: absolute;
  top: -1px;
  right: -1px;
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: var(--fs-primary);
  border: 2px solid var(--fs-page-2);
}
.formsies-ibx-avatar--teal   { background: rgba(53,208,189,0.16);  color: var(--fs-primary-2); }
.formsies-ibx-avatar--indigo { background: rgba(99,102,241,0.18);  color: var(--fs-purple-2); }
.formsies-ibx-avatar--green  { background: rgba(31,157,87,0.18);   color: var(--fs-green-2); }
.formsies-ibx-avatar--amber  { background: rgba(224,161,60,0.18);  color: var(--fs-warn-2); }
.formsies-ibx-avatar--coral  { background: rgba(224,138,106,0.18); color: var(--fs-danger-2); }

/* ---- Detail pane ---- */
.formsies-inbox__detail {
  min-height: 0;
  overflow-y: auto;
  padding: 32px 36px 60px;
}
.formsies-inbox__detail-card { max-width: 720px; margin: 0 auto; }
.formsies-inbox__detail-card.is-hidden { display: none; }
.formsies-inbox__detail-head { display: flex; align-items: flex-start; gap: 14px; margin-bottom: 22px; }
.formsies-inbox__detail-id { min-width: 0; flex: 1; }
.formsies-inbox__detail-name {
  font-family: var(--fs-font-display);
  font-weight: 600;
  font-size: 20px;
  letter-spacing: -0.02em;
  color: var(--fs-heading);
  margin: 0;
}
.formsies-inbox__detail-meta { font-size: 13px; color: var(--fs-muted); margin: 3px 0 0; }
.formsies-inbox__detail-actions { display: flex; align-items: center; gap: 8px; flex: 0 0 auto; }
.formsies-inbox__star-btn {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  border: 1px solid var(--fs-line);
  background: var(--fs-panel);
  color: var(--fs-faint);
  font-size: 15px;
  cursor: pointer;
}
.formsies-inbox__star-btn.is-on { color: var(--fs-warn); border-color: rgba(224,161,60,0.4); }
.formsies-inbox__icon-btn {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  border: 1px solid var(--fs-line);
  background: var(--fs-panel);
  color: var(--fs-muted);
  font-size: 14px;
  cursor: pointer;
}
.formsies-inbox__icon-btn--danger:hover { color: var(--fs-danger); border-color: rgba(224,138,106,0.4); }

.formsies-inbox__answers { padding: 18px 20px; }
.formsies-inbox__answers-head { margin-bottom: 12px; }
.formsies-inbox__answer-row {
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr);
  gap: 14px;
  padding: 10px 0;
  border-top: 1px solid var(--fs-line);
}
.formsies-inbox__answer-row:first-of-type { border-top: none; }
.formsies-inbox__answer-label { font-size: 13px; color: var(--fs-muted); }
.formsies-inbox__answer-value { font-size: 13.5px; color: var(--fs-text); word-break: break-word; }
.formsies-inbox__consent-yes { color: var(--fs-primary-2); }
.formsies-inbox__consent-no { color: var(--fs-danger-2); }
.formsies-inbox__answer-empty { color: var(--fs-faint); font-size: 13px; }

.formsies-inbox__detail-foot-actions { display: flex; gap: 10px; margin: 20px 0 16px; }
.formsies-inbox__detail-metadata { font-size: 11.5px; color: var(--fs-faint-2); }
.formsies-inbox__detail-empty,
.formsies-inbox__detail-foot-actions:empty { color: var(--fs-faint); }
.formsies-inbox__detail-empty { display: grid; place-items: center; height: 100%; color: var(--fs-faint); }

/* danger button variant (used in inbox + danger zone) */
.formsies-btn--danger {
  border-color: rgba(224,138,106,0.4);
  color: var(--fs-danger-2);
}
.formsies-btn--danger:hover { background: var(--fs-danger-soft); }

/* ---- Trash compact list ---- */
.formsies-inbox__trash { overflow-y: auto; padding: 20px 28px 60px; }
.formsies-inbox__trash-tabs { display: flex; gap: 8px; margin-bottom: 16px; }
.formsies-inbox__trash-card { padding: 14px 16px; margin-bottom: 10px; }
.formsies-inbox__trash-card-head { display: flex; justify-content: space-between; gap: 10px; margin-bottom: 10px; color: var(--fs-text-2); font-size: 13px; }
.formsies-inbox__trash-card-head .font-mono { color: var(--fs-faint); font-size: 11px; }
.formsies-inbox__trash-card-actions { display: flex; gap: 8px; }

@media (max-width: 860px) {
  /* Single column: the list fills the width. The detail pane is NOT removed
     (that left mobile users unable to read a submission) — instead it slides
     in as a full-screen overlay when a row is tapped (root .is-detail-open),
     with a Back control to return to the list. */
  .formsies-inbox__body { grid-template-columns: 1fr; }
  .formsies-inbox__detail {
    position: fixed;
    inset: var(--fs-nav-h) 0 0 0;
    z-index: 40;
    background: var(--fs-page);
    border-left: 0;
    transform: translateX(100%);
    transition: transform 0.22s ease;
    padding: 20px 18px 60px;
  }
  .formsies-inbox.is-detail-open .formsies-inbox__detail { transform: translateX(0); }
  .formsies-inbox__detail-back { display: inline-flex; }
  /* Detail action buttons wrap rather than overflow on narrow screens. */
  .formsies-inbox__detail-head { flex-wrap: wrap; }
  .formsies-inbox__detail-actions { flex-wrap: wrap; }
}

.formsies-sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.formsies-inbox__pager {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px;
  border-top: 1px solid var(--fs-line);
}
.formsies-inbox__pager-label { font-size: 12px; color: var(--fs-faint); }
.formsies-inbox__date-error {
  font-size: 12px;
  color: var(--fs-danger-2);
  background: var(--fs-danger-soft);
  border: 1px solid rgba(224,138,106,0.3);
  border-radius: 8px;
  padding: 8px 10px;
  margin: 0;
}
.formsies-inbox__spamseg { display: inline-flex; border: 1px solid var(--fs-line); border-radius: 8px; overflow: hidden; align-self: flex-start; }
.formsies-inbox__spamseg-item { font-size: 11px; padding: 4px 9px; color: var(--fs-faint); text-decoration: none; border-right: 1px solid var(--fs-line); }
.formsies-inbox__spamseg-item:last-child { border-right: none; }
.formsies-inbox__spamseg-item:hover { background: var(--fs-hover); color: var(--fs-text-2); }
.formsies-inbox__spamseg-item.is-active { background: var(--fs-primary-soft); color: var(--fs-primary-2); }

/* Edit Studio head-left group: 34px back arrow + title block. */
.formsies-edit-workspace__headleft { display: flex; align-items: flex-start; gap: 12px; min-width: 0; }

/* Square 42px color swatch masking the native color input (design handoff). */
.formsies-color-swatch {
  width: 42px;
  height: 42px;
  padding: 0;
  border: 1px solid var(--fs-line-strong);
  border-radius: 10px;
  background: transparent;
  cursor: pointer;
  overflow: hidden;
}
.formsies-color-swatch::-webkit-color-swatch-wrapper { padding: 0; }
.formsies-color-swatch::-webkit-color-swatch { border: none; border-radius: 9px; }
.formsies-color-swatch::-moz-color-swatch { border: none; border-radius: 9px; }

/* ---------------------------------------------------------------------
 * Account / Workspace settings section pages (Profile, Workspace Settings).
 * Reuses the editor's section-nav chrome (.formsies-edit-tab) plus the
 * existing form cards (.formsies-form-card / .fs-field / .formsies-btn).
 * ------------------------------------------------------------------ */
.formsies-acct { display: flex; flex-direction: column; min-height: 0; }
.formsies-acct__head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  padding: 22px 28px;
  border-bottom: 1px solid var(--fs-line);
}
.formsies-acct__eyebrow {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  color: var(--fs-faint);
  font-weight: 700;
  margin: 0 0 4px;
}
.formsies-acct__title {
  font-family: var(--fs-font-display);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--fs-heading);
  margin: 0;
}
.formsies-acct__headmeta { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.formsies-acct__pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 600;
  color: var(--fs-muted);
  background: var(--fs-panel-muted);
  border: 1px solid var(--fs-line);
  border-radius: 999px;
  padding: 4px 10px;
}
.formsies-acct__pill--role {
  color: var(--fs-primary-2);
  background: var(--fs-primary-soft);
  border-color: var(--fs-primary-border);
}
.formsies-acct__slug { font-family: var(--fs-font-mono); font-size: 11px; color: var(--fs-muted-2); }

.formsies-acct__body {
  display: grid;
  grid-template-columns: 232px minmax(0, 1fr);
  align-items: start;
  min-height: 0;
}
@media (max-width: 880px) {
  .formsies-acct__body { grid-template-columns: 1fr; }
}
.formsies-acct__nav {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 18px 12px;
  border-right: 1px solid var(--fs-line);
  background: var(--fs-page-2);
}
@media (max-width: 880px) {
  .formsies-acct__nav {
    border-right: 0;
    border-bottom: 1px solid var(--fs-line);
    flex-direction: row;
    flex-wrap: wrap;
  }
}
.formsies-acct__nav-foot {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--fs-line);
  display: flex;
  flex-direction: column;
  gap: 2px;
}
@media (max-width: 880px) {
  .formsies-acct__nav-foot {
    margin-top: 0;
    padding-top: 0;
    border-top: 0;
    flex-direction: row;
    width: 100%;
  }
}
.formsies-acct__nav-link {
  display: flex;
  align-items: center;
  gap: 9px;
  height: 36px;
  padding: 0 12px;
  border-radius: 9px;
  color: var(--fs-muted);
  font-size: 13px;
  font-weight: 500;
  text-decoration: none;
}
.formsies-acct__nav-link:hover { color: var(--fs-text); background: var(--fs-hover); }
.formsies-acct__nav-link--danger { color: var(--fs-danger); }
.formsies-acct__nav-link--danger:hover { color: var(--fs-danger-2); background: var(--fs-danger-soft); }

.formsies-acct__content {
  padding: 24px 28px 64px;
  min-width: 0;
  max-width: 880px;
}
.formsies-acct__flash {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  color: var(--fs-success);
  background: var(--fs-primary-soft);
  border: 1px solid var(--fs-primary-border);
  border-radius: 999px;
  padding: 5px 12px;
  margin-bottom: 14px;
}
.formsies-acct__flash.error,
.formsies-acct__flash.warning {
  color: var(--fs-danger);
  background: var(--fs-danger-soft);
  border-color: rgba(224, 138, 106, 0.3);
}

/* Avatar (64px) — uploaded image or tinted initials. */
.formsies-acct__avatar {
  width: 64px;
  height: 64px;
  flex: 0 0 auto;
  border-radius: 999px;
  overflow: hidden;
  display: inline-grid;
  place-items: center;
  font-family: var(--fs-font-display);
  font-weight: 600;
  font-size: 22px;
  color: var(--fs-primary-2);
  background: var(--fs-primary-soft);
  border: 1px solid var(--fs-primary-border);
}
.formsies-acct__avatar img { width: 100%; height: 100%; object-fit: cover; }
.formsies-acct__avatar-row { display: flex; align-items: center; gap: 16px; }
.formsies-acct__avatar-actions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 8px; }

/* Form grid helpers for the details/general cards. */
.formsies-acct__field-grid {
  display: grid;
  gap: 14px;
}
@media (min-width: 560px) {
  .formsies-acct__field-grid--2 { grid-template-columns: 1fr 1fr; }
}
.formsies-acct__card-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--fs-line);
}
.formsies-acct__hint { font-size: 11px; color: var(--fs-dim); }

/* ---- Profile: Security rows + Connected accounts ---- */
.formsies-acct__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}
.formsies-acct__row-title {
  font-size: 13.5px;
  font-weight: 600;
  color: var(--fs-text);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.formsies-acct__row-desc { font-size: 12px; color: var(--fs-dim); margin-top: 3px; }
.formsies-acct__badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 999px;
}
.formsies-acct__badge.is-on {
  color: var(--fs-primary-2);
  background: var(--fs-primary-soft);
  border: 1px solid var(--fs-primary-border);
}
.formsies-acct__badge.is-off {
  color: var(--fs-muted);
  background: var(--fs-panel-muted);
  border: 1px solid var(--fs-line);
}
.formsies-acct__provider,
.formsies-acct__keyrow {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 0;
  border-top: 1px solid var(--fs-line);
}
.formsies-acct__provider:first-of-type,
.formsies-acct__keyrow:first-of-type { border-top: 0; padding-top: 4px; }
.formsies-acct__provider-icon,
.formsies-acct__keyrow-icon {
  width: 34px;
  height: 34px;
  flex: 0 0 auto;
  border-radius: 9px;
  display: inline-grid;
  place-items: center;
  background: var(--fs-panel-muted);
  border: 1px solid var(--fs-line);
  color: var(--fs-text-2);
  font-weight: 700;
  font-size: 13px;
}
.formsies-acct__provider-main,
.formsies-acct__keyrow-main { min-width: 0; flex: 1; }
.formsies-acct__provider-name,
.formsies-acct__keyrow-name { font-size: 13px; font-weight: 600; color: var(--fs-text); }
.formsies-acct__provider-sub { font-size: 11.5px; color: var(--fs-muted); }
.formsies-acct__keyrow-meta { font-size: 11px; color: var(--fs-faint); margin-top: 2px; }
.formsies-acct__keyrow-mask { font-family: var(--fs-font-mono); font-size: 12px; color: var(--fs-muted-2); }
.formsies-acct__revoke {
  flex: 0 0 auto;
  height: 32px;
  padding: 0 12px;
  border-radius: 8px;
  border: 1px solid var(--fs-line);
  background: transparent;
  color: var(--fs-muted);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  font-family: inherit;
}
.formsies-acct__revoke:hover { color: var(--fs-danger); border-color: rgba(224, 138, 106, 0.3); }

/* ---- Profile: API key reveal banner + create form ---- */
.formsies-acct__reveal {
  background: var(--fs-primary-soft);
  border: 1px solid var(--fs-primary-border);
  border-radius: 13px;
  padding: 14px 16px;
  margin-bottom: 16px;
}
.formsies-acct__reveal-title { font-size: 12.5px; font-weight: 600; color: var(--fs-primary-2); }
.formsies-acct__reveal-desc { font-size: 12px; color: var(--fs-muted); margin: 4px 0 10px; }
.formsies-acct__reveal-row { display: flex; gap: 8px; align-items: stretch; }
.formsies-acct__reveal-code {
  flex: 1;
  min-width: 0;
  font-family: var(--fs-font-mono);
  font-size: 12.5px;
  color: var(--fs-text);
  background: var(--fs-inset-2);
  border: 1px solid var(--fs-line);
  border-radius: 9px;
  padding: 10px 12px;
  overflow-x: auto;
  white-space: nowrap;
}
.formsies-acct__chips { display: flex; flex-wrap: wrap; gap: 8px; }
.formsies-acct__chip {
  display: inline-flex;
  align-items: center;
  cursor: pointer;
  height: 32px;
  padding: 0 14px;
  border-radius: 999px;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--fs-muted);
  background: var(--fs-panel-muted);
  border: 1px solid var(--fs-line);
  user-select: none;
}
.formsies-acct__chip input { position: absolute; opacity: 0; width: 1px; height: 1px; }
.formsies-acct__chip.is-on {
  color: var(--fs-primary-2);
  background: var(--fs-primary-soft);
  border-color: var(--fs-primary-border);
}
.formsies-acct__chip:focus-within { box-shadow: 0 0 0 3px rgba(53, 208, 189, 0.18); }
.formsies-acct__empty {
  border: 1px dashed var(--fs-line-strong);
  border-radius: 12px;
  padding: 22px 16px;
  text-align: center;
}
.formsies-acct__empty-title { font-size: 13.5px; font-weight: 600; color: var(--fs-text-2); }
.formsies-acct__empty-desc { font-size: 12px; color: var(--fs-dim); margin-top: 2px; }
.formsies-btn[disabled], .formsies-btn:disabled { opacity: 0.45; cursor: not-allowed; }

/* ---- Workspace settings: General URL preview + create-workspace layout ---- */
.formsies-acct__urlchip {
  display: inline-flex;
  align-items: center;
  font-family: var(--fs-font-mono);
  font-size: 12px;
  color: var(--fs-muted-2);
  background: var(--fs-panel-muted);
  border: 1px solid var(--fs-line);
  border-radius: 8px;
  padding: 6px 10px;
  margin-top: 8px;
}
.formsies-acct__urlchip b { color: var(--fs-primary-2); font-weight: 600; }
.formsies-acct__create { max-width: 460px; margin: 56px auto; padding: 0 20px; }

/* ---- Workspace settings: Members + pending invitations ---- */
.formsies-acct__memberrow,
.formsies-acct__pendingrow {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 0;
  border-top: 1px solid var(--fs-line);
}
.formsies-acct__memberrow:first-of-type,
.formsies-acct__pendingrow:first-of-type { border-top: 0; padding-top: 4px; }
.formsies-acct__member-main { min-width: 0; flex: 1; }
.formsies-acct__member-name { font-size: 13px; font-weight: 600; color: var(--fs-text); }
.formsies-acct__member-you { color: var(--fs-muted); font-weight: 500; }
.formsies-acct__member-email,
.formsies-acct__pending-sub {
  font-family: var(--fs-font-mono);
  font-size: 11.5px;
  color: var(--fs-muted-2);
  margin-top: 2px;
}
.formsies-acct__pending-sub { font-family: inherit; color: var(--fs-muted); }
.formsies-acct__member-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 0 0 auto;
}
.formsies-acct__roleselect {
  height: 32px;
  padding: 0 10px;
  border-radius: 8px;
  font-size: 12px;
  min-height: 0;
}
.formsies-acct__iconbtn {
  width: 32px;
  height: 32px;
  flex: 0 0 auto;
  border-radius: 8px;
  border: 1px solid var(--fs-line);
  background: transparent;
  color: var(--fs-muted);
  cursor: pointer;
  font-size: 13px;
  line-height: 1;
}
.formsies-acct__iconbtn:hover { color: var(--fs-danger); border-color: rgba(224, 138, 106, 0.3); }

/* Mobile: a member row packs avatar + name/email + role-select + remove into a
   ~240px card, which crushes the name/email to a few px and overlaps the
   controls. The invite form's inline 3-column grid likewise collapses the
   email field. Below 560px, stack the controls onto their own full-width row. */
@media (max-width: 560px) {
  .formsies-acct__memberrow,
  .formsies-acct__pendingrow { flex-wrap: wrap; row-gap: 10px; }
  .formsies-acct__member-main { flex: 1 1 60%; }
  .formsies-acct__member-actions {
    flex: 1 1 100%;
    margin-left: 48px;        /* clear the avatar so actions align under the name */
    justify-content: flex-start;
  }
  .formsies-acct__member-actions form { flex: 1 1 auto; }
  .formsies-acct__roleselect { width: 100%; }
  .formsies-acct__inviteform .formsies-acct__field-grid {
    grid-template-columns: 1fr !important;
  }
}
.formsies-acct__pending-icon {
  width: 34px;
  height: 34px;
  flex: 0 0 auto;
  border-radius: 9px;
  display: inline-grid;
  place-items: center;
  background: var(--fs-panel-muted);
  border: 1px solid var(--fs-line);
  color: var(--fs-muted);
  font-size: 14px;
}
.formsies-acct__sent { font-size: 12px; font-weight: 600; color: var(--fs-primary-2); }

/* ---- Workspace settings: Danger zone tab + delete-confirm modal ---- */
.formsies-acct__nav .formsies-edit-tab[data-formsies-tab="danger"].is-active {
  background: var(--fs-danger-soft);
  color: var(--fs-danger-2);
}
.formsies-acct__nav .formsies-edit-tab[data-formsies-tab="danger"].is-active .formsies-edit-tab__dot {
  background: var(--fs-danger);
}
.formsies-acct__modalbody { padding: 22px 24px; }
.formsies-acct__modal-title {
  font-family: var(--fs-font-display);
  font-size: 17px;
  font-weight: 600;
  color: var(--fs-heading);
  margin: 0 0 6px;
}
.formsies-acct__modal-text { font-size: 13px; color: var(--fs-muted); margin: 0 0 14px; }
.formsies-acct__modal-text b { color: var(--fs-danger-2); font-family: var(--fs-font-mono); }
.formsies-acct__modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 18px;
}

/* Editor create mode: the "Draft" pill reads as not-yet-created (amber/warn),
 * distinct from the neutral is-draft used for inactive existing workflows. */
.formsies-statuspill.formsies-statuspill--new {
  background: var(--fs-warn-soft);
  color: var(--fs-warn-2);
  border-color: rgba(224, 161, 60, 0.3);
}

/* ---------------------------------------------------------------------
 * Workflows index (/a/<team>/buttons/) — the no-workflow-selected surface.
 * Sub-header + grouped board of workflow cards, or first-run empty state.
 * ------------------------------------------------------------------ */
.formsies-subhead {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 26px;
}
.formsies-subhead__titlewrap { min-width: 0; }
.formsies-subhead__eyebrow {
  margin: 0 0 4px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--fs-faint);
}
.formsies-subhead__titlerow {
  display: flex;
  align-items: baseline;
  gap: 10px;
  flex-wrap: wrap;
}
.formsies-subhead__title {
  font-family: var(--fs-font-display);
  font-weight: 600;
  font-size: 21px;
  letter-spacing: -0.02em;
  margin: 0;
  color: var(--fs-heading);
}
.formsies-subhead__count {
  font-size: 12px;
  color: var(--fs-faint);
}
.formsies-subhead__cta { flex: 0 0 auto; }

/* ---- Board ---- */
.formsies-wfboard { display: flex; flex-direction: column; gap: 30px; }
.formsies-wfgroup { min-width: 0; }
.formsies-wfgroup__head {
  display: flex;
  align-items: center;
  gap: 9px;
  margin-bottom: 14px;
}
.formsies-wfgroup__dot { width: 8px; height: 8px; border-radius: 50%; flex: 0 0 auto; }
.formsies-wfgroup__label {
  font-family: var(--fs-font-display);
  font-size: 15px;
  font-weight: 600;
  color: var(--fs-heading);
  margin: 0;
}
.formsies-wfgroup__count {
  font-size: 12px;
  color: var(--fs-faint);
}
.formsies-wfgroup__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 14px;
  align-items: start;
}

/* ---- Workflow card ---- */
.formsies-wfcard {
  display: flex;
  flex-direction: column;
  min-width: 0;
  background: var(--fs-panel);
  border: 1px solid var(--fs-line);
  border-radius: 14px;
  padding: 18px;
  transition: border-color 0.15s ease, transform 0.15s ease;
}
.formsies-wfcard:hover {
  border-color: rgba(53, 208, 189, 0.28);
  transform: translateY(-1px);
}
.formsies-wfcard.is-archived { opacity: 0.72; }
.formsies-wfcard__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 14px;
}
.formsies-wfcard__ident { min-width: 0; }
.formsies-wfcard__namerow {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 4px;
}
.formsies-wfcard__dot {
  width: 9px; height: 9px; border-radius: 3px; flex: 0 0 auto;
  border: 1px solid rgba(255, 255, 255, 0.15);
}
.formsies-wfcard__name {
  font-family: var(--fs-font-display);
  font-size: 15px;
  font-weight: 600;
  color: var(--fs-heading);
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.formsies-wfcard__meta {
  margin: 0;
  font-size: 12px;
  color: var(--fs-dim);
  overflow: hidden;
  text-overflow: ellipsis;
}
.formsies-wfcard__meta-sep { color: #3d4751; }
.formsies-wfcard__slug { color: var(--fs-faint); }
.formsies-wfcard__unread {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  height: 20px;
  padding: 0 7px;
  border-radius: 999px;
  background: rgba(53, 208, 189, 0.14);
  color: var(--fs-primary-2);
  font-family: var(--fs-font-mono);
  font-size: 11px;
  font-weight: 700;
}
.formsies-wfcard__stats {
  display: flex;
  gap: 18px;
  margin: 0 0 14px;
  padding: 12px 0;
  border-top: 1px solid var(--fs-line);
  border-bottom: 1px solid var(--fs-line);
}
.formsies-wfcard__stat { min-width: 0; }
.formsies-wfcard__statnum {
  font-family: var(--fs-font-display);
  font-size: 20px;
  font-weight: 600;
  color: var(--fs-heading);
  font-variant-numeric: tabular-nums;
  margin: 0;
}
.formsies-wfcard__statnum.is-soft { color: var(--fs-text-2); }
.formsies-wfcard__statlabel {
  font-size: 11px;
  color: var(--fs-faint);
  margin-top: 2px;
}
.formsies-wfcard__foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-top: auto;
}
.formsies-wfcard__updated {
  font-size: 11.5px;
  color: var(--fs-faint-2);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.formsies-wfcard__actions { display: flex; gap: 6px; flex: 0 0 auto; }
.formsies-wfcard__action {
  display: inline-flex;
  align-items: center;
  height: 30px;
  padding: 0 11px;
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.09);
  background: var(--fs-subtle);
  color: var(--fs-text-2);
  font-size: 12px;
  font-weight: 500;
  text-decoration: none;
  transition: background 0.15s ease, color 0.15s ease;
}
.formsies-wfcard__action:hover { background: var(--fs-hover); }
.formsies-wfcard__action--open {
  padding: 0 12px;
  border-color: transparent;
  background: rgba(53, 208, 189, 0.12);
  color: var(--fs-primary-2);
  font-weight: 600;
}
.formsies-wfcard__action--open:hover { background: rgba(53, 208, 189, 0.2); }

/* ---- First-run empty state ---- */
.formsies-firstrun {
  max-width: 720px;
  margin: 40px auto 0;
  text-align: center;
}
.formsies-firstrun__icon {
  width: 76px; height: 76px;
  border-radius: 22px;
  background: rgba(53, 208, 189, 0.1);
  border: 1px solid rgba(53, 208, 189, 0.22);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 34px;
  margin: 0 auto 22px;
}
.formsies-firstrun__title {
  font-family: var(--fs-font-display);
  font-size: 24px;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--fs-heading);
  margin: 0 0 10px;
}
.formsies-firstrun__body {
  font-size: 14px;
  color: var(--fs-muted);
  line-height: 1.6;
  margin: 0 auto 28px;
  max-width: 480px;
}
.formsies-firstrun__steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  text-align: left;
  margin: 0 0 30px;
  padding: 0;
  list-style: none;
}
.formsies-firstrun__step {
  display: flex;
  flex-direction: column;
  background: var(--fs-panel);
  border: 1px solid var(--fs-line);
  border-radius: 14px;
  padding: 18px;
}
.formsies-firstrun__step-n {
  width: 28px; height: 28px;
  border-radius: 8px;
  background: rgba(53, 208, 189, 0.12);
  color: var(--fs-primary-2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--fs-font-display);
  font-weight: 700;
  font-size: 13px;
  margin-bottom: 12px;
}
.formsies-firstrun__step-title {
  font-size: 13.5px;
  font-weight: 600;
  color: var(--fs-heading);
  margin-bottom: 5px;
}
.formsies-firstrun__step-body {
  font-size: 12.5px;
  color: var(--fs-dim);
  line-height: 1.5;
}
.formsies-firstrun__cta { display: inline-flex; height: 44px; padding: 0 24px; }
.formsies-firstrun__hint {
  margin: 14px 0 0;
  font-size: 11.5px;
  color: var(--fs-muted-2);
}

/* ---- Responsive: collapse to a single column with no overflow ---- */
@media (max-width: 700px) {
  .formsies-subhead {
    align-items: flex-start;
    flex-direction: column;
  }
  .formsies-subhead__cta { width: 100%; }
  .formsies-wfgroup__grid { grid-template-columns: 1fr; }
  .formsies-wfcard__foot { flex-wrap: wrap; }
  .formsies-firstrun__steps { grid-template-columns: 1fr; }
}

/* ---------------------------------------------------------------------
 * Authentication screens (Phase 9) — sign in, sign up, accept invite.
 * A self-contained centered-card shell on the dark gradient, independent
 * of the app rail/shell. Lives inside .formsies-scope so the --fs-* tokens
 * resolve; restyles the existing allauth/Pegasus templates only.
 * ------------------------------------------------------------------ */
.formsies-auth {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 18px;
  padding: 40px 20px 56px;
  background:
    radial-gradient(1200px 700px at 50% -200px, rgba(53, 208, 189, 0.07), transparent 60%),
    #0b0f14;
  color: var(--fs-text);
  font-family: var(--fs-font-body);
}
.formsies-auth__wrap {
  width: 100%;
  max-width: 420px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

/* Themed Django messages (logout notices, invite errors, etc.) */
.formsies-auth__alert {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 11px 14px;
  border-radius: 11px;
  font-size: 13px;
  line-height: 1.45;
  background: var(--fs-panel);
  border: 1px solid var(--fs-line-strong);
  color: var(--fs-text);
}
.formsies-auth__alert.is-error {
  background: var(--fs-danger-soft);
  border-color: rgba(224, 138, 106, 0.35);
  color: var(--fs-danger-2);
}
.formsies-auth__alert.is-success {
  background: var(--fs-primary-soft);
  border-color: var(--fs-primary-border);
  color: var(--fs-primary-2);
}
.formsies-auth__alert.is-warning {
  background: var(--fs-warn-soft);
  border-color: rgba(224, 161, 60, 0.35);
  color: var(--fs-warn-2);
}

/* ---- Card ---- */
.formsies-auth__card {
  background: var(--fs-page);
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: 18px;
  overflow: hidden;
}
.formsies-auth__body { padding: 38px 34px 30px; }
/* Small phones (iPhone SE etc.): trim the generous card padding and outer
   gutter so the form fields keep a comfortable width. */
@media (max-width: 400px) {
  .formsies-auth { padding: 28px 14px 40px; }
  .formsies-auth__body { padding: 30px 22px 26px; }
}
.formsies-auth__brand {
  display: flex;
  align-items: center;
  gap: 10px;
  justify-content: center;
  margin-bottom: 26px;
  text-decoration: none;
}
.formsies-auth__logo {
  width: 24px;
  height: 24px;
  border-radius: 7px;
  background: linear-gradient(140deg, var(--fs-primary), var(--fs-accent-dark));
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
}
.formsies-auth__logo::after {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 2px;
  background: var(--fs-page);
}
.formsies-auth__wordmark {
  font-family: var(--fs-font-display);
  font-weight: 600;
  font-size: 16px;
  letter-spacing: -0.01em;
  color: var(--fs-heading);
}
.formsies-auth__title {
  font-family: var(--fs-font-display);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--fs-heading);
  text-align: center;
  margin: 0 0 4px;
}
.formsies-auth__subtitle {
  font-size: 13px;
  color: var(--fs-dim);
  text-align: center;
  margin: 0 0 26px;
  line-height: 1.5;
}

/* ---- Form fields ---- */
.formsies-auth__form { display: block; }
.formsies-auth__field { margin-bottom: 16px; }
.formsies-auth__labelrow {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 7px;
}
.formsies-auth__label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fs-faint);
  margin-bottom: 7px;
}
.formsies-auth__labelrow .formsies-auth__label { margin-bottom: 0; }
.formsies-auth__label-opt {
  color: var(--fs-placeholder);
  font-weight: 500;
  text-transform: none;
  letter-spacing: 0;
}
.formsies-auth__forgot {
  font-size: 12px;
  color: var(--fs-primary-2);
  text-decoration: none;
}
.formsies-auth__forgot:hover { text-decoration: underline; }

/* Inputs — restyle whatever allauth/Pegasus renders inside the card. */
.formsies-auth__field input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
.formsies-auth__field select,
.formsies-auth__field textarea {
  width: 100%;
  height: 44px;
  background: var(--fs-inset);
  border: 1px solid rgba(255, 255, 255, 0.09);
  border-radius: 11px;
  padding: 0 14px;
  color: var(--fs-text);
  font-size: 14px;
  font-family: var(--fs-font-body);
  outline: none;
  transition: border-color 0.15s ease;
}
.formsies-auth__field textarea { height: auto; padding: 12px 14px; }
.formsies-auth__field input::placeholder,
.formsies-auth__field textarea::placeholder { color: var(--fs-placeholder); }
.formsies-auth__field input:focus,
.formsies-auth__field select:focus,
.formsies-auth__field textarea:focus {
  border-color: var(--fs-focus);
  box-shadow: 0 0 0 3px rgba(53, 208, 189, 0.12);
}
/* allauth renders small help text + error lists per field. */
.formsies-auth__field .helptext,
.formsies-auth__field small {
  display: block;
  margin-top: 6px;
  font-size: 11.5px;
  color: var(--fs-muted-2);
}

/* Error lists (non-field + per-field) from Django/allauth. */
.formsies-auth .errorlist {
  list-style: none;
  margin: 6px 0 0;
  padding: 0;
  font-size: 12px;
  color: var(--fs-danger-2);
}
.formsies-auth .errorlist li { margin: 2px 0; }
.formsies-auth__nonfield {
  margin-bottom: 16px;
}
.formsies-auth__nonfield .errorlist {
  margin: 0;
  padding: 11px 14px;
  border-radius: 11px;
  background: var(--fs-danger-soft);
  border: 1px solid rgba(224, 138, 106, 0.35);
}

/* ---- Checkbox row (terms) ---- */
.formsies-auth__check {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 22px;
  cursor: pointer;
}
.formsies-auth__check input[type="checkbox"] {
  accent-color: var(--fs-primary);
  width: 17px;
  height: 17px;
  margin-top: 1px;
  flex: 0 0 auto;
  cursor: pointer;
}
.formsies-auth__check-label {
  font-size: 12.5px;
  color: var(--fs-muted);
  line-height: 1.5;
}
.formsies-auth__check-label a { color: var(--fs-primary-2); text-decoration: none; }
.formsies-auth__check-label a:hover { text-decoration: underline; }

/* ---- Buttons ---- */
.formsies-auth__submit {
  width: 100%;
  height: 44px;
  border-radius: 11px;
  border: none;
  background: var(--fs-primary);
  color: var(--fs-accent-deep);
  font-size: 14px;
  font-weight: 700;
  font-family: inherit;
  cursor: pointer;
  transition: background 0.15s ease;
}
.formsies-auth__submit:hover { background: var(--fs-primary-hover); }
.formsies-auth__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  height: 44px;
  border-radius: 11px;
  font-size: 13.5px;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.15s ease, border-color 0.15s ease;
}
.formsies-auth__btn--primary {
  border: none;
  background: var(--fs-primary);
  color: var(--fs-accent-deep);
  font-weight: 700;
  font-size: 14px;
}
.formsies-auth__btn--primary:hover { background: var(--fs-primary-hover); }
.formsies-auth__btn--secondary {
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: transparent;
  color: var(--fs-text-2);
  font-weight: 500;
  margin-top: 10px;
}
.formsies-auth__btn--secondary:hover { background: rgba(255, 255, 255, 0.04); }

/* Focus visibility for keyboard users across all interactive auth controls. */
.formsies-auth a:focus-visible,
.formsies-auth button:focus-visible,
.formsies-auth input:focus-visible,
.formsies-auth [type="submit"]:focus-visible {
  outline: 2px solid var(--fs-primary);
  outline-offset: 2px;
}

/* ---- "or" divider + social ---- */
.formsies-auth__divider {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 18px 0;
}
.formsies-auth__divider::before,
.formsies-auth__divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: rgba(255, 255, 255, 0.08);
}
.formsies-auth__divider span { font-size: 12px; color: var(--fs-faint-2); }
.formsies-auth__social { margin: 0; }
.formsies-auth__social-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  height: 44px;
  border-radius: 11px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: var(--fs-subtle);
  color: var(--fs-text);
  font-size: 13.5px;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  transition: background 0.15s ease;
}
.formsies-auth__social-btn:hover { background: var(--fs-hover); }
.formsies-auth__social-btn img { width: 18px; height: 18px; }
.formsies-auth__social + .formsies-auth__social { margin-top: 10px; }

/* ---- Secondary link + footer strip ---- */
.formsies-auth__alt { text-align: center; margin-top: 18px; }
.formsies-auth__alt a {
  font-size: 12.5px;
  color: var(--fs-muted-2);
  text-decoration: none;
}
.formsies-auth__alt a:hover { color: var(--fs-text-2); }
.formsies-auth__foot {
  border-top: 1px solid var(--fs-line);
  padding: 16px;
  text-align: center;
  font-size: 13px;
  color: var(--fs-dim);
}
.formsies-auth__link {
  color: var(--fs-primary-2);
  text-decoration: none;
  font-weight: 600;
}
.formsies-auth__link:hover { text-decoration: underline; }
.formsies-auth__copyright {
  text-align: center;
  font-size: 11.5px;
  color: var(--fs-faint-2);
  margin: 0;
}

/* ---- Accept-invitation specifics ---- */
.formsies-auth__invite {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.formsies-auth__invite-avatar {
  position: relative;
  margin-bottom: 20px;
}
.formsies-auth__invite-mark {
  width: 60px;
  height: 60px;
  border-radius: 16px;
  background: linear-gradient(135deg, var(--fs-primary-2), var(--fs-accent-dark));
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--fs-font-display);
  font-weight: 700;
  font-size: 24px;
  color: var(--fs-accent-deep);
}
.formsies-auth__invite-badge {
  position: absolute;
  right: -10px;
  bottom: -10px;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: linear-gradient(135deg, #f0a868, #c5683a);
  border: 3px solid var(--fs-page);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--fs-font-display);
  font-weight: 700;
  font-size: 11px;
  color: #2a1206;
}
.formsies-auth__eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--fs-faint);
  margin-bottom: 8px;
}
.formsies-auth__invite-title {
  font-family: var(--fs-font-display);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--fs-heading);
  margin: 0 0 10px;
}
.formsies-auth__invite-text {
  font-size: 13.5px;
  color: var(--fs-muted);
  line-height: 1.6;
  margin: 0 auto;
  max-width: 280px;
}
.formsies-auth__invite-text strong { color: var(--fs-text); font-weight: 600; }
.formsies-auth__rolechip {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  height: 26px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  font-size: 12px;
  color: var(--fs-muted);
  margin: 14px 0 24px;
}
.formsies-auth__rolechip strong { color: var(--fs-text); font-weight: 600; }
.formsies-auth__actions { margin-top: 6px; }
.formsies-auth__danger {
  font-size: 13px;
  color: var(--fs-danger-2);
  margin: 0 0 14px;
  line-height: 1.5;
}

/* ---- Responsive: keep the card tidy down to small phones ---- */
@media (max-width: 480px) {
  .formsies-auth { padding: 24px 14px 40px; }
  .formsies-auth__body { padding: 28px 22px 24px; }
  .formsies-auth__title,
  .formsies-auth__invite-title { font-size: 20px; }
}

/* ---------------------------------------------------------------------
 * Billing / Subscription (Phase 10) — team-scoped subscription page.
 * Restyles the existing Pegasus/Stripe subscription views onto the dark
 * Formsies surface. All figures (plan, price, dates, usage) come from real
 * subscription / plan-limit data — never the prototype's sample values.
 * ------------------------------------------------------------------ */
.formsies-bill { display: flex; flex-direction: column; gap: 22px; }

/* Sub-header: back · BILLING / Subscription · status pill */
.formsies-billhead {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.formsies-billhead__back {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 10px;
  border: 1px solid var(--fs-line-strong);
  background: var(--fs-subtle);
  color: var(--fs-text-2);
  font-size: 16px;
  text-decoration: none;
  flex: 0 0 auto;
  transition: background 0.15s ease;
}
.formsies-billhead__back:hover { background: var(--fs-hover); }
.formsies-billhead__titlewrap { min-width: 0; }
.formsies-billhead__eyebrow {
  margin: 0 0 3px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--fs-faint);
}
.formsies-billhead__titlerow {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.formsies-billhead__title {
  font-family: var(--fs-font-display);
  font-weight: 600;
  font-size: 21px;
  letter-spacing: -0.02em;
  margin: 0;
  color: var(--fs-heading);
}

/* Extra status-pill variants used by billing state. */
.formsies-statuspill.is-warn {
  background: var(--fs-warn-soft);
  color: var(--fs-warn-2);
  border-color: rgba(224, 161, 60, 0.3);
}

/* Cards + layout */
.formsies-bill-card {
  background: var(--fs-panel);
  border: 1px solid var(--fs-line);
  border-radius: 16px;
  padding: 22px;
}
.formsies-bill__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}
.formsies-bill__cardlabel {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--fs-faint);
  margin: 0 0 8px;
}

/* Upgrade hero (not-subscribed) */
.formsies-bill-hero {
  display: flex;
  align-items: flex-start;
  gap: 18px;
  background:
    radial-gradient(700px 220px at 0% -40%, rgba(53, 208, 189, 0.08), transparent 70%),
    var(--fs-panel);
  border: 1px solid var(--fs-primary-border);
  border-radius: 16px;
  padding: 22px;
}
.formsies-bill-hero__icon {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  background: var(--fs-primary-soft);
  border: 1px solid var(--fs-primary-border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--fs-primary-2);
  font-size: 22px;
  flex: 0 0 auto;
}
.formsies-bill-hero__title {
  font-family: var(--fs-font-display);
  font-size: 20px;
  font-weight: 600;
  color: var(--fs-heading);
  margin: 0 0 4px;
}
.formsies-bill-hero__text {
  font-size: 13px;
  color: var(--fs-muted);
  line-height: 1.55;
  margin: 0;
  max-width: 60ch;
}

/* Current-plan card */
.formsies-bill-plan__name {
  font-family: var(--fs-font-display);
  font-size: 26px;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--fs-heading);
  margin: 0;
  display: flex;
  align-items: baseline;
  gap: 10px;
  flex-wrap: wrap;
}
.formsies-bill-plan__price {
  font-family: var(--fs-font-body);
  font-size: 14px;
  font-weight: 500;
  color: var(--fs-dim);
}
.formsies-bill-plan__meta {
  font-size: 12.5px;
  color: var(--fs-dim);
  margin: 8px 0 0;
  line-height: 1.5;
}
.formsies-bill-plan__meta strong { color: var(--fs-text-2); font-weight: 600; }
.formsies-bill__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}
.formsies-bill__hint {
  font-size: 12px;
  color: var(--fs-muted-2);
  margin: 14px 0 0;
  line-height: 1.5;
}
.formsies-bill__divider {
  border: 0;
  border-top: 1px solid var(--fs-line);
  margin: 20px 0;
}

/* Usage bars (real plan caps only) */
.formsies-usage { display: flex; flex-direction: column; gap: 16px; }
.formsies-usage__row { min-width: 0; }
.formsies-usage__top {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 7px;
}
.formsies-usage__label { font-size: 13px; color: var(--fs-text-2); }
.formsies-usage__value {
  font-family: var(--fs-font-mono);
  font-size: 12.5px;
  color: var(--fs-muted);
  font-variant-numeric: tabular-nums;
}
.formsies-usage__value strong { color: var(--fs-text); font-weight: 600; }
.formsies-usage__bar {
  height: 8px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
  overflow: hidden;
}
.formsies-usage__bar-fill {
  height: 100%;
  border-radius: 999px;
  background: var(--fs-primary);
}
.formsies-usage__bar-fill.is-full { background: var(--fs-warn); }

/* Billing-history note (invoices live in Stripe) */
.formsies-bill-note {
  font-size: 13px;
  color: var(--fs-muted);
  line-height: 1.6;
  margin: 0;
}
.formsies-bill-note__sub {
  font-size: 11.5px;
  color: var(--fs-faint-2);
  margin: 14px 0 0;
}

/* Stripe pricing table wrapper — never overflow the page horizontally. */
.formsies-bill-pricing { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.formsies-bill-pricing stripe-pricing-table { display: block; }

@media (max-width: 900px) {
  .formsies-bill__grid { grid-template-columns: 1fr; }
}
@media (max-width: 700px) {
  .formsies-bill-hero { flex-direction: column; gap: 12px; }
  .formsies-bill__actions .formsies-btn { width: 100%; }
}

/* ---------------------------------------------------------------------
 * Edit Studio · Fields builder (design handoff: Formsies Editor → Fields).
 * Each field is a dark card row with reorder arrows, label + type + page
 * controls, a Required/Optional pill toggle, a delete button, and a
 * conditional options input for Dropdown / Note types. Rows are injected by
 * button_form.js; these classes give them the handoff's exact surface.
 * ------------------------------------------------------------------ */
.formsies-fields__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 24px;
}
.formsies-fields__addbtn {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 36px;
  padding: 0 14px;
  border-radius: 9px;
  border: 1px solid var(--fs-primary-border);
  background: var(--fs-primary-soft);
  color: var(--fs-primary-2);
  font-size: 13px;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  transition: background 0.15s ease;
}
.formsies-fields__addbtn:hover { background: rgba(53, 208, 189, 0.16); }
.formsies-fields__addbtn span { font-size: 15px; line-height: 1; }

.formsies-fields__rows { display: flex; flex-direction: column; gap: 8px; }
.formsies-fields__footnote {
  font-size: 12px;
  color: var(--fs-faint-2);
  margin-top: 12px;
  line-height: 1.5;
}

.formsies-fieldrow {
  background: var(--fs-panel);
  border: 1px solid var(--fs-line);
  border-radius: 13px;
  padding: 12px 14px;
}
.formsies-fieldrow__main {
  display: flex;
  align-items: center;
  gap: 10px;
}
.formsies-fieldrow__reorder {
  display: flex;
  flex-direction: column;
  gap: 1px;
  flex: 0 0 auto;
}
.formsies-fieldrow__arrow {
  width: 22px;
  height: 18px;
  border: 0;
  background: transparent;
  color: var(--fs-faint-2);
  cursor: pointer;
  font-size: 11px;
  line-height: 1;
  border-radius: 4px;
}
.formsies-fieldrow__arrow:hover:not(:disabled) { color: var(--fs-text-2); }
.formsies-fieldrow__arrow:disabled { opacity: 0.35; cursor: default; }

/* Shared control look for the inline label / type / page inputs. */
.formsies-fieldrow__label,
.formsies-fieldrow__type,
.formsies-fieldrow__page,
.formsies-fieldrow__options {
  height: 36px;
  background: var(--fs-inset);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 9px;
  padding: 0 12px;
  color: var(--fs-text);
  font-size: 13px;
  font-family: inherit;
  outline: none;
  transition: border-color 0.15s ease;
}
.formsies-fieldrow__label:focus,
.formsies-fieldrow__type:focus,
.formsies-fieldrow__page:focus,
.formsies-fieldrow__options:focus { border-color: var(--fs-focus); }
.formsies-fieldrow__label { flex: 1 1 auto; min-width: 0; }
.formsies-fieldrow__type {
  flex: 0 0 120px;
  padding: 0 8px;
  color: var(--fs-text-2);
  font-size: 12.5px;
  cursor: pointer;
}
.formsies-fieldrow__page {
  flex: 0 0 84px;
  padding: 0 8px;
  color: var(--fs-muted);
  font-size: 12.5px;
  cursor: pointer;
}
.formsies-fieldrow__page:disabled { opacity: 0.55; cursor: default; }

.formsies-fieldrow__req {
  flex: 0 0 auto;
  height: 32px;
  padding: 0 12px;
  border-radius: 8px;
  cursor: pointer;
  font-family: inherit;
  font-size: 11.5px;
  font-weight: 600;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: transparent;
  color: var(--fs-muted-2);
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}
.formsies-fieldrow__req.is-on {
  border-color: var(--fs-primary-border);
  background: var(--fs-primary-soft);
  color: var(--fs-primary-2);
}
.formsies-fieldrow__del {
  flex: 0 0 auto;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  border: 1px solid var(--fs-line);
  background: transparent;
  color: var(--fs-faint);
  cursor: pointer;
  font-size: 13px;
  transition: color 0.15s ease, border-color 0.15s ease;
}
.formsies-fieldrow__del:hover {
  color: var(--fs-danger);
  border-color: rgba(224, 138, 106, 0.3);
}
.formsies-fieldrow__options {
  width: 100%;
  height: 34px;
  color: var(--fs-muted);
  font-size: 12.5px;
  margin-top: 8px;
}

/* Stack the row controls on narrow viewports so nothing overflows. */
@media (max-width: 600px) {
  .formsies-fieldrow__main { flex-wrap: wrap; }
  .formsies-fieldrow__label { flex: 1 1 100%; order: -1; }
  .formsies-fieldrow__type,
  .formsies-fieldrow__page { flex: 1 1 auto; }
}

/* ============================================================
   Submissions tab — the full two-pane inbox rendered inline in
   the Command Center (no modal). The standalone inbox page gets
   its height from the viewport-filling workspace; inside a tab
   panel we give it an explicit, bounded height so the two-pane
   grid + per-pane scrolling work in normal page flow.
   ============================================================ */
.formsies-inbox--in-tab {
  height: clamp(440px, 72vh, 760px);
  border: 1px solid var(--fs-line);
  border-radius: 16px;
  overflow: hidden;
  background: var(--fs-page);
}
.formsies-inbox--in-tab .formsies-inbox__head { padding: 14px 18px; }

@media (max-width: 860px) {
  /* Let the list size to content; the detail pane is a fixed overlay
     (see .formsies-inbox__detail @ max-width:860px), so no fixed height
     is needed and a tall empty column is avoided. */
  .formsies-inbox--in-tab { height: auto; min-height: 60vh; }
}

/* ============================================================
   Formsies app toast notifications (Django messages).
   Replaces the full-width banner that pushed the app shell down.
   Fixed below the 56px topbar, top-right, never affecting layout.
   Rendered by buttons/_formsies_toasts.html; close + auto-dismiss
   in formsies.js (bindFormsiesToasts).
   ============================================================ */
.formsies-toasts {
  position: fixed;
  top: calc(var(--fs-nav-h) + 14px);
  right: 18px;
  z-index: 1000;
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: min(380px, calc(100vw - 32px));
  pointer-events: none; /* let clicks through the gaps; toasts re-enable below */
}
.formsies-toast {
  pointer-events: auto;
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 12px 12px 14px;
  border-radius: 14px;
  border: 1px solid var(--fs-line);
  border-left-width: 3px;
  background: var(--fs-panel);
  color: var(--fs-text);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.38);
  font-size: 13px;
  line-height: 1.4;
  transition: opacity 0.18s ease, transform 0.18s ease;
}
.formsies-toast.is-leaving { opacity: 0; transform: translateY(-6px); }
.formsies-toast__icon {
  flex: 0 0 auto;
  font-size: 13px;
  line-height: 1.45;
  color: var(--fs-muted);
}
.formsies-toast__body {
  flex: 1 1 auto;
  min-width: 0;
  color: var(--fs-text);
  word-break: break-word;
}
.formsies-toast__close {
  flex: 0 0 auto;
  appearance: none;
  border: 0;
  background: transparent;
  color: var(--fs-faint);
  font-size: 16px;
  line-height: 1;
  padding: 0 2px;
  cursor: pointer;
  border-radius: 6px;
}
.formsies-toast__close:hover { color: var(--fs-heading); }
.formsies-toast__close:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--fs-primary-soft);
}
/* Level accents (left border + icon tint) using Formsies tokens. */
.formsies-toast.is-success { border-left-color: var(--fs-primary); }
.formsies-toast.is-success .formsies-toast__icon { color: var(--fs-primary-2); }
.formsies-toast.is-error { border-left-color: var(--fs-danger); }
.formsies-toast.is-error .formsies-toast__icon { color: var(--fs-danger-2, var(--fs-danger)); }
.formsies-toast.is-warning { border-left-color: var(--fs-warn); }
.formsies-toast.is-warning .formsies-toast__icon { color: var(--fs-warn); }
.formsies-toast.is-info,
.formsies-toast.is-debug { border-left-color: var(--fs-primary-2); }

@media (max-width: 640px) {
  .formsies-toasts {
    top: calc(var(--fs-nav-h) + 8px);
    left: 12px;
    right: 12px;
    width: auto;
  }
}
@media (prefers-reduced-motion: reduce) {
  .formsies-toast { transition: none; }
}


/* =====================================================================
 * CLEANUP PASS (2026-06-17) — Embed panel + Embed setup guide
 *
 * Folds the out-of-band `?v=…-help1` help styles into the source of truth
 * and replaces the raw DaisyUI/Tailwind utility soup on the Embed panel and
 * the Embed setup-guide page with scoped Formsies components, so both surfaces
 * use --fs-* tokens (legible sizes, brand surfaces) instead of arbitrary
 * `text-[11px]` / `bg-base-100/90` values. See CLEANUP.md for the markup swaps.
 * ================================================================== */

/* ---- Section title: collapse the duplicate into one rule ----
 * `.formsies-studio__section-title` (Basics/Fields/Design) and
 * `.formsies-form-section__title` (Availability/Messaging/Integrations/
 * Advanced) were two near-identical declarations. Alias them so a single
 * source governs every Edit-section heading — markup can use either while
 * templates are migrated onto `.formsies-studio__section-title`. */
.formsies-scope .formsies-form-section__title {
  font-family: var(--fs-font-display);
  font-size: 18px;
  text-transform: none;
  letter-spacing: -0.02em;
  color: var(--fs-heading);
  font-weight: 600;
  margin: 0 0 4px;
}
.formsies-scope .formsies-form-section__desc,
.formsies-scope .formsies-studio__section-desc {
  font-size: 13px;
  color: var(--fs-muted);   /* was --fs-dim; lift help/desc contrast */
  margin: 0 0 16px;
}

/* ---- Legibility floor for help/fine-print copy ----
 * The Tailwind markup leaned on text-[11px] + text-base-content/55 (small AND
 * low-contrast). Inside these scoped components, help text is >=12px and uses
 * --fs-muted rather than a translucent base-content. */
.formsies-scope .formsies-form-card__help,
.formsies-scope .fs-help-text,
.formsies-scope .fs-help-fine { color: var(--fs-muted); }
.formsies-scope .formsies-form-card__help { font-size: 12px; }

/* ---------------------------------------------------------------------
 * Embed panel (Command Center → Embed) and Share strip
 * ------------------------------------------------------------------ */
.formsies-embed { display: flex; flex-direction: column; gap: 14px; min-width: 0; }
.formsies-embed__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}
.formsies-embed__head-actions { display: flex; flex-wrap: wrap; gap: 8px; }

/* Mono code block for snippets / hosted URLs (replaces <pre class="bg-base…">). */
.formsies-embed__snippet,
.fs-help-code {
  margin: 0;
  font-family: var(--fs-font-mono);
  font-size: 12px;
  line-height: 1.6;
  color: var(--fs-primary-2);
  background: var(--fs-inset);
  border: 1px solid var(--fs-line);
  border-radius: 12px;
  padding: 12px 14px;
  overflow-x: auto;
  white-space: pre;
}
.fs-help-code { color: var(--fs-text-2); }
.fs-help-code .tok-tag { color: var(--fs-primary-2); }

/* "Placement tag" picker chips. */
.formsies-embed__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  min-width: 0;
}
.formsies-embed__tag {
  display: inline-flex;
  align-items: center;
  height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid var(--fs-line);
  background: var(--fs-subtle);
  color: var(--fs-muted);
  font-family: var(--fs-font-mono);
  font-size: 11.5px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}
.formsies-embed__tag:hover { background: var(--fs-hover); color: var(--fs-text); }
.formsies-embed__tag.is-active {
  background: var(--fs-primary-soft);
  color: var(--fs-primary-2);
  border-color: var(--fs-primary-border);
}
.formsies-embed__current {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--fs-font-mono);
  font-size: 11.5px;
  color: var(--fs-muted);
}
.formsies-embed__current b { color: var(--fs-text); font-weight: 600; }

/* Read-only share-link row: input + copy/open buttons. */
.formsies-embed__row {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}
.formsies-embed__row .formsies-input { flex: 1 1 240px; min-width: 0; }
.formsies-embed__status { font-size: 12px; color: var(--fs-muted); }

/* Scoped input for surfaces that don't load the Edit-Studio .fs-field sheet
 * (the Embed panel + the embed-help page). Matches the dark inset field look. */
.formsies-scope .formsies-input {
  width: 100%;
  height: 38px;
  padding: 0 12px;
  border-radius: 10px;
  background: var(--fs-inset);
  border: 1px solid var(--fs-line-strong);
  color: var(--fs-text);
  font-family: var(--fs-font-mono);
  font-size: 12.5px;
  outline: none;
  transition: border-color 0.15s ease;
}
.formsies-scope .formsies-input:focus { border-color: var(--fs-focus); }
.formsies-scope .formsies-input::placeholder {
  color: var(--fs-placeholder);
  font-family: var(--fs-font-body);
}
.formsies-embed__tip { font-size: 12px; color: var(--fs-muted); margin: 0; }
.formsies-embed__tip b { color: var(--fs-text-2); font-weight: 600; }

/* ---------------------------------------------------------------------
 * Embed setup-guide page (/buttons/<slug>/embed/help/)
 * ------------------------------------------------------------------ */
.formsies-help { display: flex; flex-direction: column; gap: 14px; }
.fs-help-card {
  background: var(--fs-panel);
  border: 1px solid var(--fs-line);
  border-radius: 16px;
  padding: 18px 20px;
}
.fs-help-card__title {
  font-family: var(--fs-font-display);
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--fs-heading);
  margin: 0 0 10px;
}
.fs-help-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--fs-primary-2);
  margin: 14px 0 4px;
}
.fs-help-label:first-of-type { margin-top: 0; }
.fs-help-text { font-size: 13px; line-height: 1.6; color: var(--fs-muted); margin: 0; }
.fs-help-steps,
.fs-help-list {
  margin: 4px 0 0;
  padding-left: 20px;
  font-size: 13px;
  line-height: 1.6;
  color: var(--fs-text-2);
}
.fs-help-steps li + li,
.fs-help-list li + li { margin-top: 4px; }
.fs-help-note {
  margin-top: 12px;
  background: var(--fs-panel-muted);
  border: 1px solid var(--fs-line);
  border-radius: 12px;
  padding: 12px 14px;
}
.fs-help-note__title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fs-warn-2);
  margin: 0 0 6px;
}
.fs-help-note .fs-help-list { color: var(--fs-muted); }

/* Numbered step bubble used in the Quick-start list. */
.fs-help-step {
  flex: 0 0 auto;
  width: 22px;
  height: 22px;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  background: var(--fs-primary-soft);
  border: 1px solid var(--fs-primary-border);
  color: var(--fs-primary-2);
  font-family: var(--fs-font-mono);
  font-size: 11px;
  font-weight: 600;
}

/* Platform jump-nav chips (Wix / WordPress / …). */
.fs-help-chip {
  display: inline-flex;
  align-items: center;
  height: 30px;
  padding: 0 13px;
  border-radius: 999px;
  border: 1px solid var(--fs-line);
  background: var(--fs-subtle);
  color: var(--fs-text-2);
  font-size: 12.5px;
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}
.fs-help-chip:hover {
  background: var(--fs-primary-soft);
  color: var(--fs-primary-2);
  border-color: var(--fs-primary-border);
}

/* Field-mapping table (Zapier guide — e.g. Placeholder → Zapier Field). */
.fs-help-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  margin: 6px 0 4px;
  font-size: 13px;
  border: 1px solid var(--fs-line);
  border-radius: 12px;
  overflow: hidden;
}
.fs-help-table th,
.fs-help-table td {
  text-align: left;
  padding: 9px 12px;
  border-bottom: 1px solid var(--fs-line);
  color: var(--fs-text-2);
  vertical-align: top;
}
.fs-help-table thead th {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fs-primary-2);
  background: var(--fs-panel-muted);
}
.fs-help-table tbody tr:last-child td {
  border-bottom: 0;
}
.fs-help-table code {
  white-space: nowrap;
}
