/**
 * Form Components
 * Input, textarea, select, and form styles
 *
 * @package Bonusovekody
 * @since 2.0.0
 */

/* ============================================
 * BASE INPUTS
 * ============================================ */

input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="url"],
input[type="number"],
textarea,
select {
    width: 100%;
    padding: var(--input-padding-y) var(--input-padding-x);
    font-family: var(--font-body);
    font-size: var(--font-size-base);
    line-height: var(--line-height-base);
    color: #666;
    background: var(--color-bg-primary);
    border: 1px solid var(--color-border);
    border-radius: var(--input-radius);
    transition: border-color var(--transition-fast) var(--ease-out);
}

input:focus,
textarea:focus,
select:focus {
    outline: none;
    border: var(--space-1) solid var(--color-primary);
}

textarea {
    resize: vertical;
    min-height: 120px;
}

/* ============================================
 * INPUT STATES
 * ============================================ */

input.error,
textarea.error {
    border: var(--space-1) solid var(--color-error);
}

input.success,
textarea.success {
    border: var(--space-1) solid var(--color-success);
}

input:disabled,
textarea:disabled,
select:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    background: var(--color-bg-secondary);
}

/* ============================================
 * FORM LABELS
 * ============================================ */

label {
    display: block;
    margin-bottom: var(--space-2);
    font-weight: var(--font-weight-medium);
    color: var(--color-text-primary);
}

/* ============================================
 * FORM GROUPS
 * ============================================ */

.form-group {
    margin-bottom: var(--space-5);
}

.form-row {
    display: flex;
    gap: var(--space-4);
}

.form-row .form-group {
    flex: 1;
}

/* ============================================
 * HELPER TEXT
 * ============================================ */

.form-help {
    display: block;
    margin-top: var(--space-2);
    font-size: var(--font-size-small);
    color: var(--color-text-muted);
}

.form-error {
    display: block;
    margin-top: var(--space-2);
    font-size: var(--font-size-small);
    color: var(--color-error);
}

.form-success {
    display: block;
    margin-top: var(--space-2);
    font-size: var(--font-size-small);
    color: var(--color-success);
}

.wpcf7-not-valid-tip {
    font-size: 13px;
}

/* ============================================
 * RESPONSIVE
 * ============================================ */

@media (max-width: 767px) {
    .form-row {
        flex-direction: column;
    }
}
