/* CAMINHO: /css/global/forms.css */
/* OBJETIVO: Formulários, filtros, inputs e campos */

.erp-form {
    width: 100%;
}

.erp-form-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.erp-form-grid-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.erp-form-grid-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.erp-form-row {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
}

.erp-form-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
    width: 100%;
}

.erp-label {
    font-size: 13px;
    font-weight: 800;
    color: var(--erp-gray-700);
}

.erp-label-required::after {
    content: " *";
    color: var(--erp-danger);
}

.erp-input,
.erp-select,
.erp-textarea {
    width: 100%;
    min-height: 42px;
    border: 1px solid var(--erp-border);
    background: var(--erp-white);
    color: var(--erp-text);
    border-radius: var(--erp-radius);
    padding: 10px 12px;
    font-size: 14px;
    outline: none;
    transition: var(--erp-transition);
}

.erp-textarea {
    min-height: 110px;
    resize: vertical;
}

.erp-input:focus,
.erp-select:focus,
.erp-textarea:focus {
    border-color: var(--erp-primary);
    box-shadow: 0 0 0 4px rgba(91, 75, 255, 0.12);
}

.erp-input::placeholder,
.erp-textarea::placeholder {
    color: var(--erp-gray-400);
}

.erp-input[disabled],
.erp-select[disabled],
.erp-textarea[disabled] {
    background: var(--erp-gray-100);
    color: var(--erp-gray-500);
    cursor: not-allowed;
}

.erp-help {
    font-size: 12px;
    color: var(--erp-text-soft);
}

.erp-error {
    font-size: 12px;
    font-weight: 700;
    color: var(--erp-danger);
}

.erp-filter {
    background: var(--erp-white);
    border: 1px solid var(--erp-border);
    border-radius: var(--erp-radius-lg);
    padding: 18px;
    box-shadow: var(--erp-shadow-sm);
    margin-bottom: 18px;
}

.erp-filter-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 14px;
}

.erp-filter-title {
    margin: 0;
    font-size: 17px;
    font-weight: 800;
    color: var(--erp-gray-900);
}

.erp-filter-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.erp-filter-actions {
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
    gap: 10px;
    flex-wrap: wrap;
}

.erp-checkbox-group,
.erp-radio-group {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.erp-check {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 600;
    color: var(--erp-gray-700);
    cursor: pointer;
}

.erp-check input {
    width: 16px;
    height: 16px;
    accent-color: var(--erp-primary);
}

.erp-input-inline {
    display: flex;
    align-items: center;
    gap: 8px;
}

.erp-input-prefix,
.erp-input-suffix {
    min-height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 12px;
    border: 1px solid var(--erp-border);
    background: var(--erp-gray-50);
    color: var(--erp-text-soft);
    font-weight: 800;
}

.erp-input-prefix {
    border-radius: var(--erp-radius) 0 0 var(--erp-radius);
    border-right: 0;
}

.erp-input-suffix {
    border-radius: 0 var(--erp-radius) var(--erp-radius) 0;
    border-left: 0;
}

.erp-input-inline .erp-input {
    border-radius: 0;
}
/* =========================================================
   V160_TELAS_CORRIGIDAS
   OBJETIVO: Corrigir telas com formulários usando input/select/textarea sem classe.
   REGRA: Toda tela que usa .erp-form passa a herdar o padrão visual global.
   ========================================================= */
.erp-form label:not(.erp-check) {
    display: flex;
    flex-direction: column;
    gap: 6px;
    width: 100%;
    min-width: 0;
    margin: 0;
    font-size: 13px;
    font-weight: 800;
    color: var(--erp-gray-700);
}

.erp-form input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
.erp-form select,
.erp-form textarea {
    width: 100%;
    min-width: 0;
    min-height: 42px;
    border: 1px solid var(--erp-border);
    background: var(--erp-white);
    color: var(--erp-text);
    border-radius: var(--erp-radius);
    padding: 10px 12px;
    font-size: 14px;
    line-height: 1.25;
    outline: none;
    transition: var(--erp-transition);
}

.erp-form textarea {
    min-height: 104px;
    resize: vertical;
}

.erp-form input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):focus,
.erp-form select:focus,
.erp-form textarea:focus {
    border-color: var(--erp-primary);
    box-shadow: 0 0 0 4px rgba(91, 75, 255, 0.12);
}

.erp-form input::placeholder,
.erp-form textarea::placeholder {
    color: var(--erp-gray-400);
}

.erp-form input[type="checkbox"],
.erp-form input[type="radio"] {
    width: 16px;
    height: 16px;
    accent-color: var(--erp-primary);
}

.erp-form > label:not(:first-child) {
    margin-top: 12px;
}

.erp-form > button,
.erp-form > .erp-btn {
    margin-top: 14px;
    margin-right: 8px;
}

.erp-form-grid > label,
.erp-filter-grid > label {
    min-width: 0;
}

.erp-grid-2 .erp-form-grid {
    grid-template-columns: repeat(2, minmax(220px, 1fr));
}

.erp-filter-actions,
.erp-form-actions {
    margin-top: 14px;
}
