/* ==========================================================================
   OpenHaft — Forms: Contact Section, Form Inputs
   ========================================================================== */

/* ---------- Contact Section ---------- */
.contact-section {
    padding: 100px 0;
    background: var(--bg-secondary);
}

.contact-grid {
    display: grid;
    grid-template-columns: 1fr 1.3fr;
    gap: 4rem;
    align-items: start;
}

/* Contact Info Card */
.contact-info__card {
    background: var(--bg-elevated);
    color: var(--text-primary);
    border-radius: var(--radius-lg);
    padding: 3rem;
    border: 1px solid var(--border-default);
}
.contact-info__title {
    font-family: var(--font-heading);
    font-size: 1.6rem; color: var(--text-primary);
    margin-bottom: 0.25rem;
}
.contact-info__tagline {
    color: var(--color-gold); font-size: 0.9rem;
    letter-spacing: 0.05em;
    margin-bottom: 2.5rem;
}

.contact-info__items {
    display: flex; flex-direction: column; gap: 1.75rem;
}
.contact-info__item {
    display: flex; gap: 1rem; align-items: flex-start;
}
.contact-info__item svg {
    color: var(--color-gold); flex-shrink: 0; margin-top: 2px;
}
.contact-info__item strong {
    display: block; font-size: 0.72rem;
    text-transform: uppercase; letter-spacing: 0.1em;
    color: var(--color-gray-500); margin-bottom: 0.2rem;
}
.contact-info__item span,
.contact-info__item a {
    color: var(--text-primary); font-size: 0.95rem;
}
.contact-info__item a:hover { color: var(--color-gold); }

/* ---------- Contact Form ---------- */
.contact-form {
    display: flex; flex-direction: column; gap: 0;
}
.contact-form__row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
}
.contact-form__field {
    position: relative;
    margin-bottom: 1.75rem;
}
.contact-form__field input,
.contact-form__field select,
.contact-form__field textarea {
    width: 100%;
    padding: 1.25rem 0 0.5rem;
    border: none;
    border-bottom: 2px solid var(--border-default);
    border-radius: 0;
    font-family: var(--font-body);
    font-size: 1rem;
    transition: border-color 0.3s ease;
    background: transparent;
    color: var(--text-primary);
    outline: none;
}
.contact-form__field input:focus,
.contact-form__field select:focus,
.contact-form__field textarea:focus {
    border-color: var(--color-gold);
}
.contact-form__field label {
    position: absolute;
    top: 1rem;
    left: 0;
    font-size: 0.95rem;
    font-weight: 400;
    color: var(--color-gray-500);
    pointer-events: none;
    transition: all 0.25s ease;
}
.contact-form__field input:focus ~ label,
.contact-form__field input:not(:placeholder-shown) ~ label,
.contact-form__field textarea:focus ~ label,
.contact-form__field textarea:not(:placeholder-shown) ~ label,
.contact-form__field select:focus ~ label,
.contact-form__field select.has-value ~ label {
    top: -0.25rem;
    font-size: 0.7rem;
    font-weight: 700;
    color: var(--color-gold-dark);
    letter-spacing: 0.1em;
    text-transform: uppercase;
}
.contact-form__field textarea {
    resize: vertical; min-height: 100px;
    padding-top: 1.5rem;
}
.contact-form__field select {
    cursor: pointer;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239e9e9e' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0 center;
}

.contact-form__consent {
    margin-bottom: 1.5rem;
}
.contact-form__consent label {
    display: flex; gap: 0.5rem; align-items: flex-start;
    font-size: 0.82rem; color: var(--color-gray-700);
    cursor: pointer;
    position: static;
    pointer-events: auto;
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0;
}
.contact-form__consent input[type="checkbox"] {
    margin-top: 3px; flex-shrink: 0;
    accent-color: var(--color-gold);
}

.contact-form__submit { width: 100%; }

/* ---------- Contact Alerts ---------- */
.contact-alert {
    padding: 1rem 1.5rem;
    border-radius: var(--radius-md);
    margin-bottom: 1.5rem;
    font-size: 0.95rem;
}
.contact-alert--success {
    background: #e8f5e9; border: 1px solid #a5d6a7;
    color: #2e7d32;
}
.contact-alert--error {
    background: #ffebee; border: 1px solid #ef9a9a;
    color: #c62828;
}
