.forms-page {
    display: grid;
    gap: var(--space-5);
}

.forms-list-shell,
.forms-panel,
.forms-palette,
.forms-canvas,
.forms-properties,
.forms-preview-panel,
.forms-import-card {
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    background: var(--bg-elevated);
    box-shadow: var(--shadow-card);
}

.forms-list-shell,
.forms-panel,
.forms-palette,
.forms-canvas,
.forms-properties,
.forms-preview-panel,
.forms-import-card {
    padding: 18px;
}

.forms-filterbar,
.forms-add-step {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3);
    align-items: center;
}

.forms-filterbar .form-control {
    max-width: 260px;
}

.forms-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--space-4);
    margin-top: var(--space-4);
}

.forms-form-card {
    display: grid;
    gap: var(--space-3);
    min-width: 0;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: color-mix(in srgb, var(--bg-elevated) 88%, var(--bg-muted));
    padding: 16px;
}

.forms-form-card h3,
.forms-panel h3,
.forms-palette h3,
.forms-canvas h3,
.forms-properties h3,
.forms-preview-panel h3,
.forms-import-card h2 {
    margin: 0;
    color: var(--text);
    font-size: var(--font-lg);
    line-height: 1.2;
}

.forms-form-card p,
.forms-palette p,
.forms-canvas p,
.forms-panel p {
    margin: 0;
    color: var(--text-muted);
}

.forms-form-card__top,
.forms-panel__header,
.forms-canvas__header,
.forms-preview-header,
.forms-step-card__bar,
.forms-field-card,
.forms-card-actions,
.forms-field-actions {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.forms-form-card__top,
.forms-panel__header,
.forms-canvas__header,
.forms-preview-header,
.forms-step-card__bar {
    justify-content: space-between;
}

.forms-form-card__meta {
    color: var(--text-muted);
    font-size: var(--font-sm);
}

.forms-mini-chip,
.forms-field-badges span {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    background: var(--bg-muted);
    color: var(--text-muted);
    font-size: var(--font-xs);
    font-weight: 800;
    padding: 3px 8px;
}

.forms-card-actions {
    flex-wrap: wrap;
    align-items: center;
}

.forms-card-actions form,
.forms-field-actions form,
.forms-step-delete {
    margin: 0;
}

.forms-empty,
.forms-empty-drop {
    border: 1px dashed var(--border-strong);
    border-radius: var(--radius-sm);
    background: var(--bg-muted);
    color: var(--text-muted);
    padding: 16px;
    text-align: center;
}

.forms-pagination {
    margin-top: var(--space-4);
}

.forms-form-shell {
    max-width: 840px;
}

.forms-metadata-form,
.forms-field-form,
.forms-step-edit,
.forms-import-form {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-4);
}

.forms-metadata-form .section-actions,
.forms-field-form .section-actions,
.forms-import-form .section-actions,
.forms-field-form .form-group,
.forms-field-form .forms-toggle-row {
    grid-column: 1 / -1;
}

.forms-builder-meta {
    display: grid;
}

.forms-builder-layout {
    display: grid;
    grid-template-columns: minmax(170px, 220px) minmax(0, 1fr) minmax(260px, 330px);
    gap: var(--space-4);
    align-items: start;
}

.forms-palette,
.forms-properties {
    position: sticky;
    top: calc(var(--topbar-height) + 16px);
    max-height: calc(100vh - var(--topbar-height) - 32px);
    overflow: auto;
}

.forms-palette-grid {
    display: grid;
    gap: var(--space-2);
    margin-top: var(--space-4);
}

.forms-palette-item {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr);
    gap: var(--space-2);
    align-items: center;
    min-height: 44px;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--bg-elevated);
    color: var(--text);
    padding: 8px;
}

.forms-palette-item:hover,
.forms-field-card:hover,
.forms-step-card:hover {
    border-color: var(--border-strong);
    background: var(--bg-muted);
}

.forms-palette-item span,
.forms-field-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border-radius: var(--radius-sm);
    background: var(--primary-soft);
    color: var(--primary);
    font-size: var(--font-xs);
    font-weight: 900;
}

.forms-palette-item strong {
    overflow-wrap: anywhere;
    color: var(--text);
    font-size: var(--font-sm);
}

.forms-step-stack {
    display: grid;
    gap: var(--space-4);
    margin-top: var(--space-4);
}

.forms-step-card {
    display: grid;
    gap: var(--space-3);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    background: var(--bg-elevated);
    padding: 14px;
}

.forms-step-card.is-dragging,
.forms-field-card.is-dragging {
    opacity: 0.55;
}

.forms-step-summary {
    min-width: 0;
    margin-right: auto;
}

.forms-step-card__bar h4,
.forms-preview-step h4,
.forms-preview-intro h4,
.forms-import-step h3 {
    margin: 0;
    color: var(--text);
    font-size: var(--font-md);
    line-height: 1.25;
}

.forms-step-card__bar p,
.forms-import-step p {
    margin: 3px 0 0;
    color: var(--text-muted);
    font-size: var(--font-sm);
}

.forms-drag-handle {
    flex: 0 0 auto;
    color: var(--text-muted);
    cursor: grab;
    font-weight: 900;
}

.forms-step-edit {
    grid-template-columns: minmax(160px, 1.2fr) minmax(160px, 1fr) 84px auto;
    gap: var(--space-2);
}

.forms-order-input {
    min-width: 72px;
}

.forms-field-list {
    display: grid;
    gap: var(--space-2);
    min-height: 58px;
}

.forms-field-list.is-drop-target {
    outline: 3px solid var(--focus);
    outline-offset: 3px;
}

