:root {
    --form-label-bg: linear-gradient(180deg, #f5f9ff 0%, #edf4fb 100%);
    --form-label-border: #d7e4f2;
    --form-row-gap: 12px;
    --input-bg: #ffffff;
    --input-border: #c8d8ea;
    --input-border-focus: #0f6cbd;
    --input-shadow-focus: 0 0 0 4px rgba(15, 108, 189, 0.14);
}

.app-form-card {
    border: 1px solid #dbe6f2;
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, #f8fbff 100%);
    padding: 18px;
    box-shadow: 0 14px 30px rgba(16, 35, 68, 0.06);
}

.app-form {
    display: grid;
    gap: 12px;
}

.app-form-row {
    display: grid;
    grid-template-columns: minmax(160px, 220px) minmax(0, 1fr);
    gap: var(--form-row-gap);
    align-items: center;
}

.app-form-label {
    margin: 0;
    font-weight: 600;
    color: #33465f;
    background: var(--form-label-bg);
    border: 1px solid var(--form-label-border);
    border-radius: 12px;
    min-height: 44px;
    display: flex;
    align-items: center;
    padding: 10px 12px;
}

.app-form-field > input,
.app-form-field > select,
.app-form-field > textarea,
.app-form-field > .input {
    width: 100%;
    margin: 0;
}

.app-form-field > input,
.app-form-field > select,
.app-form-field > textarea,
.app-form-field > .input,
.app-form-field .form-control,
.app-form-field .form-select {
    min-height: 44px;
    border: 1px solid var(--input-border);
    background: var(--input-bg);
    border-radius: 12px;
    padding: 10px 12px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.app-form-field > textarea,
.app-form-field textarea.form-control {
    min-height: 110px;
}

.app-form-field > input:focus,
.app-form-field > select:focus,
.app-form-field > textarea:focus,
.app-form-field > .input:focus,
.app-form-field .form-control:focus,
.app-form-field .form-select:focus {
    border-color: var(--input-border-focus);
    box-shadow: var(--input-shadow-focus);
    outline: 0;
}

.app-form-check {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 40px;
}

.app-form-actions {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
    padding-top: 8px;
}

.app-form-actions button,
.app-form-actions .btn {
    width: auto;
    margin: 0;
}

@media (max-width: 991px) {
    .app-form-row {
        grid-template-columns: 1fr;
        gap: 6px;
        align-items: start;
    }
}
