.app-client-notice {
    background: #1f2937;
    border-radius: 6px;
    box-shadow: 0 14px 30px rgba(20, 35, 55, 0.18);
    color: #ffffff;
    font-size: 14px;
    line-height: 1.45;
    max-width: min(520px, calc(100vw - 32px));
    padding: 12px 16px;
    position: fixed;
    right: 16px;
    top: 82px;
    transition: opacity 0.2s ease, transform 0.2s ease;
    white-space: pre-line;
    z-index: 2050;
}

.app-client-notice-danger {
    background: #dc3545;
}

.app-client-notice-success {
    background: #198754;
}

.app-client-notice.is-leaving {
    opacity: 0;
    transform: translateY(-8px);
}

.modal {
    overflow: hidden;
    overscroll-behavior: contain;
    z-index: 1060;
}

body.app-modal-scroll-locked {
    overflow: hidden !important;
    overscroll-behavior: none;
}

.modal-dialog {
    --app-modal-gutter: clamp(12px, 2vw, 28px);
    margin-left: auto;
    margin-right: auto;
    max-width: min(760px, calc(100vw - (var(--app-modal-gutter) * 2)));
    width: calc(100vw - (var(--app-modal-gutter) * 2));
}

.modal-dialog.modal-lg {
    max-width: min(1080px, calc(100vw - (var(--app-modal-gutter) * 2)));
}

.modal-dialog.modal-xl {
    max-width: min(1480px, calc(100vw - (var(--app-modal-gutter) * 2)));
}

.modal-dialog-scrollable {
    max-height: calc(100vh - (var(--app-modal-gutter) * 2));
}

.modal-dialog-scrollable .modal-content {
    max-height: calc(100vh - (var(--app-modal-gutter) * 2));
}

.modal-content {
    background: #ffffff;
    display: flex;
    flex-direction: column;
    max-height: calc(100vh - (var(--app-modal-gutter, 24px) * 2));
    overflow: hidden;
}

.modal-body {
    background: #ffffff;
    flex: 1 1 auto;
    min-height: 0;
    overscroll-behavior: contain;
    overflow-y: auto;
}

.modal-backdrop {
    background-color: #26323d;
    z-index: 1050;
}

.modal-backdrop.show {
    opacity: 0.58;
}

.modal-content {
    border: 0;
    box-shadow: 0 22px 70px rgba(15, 23, 42, 0.22);
}

/* Compact admin density */
.breadcrumb {
    font-size: 13px;
}

.card {
    margin-bottom: 16px;
}

.card .card-body {
    padding: 18px;
}

.card-title {
    font-size: 16px;
    margin-bottom: 8px;
}

.card-subtitle {
    font-size: 13px;
    line-height: 1.5;
}

.container-fluid .row {
    --bs-gutter-x: 18px;
    --bs-gutter-y: 12px;
}

.form-group {
    margin-bottom: 12px;
}

.form-label,
form label {
    font-size: 13px;
    margin-bottom: 4px;
}

.form-control,
.form-select {
    font-size: 14px;
    padding-bottom: 8px;
    padding-top: 8px;
}

.form-floating > .form-control,
.form-floating > .form-control-plaintext,
.form-floating > .form-select {
    min-height: 48px;
}

.form-floating > label {
    padding-bottom: 12px;
    padding-top: 12px;
}

.btn {
    --bs-btn-padding-y: 0.42rem;
    --bs-btn-padding-x: 0.75rem;
}

.table > :not(caption) > * > * {
    padding: 9px 12px;
}

.table-sm > :not(caption) > * > * {
    padding: 7px 10px;
}

.modal-header,
.modal-footer {
    padding: 12px 16px;
}

.modal-body {
    padding: 16px;
}

.alert {
    margin-bottom: 14px;
    padding: 10px 14px;
}

.app-avatar {
    align-items: center;
    background: #26c6da;
    border-radius: 50%;
    color: #ffffff;
    display: inline-flex;
    font-weight: 700;
    justify-content: center;
}

.app-avatar-sm {
    height: 34px;
    width: 34px;
}

.app-avatar-lg {
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.2);
    font-size: 22px;
    height: 64px;
    width: 64px;
}

.app-stat-card,
.app-feature,
.auth-box {
    border-radius: 8px;
}

.app-stat-icon {
    align-items: center;
    border-radius: 8px;
    display: inline-flex;
    flex: 0 0 52px;
    font-size: 26px;
    height: 52px;
    justify-content: center;
    width: 52px;
}

.app-feature {
    background: #f6f9fb;
    height: 100%;
    padding: 18px;
}

.app-feature i,
.app-feature strong {
    display: block;
}

.app-feature i {
    font-size: 28px;
    margin-bottom: 8px;
}

.app-feature p {
    color: #6c757d;
    line-height: 1.7;
    margin: 8px 0 0;
}

.app-check-list {
    display: grid;
    gap: 8px;
}

.app-check-row {
    align-items: flex-start;
    border: 1px solid #e9ecef;
    border-radius: 8px;
    display: flex;
    gap: 8px;
    margin: 0;
    padding: 9px 10px;
}

.app-check-row input {
    margin-top: 4px;
}

.app-check-row strong,
.app-check-row small {
    display: block;
}

.app-check-row small {
    color: #6c757d;
}

.app-form-field-list {
    display: grid;
    gap: 10px;
}

.app-form-field-row {
    border: 1px solid #e9ecef;
    border-radius: 8px;
    padding: 10px;
}

.app-form-field-head,
.app-inline-checks {
    align-items: center;
    display: flex;
    gap: 12px;
}

.app-form-field-head {
    border-bottom: 1px solid #eef2f5;
    justify-content: space-between;
    margin-bottom: 10px;
    padding-bottom: 8px;
}

.app-form-field-order {
    align-items: center;
    background: #f6f9fb;
    border-radius: 8px;
    color: #6c757d;
    display: inline-flex;
    height: 34px;
    justify-content: center;
    width: 34px;
}

.app-inline-checks {
    background: #f6f9fb;
    border-radius: 8px;
    flex-wrap: wrap;
    min-height: 38px;
    padding: 8px 10px;
}

.app-inline-checks label {
    margin: 0;
}

.app-check-toggle {
    align-items: center;
    color: #425466;
    cursor: pointer;
    display: inline-flex;
    font-size: 13px;
    gap: 7px;
    user-select: none;
}

.app-check-toggle input {
    height: 1px;
    opacity: 0;
    position: absolute;
    width: 1px;
}

.app-check-toggle span {
    align-items: center;
    background: #ffffff;
    border: 1px solid #cdd8e2;
    border-radius: 6px;
    display: inline-flex;
    flex: 0 0 20px;
    height: 20px;
    justify-content: center;
    transition: background 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease;
    width: 20px;
}