.forms-field-card {
    min-width: 0;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--bg-elevated);
    padding: 10px;
}

.forms-field-card.is-inactive {
    opacity: 0.66;
}

.forms-field-main {
    display: grid;
    min-width: 0;
    margin-right: auto;
}

.forms-field-main strong,
.forms-field-main span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.forms-field-main span {
    color: var(--text-muted);
    font-size: var(--font-xs);
}

.forms-field-badges {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-1);
    justify-content: flex-end;
}

.forms-field-actions {
    flex-wrap: wrap;
    justify-content: flex-end;
}

.forms-step-delete {
    justify-self: start;
}

.forms-add-step {
    margin-top: var(--space-4);
    border-top: 1px solid var(--border);
    padding-top: var(--space-4);
}

.forms-add-step .form-control {
    min-width: min(280px, 100%);
}

.forms-properties {
    display: grid;
    gap: var(--space-4);
}

.forms-field-form {
    grid-template-columns: 1fr;
}

.forms-toggle-row {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-4);
}

.forms-toggle-row label {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    color: var(--text);
    font-weight: 800;
}

.forms-preview-panel {
    display: grid;
    gap: var(--space-4);
}

.forms-preview-intro {
    display: grid;
    gap: var(--space-3);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--bg-muted);
    padding: 16px;
}

.forms-preview-intro p {
    margin: 0;
    color: var(--text-muted);
}

.forms-preview-step {
    display: grid;
    gap: var(--space-3);
}

.forms-preview-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-3);
}

.forms-preview-field {
    display: grid;
    gap: 7px;
    min-width: 0;
}

.forms-width-25 {
    grid-column: span 1;
}

.forms-width-50 {
    grid-column: span 2;
}

.forms-width-75 {
    grid-column: span 3;
}

.forms-width-100 {
    grid-column: 1 / -1;
}

.forms-preview-field > span {
    color: var(--text);
    font-size: var(--font-sm);
    font-weight: 800;
}

.forms-preview-field em {
    color: var(--danger);
    font-style: normal;
    font-size: var(--font-xs);
}

.forms-preview-options {
    display: grid;
    gap: var(--space-2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--bg-elevated);
    padding: 10px;
}

.forms-preview-options span {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
}

.forms-signature-pad {
    display: grid;
    gap: var(--space-2);
}

.forms-signature-pad canvas,
.forms-signature-preview {
    width: 100%;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--bg-elevated);
    color: var(--text);
    touch-action: none;
}

.forms-signature-pad canvas {
    display: block;
    height: 220px;
    min-height: 220px;
}

.forms-signature-preview {
    min-height: 160px;
    position: relative;
}

.forms-signature-preview::after {
    content: "";
    position: absolute;
    right: 18px;
    bottom: 28px;
    left: 18px;
    border-bottom: 1px solid var(--border-strong);
}

.forms-signature-image {
    display: block;
    width: min(100%, 520px);
    min-height: 120px;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--bg-elevated);
    object-fit: contain;
}

.forms-preview-actions {
    display: flex;
    justify-content: flex-end;
    gap: var(--space-2);
}

.forms-import-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(300px, 0.8fr);
    gap: var(--space-4);
    align-items: start;
}

.forms-json-textarea {
    min-height: 360px;
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: var(--font-sm);
}

.forms-generator-form {
    display: grid;
    gap: var(--space-4);
}

.forms-generator-prompt {
    min-height: 260px;
}

.forms-generator-upload {
    display: grid;
    gap: var(--space-3);
    border: 1px dashed var(--border-strong);
    border-radius: var(--radius-sm);
    background: var(--bg-muted);
    padding: 16px;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}

.forms-generator-upload.is-dragging {
    border-color: var(--primary);
    background: var(--primary-soft);
    box-shadow: 0 0 0 3px var(--focus);
}

.forms-generator-upload input[type="file"] {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
}

.forms-generator-upload label {
    display: grid;
    gap: var(--space-1);
    margin: 0;
    color: var(--text);
    cursor: pointer;
    text-align: center;
}

.forms-generator-upload label span {
    color: var(--text-muted);
    font-size: var(--font-sm);
}

.forms-generator-file-list {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    justify-content: center;
    min-height: 0;
}

.forms-generator-file-list span {
    display: inline-flex;
    max-width: 100%;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: var(--bg-elevated);
    color: var(--text-muted);
    font-size: var(--font-xs);
    font-weight: 800;
    overflow-wrap: anywhere;
    padding: 4px 9px;
}

.forms-import-summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: var(--space-3);
    margin-top: var(--space-4);
}

.forms-import-summary > div {
    display: grid;
    gap: var(--space-1);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--bg-muted);
    padding: 12px;
}

.forms-import-summary span {
    color: var(--text-muted);
    font-size: var(--font-xs);
    font-weight: 800;
}

.forms-import-preview {
    display: grid;
    gap: var(--space-3);
    margin-top: var(--space-4);
}

.forms-import-step {
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 12px;
}

.forms-import-fields {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin-top: var(--space-3);
}

.forms-import-fields span {
    display: inline-flex;
    gap: var(--space-2);
    border-radius: 999px;
    background: var(--bg-muted);
    padding: 4px 9px;
}

.forms-import-fields small {
    color: var(--text-muted);
}

.forms-builder-page {
    gap: var(--space-6);
}

.forms-builder-hero {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-5);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    background: var(--bg-elevated);
    box-shadow: var(--shadow-card);
    padding: 20px;
}

.forms-builder-hero__main {
    display: grid;
    min-width: 0;
    gap: var(--space-2);
}

