/**
 * Generic contact form styles for venues, suppliers, and planners
 */

/* Contact form container */
.contact-form-container {
    margin: 2em 0;
    padding: 2em;
    background-color: #f9f9f9;
    border-radius: 8px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.05);
}

/* Contact form title */
.contact-form-title {
    margin-bottom: 1em;
    font-size: 24px;
    color: #333;
}

/* Specific styling for different post types */
.venue-contact-form .contact-form-title {
    color: var(--hotel-inn-beyond--palette--primary, #333);
}

.supplier-contact-form .contact-form-title {
    color: var(--hotel-inn-beyond--palette--primary, #333);
}

.planner-contact-form .contact-form-title {
    color: var(--hotel-inn-beyond--palette--primary, #333);
}

/* Contact Form 7 styling overrides */
.contact-form-container .wpcf7-form {
    margin: 0;
}

.contact-form-container .wpcf7-form-control {
    width: 100%;
    padding: 10px;
    margin-bottom: 15px;
    border: 1px solid #ddd;
    border-radius: 4px;
}

.contact-form-container .wpcf7-form-control:focus {
    border-color: var(--hotel-inn-beyond--palette--primary);
    outline: none;
}

.contact-form-container .wpcf7-submit {
    background-color: var(--hotel-inn-beyond--palette--button-background) !important;
    color: var(--hotel-inn-beyond--palette--button-text) !important;
    padding: 12px 24px;
    border-radius: 4px;
    cursor: pointer;
    font-size: 16px;
    transition: background-color 0.3s ease;
}

.contact-form-container .wpcf7-submit:hover {
    background-color: var(--hotel-inn-beyond--palette--button-hover) !important;
    border-color: var(--hotel-inn-beyond--palette--primary-light) !important;
}

/* Form validation messages */
.contact-form-container .wpcf7-not-valid-tip {
    color: #d63638;
    font-size: 12px;
    margin-top: 5px;
}

.contact-form-container .wpcf7-validation-errors {
    background-color: #fcf2f2;
    border: 1px solid #d63638;
    color: #d63638;
    padding: 10px;
    margin-bottom: 15px;
    border-radius: 4px;
}

.contact-form-container .wpcf7-mail-sent-ok {
    background-color: #f0f8ff;
    border: 1px solid var(--hotel-inn-beyond--palette--primary);
    color: var(--hotel-inn-beyond--palette--primary);
    padding: 10px;
    margin-bottom: 15px;
    border-radius: 4px;
}

/* 2-Column Layout for Desktop */
@media (min-width: 768px) {
    .contact-form-container .two-column-wrapper {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 2em;
        align-items: start;
        margin-bottom: 1.5em;
    }

    /* Left column - Personal details */
    .contact-form-container .left-column {
        display: flex;
        flex-direction: column;
    }

    /* Right column - Message */
    .contact-form-container .right-column {
        display: flex;
        flex-direction: column;
    }

    /* Make textarea fill the available height */
    .contact-form-container .right-column .wpcf7-textarea {
        min-height: 200px;
        resize: vertical;
        height: 100%;
    }

    /* Ensure left column fields have consistent spacing */
    .contact-form-container .left-column .wpcf7-form-control {
        margin-bottom: 15px;
    }

    /* Submit button styling */
    .contact-form-container .wpcf7-form > div:last-child {
        text-align: center;
        margin-top: 1em;
    }
}

/* Responsive adjustments */
@media (max-width: 767px) {
    .contact-form-container {
        padding: 1.5em;
        margin: 1.5em 0;
    }

    .contact-form-title {
        font-size: 20px;
    }

    /* Single column on mobile */
    .contact-form-container .two-column-wrapper {
        display: block;
    }

    .contact-form-container .left-column,
    .contact-form-container .right-column {
        margin-bottom: 1em;
    }

    /* Adjust textarea height on mobile */
    .contact-form-container .right-column .wpcf7-textarea {
        min-height: 120px;
    }
}

/* Legacy support for existing venue-contact-form class */
.venue-contact-form {
    margin: 2em 0;
    padding: 2em;
    background-color: #f9f9f9;
    border-radius: 8px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.05);
}

.venue-contact-title {
    margin-bottom: 1em;
    font-size: 24px;
    color: #333;
}
