/* Form Section CSS Fixes for Service SENEC */

/* Gravity Forms Basic Styling Fixes */
.gform_wrapper {
    max-width: 100% !important;
    margin: 0 auto !important;
}

.gform_body {
    padding: 0 !important;
}

.gform_fields {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.gfield {
    margin-bottom: 20px !important;
    padding: 0 !important;
}

.gfield_label {
    font-weight: 600 !important;
    margin-bottom: 8px !important;
    display: block !important;
    color: #333 !important;
}

/* Input Field Styling */
.gform_wrapper input[type="text"],
.gform_wrapper input[type="email"],
.gform_wrapper input[type="tel"],
.gform_wrapper input[type="url"],
.gform_wrapper input[type="password"],
.gform_wrapper input[type="number"],
.gform_wrapper textarea,
.gform_wrapper select {
    width: 100% !important;
    padding: 12px 16px !important;
    border: 2px solid #e1e5e9 !important;
    border-radius: 4px !important;
    font-size: 16px !important;
    line-height: 1.5 !important;
    background-color: #fff !important;
    transition: border-color 0.3s ease !important;
    box-sizing: border-box !important;
}

.gform_wrapper input[type="text"]:focus,
.gform_wrapper input[type="email"]:focus,
.gform_wrapper input[type="tel"]:focus,
.gform_wrapper input[type="url"]:focus,
.gform_wrapper input[type="password"]:focus,
.gform_wrapper input[type="number"]:focus,
.gform_wrapper textarea:focus,
.gform_wrapper select:focus {
    border-color: #007cba !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(0, 124, 186, 0.1) !important;
}

/* Textarea Specific */
.gform_wrapper textarea {
    min-height: 120px !important;
    resize: vertical !important;
}

/* Radio and Checkbox Styling */
.gform_wrapper .gchoice {
    margin-bottom: 10px !important;
}

.gform_wrapper .gchoice label {
    display: flex !important;
    align-items: center !important;
    cursor: pointer !important;
    font-weight: normal !important;
}

.gform_wrapper input[type="radio"],
.gform_wrapper input[type="checkbox"] {
    margin-right: 10px !important;
    width: auto !important;
}

/* Submit Button Styling */
.gform_wrapper .gform_footer {
    padding: 20px 0 0 0 !important;
    margin: 0 !important;
}

.gform_wrapper .gform_button,
.gform_wrapper input[type="submit"] {
    background-color: #007cba !important;
    color: white !important;
    padding: 15px 30px !important;
    border: none !important;
    border-radius: 4px !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: background-color 0.3s ease !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
}

.gform_wrapper .gform_button:hover,
.gform_wrapper input[type="submit"]:hover {
    background-color: #005a87 !important;
}

/* Error Styling */
.gform_wrapper .gfield_error {
    background-color: #fef2f2 !important;
    border: 1px solid #fecaca !important;
    border-radius: 4px !important;
    padding: 15px !important;
}

.gform_wrapper .gfield_error .gfield_label {
    color: #dc2626 !important;
}

.gform_wrapper .gfield_error input,
.gform_wrapper .gfield_error textarea,
.gform_wrapper .gfield_error select {
    border-color: #dc2626 !important;
}

.gform_wrapper .validation_error {
    color: #dc2626 !important;
    font-size: 14px !important;
    margin-top: 5px !important;
}

/* Required Field Indicator */
.gform_wrapper .gfield_required {
    color: #dc2626 !important;
    font-weight: bold !important;
}

/* Form Container Styling */
.form-container {
    background: #fff !important;
    padding: 40px !important;
    border-radius: 8px !important;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1) !important;
    margin: 20px 0 !important;
}

.form-container__form {
    max-width: 100% !important;
}

/* Responsive Design */
@media (max-width: 768px) {
    .form-container {
        padding: 20px !important;
        margin: 10px !important;
    }
    
    .gform_wrapper input[type="text"],
    .gform_wrapper input[type="email"],
    .gform_wrapper input[type="tel"],
    .gform_wrapper input[type="url"],
    .gform_wrapper input[type="password"],
    .gform_wrapper input[type="number"],
    .gform_wrapper textarea,
    .gform_wrapper select {
        font-size: 16px !important; /* Prevents zoom on iOS */
    }
}

/* Half Width Fields */
.gform_wrapper .gfield--width-half {
    width: 48% !important;
    display: inline-block !important;
    vertical-align: top !important;
    margin-right: 4% !important;
}

.gform_wrapper .gfield--width-half:nth-child(even) {
    margin-right: 0 !important;
}

@media (max-width: 768px) {
    .gform_wrapper .gfield--width-half {
        width: 100% !important;
        margin-right: 0 !important;
        display: block !important;
    }
}

/* Loading Spinner */
.gform_wrapper .gform_ajax_spinner {
    display: inline-block !important;
    margin-left: 10px !important;
}

/* Success Message */
.gform_confirmation_wrapper {
    background-color: #f0f9ff !important;
    border: 1px solid #bae6fd !important;
    border-radius: 4px !important;
    padding: 20px !important;
    margin: 20px 0 !important;
    color: #0c4a6e !important;
}

/* Fix for any layout issues */
.gform_wrapper * {
    box-sizing: border-box !important;
}

/* Ensure form doesn't break layout */
.gform_wrapper {
    overflow: hidden !important;
}

/* Fix for inline radio/checkbox groups */
.gf_list_inline .gchoice {
    display: inline-block !important;
    margin-right: 20px !important;
    margin-bottom: 10px !important;
}

/* File Upload Styling */
.gform_wrapper input[type="file"] {
    padding: 8px !important;
    border: 2px dashed #e1e5e9 !important;
    background-color: #f9fafb !important;
}

.gform_wrapper input[type="file"]:hover {
    border-color: #007cba !important;
    background-color: #f0f9ff !important;
}