.forms-builder-kicker {
    color: var(--text-muted);
    font-size: var(--font-xs);
    font-weight: 900;
    text-transform: uppercase;
}

.forms-builder-hero h2 {
    margin: 0;
    color: var(--text);
    font-size: var(--font-2xl);
    line-height: 1.1;
}

.forms-builder-meta-pills,
.forms-builder-actions,
.forms-step-actions,
.forms-preview-title,
.forms-side-header {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-2);
}

.forms-builder-meta-pills span,
.forms-stage-pill,
.forms-step-order,
.forms-step-count,
.forms-preview-title > span {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: var(--bg-muted);
    color: var(--text-muted);
    font-size: var(--font-xs);
    font-weight: 900;
    padding: 4px 10px;
}

.forms-status-pill.is-draft {
    border-color: color-mix(in srgb, var(--warning) 34%, var(--border));
    background: var(--warning-soft);
    color: #92400e;
}

.forms-status-pill.is-published {
    border-color: color-mix(in srgb, var(--success) 34%, var(--border));
    background: var(--success-soft);
    color: var(--success);
}

.forms-status-pill.is-archived {
    border-color: color-mix(in srgb, var(--danger) 28%, var(--border));
    background: var(--danger-soft);
    color: var(--danger);
}

.forms-builder-actions {
    justify-content: flex-end;
}

.forms-builder-actions form,
.forms-step-actions form {
    margin: 0;
}

.forms-panel,
.forms-palette,
.forms-canvas,
.forms-properties,
.forms-preview-panel {
    border-radius: var(--radius-md);
}

.forms-builder-meta .forms-panel {
    border-left: 4px solid var(--primary);
}

.forms-builder-layout {
    grid-template-columns: minmax(190px, 250px) minmax(0, 1fr) minmax(290px, 360px);
    gap: var(--space-5);
}

.forms-palette,
.forms-properties {
    padding: 16px;
}

.forms-canvas {
    padding: 20px;
}

.forms-side-header {
    align-items: flex-start;
    margin-bottom: var(--space-4);
}

.forms-side-header > div {
    display: grid;
    gap: var(--space-1);
    min-width: 0;
}

.forms-side-header p {
    margin: 0;
    color: var(--text-muted);
    font-size: var(--font-sm);
}

.forms-panel-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border-radius: var(--radius-sm);
    background: var(--primary-soft);
    color: var(--primary);
    font-weight: 900;
}

.forms-palette-grid {
    gap: var(--space-3);
    margin-top: 0;
}

.forms-palette-item {
    grid-template-columns: 38px minmax(0, 1fr);
    min-height: 62px;
    border-radius: var(--radius-sm);
    padding: 10px;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}

.forms-palette-item span {
    grid-row: span 2;
    width: 38px;
    height: 38px;
}

.forms-palette-item small {
    overflow: hidden;
    color: var(--text-muted);
    font-size: var(--font-xs);
    font-weight: 800;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.forms-palette-item:hover,
.forms-palette-item.is-active {
    border-color: var(--primary);
    box-shadow: 0 0 0 3px var(--focus);
    transform: translateY(-1px);
}

.forms-canvas__header {
    border-bottom: 1px solid var(--border);
    margin: -2px -2px var(--space-4);
    padding: 2px 2px var(--space-4);
}

.forms-step-stack {
    gap: var(--space-5);
}

.forms-step-card {
    position: relative;
    gap: var(--space-4);
    border-radius: var(--radius-md);
    background: var(--bg-elevated);
    padding: 16px;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}

.forms-step-card::before {
    position: absolute;
    top: 16px;
    bottom: 16px;
    left: 0;
    width: 4px;
    border-radius: 0 999px 999px 0;
    background: var(--bg-subtle);
    content: "";
}

.forms-step-card.is-selected {
    border-color: color-mix(in srgb, var(--primary) 46%, var(--border));
    box-shadow: 0 0 0 3px var(--focus), var(--shadow-card);
}

.forms-step-card.is-selected::before {
    background: var(--primary);
}

.forms-step-card__bar {
    align-items: flex-start;
    gap: var(--space-3);
}

.forms-step-summary {
    display: grid;
    gap: var(--space-1);
}

.forms-step-card__bar h4 {
    font-size: var(--font-lg);
}

.forms-step-actions {
    justify-content: flex-end;
    margin-left: auto;
}

.forms-drag-handle,
.forms-field-drag {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    min-width: 28px;
    height: 28px;
    border: 1px solid var(--border);
    border-radius: var(--radius-xs);
    background: var(--bg-muted);
    color: var(--text-muted);
    cursor: grab;
    font-size: var(--font-xs);
}

.forms-step-edit {
    grid-template-columns: minmax(180px, 1.25fr) minmax(160px, 1fr) 88px auto;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: color-mix(in srgb, var(--bg-muted) 74%, var(--bg-elevated));
    padding: 10px;
}

.forms-field-list {
    gap: var(--space-3);
    border: 1px dashed transparent;
    border-radius: var(--radius-sm);
    padding: 2px;
    transition: background 0.15s ease, border-color 0.15s ease, outline-color 0.15s ease;
}

.forms-field-list.is-drop-target {
    border-color: var(--primary);
    background: var(--primary-soft);
    outline: 0;
}

.forms-field-card {
    display: grid;
    grid-template-columns: 28px 38px minmax(140px, 1fr) minmax(150px, auto) auto;
    gap: var(--space-3);
    align-items: center;
    border-radius: var(--radius-sm);
    padding: 12px;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}

.forms-field-card:hover {
    box-shadow: 0 8px 24px rgba(31, 31, 28, 0.08);
    transform: translateY(-1px);
}

.forms-field-card.is-dragging,
.forms-step-card.is-dragging {
    border-color: var(--primary);
    box-shadow: var(--shadow-popover);
    opacity: 0.72;
}

.forms-field-icon {
    width: 38px;
    height: 38px;
}

.forms-field-main strong {
    color: var(--text);
    font-size: var(--font-md);
}

.forms-field-badges span {
    border: 1px solid var(--border);
    background: var(--bg-muted);
}

.forms-field-badges .is-type {
    background: var(--primary-soft);
    color: var(--primary);
}

.forms-field-badges .is-required {
    background: var(--warning-soft);
    color: #92400e;
}

.forms-field-badges .is-active {
    background: var(--success-soft);
    color: var(--success);
}

.forms-field-badges .is-inactive {
    background: var(--danger-soft);
    color: var(--danger);
}

.forms-field-actions .btn {
    min-height: 30px;
}

.forms-field-actions form {
    flex: 0 0 auto;
}

.forms-empty-drop {
    padding: 18px;
}

.forms-add-step-card {
    display: grid;
    gap: var(--space-4);
    margin-top: var(--space-5);
    border: 1px dashed var(--border-strong);
    border-radius: var(--radius-md);
    background: color-mix(in srgb, var(--bg-muted) 72%, var(--bg-elevated));
    padding: 16px;
}

.forms-add-step-card > div {
    display: grid;
    gap: var(--space-1);
}

.forms-add-step-card strong {
    color: var(--text);
}

.forms-add-step-card span {
    color: var(--text-muted);
    font-size: var(--font-sm);
}

.forms-add-step {
    margin-top: 0;
    border-top: 0;
    padding-top: 0;
}

.forms-property-section {
    display: grid;
    gap: var(--space-3);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: color-mix(in srgb, var(--bg-elevated) 82%, var(--bg-muted));
    padding: 12px;
}

.forms-property-section h4 {
    margin: 0;
    color: var(--text);
    font-size: var(--font-sm);
    font-weight: 900;
}

.forms-field-form > .btn {
    width: 100%;
}

.forms-toggle-row {
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--bg-elevated);
    padding: 10px;
}

