/* ---------- FORM THEME (κουμπώνει στο υπάρχον θέμα) ---------- */
:root {
    --field-bg: var(--surface);
    --field-bd: color-mix(in oklab, var(--text) 14%, transparent);
    --field-bd-hover: color-mix(in oklab, var(--brand) 35%, transparent);
    --field-bd-focus: color-mix(in oklab, var(--brand-2) 50%, transparent);
    --field-ph: color-mix(in oklab, var(--muted) 80%, transparent);
    --field-ring: 0 0 0 4px color-mix(in oklab, var(--brand) 28%, transparent);
}

/* Βασικό στυλ για inputs, selects, textarea */
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="url"],
input[type="search"],
input[type="number"],
input[type="password"],
select,
textarea {
    width: 100%;
    padding: 12px 14px;
    border-radius: calc(var(--radius) - 2px);
    border: 1px solid var(--field-bd);
    background: var(--field-bg);
    color: var(--text);
    box-shadow: var(--shadow);
    transition: border-color .15s ease, box-shadow .15s ease, background-color .15s ease;
    outline: none;
    font: inherit;
}

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

/* Placeholder */
input::placeholder,
textarea::placeholder {
    color: var(--field-ph);
}

/* Hover / Focus */
input:hover,
select:hover,
textarea:hover {
    border-color: var(--field-bd-hover);
}

input:focus,
select:focus,
textarea:focus {
    border-color: var(--field-bd-focus);
    box-shadow: var(--shadow), var(--field-ring);
}

/* Disabled/readonly */
input[disabled],
select[disabled],
textarea[disabled],
input[readonly],
textarea[readonly] {
    opacity: .6;
    cursor: not-allowed;
}

/* Σφάλματα: πρόσθεσε .is-invalid στο element όταν υπάρχει λάθος */
.is-invalid {
    border-color: color-mix(in oklab, var(--danger) 70%, transparent) !important;
}

.is-invalid:focus {
    box-shadow: var(--shadow), 0 0 0 4px color-mix(in oklab, var(--danger) 35%, transparent) !important;
}

/* Labels και μικρό helper text */
label {
    display: block;
    font-weight: 600;
    margin: 6px 0 6px;
}

.small-help {
    color: var(--muted);
    font-size: .92rem;
    margin-top: 4px;
}

/* Ομάδες πεδίων σε grid (χωρίς να αλλάξεις HTML) */
.form-grid-2 {
    display: grid;
    gap: 12px;
    grid-template-columns: 1fr 1fr;
}

.form-grid-3 {
    display: grid;
    gap: 12px;
    grid-template-columns: 1fr 1fr 1fr;
}

@media (max-width: 800px) {

    .form-grid-2,
    .form-grid-3 {
        grid-template-columns: 1fr;
    }
}

/* Custom dropdown arrow (χωρίς πρόσθετο HTML) */
select {
    appearance: none;
    background-image:
        url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'><polyline points='6 9 12 15 18 9'/></svg>");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 40px;
}

/* Μεγαλύτερη εκδοχή αν θέλεις πιο premium αίσθηση */
.input-lg,
.select-lg,
.textarea-lg {
    padding: 14px 16px;
    border-radius: var(--radius);
    font-size: 1.04rem;
}

/* Μικρή εκδοχή για tight φόρμες */
.input-sm,
.select-sm,
.textarea-sm {
    padding: 10px 12px;
    border-radius: calc(var(--radius) - 4px);
    font-size: .94rem;
}

.btn,
.btn.primary,
.btn.outline {
    cursor: pointer;
}