.app-check-toggle span::after {
    border: solid #ffffff;
    border-width: 0 2px 2px 0;
    content: "";
    height: 9px;
    opacity: 0;
    transform: rotate(45deg) translate(-1px, -1px);
    width: 5px;
}

.app-check-toggle input:checked + span {
    background: #26c6da;
    border-color: #26c6da;
    box-shadow: 0 5px 14px rgba(38, 198, 218, 0.22);
}

.app-check-toggle input:checked + span::after {
    opacity: 1;
}

.app-check-toggle input:focus-visible + span {
    box-shadow: 0 0 0 3px rgba(38, 198, 218, 0.2);
}

.app-column-assist {
    background: #f8fbfd;
    border: 1px solid #e1eaf1;
    border-radius: 8px;
    padding: 14px;
}

.app-column-assist-head {
    align-items: flex-start;
    display: flex;
    gap: 14px;
    justify-content: space-between;
}

.app-column-assist-head strong {
    color: #24364b;
    display: block;
    font-weight: 700;
    margin-bottom: 2px;
}

.app-column-assist-head small {
    color: #748494;
    display: block;
}

.app-column-assist-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
}

.app-column-picker {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
    min-height: 38px;
}

.app-column-picker-chip {
    background: #ffffff;
    border: 1px solid #d8e4ec;
    border-radius: 999px;
    color: #24364b;
    font-size: 13px;
    line-height: 1;
    padding: 9px 12px;
    transition: background 0.16s ease, border-color 0.16s ease, color 0.16s ease;
}

.app-column-picker-chip:hover,
.app-column-picker-chip:focus-visible {
    background: #e8f9fc;
    border-color: #26c6da;
    color: #007c91;
}

.app-column-list-tags {
    position: relative;
}

.app-floating-tag-field {
    margin-top: 6px;
}

.app-floating-tag-label {
    background: #ffffff;
    color: #607487;
    font-size: 12px;
    left: 12px;
    line-height: 1.2;
    max-width: calc(100% - 24px);
    overflow: hidden;
    padding: 0 6px;
    position: absolute;
    text-overflow: ellipsis;
    top: -7px;
    white-space: nowrap;
    z-index: 2;
}

.app-edit-column-settings {
    background: #ffffff;
    border: 1px solid #e1eaf1;
    border-radius: 8px;
    padding: 10px;
    width: 100%;
}

.app-edit-column-settings-head strong,
.app-edit-column-settings-head small {
    display: block;
}

.app-edit-column-settings-head strong {
    color: #24364b;
    font-weight: 700;
}

.app-edit-column-settings-head small {
    color: #748494;
    margin-top: 2px;
}

.app-virtual-link-builder {
    background: #ffffff;
    border: 1px solid #dfeaf2;
    border-radius: 8px;
    padding: 12px;
}

.app-virtual-link-builder-head {
    align-items: center;
    display: flex;
    justify-content: space-between;
    margin-bottom: 10px;
}

.app-virtual-link-builder-head strong,
.app-virtual-link-builder-head small {
    display: block;
}

.app-virtual-link-builder-head strong {
    color: #24364b;
    font-weight: 700;
}

.app-virtual-link-builder-head small {
    color: #748494;
    margin-top: 2px;
}

.app-virtual-link-builder-grid {
    align-items: stretch;
    display: grid;
    gap: 10px;
    grid-template-columns: minmax(120px, 0.75fr) minmax(140px, 0.8fr) minmax(140px, 0.8fr) minmax(260px, 1.6fr) minmax(130px, 0.75fr) auto;
}

.app-virtual-link-builder-grid .btn {
    min-height: 48px;
    white-space: nowrap;
}

.app-edit-column-list {
    display: grid;
    gap: 8px;
    margin-top: 10px;
}

.app-edit-column-row {
    background: #f8fbfd;
    border: 1px solid #e6eef4;
    border-radius: 8px;
    display: grid;
    gap: 10px;
    grid-template-columns: minmax(180px, 260px) minmax(260px, 1fr);
    padding: 10px;
}

.app-edit-column-title strong,
.app-edit-column-title small {
    display: block;
    min-width: 0;
}