.forms-preview-panel {
    background: color-mix(in srgb, var(--bg-muted) 62%, var(--bg-elevated));
}

.forms-preview-title {
    justify-content: space-between;
}

.forms-preview-title > div {
    display: grid;
    gap: var(--space-1);
}

.forms-preview-title p {
    margin: 0;
    color: var(--text-muted);
}

.forms-preview-device {
    overflow: hidden;
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-md);
    background: var(--bg-elevated);
    box-shadow: var(--shadow-card);
}

.forms-preview-toolbar {
    display: flex;
    align-items: center;
    gap: 7px;
    border-bottom: 1px solid var(--border);
    background: var(--bg-muted);
    padding: 10px 14px;
}

.forms-preview-toolbar span {
    width: 9px;
    height: 9px;
    border-radius: 999px;
    background: var(--border-strong);
}

.forms-preview-toolbar strong {
    overflow: hidden;
    margin-left: var(--space-2);
    color: var(--text-muted);
    font-size: var(--font-xs);
    text-overflow: ellipsis;
    white-space: nowrap;
}

.forms-preview-progress {
    display: grid;
    gap: var(--space-2);
    border-bottom: 1px solid var(--border);
    padding: 14px 18px;
}

.forms-preview-progress span {
    color: var(--text-muted);
    font-size: var(--font-xs);
    font-weight: 900;
}

.forms-preview-progress div {
    overflow: hidden;
    height: 8px;
    border-radius: 999px;
    background: var(--bg-muted);
}

.forms-preview-progress i {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: var(--primary);
}

.forms-preview-screen {
    display: grid;
    gap: var(--space-5);
    padding: 18px;
}

.forms-preview-intro {
    border-radius: var(--radius-md);
    background: color-mix(in srgb, var(--primary-soft) 70%, var(--bg-elevated));
}

.forms-preview-step {
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    background: var(--bg-elevated);
    padding: 16px;
}

.forms-preview-step-title {
    display: grid;
    gap: var(--space-1);
}

.forms-preview-step-title span {
    color: var(--text-muted);
    font-size: var(--font-xs);
    font-weight: 900;
    text-transform: uppercase;
}

.forms-preview-grid {
    margin-top: var(--space-3);
}

.forms-is-dragging-field .forms-field-list,
.forms-is-dragging-palette .forms-field-list {
    border-color: var(--border-strong);
}

.forms-is-dragging-step .forms-step-stack {
    cursor: grabbing;
}

.forms-campaign-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(310px, 1fr));
    gap: var(--space-4);
    margin-top: var(--space-4);
}

.forms-campaign-card {
    display: grid;
    gap: var(--space-4);
    min-width: 0;
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    background: color-mix(in srgb, var(--bg-elevated) 88%, var(--bg-muted));
    box-shadow: var(--shadow-card);
    padding: 16px;
}

.forms-campaign-card__top,
.forms-public-header,
.forms-public-actions,
.forms-public-link-box {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-2);
}

.forms-campaign-card__top {
    justify-content: space-between;
}

.forms-campaign-card__body {
    display: grid;
    gap: var(--space-2);
}

.forms-campaign-card h3 {
    margin: 0;
    color: var(--text);
    font-size: var(--font-xl);
    line-height: 1.15;
}

.forms-campaign-card p,
.forms-campaign-copy p {
    margin: 0;
    color: var(--text-muted);
}

.forms-campaign-meta,
.forms-definition-list,
.forms-campaign-copy {
    display: grid;
    gap: var(--space-2);
}

.forms-campaign-meta span,
.forms-definition-list div {
    display: flex;
    justify-content: space-between;
    gap: var(--space-3);
    border-bottom: 1px solid var(--border);
    color: var(--text-muted);
    font-size: var(--font-sm);
    padding-bottom: var(--space-2);
}

.forms-campaign-meta span:last-child,
.forms-definition-list div:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.forms-campaign-meta strong,
.forms-definition-list strong {
    color: var(--text);
    text-align: right;
}

.forms-inline-warning,
.forms-inline-note {
    border: 1px solid color-mix(in srgb, var(--warning) 34%, var(--border));
    border-radius: var(--radius-sm);
    background: var(--warning-soft);
    color: #92400e;
    padding: 10px 12px;
}

.forms-inline-note {
    display: grid;
    gap: var(--space-1);
}

.forms-campaign-form {
    display: grid;
    gap: var(--space-4);
}

.forms-campaign-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-4);
    margin-top: var(--space-4);
}

.forms-campaign-form-grid .form-group-full,
.forms-campaign-form-grid .forms-toggle-row {
    grid-column: 1 / -1;
}

.forms-campaign-detail-grid {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
    gap: var(--space-4);
}

.forms-public-link-box input {
    flex: 1 1 320px;
}

.forms-status-pill.is-campaign-draft {
    border-color: color-mix(in srgb, var(--warning) 34%, var(--border));
    background: var(--warning-soft);
    color: #92400e;
}

.forms-status-pill.is-campaign-active {
    border-color: color-mix(in srgb, var(--success) 34%, var(--border));
    background: var(--success-soft);
    color: var(--success);
}

.forms-status-pill.is-campaign-closed,
.forms-status-pill.is-campaign-archived {
    border-color: color-mix(in srgb, var(--danger) 28%, var(--border));
    background: var(--danger-soft);
    color: var(--danger);
}

.forms-public-page {
    position: relative;
    min-height: 100vh;
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--bg-muted) 76%, transparent), color-mix(in srgb, var(--bg) 90%, transparent)),
        var(--forms-campaign-bg, linear-gradient(180deg, var(--bg-muted), var(--bg)));
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
    color: var(--text);
    padding: clamp(18px, 4vw, 44px);
}

.forms-public-page.has-svg-background {
    overflow: hidden;
    background: linear-gradient(180deg, color-mix(in srgb, var(--bg-muted) 76%, transparent), color-mix(in srgb, var(--bg) 90%, transparent));
}

.forms-public-page.has-svg-background::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    background: linear-gradient(180deg, color-mix(in srgb, var(--bg-muted) 76%, transparent), color-mix(in srgb, var(--bg) 90%, transparent));
}

.forms-public-page.has-svg-background > :not(.forms-public-bg-image) {
    position: relative;
    z-index: 2;
}

.forms-public-bg-image {
    position: fixed;
    inset: 0;
    z-index: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    pointer-events: none;
}

.forms-public-page.is-embedded {
    min-height: 0;
    background: transparent;
    padding: 0;
}

.forms-public-header {
    max-width: 1060px;
    margin: 0 auto var(--space-4);
    color: var(--text-muted);
    font-weight: 900;
}

.forms-public-brand {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    overflow: hidden;
    border-radius: var(--radius-sm);
    background: var(--primary);
    color: white;
}

.forms-public-brand img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.forms-public-shell {
    display: grid;
    gap: var(--space-5);
    max-width: 1060px;
    margin: 0 auto;
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    background: color-mix(in srgb, var(--bg-elevated) 94%, transparent);
    backdrop-filter: blur(10px);
    box-shadow: var(--shadow-card);
    padding: clamp(18px, 4vw, 32px);
}

.forms-wysiwyg-source {
    display: none;
}

.forms-wysiwyg {
    overflow: hidden;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--bg-elevated);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5);
}

.forms-wysiwyg-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
    border-bottom: 1px solid var(--border);
    background: var(--bg-muted);
    padding: 8px;
}

.forms-wysiwyg-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 34px;
    height: 30px;
    border: 1px solid var(--border);
    border-radius: 7px;
    background: var(--bg-elevated);
    color: var(--text);
    font-size: var(--font-xs);
    font-weight: 900;
    line-height: 1;
    cursor: pointer;
    transition: border-color 0.15s ease, color 0.15s ease, transform 0.15s ease;
}

.forms-wysiwyg-button:hover,
.forms-wysiwyg-button:focus {
    border-color: var(--primary);
    color: var(--primary);
    outline: none;
    transform: translateY(-1px);
}

.forms-wysiwyg-editor {
    min-height: 132px;
    padding: 12px 14px;
    color: var(--text);
    line-height: 1.55;
}

.forms-wysiwyg-editor:focus {
    outline: 2px solid color-mix(in srgb, var(--primary) 28%, transparent);
    outline-offset: -2px;
}

.forms-rich-text {
    color: inherit;
    line-height: 1.6;
}

.forms-rich-text p,
.forms-wysiwyg-editor p {
    margin: 0 0 0.75em;
}

.forms-rich-text p:last-child,
.forms-wysiwyg-editor p:last-child {
    margin-bottom: 0;
}

.forms-rich-text ul,
.forms-rich-text ol,
.forms-wysiwyg-editor ul,
.forms-wysiwyg-editor ol {
    margin: 0.25em 0 0.75em;
    padding-left: 1.35em;
}

.forms-rich-text a {
    color: var(--primary);
    font-weight: 800;
}