.app-edit-column-title strong {
    color: #24364b;
    font-weight: 700;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.app-edit-column-title small {
    color: #8a9aaa;
    font-size: 12px;
    margin-top: 2px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.app-edit-column-group {
    display: grid;
    gap: 8px;
    grid-column: 1 / -1;
    grid-template-columns: minmax(190px, 1.1fr) minmax(135px, 0.75fr) minmax(170px, 1fr);
}

.app-edit-column-group.is-basic {
    align-items: center;
    grid-column: auto;
    grid-template-columns: auto minmax(150px, 1fr);
}

.app-edit-column-address {
    background: #ffffff;
    border: 1px solid #dfeaf2;
    border-radius: 8px;
    grid-column: 1 / -1;
    padding: 10px;
}

.app-edit-column-link {
    align-items: center;
    background: #f4fbfd;
    border: 1px solid #bfeaf1;
    border-radius: 8px;
    display: grid;
    gap: 8px;
    grid-column: 1 / -1;
    grid-template-columns: minmax(160px, 0.9fr) auto minmax(260px, 1.4fr) minmax(140px, 0.8fr) minmax(140px, 0.8fr) minmax(120px, 0.6fr) auto;
    padding: 10px;
}

.app-edit-column-link-head strong,
.app-edit-column-link-head small {
    display: block;
}

.app-edit-column-link-head strong {
    color: #0f8fa1;
    font-weight: 700;
}

.app-edit-column-link-head small {
    color: #698092;
    font-size: 12px;
    margin-top: 2px;
}

.app-edit-column-address-head {
    color: #24364b;
    font-size: 12px;
    font-weight: 700;
    margin-bottom: 8px;
}

.app-edit-column-address-grid {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
}

@media (min-width: 1200px) {
    .app-edit-column-row {
        grid-template-columns: minmax(190px, 280px) minmax(250px, 320px) minmax(520px, 1fr);
    }

    .app-edit-column-group {
        grid-column: auto;
    }
}

.app-edit-column-row .app-check-toggle em {
    font-style: normal;
}

.app-edit-profile-settings {
    background: #ffffff;
    border: 1px solid #dfeaf2;
    border-radius: 8px;
    padding: 10px;
}

.app-edit-profile-list {
    display: grid;
    gap: 10px;
    margin-top: 10px;
}

.app-edit-profile-row {
    background: #f8fbfd;
    border: 1px solid #e6eef4;
    border-radius: 8px;
    display: grid;
    gap: 8px;
    padding: 10px;
}

.app-edit-profile-head {
    display: grid;
    gap: 8px;
    grid-template-columns: minmax(180px, 1fr) minmax(120px, 160px) auto;
}

.app-edit-profile-columns {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 14px;
}

.app-edit-profile-columns .app-check-toggle em {
    font-style: normal;
}

.app-condition-builder {
    background: #fff;
    border: 1px solid #dfeaf2;
    border-radius: 8px;
    display: grid;
    gap: 8px;
    padding: 8px;
}

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

.app-condition-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.app-condition-group {
    background: rgba(14, 165, 233, 0.04);
    border: 1px solid #d7e7f1;
    border-radius: 8px;
    display: grid;
    gap: 6px;
    padding: 8px;
}

.app-condition-group-head {
    align-items: center;
    display: grid;
    gap: 6px;
    grid-template-columns: 58px auto 96px auto 120px 1fr auto;
}

.app-condition-group-compact > .app-condition-group-head {
    grid-template-columns: auto 96px 1fr auto;
}

.app-condition-group-compact.app-condition-first-item > .app-condition-group-head {
    grid-template-columns: 1fr auto;
}

.app-condition-group-compact > .app-condition-group-head > [data-condition-join] {
    display: none;
}

.app-condition-group.app-condition-first-item > .app-condition-group-head > [data-condition-join],
.app-condition-group.app-condition-first-item > .app-condition-group-head > [data-condition-join-label],
.app-condition-group.app-condition-first-item > .app-condition-group-head > [data-condition-join-mode] {
    display: none;
}

.app-condition-group-list {
    display: grid;
    gap: 6px;
}

.app-condition-row {
    align-items: center;
    display: grid;
    gap: 6px;
    grid-template-columns: 58px minmax(160px, 1.1fr) minmax(150px, 0.9fr) minmax(160px, 1fr) 96px auto;
}

.app-relation-rule-condition-line.app-condition-first-item {
    grid-template-columns: minmax(180px, 1fr) minmax(120px, 0.75fr) minmax(180px, 1fr) 48px;
}

.app-relation-rule-condition-line.app-condition-first-item > [data-condition-join],
.app-relation-rule-condition-line.app-condition-first-item > [data-condition-join-mode] {
    display: none;
}

.app-condition-group-compact > .app-condition-group-list > .app-relation-rule-condition-line:first-child {
    grid-template-columns: minmax(180px, 1fr) minmax(120px, 0.6fr) minmax(180px, 1fr) 96px auto;
}

.app-condition-group-compact > .app-condition-group-list > .app-relation-rule-condition-line:first-child > [data-condition-join] {
    display: none;
}

.app-condition-group-compact > .app-condition-group-list > .app-relation-rule-condition-line.app-condition-first-item {
    grid-template-columns: minmax(180px, 1fr) minmax(120px, 0.75fr) minmax(180px, 1fr) 48px;
}

.app-condition-join-mode {
    min-width: 86px;
}

.app-condition-select-label {
    color: #6b7f90;
    font-size: 0.76rem;
    font-weight: 700;
    margin: 0;
    white-space: nowrap;
}

.app-settings-subpanel {
    background: #f8fbfd;
    border: 1px solid #dfeaf2;
    border-radius: 8px;
    padding: 12px;
}

.app-relation-impact {
    background: #f3fbff;
}

.app-relation-impact-grid {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
}

.app-relation-impact-item {
    background: #fff;
    border: 1px solid #d8e8f2;
    border-radius: 6px;
    min-height: 58px;
    padding: 8px 10px;
}

.app-relation-impact-item span {
    color: #6b7f90;
    display: block;
    font-size: 0.76rem;
    font-weight: 700;
    margin-bottom: 4px;
}

.app-relation-impact-item strong {
    color: #18324a;
    display: block;
    font-size: 0.88rem;
    font-weight: 700;
    line-height: 1.35;
    overflow-wrap: anywhere;
}

.app-relation-impact-item-danger {
    background: #fff6f6;
    border-color: #ffd0d0;
}

.app-relation-impact-item-danger span,
.app-relation-impact-item-danger strong {
    color: #b42318;
}

.app-relation-graph {
    background: #f8fbfd;
    border: 1px solid #dfeaf2;
    border-radius: 8px;
    padding: 12px;
}

.app-relation-graph-empty {
    color: #6b7f90;
    font-size: 0.86rem;
}

.app-relation-graph-head {
    align-items: center;
    display: flex;
    gap: 12px;
    justify-content: space-between;
    margin-bottom: 0;
}

.app-relation-graph-head strong {
    color: #143047;
    display: block;
}

.app-relation-graph-head p {
    color: #6b7f90;
    font-size: 0.82rem;
    margin: 2px 0 0;
}

.app-relation-graph-head > span {
    background: #e9f8fc;
    border: 1px solid #c9edf5;
    border-radius: 999px;
    color: #0f6f83;
    font-size: 0.78rem;
    font-weight: 700;
    padding: 4px 10px;
    white-space: nowrap;
}

.app-relation-graph-head-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
}

.app-relation-graph-head-actions > span {
    background: #e9f8fc;
    border: 1px solid #c9edf5;
    border-radius: 999px;
    color: #0f6f83;
    font-size: 0.78rem;
    font-weight: 700;
    padding: 4px 10px;
    white-space: nowrap;
}

.app-relation-graph-canvas {
    display: grid;
    gap: 8px;
}

.app-relation-graph-body {
    margin-top: 10px;
}

.app-relation-graph-warnings {
    display: grid;
    gap: 6px;
    margin-bottom: 10px;
}

.app-relation-graph-warning {
    background: #fff7ed;
    border: 1px solid #fed7aa;
    border-radius: 7px;
    display: grid;
    gap: 2px;
    padding: 8px 10px;
}

.app-relation-graph-warning strong {
    color: #9a3412;
    font-size: 0.8rem;
}

.app-relation-graph-warning span {
    color: #431407;
    font-size: 0.78rem;
    overflow-wrap: anywhere;
}

.app-relation-graph-edge {
    align-items: stretch;
    background: #ffffff;
    border: 1px solid #d8e8f2;
    border-radius: 8px;
    display: grid;
    gap: 8px;
    grid-template-columns: minmax(180px, 1fr) 150px minmax(180px, 1fr) minmax(180px, 1fr);
    padding: 8px;
}

.app-relation-graph-edge.is-inactive {
    opacity: 0.55;
}

.app-relation-graph-node {
    background: #f6fbff;
    border: 1px solid #d7e9f5;
    border-radius: 7px;
    padding: 8px 10px;
}

.app-relation-graph-node span,
.app-relation-graph-meta span,
.app-relation-graph-arrow small {
    color: #6b7f90;
    display: block;
    font-size: 0.72rem;
}

.app-relation-graph-node strong {
    color: #18324a;
    display: block;
    font-size: 0.86rem;
    line-height: 1.35;
    margin-top: 2px;
}

.app-relation-graph-arrow {
    align-items: center;
    color: #0ea5e9;
    display: grid;
    justify-items: center;
    text-align: center;
}

.app-relation-graph-arrow span {
    font-size: 1.25rem;
    font-weight: 800;
    line-height: 1;
}

.app-relation-graph-meta {
    align-content: center;
    background: #fbfdff;
    border: 1px solid #e3eef5;
    border-radius: 7px;
    display: grid;
    gap: 3px;
    padding: 8px 10px;
}

.app-relation-graph-meta span:last-child {
    color: #143047;
}

.app-relation-graph-editor-summary {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 12px;
}

.app-relation-graph-editor-summary span {
    background: #eef8fb;
    border: 1px solid #cfedf5;
    border-radius: 999px;
    color: #0f6f83;
    font-size: 0.78rem;
    font-weight: 700;
    padding: 4px 10px;
}

.app-relation-graph-editor-help {
    align-items: center;
    background: #f8fcff;
    border: 1px dashed #bfd8e9;
    border-radius: 8px;
    color: #51687b;
    display: flex;
    gap: 8px;
    margin-bottom: 12px;
    padding: 8px 10px;
}

.app-relation-graph-editor-section {
    display: grid;
    gap: 8px;
    margin-top: 14px;
}

.app-relation-graph-editor-section h6 {
    color: #143047;
    font-weight: 800;
    margin: 0;
}

.app-relation-graph-table-grid,
.app-relation-graph-editor-list {
    display: grid;
    gap: 8px;
}

.app-relation-graph-table-grid {
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.app-relation-graph-table-card,
.app-relation-graph-editor-relation {
    background: #ffffff;
    border: 1px solid #d8e8f2;
    border-radius: 8px;
    padding: 10px;
}

.app-relation-graph-table-card {
    transition: border-color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease;
}

.app-relation-graph-table-card.is-drop-target {
    border-color: #26c6da;
    box-shadow: 0 0 0 3px rgba(38, 198, 218, 0.14);
    transform: translateY(-1px);
}

.app-relation-graph-table-card.is-line-source {
    border-color: #6c63ff;
    box-shadow: 0 0 0 3px rgba(108, 99, 255, 0.12);
}

.app-relation-graph-table-card.is-drop-invalid {
    border-color: #ef5350;
    box-shadow: 0 0 0 3px rgba(239, 83, 80, 0.12);
}

.app-relation-graph-table-card-head {
    align-items: flex-start;
    display: flex;
    gap: 8px;
    justify-content: space-between;
}

.app-relation-graph-table-card-head .btn,
.app-relation-graph-line-handle {
    flex: 0 0 auto;
    white-space: nowrap;
}

.app-relation-graph-line-handle {
    align-items: center;
    background: #f8fcff;
    border: 1px solid #cfe4ef;
    border-radius: 999px;
    color: #0f6f83;
    cursor: crosshair;
    display: inline-flex;
    font-size: 0.76rem;
    font-weight: 800;
    gap: 5px;
    min-height: 30px;
    padding: 4px 9px;
}

.app-relation-graph-line-handle:hover {
    background: #e9f8fb;
    border-color: #26c6da;
}

.app-relation-graph-line-drag {
    background: linear-gradient(90deg, #26c6da, #6c63ff);
    border-radius: 999px;
    box-shadow: 0 0 0 3px rgba(38, 198, 218, 0.16);
    height: 3px;
    left: 0;
    pointer-events: none;
    position: fixed;
    top: 0;
    transform-origin: 0 50%;
    width: 1px;
    z-index: 3000;
}

body.is-relation-graph-line-dragging {
    user-select: none;
}

.app-relation-graph-table-card strong,
.app-relation-graph-editor-route strong {
    color: #143047;
    display: block;
    font-size: 0.9rem;
    overflow-wrap: anywhere;
}

.app-relation-graph-table-columns {
    display: grid;
    gap: 8px;
    grid-template-columns: 1fr 1fr;
    margin-top: 8px;
}

.app-relation-graph-table-columns span,
.app-relation-graph-editor-route span {
    color: #6b7f90;
    display: block;
    font-size: 0.74rem;
    margin-bottom: 3px;
}

.app-relation-graph-table-columns em {
    color: #94a3b8;
    font-style: normal;
    font-size: 0.78rem;
}

.app-relation-graph-chip {
    background: #edf9fc;
    border: 1px solid #cdeef5;
    border-radius: 999px;
    color: #0f6f83;
    cursor: pointer;
    display: inline-flex;
    font-size: 0.74rem;
    font-weight: 700;
    margin: 2px 3px 2px 0;
    max-width: 100%;
    padding: 3px 8px;
    text-align: left;
}

.app-relation-graph-chip:hover {
    background: #dff5fa;
}

.app-relation-graph-editor-relation {
    align-items: center;
    display: grid;
    gap: 10px;
    grid-template-columns: minmax(180px, 0.9fr) minmax(280px, 1.6fr) auto;
}

.app-relation-graph-editor-relation.is-inactive {
    opacity: 0.58;
}

.app-relation-graph-editor-facts {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.app-relation-graph-editor-facts span {
    background: #f7fbff;
    border: 1px solid #e1edf5;
    border-radius: 999px;
    color: #31506a;
    font-size: 0.73rem;
    padding: 3px 8px;
}

.app-code-preview {
    max-height: 220px;
    overflow: auto;
    border: 1px solid #1e293b;
    border-radius: 6px;
    background: #0f172a;
    color: #e2e8f0;
    font-size: 0.82rem;
    line-height: 1.5;
    padding: 12px;
    white-space: pre-wrap;
}

.app-relation-key-row {
    grid-template-columns: 58px minmax(180px, 1fr) 24px minmax(180px, 1fr) auto;
}

.app-relation-rule-row {
    background: rgba(14, 165, 233, 0.04);
    border: 1px solid #d7e7f1;
    border-radius: 8px;
    display: grid;
    gap: 8px;
    padding: 8px;
}

.app-relation-rule-main {
    align-items: center;
    display: grid;
    gap: 6px;
    grid-template-columns: minmax(112px, 0.7fr) minmax(180px, 1.15fr) 24px minmax(180px, 1.15fr) minmax(104px, 0.65fr) minmax(132px, 0.75fr) auto;
}

.app-relation-formula-field {
    grid-column: 1 / -1;
}

.app-relation-formula-builder {
    border: 1px solid #dfeaf2;
    border-radius: 8px;
    margin-bottom: 10px;
    padding: 10px;
}

.app-relation-formula-template-grid {
    display: grid;
    gap: 8px;
    grid-template-columns: minmax(180px, 1fr) minmax(160px, 1fr) minmax(160px, 1fr) minmax(96px, 0.5fr);
}

.app-relation-formula-token-list {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 8px;
    max-height: 88px;
    overflow: auto;
}

.app-relation-formula-token {
    border-color: #d7e6ef;
    color: #23445c;
    font-size: 0.78rem;
    line-height: 1.25;
    padding: 4px 8px;
}

.app-relation-formula-textarea {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    line-height: 1.45;
    min-height: 88px;
}

.app-relation-formula-preview-wrap {
    margin-top: 10px;
}

.app-relation-formula-preview-title {
    color: #6b7f90;
    font-size: 0.78rem;
    font-weight: 700;
    margin-bottom: 4px;
}

.app-relation-formula-preview {
    margin: 0;
    max-height: 140px;
    overflow: auto;
    white-space: pre-wrap;
}

.app-relation-formula-help {
    color: #49677d;
    font-size: 0.82rem;
    margin-top: 8px;
}

.app-relation-formula-help summary {
    cursor: pointer;
    font-weight: 700;
}

.app-relation-formula-help-body {
    display: grid;
    gap: 8px;
    margin-top: 6px;
}

.app-relation-formula-help-list {
    display: grid;
    gap: 4px 10px;
    grid-template-columns: max-content 1fr;
}

.app-relation-compute-builder {
    background: rgba(15, 118, 110, 0.04);
    border: 1px solid #d7e7f1;
    border-radius: 8px;
    margin-bottom: 10px;
    padding: 10px;
}

.app-relation-compute-dataset-list {
    display: grid;
    gap: 8px;
}

.app-relation-compute-dataset-row {
    background: #fff;
    border: 1px solid #dceaf2;
    border-radius: 8px;
    padding: 8px;
}

.app-relation-compute-dataset-head,
.app-relation-compute-dataset-grid,
.app-relation-compute-process-grid,
.app-relation-compute-filter-row {
    align-items: center;
    display: grid;
    gap: 6px;
}

.app-relation-compute-dataset-head {
    grid-template-columns: minmax(140px, 0.6fr) minmax(220px, 1fr) auto;
}

.app-relation-compute-dataset-grid {
    grid-template-columns: minmax(160px, 0.7fr) minmax(160px, 0.7fr) minmax(240px, 1.4fr);
    margin-top: 8px;
}

.app-relation-compute-terms {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.app-relation-compute-terms span {
    background: #f6fbff;
    border: 1px solid #d8e8f2;
    border-radius: 999px;
    color: #406075;
    font-size: 0.78rem;
    padding: 4px 9px;
}

.app-relation-compute-process-grid {
    grid-template-columns: repeat(4, minmax(120px, 1fr));
}

.app-relation-job-targets {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    max-width: 280px;
}

.app-relation-job-target-chip {
    background: #f6fbff;
    border: 1px solid #d8e8f2;
    border-radius: 999px;
    color: #36566d;
    display: inline-flex;
    font-size: 0.75rem;
    max-width: 100%;
    overflow-wrap: anywhere;
    padding: 2px 7px;
}

.app-relation-compute-filter-list {
    display: grid;
    gap: 6px;
    margin-top: 8px;
}

.app-relation-compute-split-list {
    display: grid;
    gap: 6px;
}

.app-relation-compute-split-row {
    align-items: center;
    display: grid;
    gap: 6px;
    grid-template-columns: minmax(110px, 0.6fr) repeat(4, minmax(120px, 1fr)) auto;
}

.app-relation-compute-array-list {
    grid-column: 1 / -1;
}

.app-relation-compute-array-toolbar {
    align-items: center;
    display: grid;
    gap: 6px;
}

.app-relation-compute-array-toolbar {
    grid-template-columns: minmax(150px, 0.35fr) minmax(260px, 1fr);
    margin-bottom: 6px;
}

.app-relation-compute-array-tag-input {
    min-width: 0;
    position: relative;
}

.app-relation-compute-array-range {
    display: grid;
    gap: 6px;
    grid-template-columns: minmax(90px, 1fr) 80px 80px 80px auto;
    margin-top: 6px;
}

.app-relation-compute-array-tag-input .app-tag-input-box {
    background: #ffffff;
    min-height: 42px;
    padding: 5px 8px;
}

.app-relation-compute-array-tag-input .app-tag-entry {
    min-height: 28px;
}

.app-relation-compute-array-tag-input .app-tag-chip-label,
.app-relation-compute-array-tag-input .app-tag-chip-remove {
    min-height: 24px;
}

.app-relation-compute-array-tag-input .app-tag-chip-label {
    padding: 2px 7px 2px 9px;
}

.app-relation-compute-array-tag-input .app-tag-chip-remove {
    padding: 2px 7px 2px 3px;
}

@media (max-width: 900px) {
    .app-relation-compute-array-range {
        grid-template-columns: 1fr 1fr;
    }

    .app-relation-compute-array-range .btn {
        grid-column: 1 / -1;
    }
}

.app-relation-compute-split-row.is-split-array [data-relation-compute-array-list] {
    display: none;
}

.app-relation-compute-split-row.is-list-array [data-relation-compute-split-dataset],
.app-relation-compute-split-row.is-list-array [data-relation-compute-split-column],
.app-relation-compute-split-row.is-list-array [data-relation-compute-split-separator] {
    opacity: 0.45;
    pointer-events: none;
}

.app-relation-compute-filter-row {
    grid-template-columns: minmax(160px, 0.8fr) minmax(100px, 0.45fr) minmax(180px, 1fr) auto;
}

.app-relation-compute-columns select {
    min-height: 96px;
}

.app-relation-compute-preview {
    background: #f7fbfe;
    border: 1px solid #d7e9f5;
    border-radius: 8px;
    padding: 8px 10px;
}

.app-relation-compute-preview summary {
    color: #143047;
    cursor: pointer;
    font-weight: 700;
}

.app-relation-compute-preview-body {
    margin-top: 8px;
}

.app-relation-preview-chip-list {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin: 6px 0;
}

.app-relation-preview-chip {
    background: #e9f8fc;
    border: 1px solid #c6ebf3;
    border-radius: 999px;
    color: #0c6883;
    display: inline-flex;
    font-size: 0.78rem;
    padding: 4px 8px;
}

.app-relation-error-context,
.app-relation-error-compact {
    background: #fff7ed;
    border: 1px solid #fed7aa;
    border-radius: 8px;
    color: #7c2d12;
    padding: 8px 10px;
}

.app-relation-error-compact {
    max-width: 320px;
}

.app-relation-error-title {
    color: #431407;
    font-size: 0.86rem;
    font-weight: 700;
    line-height: 1.35;
    overflow-wrap: anywhere;
}

.app-relation-error-chip-list {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 6px;
}

.app-relation-error-chip {
    align-items: center;
    background: #ffedd5;
    border: 1px solid #fdba74;
    border-radius: 999px;
    display: inline-flex;
    gap: 5px;
    max-width: 100%;
    padding: 3px 8px;
}

.app-relation-error-chip span,
.app-relation-error-cause span {
    color: #9a3412;
    font-size: 0.72rem;
    font-weight: 700;
}

.app-relation-error-chip strong {
    color: #431407;
    font-size: 0.78rem;
    font-weight: 700;
    overflow-wrap: anywhere;
}

.app-relation-error-cause {
    display: grid;
    gap: 2px;
    margin-top: 6px;
}

.app-relation-error-cause strong {
    color: #431407;
    font-size: 0.8rem;
    font-weight: 600;
    overflow-wrap: anywhere;
}

.app-relation-diff-list {
    display: grid;
    gap: 8px;
}

.app-relation-diff-item {
    background: #f8fbff;
    border: 1px solid #d8e8f6;
    border-radius: 8px;
    display: grid;
    gap: 8px;
    padding: 8px;
}

.app-relation-diff-meta {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.app-relation-diff-index {
    background: #e0f2fe;
    border-radius: 999px;
    color: #0369a1;
    font-size: 0.72rem;
    font-weight: 800;
    padding: 2px 7px;
}

.app-relation-diff-column {
    color: #143047;
    font-size: 0.86rem;
}

.app-relation-diff-key {
    color: #64748b;
    font-size: 0.75rem;
    overflow-wrap: anywhere;
}

.app-relation-diff-flow {
    align-items: center;
    display: grid;
    gap: 8px;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
}

.app-relation-diff-side {
    display: grid;
    gap: 3px;
    min-width: 0;
}

.app-relation-diff-label {
    color: #64748b;
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0;
}

.app-relation-diff-value {
    border-radius: 7px;
    display: block;
    font-size: 0.78rem;
    line-height: 1.45;
    max-height: 82px;
    min-height: 32px;
    overflow: auto;
    overflow-wrap: anywhere;
    padding: 6px 8px;
    white-space: pre-wrap;
}

.app-relation-diff-value-before {
    background: #fff7ed;
    border: 1px solid #fed7aa;
    color: #7c2d12;
}

.app-relation-diff-value-after {
    background: #ecfdf5;
    border: 1px solid #bbf7d0;
    color: #14532d;
}

.app-relation-diff-arrow {
    color: #0ea5e9;
    font-size: 0.95rem;
    font-weight: 900;
}

.app-relation-rule-conditions {
    grid-column: 1 / -1;
}

.app-relation-rule-condition-head,
.app-relation-rule-condition-line {
    align-items: center;
    display: grid;
    gap: 6px;
    grid-template-columns: 58px minmax(180px, 1fr) minmax(120px, 0.6fr) minmax(180px, 1fr);
}

.app-relation-rule-condition-head {
    grid-template-columns: minmax(240px, 1fr);
    margin-bottom: 6px;
}

.app-relation-rule-condition-head > [data-relation-condition-group-add] {
    width: 100%;
}

.app-relation-rule-condition-line {
    grid-template-columns: 58px minmax(180px, 1fr) minmax(120px, 0.75fr) minmax(180px, 1fr) 96px 48px;
}

.app-relation-rule-condition-list {
    display: grid;
    gap: 6px;
}

.app-relation-disabled-select {
    background-color: #eef4f8;
    color: #6b7f90;
}

.app-relation-parent-key-list {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.app-condition-join {
    color: #008ec4;
    font-size: 0.76rem;
    font-weight: 700;
    text-align: right;
}

@media (max-width: 768px) {
    .app-condition-group-head,
    .app-condition-row {
        grid-template-columns: 1fr auto;
    }

    .app-condition-join {
        grid-column: 1 / -1;
        text-align: left;
    }

    .app-condition-group-head > .form-select,
    .app-condition-group-head > .btn,
    .app-condition-group-head > .app-condition-select-label {
        grid-column: 1 / -1;
    }

    .app-condition-row > .form-control,
    .app-condition-row > .form-select {
        grid-column: 1 / -1;
    }

    .app-relation-key-row,
    .app-relation-rule-main {
        grid-template-columns: 1fr auto;
    }

    .app-relation-rule-main > .form-control,
    .app-relation-rule-main > .form-select,
    .app-relation-rule-main > .text-muted {
        grid-column: 1 / -1;
    }

    .app-relation-rule-conditions {
        grid-column: 1 / -1;
    }

    .app-relation-formula-field {
        grid-column: 1 / -1;
    }

    .app-relation-formula-template-grid {
        grid-template-columns: 1fr;
    }

    .app-relation-rule-condition-head,
    .app-relation-rule-condition-line {
        grid-template-columns: 1fr;
    }

    .app-relation-diff-flow {
        grid-template-columns: 1fr;
    }

    .app-relation-diff-arrow {
        text-align: center;
    }

    .app-relation-graph-head {
        align-items: flex-start;
        flex-direction: column;
    }

    .app-relation-graph-head-actions {
        justify-content: flex-start;
        width: 100%;
    }

    .app-relation-graph-edge {
        grid-template-columns: 1fr;
    }

    .app-relation-graph-table-columns,
    .app-relation-graph-editor-relation {
        grid-template-columns: 1fr;
    }
}

.app-floating-field > .form-control,
.app-floating-field > .form-select {
    border-radius: 8px;
    min-height: 48px;
}

.app-floating-field > textarea.form-control {
    min-height: 96px;
}

.app-floating-field > label {
    color: #6c757d;
}

.app-floating-field.is-disabled {
    opacity: 0.55;
}

.app-labelled-field {
    background: #ffffff;
    border: 1px solid #dce5eb;
    border-radius: 8px;
    box-sizing: border-box;
    min-height: 48px;
    padding: 15px 11px 8px;
    position: relative;
    transition: border-color 0.18s ease, box-shadow 0.18s ease;
    width: 100%;
}

.app-labelled-field:focus-within {
    border-color: #26c6da;
    box-shadow: 0 0 0 3px rgba(38, 198, 218, 0.16);
}

.app-labelled-field > .app-field-label {
    background: #ffffff;
    color: #6c7d8c;
    font-size: 13px;
    left: 10px;
    line-height: 1.2;
    max-width: calc(100% - 20px);
    overflow: hidden;
    padding: 0 6px;
    position: absolute;
    text-overflow: ellipsis;
    top: -0.55rem;
    transition: color 0.18s ease;
    white-space: nowrap;
    z-index: 2;
}

.app-labelled-field:focus-within > .app-field-label {
    color: #1297a8;
}

.app-field-settings-grid > [class*="col-"] {
    position: relative;
}

.app-field-setting-section {
    align-items: center;
    color: #24364b;
    display: flex;
    font-size: 0.88rem;
    font-weight: 700;
    gap: 10px;
    margin-top: 4px;
}

.app-field-setting-section::after {
    background: #e5edf3;
    content: "";
    flex: 1 1 auto;
    height: 1px;
}

.app-field-setting-section > span {
    align-items: center;
    display: inline-flex;
    gap: 6px;
    white-space: nowrap;
}

.app-field-settings-grid > [class*="col-"] > .form-label {
    background: #ffffff;
    color: #6c7d8c;
    font-size: 13px;
    left: calc(var(--bs-gutter-x, 1.5rem) * 0.5 + 10px);
    line-height: 1.2;
    margin: 0;
    max-width: calc(100% - var(--bs-gutter-x, 1.5rem) - 20px);
    overflow: hidden;
    padding: 0 6px;
    position: absolute;
    text-overflow: ellipsis;
    top: -0.55rem;
    transition: color 0.18s ease;
    white-space: nowrap;
    z-index: 2;
}

.app-field-settings-grid > [class*="col-"]:focus-within > .form-label {
    color: #1297a8;
}

.app-field-settings-grid > [class*="col-"] > .form-control,
.app-field-settings-grid > [class*="col-"] > .form-select {
    border-color: #dce5eb;
    border-radius: 8px;
    min-height: 48px;
    padding-bottom: 7px;
    padding-top: 17px;
}

.app-field-settings-grid > [class*="col-"] > .form-select {
    padding-right: 32px;
}

.app-field-settings-grid > [class*="col-"] > textarea.form-control {
    min-height: 100px;
}

.app-field-settings-grid > [class*="col-"] > .form-control:focus,
.app-field-settings-grid > [class*="col-"] > .form-select:focus,
.app-field-settings-grid .app-settings-tag-input:focus-within,
.app-field-settings-grid .app-inline-checks:focus-within {
    border-color: #26c6da;
    box-shadow: 0 0 0 3px rgba(38, 198, 218, 0.16);
}

.app-field-settings-grid .app-settings-tag-input,
.app-field-settings-grid .app-inline-checks {
    background: #ffffff;
    border: 1px solid #dce5eb;
    border-radius: 8px;
    box-sizing: border-box;
    min-height: 48px;
    padding: 15px 11px 8px;
    transition: border-color 0.18s ease, box-shadow 0.18s ease;
    width: 100%;
}

.app-field-settings-grid .app-settings-tag-input .app-tag-input-box {
    border: 0;
    min-height: 24px;
    padding: 0;
}

.app-field-settings-grid .form-text {
    display: block;
    margin-top: 4px;
}

.app-labelled-field > .form-control,
.app-labelled-field > .form-select,
.app-labelled-field .app-suggest-box > .form-control {
    border: 0;
    box-shadow: none;
    min-height: 24px;
    padding: 0;
}

.app-labelled-field > .form-control:focus,
.app-labelled-field > .form-select:focus,
.app-labelled-field .app-suggest-box > .form-control:focus {
    border: 0;
    box-shadow: none;
}

.app-labelled-field .app-choice-options {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 14px;
}

.app-labelled-field .form-check {
    margin-bottom: 0;
}

.app-labelled-field.app-choice-field,
.app-labelled-field .app-tag-input-box {
    border-color: #dce5eb;
}

.app-date-picker {
    color-scheme: light;
}

.app-date-picker::-webkit-calendar-picker-indicator {
    cursor: pointer;
}

.app-icon-button {
    align-items: center;
    border: 0;
    border-radius: 999px;
    display: inline-flex;
    flex: 0 0 auto;
    height: 34px;
    justify-content: center;
    padding: 0;
    transition: background 0.16s ease, color 0.16s ease, transform 0.16s ease;
    width: 34px;
}

.app-icon-button:hover {
    transform: translateY(-1px);
}

.app-icon-button-light {
    background: #f6f9fb;
    color: #425466;
}

.app-icon-button-light:hover {
    background: #dff5f8;
    color: #0f8fa1;
}

.app-icon-button-light.is-active {
    background: #26c6da;
    color: #ffffff;
}

.app-icon-button-danger {
    background: #fff1f3;
    color: #fb4568;
}

.app-icon-button-danger:hover {
    background: #fb4568;
    color: #ffffff;
}

.app-postal-field .form-label {
    color: #24364b;
    font-size: 13px;
    font-weight: 700;
    margin-bottom: 6px;
}

.app-postal-control {
    display: grid;
    gap: 8px;
    grid-template-columns: minmax(0, 1fr) auto;
}

.app-postal-control .form-control {
    border-radius: 8px;
    min-height: 48px;
}

.app-postal-control .btn {
    align-items: center;
    border-radius: 8px;
    display: inline-flex;
    min-height: 48px;
    white-space: nowrap;
}

.app-search-settings {
    background: #f7fafc;
    border: 1px solid #e3ecf2;
    border-radius: 8px;
    padding: 12px;
}

.app-param-map-list {
    display: grid;
    gap: 8px;
}

.app-param-map-row {
    align-items: center;
    display: grid;
    gap: 8px;
    grid-template-columns: minmax(180px, 1fr) 24px minmax(180px, 1fr) 40px;
}

@media (max-width: 767.98px) {
    .app-param-map-row {
        grid-template-columns: 1fr;
    }

    .app-param-map-row > i {
        display: none;
    }
}

.app-choice-field {
    box-sizing: border-box;
    border: 1px solid #e9ecef;
    border-radius: 8px;
    min-height: 48px;
    padding: 8px 10px;
    width: 100%;
}

.app-choice-field.app-labelled-field {
    border-color: #dce5eb;
    padding: 15px 11px 8px;
}

.app-suggest-field,
.app-suggest-box {
    position: relative;
}

.app-labelled-field .app-suggest-box {
    position: static;
}

.app-suggest-box.app-floating-field > .form-control {
    border-radius: 8px;
    min-height: 48px;
}

.app-suggest-box.app-floating-field > label {
    color: #6c757d;
}

.app-suggest-box:focus-within > .form-control {
    border-color: #26c6da;
    box-shadow: 0 0 0 0.15rem rgba(38, 198, 218, 0.15);
}

.app-labelled-field .app-suggest-box:focus-within > .form-control {
    border-color: transparent;
    box-shadow: none;
}

.app-suggest-menu {
    background: #ffffff;
    border: 1px solid #dce5eb;
    border-radius: 8px;
    box-shadow: 0 16px 34px rgba(31, 45, 61, 0.12);
    display: none;
    left: 0;
    max-height: 240px;
    overflow-y: auto;
    position: absolute;
    right: 0;
    top: calc(100% + 4px);
    z-index: 1060;
}

.app-suggest-menu.is-open {
    display: block;
}

.app-suggest-menu.app-floating-menu-portal,
.app-tag-suggestions.app-floating-menu-portal {
    right: auto;
    top: auto;
    z-index: 2060;
}

.app-suggest-menu button {
    background: transparent;
    border: 0;
    color: #425466;
    display: block;
    padding: 9px 12px;
    text-align: left;
    width: 100%;
}

.app-suggest-menu button:hover {
    background: #edf8fb;
    color: #0f8fa1;
}

.app-suggest-menu strong,
.app-suggest-menu small {
    display: block;
}

.app-suggest-menu small {
    color: #97a6b2;
}

.app-tag-input-box {
    align-items: center;
    border: 1px solid #dce5eb;
    border-radius: 8px;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    min-height: 58px;
    padding: 8px;
}

.app-labelled-field > .app-tag-input-box {
    border: 0;
    min-height: 24px;
    padding: 0;
}

.app-floating-tag-field > .app-tag-input-box {
    min-height: 48px;
    padding: 13px 10px 7px;
}

.app-tag-input {
    position: relative;
}

.app-column-tag-input {
    position: relative;
}

.app-tag-input-box:focus-within {
    border-color: #26c6da;
    box-shadow: 0 0 0 0.15rem rgba(38, 198, 218, 0.15);
}

.app-labelled-field > .app-tag-input-box:focus-within {
    border-color: transparent;
    box-shadow: none;
}

.app-floating-tag-field:focus-within > .app-floating-tag-label {
    color: #1297a8;
}

.app-tag-list {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 6px;
}

.app-labelled-field .app-tag-list,
.app-field-settings-grid .app-settings-tag-input .app-tag-list {
    gap: 4px;
}

.app-tag-chip {
    align-items: center;
    background: #edf8fb;
    border: 1px solid #d4f0f4;
    border-radius: 999px;
    color: #0f8fa1;
    display: inline-flex;
    max-width: 100%;
    overflow: hidden;
}

.app-tag-chip-label,
.app-tag-chip-remove {
    background: transparent;
    border: 0;
    color: inherit;
    min-height: 30px;
}

.app-labelled-field .app-tag-chip-label,
.app-labelled-field .app-tag-chip-remove,
.app-field-settings-grid .app-settings-tag-input .app-tag-chip-label,
.app-field-settings-grid .app-settings-tag-input .app-tag-chip-remove {
    font-size: 0.875rem;
    min-height: 22px;
}

.app-tag-chip-label {
    overflow: hidden;
    padding: 4px 8px 4px 10px;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.app-tag-chip-label.is-readonly {
    cursor: default;
}

.app-tag-chip-remove {
    align-items: center;
    display: inline-flex;
    justify-content: center;
    padding: 4px 8px 4px 4px;
}

.app-labelled-field .app-tag-chip-label,
.app-field-settings-grid .app-settings-tag-input .app-tag-chip-label {
    padding: 2px 7px 2px 9px;
}

.app-labelled-field .app-tag-chip-remove,
.app-field-settings-grid .app-settings-tag-input .app-tag-chip-remove {
    padding: 2px 7px 2px 3px;
}

.app-tag-entry {
    border: 0;
    flex: 1 1 160px;
    min-height: 34px;
    min-width: 120px;
    outline: 0;
}

.app-labelled-field .app-tag-entry,
.app-field-settings-grid .app-settings-tag-input .app-tag-entry {
    min-height: 22px;
}

.app-tag-entry:disabled {
    background: transparent;
    flex-basis: 0;
    min-width: 0;
}

.app-tag-suggestions {
    background: #ffffff;
    border: 1px solid #dce5eb;
    border-radius: 8px;
    box-shadow: 0 16px 34px rgba(31, 45, 61, 0.12);
    display: none;
    left: 0;
    max-height: 240px;
    overflow-y: auto;
    position: absolute;
    right: 0;
    top: calc(100% + 4px);
    z-index: 1060;
}

.app-tag-suggestions.is-open {
    display: block;
}

.app-tag-suggestions button {
    background: transparent;
    border: 0;
    color: #425466;
    display: block;
    padding: 9px 12px;
    text-align: left;
    width: 100%;
}

.app-tag-suggestions button:hover {
    background: #edf8fb;
    color: #0f8fa1;
}

.app-tag-suggestions strong,
.app-tag-suggestions small {
    display: block;
}

.app-tag-suggestions small {
    color: #97a6b2;
}

.app-relation-cascade-preview {
    background: #f8fbfd;
    border: 1px solid #d9e7f0;
    border-radius: 8px;
    padding: 12px;
}

.app-relation-cascade-item {
    background: #ffffff;
    border: 1px solid #dbe8f1;
    border-left: 4px solid #c8d8e4;
    border-radius: 8px;
    margin-top: 8px;
    padding: 10px 12px;
}

.app-relation-cascade-item.is-run {
    border-left-color: #25c2d1;
}

.app-relation-cascade-item.is-skip {
    border-left-color: #b8c5cf;
    opacity: 0.82;
}

.app-relation-cascade-main {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px 12px;
}

.app-relation-cascade-main strong {
    color: #16324f;
}

.app-relation-cascade-depth,
.app-relation-cascade-status {
    background: #edf8fb;
    border-radius: 999px;
    color: #0788a0;
    font-size: 12px;
    font-weight: 700;
    padding: 3px 8px;
}

.app-relation-cascade-item.is-skip .app-relation-cascade-status {
    background: #eef3f7;
    color: #637487;
}

.app-relation-cascade-meta {
    color: #728295;
    display: flex;
    flex-wrap: wrap;
    font-size: 12px;
    gap: 6px 14px;
    margin-top: 6px;
}

.app-relation-cascade-children {
    border-left: 1px dashed #c9d8e4;
    margin: 10px 0 0 12px;
    padding-left: 12px;
}

@media (max-width: 767.98px) {
    .app-menu-editor-row {
        align-items: stretch;
        flex-direction: column;
    }

    .app-menu-editor-children {
        margin-left: 12px;
    }

    .app-menu-summary {
        min-width: 0;
    }

    .app-menu-actions {
        grid-template-columns: repeat(6, 34px);
    }

    .app-form-designer-grid,
    .app-form-preview-grid {
        grid-template-columns: 1fr;
    }

    .app-form-designer-field,
    .app-form-preview-cell {
        grid-column: span 1 !important;
    }

    .app-form-candidate-missing {
        align-items: stretch;
        flex-direction: column;
    }
}

.app-login-mark {
    align-items: center;
    background: #edf8fb;
    border-radius: 8px;
    display: inline-flex;
    height: 58px;
    justify-content: center;
    width: 58px;
}

.app-login-mark img {
    max-height: 34px;
}

.auth-box {
    max-width: 420px;
    width: calc(100% - 32px);
}

.app-first-run-box {
    max-width: 1040px;
}

.dropdown-item button,
button.dropdown-item {
    cursor: pointer;
}