.forms-public-hero .forms-rich-text,
.forms-public-intro .forms-rich-text,
.forms-public-thanks .forms-rich-text {
    margin-top: var(--space-2);
    color: var(--text-muted);
}

.forms-public-hero {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-4);
}

.forms-public-hero h1,
.forms-public-step-title h2,
.forms-public-thanks h2,
.forms-public-unavailable h1 {
    margin: 0;
    color: var(--text);
    line-height: 1.12;
}

.forms-public-hero h1 {
    font-size: clamp(2rem, 4vw, 3rem);
}

.forms-public-hero p,
.forms-public-step-title p,
.forms-public-thanks p,
.forms-public-unavailable p {
    margin: var(--space-2) 0 0;
    color: var(--text-muted);
}

.forms-public-progress {
    display: grid;
    gap: var(--space-2);
}

.forms-public-progress span {
    color: var(--text-muted);
    font-size: var(--font-xs);
    font-weight: 900;
}

.forms-public-progress div {
    overflow: hidden;
    height: 10px;
    border-radius: 999px;
    background: var(--bg-muted);
}

.forms-public-progress i {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: var(--primary);
    transition: width 0.18s ease;
}

.forms-deadline-notice {
    border: 1px solid color-mix(in srgb, var(--primary) 24%, var(--border));
    border-radius: var(--radius-sm);
    background: color-mix(in srgb, var(--primary-soft) 76%, var(--bg-elevated));
    color: var(--primary);
    font-weight: 900;
    padding: 12px 14px;
}

.forms-public-form,
.forms-public-screen,
.forms-public-step-title,
.forms-public-thanks,
.forms-public-unavailable {
    display: grid;
    gap: var(--space-4);
}

.forms-public-screen {
    display: none;
}

.forms-public-screen.is-active {
    display: grid;
}

.forms-public-intro {
    padding: clamp(18px, 3vw, 26px);
}

.forms-public-intro h2 {
    margin: 0;
}

.forms-public-field-grid .form-control {
    min-height: 44px;
}

.forms-public-actions {
    justify-content: flex-end;
    border-top: 1px solid var(--border);
    padding-top: var(--space-4);
}

.forms-field-error {
    color: var(--danger);
    font-weight: 800;
}

.forms-public-thanks,
.forms-public-unavailable {
    justify-items: center;
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    background: var(--bg-muted);
    padding: clamp(22px, 5vw, 44px);
    text-align: center;
}

.forms-response-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: var(--space-3);
}

.forms-response-stats > div {
    display: grid;
    gap: var(--space-1);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--bg-muted);
    padding: 14px;
}

.forms-response-stats span,
.forms-response-row span,
.forms-answer-item span {
    color: var(--text-muted);
    font-size: var(--font-xs);
    font-weight: 800;
}

.forms-response-stats strong {
    color: var(--text);
    font-size: var(--font-xl);
}

.forms-response-list,
.forms-answer-list {
    display: grid;
    gap: var(--space-2);
    margin-top: var(--space-4);
}

.forms-response-row {
    display: grid;
    grid-template-columns: minmax(120px, 0.8fr) minmax(150px, 1fr) minmax(150px, 1fr) minmax(100px, 0.7fr) minmax(100px, 0.7fr);
    gap: var(--space-3);
    align-items: center;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--bg-elevated);
    padding: 10px 12px;
}

.forms-answer-item {
    display: grid;
    grid-template-columns: minmax(220px, 0.8fr) minmax(0, 1fr);
    gap: var(--space-4);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--bg-muted);
    padding: 12px;
}

.forms-answer-item div {
    display: grid;
    gap: var(--space-1);
}

.forms-answer-item p {
    margin: 0;
    color: var(--text);
    white-space: pre-wrap;
}

.forms-responses-table td strong,
.forms-responses-table td span {
    display: block;
}

.forms-status-pill.is-response-draft {
    border-color: color-mix(in srgb, var(--warning) 34%, var(--border));
    background: var(--warning-soft);
    color: #92400e;
}

.forms-status-pill.is-response-submitted {
    border-color: color-mix(in srgb, var(--success) 34%, var(--border));
    background: var(--success-soft);
    color: var(--success);
}

.forms-analysis-filterbar {
    margin-top: var(--space-4);
}

.forms-analysis-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: var(--space-2);
}

.forms-analysis-accordion-group {
    display: grid;
    gap: var(--space-3);
}

.forms-check-filter {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    min-height: 40px;
    color: var(--text-muted);
    font-size: var(--font-sm);
    font-weight: 700;
}

.forms-check-filter input {
    width: 16px;
    height: 16px;
}

.forms-analysis-step .forms-panel__header {
    align-items: flex-start;
}

.forms-analysis-step-title,
.forms-analysis-step .forms-panel__header > div {
    display: grid;
    gap: var(--space-1);
    min-width: 0;
}

.forms-analysis-accordion-header {
    display: grid;
    grid-template-columns: minmax(240px, 0.8fr) minmax(0, 1.2fr);
    gap: var(--space-3);
    justify-content: stretch;
}

.forms-analysis-accordion-toggle {
    display: inline-flex;
    align-items: flex-start;
    gap: var(--space-2);
    width: 100%;
    border: 0;
    background: transparent;
    color: var(--text);
    padding: 0;
    text-align: left;
}

.forms-analysis-accordion-toggle:focus-visible {
    border-radius: var(--radius-sm);
    outline: 3px solid var(--focus);
    outline-offset: 4px;
}

.forms-analysis-accordion-marker {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 24px;
    width: 24px;
    height: 24px;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--bg-muted);
    color: var(--primary);
    font-size: var(--font-sm);
    font-weight: 900;
}

.forms-analysis-accordion-marker::before {
    content: "+";
}

.is-open > .forms-analysis-accordion-header .forms-analysis-accordion-marker::before,
.is-open > .forms-analysis-comparison-step__header .forms-analysis-accordion-marker::before {
    content: "-";
}

.forms-analysis-accordion-text {
    display: grid;
    gap: 2px;
    min-width: 0;
}

.forms-analysis-accordion-text span:first-child {
    color: var(--text);
    font-weight: 800;
    line-height: 1.25;
}

.forms-analysis-accordion-text span + span {
    display: -webkit-box;
    overflow: hidden;
    color: var(--text-muted);
    font-size: var(--font-sm);
    font-weight: 500;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.forms-analysis-accordion-body[hidden] {
    display: none;
}

.forms-analysis-step-metrics,
.forms-analysis-mini-metrics,
.forms-analysis-number-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
    gap: var(--space-3);
    margin-top: var(--space-4);
}

.forms-analysis-step-metrics--header {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-2);
    margin-top: 0;
}

.forms-analysis-step-metrics > div,
.forms-analysis-mini-metrics > div,
.forms-analysis-number-grid > div {
    display: grid;
    gap: var(--space-1);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--bg-muted);
    padding: 12px;
}

.forms-analysis-step-metrics--header > div {
    padding: 9px 10px;
}

.forms-analysis-step-empty {
    grid-column: span 2;
}

.forms-analysis-step-empty strong {
    overflow-wrap: anywhere;
}

.forms-analysis-step-metrics span,
.forms-analysis-mini-metrics span,
.forms-analysis-number-grid span,
.forms-analysis-field-card__header span {
    color: var(--text-muted);
    font-size: var(--font-xs);
    font-weight: 800;
}

.forms-analysis-step-metrics strong,
.forms-analysis-mini-metrics strong,
.forms-analysis-number-grid strong {
    color: var(--text);
}

.forms-analysis-field-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--space-3);
    margin-top: var(--space-4);
}

.forms-analysis-field-card {
    display: grid;
    gap: var(--space-3);
    min-width: 0;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--bg-elevated);
    padding: 12px;
}

.forms-analysis-field-card__header,
.forms-analysis-field-badges {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-3);
}

.forms-analysis-field-card__header h4 {
    margin: 0 0 4px;
    color: var(--text);
    font-size: var(--font-sm);
    line-height: 1.25;
    overflow-wrap: anywhere;
}

.forms-analysis-field-badges {
    flex-wrap: wrap;
    justify-content: flex-end;
}

.forms-analysis-field-badges span {
    border-radius: 999px;
    background: var(--bg-muted);
    color: var(--text-muted);
    font-size: var(--font-xs);
    font-weight: 800;
    padding: 3px 8px;
    white-space: nowrap;
}

.forms-analysis-table-wrap {
    overflow-x: auto;
}

.forms-analysis-mini-table {
    min-width: 360px;
}

.forms-analysis-chart {
    display: grid;
    gap: 10px;
}

.forms-analysis-chart h5 {
    margin: 0;
    color: var(--text);
    font-size: var(--font-sm);
    line-height: 1.25;
}

.forms-analysis-bar {
    display: grid;
    gap: 5px;
    min-width: 0;
}

.forms-analysis-bar__label {
    display: flex;
    justify-content: space-between;
    gap: var(--space-2);
    min-width: 0;
    color: var(--text);
    font-size: var(--font-xs);
}

.forms-analysis-bar__label span {
    overflow: hidden;
    min-width: 0;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.forms-analysis-bar__label strong {
    flex: 0 0 auto;
    color: var(--text-muted);
    font-weight: 800;
}

.forms-analysis-bar__track {
    overflow: hidden;
    height: 8px;
    border-radius: 999px;
    background: var(--bg-muted);
}

.forms-analysis-bar__track span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: var(--primary);
}

.forms-analysis-bar.is-empty .forms-analysis-bar__track span {
    background: var(--warning);
}

.forms-analysis-text-list {
    display: grid;
    gap: var(--space-2);
}

.forms-analysis-text-list > div {
    display: grid;
    gap: var(--space-1);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--bg-muted);
    padding: 10px;
}

.forms-analysis-text-list p {
    overflow: auto;
    max-height: 150px;
    margin: 0;
    color: var(--text);
    overflow-wrap: anywhere;
    white-space: pre-wrap;
}

.forms-analysis-text-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
}

.forms-analysis-comparison-step {
    overflow: hidden;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--bg-elevated);
}

.forms-analysis-comparison-step__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    background: var(--bg-muted);
    padding: 12px;
}

.forms-analysis-comparison-step__header h4,
.forms-analysis-step-title h3 {
    margin: 0;
}

.forms-analysis-comparison {
    overflow-x: auto;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    margin-top: var(--space-4);
}

.forms-analysis-comparison-step .forms-analysis-comparison {
    border-width: 1px 0 0;
    border-radius: 0;
    margin-top: 0;
}

.forms-analysis-comparison table {
    min-width: 960px;
}

.forms-analysis-comparison th,
.forms-analysis-comparison td {
    min-width: 180px;
    max-width: 280px;
    vertical-align: top;
    white-space: normal;
    overflow-wrap: anywhere;
}

.forms-analysis-comparison thead th {
    position: sticky;
    top: var(--topbar-height, 0px);
    z-index: 2;
    background: var(--bg-elevated);
}

.forms-analysis-comparison th:first-child {
    position: sticky;
    left: 0;
    z-index: 3;
    min-width: 260px;
    background: var(--bg-elevated);
}

.forms-analysis-comparison tbody th span {
    display: block;
    margin-top: 4px;
    color: var(--text-muted);
    font-size: var(--font-xs);
    font-weight: 800;
}

.forms-ai-config {
    display: grid;
    gap: var(--space-4);
    margin-top: var(--space-4);
}

.forms-ai-actions-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--space-3);
}

.forms-ai-action-card {
    position: relative;
    display: grid;
    gap: var(--space-2);
    min-width: 0;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--bg-elevated);
    padding: 12px;
    cursor: pointer;
}

.forms-ai-action-card.is-selected,
.forms-ai-action-card:has(input:checked) {
    border-color: var(--primary);
    box-shadow: 0 0 0 3px var(--focus);
}

.forms-ai-action-card input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.forms-ai-action-card span {
    color: var(--text);
    font-weight: 900;
}

.forms-ai-action-card small {
    color: var(--text-muted);
    font-size: var(--font-sm);
    line-height: 1.35;
}

.forms-ai-options-grid {
    display: grid;
    grid-template-columns: minmax(260px, 1fr) auto auto auto;
    gap: var(--space-3);
    align-items: end;
}

.forms-ai-options-grid .form-group {
    margin: 0;
}

.forms-ai-runbar {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3);
    align-items: center;
    justify-content: flex-end;
    margin-top: var(--space-4);
    border-top: 1px solid var(--border);
    padding-top: var(--space-4);
}

.forms-ai-runbar form {
    margin: 0;
}

.forms-ai-runbar span {
    color: var(--text-muted);
    font-size: var(--font-sm);
    font-weight: 800;
}

.forms-ai-context-preview,
.forms-ai-result-text {
    overflow: auto;
    max-height: 520px;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--bg-muted);
    color: var(--text);
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: var(--font-sm);
    line-height: 1.55;
    padding: 14px;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
}

.forms-ai-result-meta {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: var(--space-3);
    margin-bottom: var(--space-4);
}

.forms-ai-result-meta > div {
    display: grid;
    gap: var(--space-1);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--bg-muted);
    padding: 12px;
}

.forms-ai-result-meta span {
    color: var(--text-muted);
    font-size: var(--font-xs);
    font-weight: 800;
}

.forms-ai-copy-source {
    position: fixed;
    left: -9999px;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}

@media (max-width: 1180px) {
    .forms-builder-layout,
    .forms-import-layout,
    .forms-campaign-detail-grid {
        grid-template-columns: 1fr;
    }

    .forms-palette,
    .forms-properties {
        position: static;
    }

    .forms-palette-grid {
        grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    }

    .forms-field-card {
        grid-template-columns: 28px 38px minmax(0, 1fr);
    }

    .forms-field-badges,
    .forms-field-actions {
        grid-column: 3;
        justify-content: flex-start;
    }
}

@media (max-width: 767px) {
    .forms-filterbar .form-control,
    .forms-filterbar .btn,
    .forms-check-filter,
    .forms-add-step .form-control,
    .forms-add-step .btn {
        max-width: none;
        width: 100%;
    }

    .forms-metadata-form,
    .forms-step-edit,
    .forms-import-form {
        grid-template-columns: 1fr;
    }

    .forms-builder-hero,
    .forms-step-card__bar,
    .forms-preview-title {
        display: grid;
    }

    .forms-builder-actions,
    .forms-step-actions {
        justify-content: stretch;
    }

    .forms-builder-actions .btn,
    .forms-builder-actions form,
    .forms-builder-actions button,
    .forms-step-actions .btn,
    .forms-step-actions form,
    .forms-step-actions button {
        width: 100%;
    }

    .forms-field-card {
        display: flex;
        align-items: flex-start;
        flex-direction: column;
    }

    .forms-field-badges,
    .forms-field-actions {
        justify-content: flex-start;
    }

    .forms-preview-grid {
        grid-template-columns: 1fr;
    }

    .forms-campaign-form-grid {
        grid-template-columns: 1fr;
    }

    .forms-public-hero,
    .forms-public-actions {
        display: grid;
    }

    .forms-response-row,
    .forms-answer-item {
        grid-template-columns: 1fr;
    }

    .forms-analysis-actions,
    .forms-analysis-comparison-step__header {
        flex-wrap: wrap;
        justify-content: stretch;
    }

    .forms-analysis-actions .btn,
    .forms-analysis-comparison-step__header .forms-mini-chip {
        width: 100%;
    }

    .forms-analysis-accordion-header,
    .forms-analysis-step-metrics--header {
        grid-template-columns: 1fr;
    }

    .forms-analysis-step-empty {
        grid-column: auto;
    }

    .forms-analysis-field-grid {
        grid-template-columns: 1fr;
    }

    .forms-analysis-field-card__header {
        display: grid;
    }

    .forms-analysis-field-badges {
        justify-content: flex-start;
    }

    .forms-analysis-comparison thead th,
    .forms-analysis-comparison th:first-child {
        position: static;
    }

    .forms-ai-options-grid,
    .forms-ai-runbar {
        display: grid;
        grid-template-columns: 1fr;
        justify-content: stretch;
    }

    .forms-ai-runbar .btn,
    .forms-ai-runbar form,
    .forms-ai-options-grid .btn {
        width: 100%;
    }

    .forms-public-actions .btn {
        width: 100%;
    }

    .forms-width-25,
    .forms-width-50,
    .forms-width-75,
    .forms-width-100 {
        grid-column: 1 / -1;
    }
}
