.elementor-20 .elementor-element.elementor-element-0683cfb:not(.elementor-motion-effects-element-type-background), .elementor-20 .elementor-element.elementor-element-0683cfb > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:var( --e-global-color-primary );}.elementor-20 .elementor-element.elementor-element-0683cfb{transition:background 0.3s, border 0.3s, border-radius 0.3s, box-shadow 0.3s;padding:130px 0px 110px 0px;}.elementor-20 .elementor-element.elementor-element-0683cfb > .elementor-background-overlay{transition:background 0.3s, border-radius 0.3s, opacity 0.3s;}.elementor-20 .elementor-element.elementor-element-7088728 > .elementor-element-populated{padding:0px 15px 0px 15px;}.elementor-20 .elementor-element.elementor-element-4e2866c .page_banner{text-align:center;}.elementor-20 .elementor-element.elementor-element-8233810:not(.elementor-motion-effects-element-type-background), .elementor-20 .elementor-element.elementor-element-8233810 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:var( --e-global-color-accent );}.elementor-20 .elementor-element.elementor-element-8233810{transition:background 0.3s, border 0.3s, border-radius 0.3s, box-shadow 0.3s;padding:120px 0px 90px 0px;}.elementor-20 .elementor-element.elementor-element-8233810 > .elementor-background-overlay{transition:background 0.3s, border-radius 0.3s, opacity 0.3s;}.elementor-20 .elementor-element.elementor-element-d0b9807 > .elementor-element-populated{padding:0px 15px 0px 15px;}.elementor-20 .elementor-element.elementor-element-77a26d6 .contact_info_box .iconbox_block .iconbox_icon svg path{fill:var( --e-global-color-primary );}.elementor-20 .elementor-element.elementor-element-2ca94aa:not(.elementor-motion-effects-element-type-background), .elementor-20 .elementor-element.elementor-element-2ca94aa > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:var( --e-global-color-accent );}.elementor-20 .elementor-element.elementor-element-2ca94aa{transition:background 0.3s, border 0.3s, border-radius 0.3s, box-shadow 0.3s;padding:0px 0px 120px 0px;}.elementor-20 .elementor-element.elementor-element-2ca94aa > .elementor-background-overlay{transition:background 0.3s, border-radius 0.3s, opacity 0.3s;}.elementor-20 .elementor-element.elementor-element-61e5893:not(.elementor-motion-effects-element-type-background) > .elementor-widget-wrap, .elementor-20 .elementor-element.elementor-element-61e5893 > .elementor-widget-wrap > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:var( --e-global-color-a1b36ed );}.elementor-20 .elementor-element.elementor-element-61e5893 > .elementor-widget-wrap > .elementor-widget:not(.elementor-widget__width-auto):not(.elementor-widget__width-initial):not(:last-child):not(.elementor-absolute){--kit-widget-spacing:0px;}.elementor-20 .elementor-element.elementor-element-61e5893 > .elementor-element-populated, .elementor-20 .elementor-element.elementor-element-61e5893 > .elementor-element-populated > .elementor-background-overlay, .elementor-20 .elementor-element.elementor-element-61e5893 > .elementor-background-slideshow{border-radius:32px 32px 32px 32px;}.elementor-20 .elementor-element.elementor-element-61e5893 > .elementor-element-populated{transition:background 0.3s, border 0.3s, border-radius 0.3s, box-shadow 0.3s;margin:0px 0px 0px 0px;--e-column-margin-right:0px;--e-column-margin-left:0px;padding:50px 50px 50px 50px;}.elementor-20 .elementor-element.elementor-element-61e5893 > .elementor-element-populated > .elementor-background-overlay{transition:background 0.3s, border-radius 0.3s, opacity 0.3s;}.elementor-20 .elementor-element.elementor-element-e5d239e{background-color:var( --e-global-color-a1b36ed );}.elementor-20 .elementor-element.elementor-element-a1fe842 > .elementor-element-populated{margin:30px 0px 0px 48px;--e-column-margin-right:0px;--e-column-margin-left:48px;padding:0px 15px 0px 15px;}.elementor-20 .elementor-element.elementor-element-af771c7{padding:0px 0px 0px 0px;border-radius:20px 20px 20px 20px;}.elementor-20 .elementor-element.elementor-element-af771c7 iframe{height:630px;}@media(max-width:1024px){.elementor-20 .elementor-element.elementor-element-4e2866c .page_title{font-size:40px;}}@media(max-width:767px){.elementor-20 .elementor-element.elementor-element-4e2866c .page_title{font-size:30px;}}@media(min-width:768px){.elementor-20 .elementor-element.elementor-element-61e5893{width:53%;}.elementor-20 .elementor-element.elementor-element-a1fe842{width:47%;}}@media(max-width:1024px) and (min-width:768px){.elementor-20 .elementor-element.elementor-element-61e5893{width:100%;}.elementor-20 .elementor-element.elementor-element-a1fe842{width:100%;}}/* Start custom CSS for shortcode, class: .elementor-element-e5d239e *//* Contact Form 7 - Professional Styling (Page ID 20) */
.page-id-20 .wpcf7-form {
    max-width: 100%;
    margin: 0 auto;
}

/* Form Item Container */
.page-id-20 .cs_form_item {
    margin-bottom: 28px;
    position: relative;
}

/* Label Styling - Modern & Clean */
.page-id-20 .cs_form_item label {
    display: block;
    margin-bottom: 10px;
    font-weight: 600;
    color: #2c3e50;
    font-size: 15px;
    letter-spacing: 0.3px;
    transition: color 0.3s ease;
}

/* Input & Textarea Base Styling */
.page-id-20 .wpcf7-form-control {
    width: 100%;
    padding: 16px 20px;
    border: 2px solid #e8ecef;
    border-radius: 10px;
    font-size: 15px;
    color: #2c3e50;
    background-color: #ffffff;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    font-family: inherit;
    line-height: 1.5;
}

/* Input Hover State */
.page-id-20 .wpcf7-form-control:hover {
    border-color: #d1d5db;
    background-color: #fafbfc;
}

/* Input Focus State - Brand Color */
.page-id-20 .wpcf7-form-control:focus {
    outline: none;
    border-color: #89110c;
    background-color: #ffffff;
    box-shadow: 0 0 0 4px rgba(137, 17, 12, 0.08);
    transform: translateY(-1px);
}

/* Placeholder Styling */
.page-id-20 .wpcf7-form-control::placeholder {
    color: #9ca3af;
    opacity: 1;
    font-size: 14px;
}

/* Textarea Specific */
.page-id-20 .wpcf7-textarea {
    height: 120px !important;
    resize: vertical;
    line-height: 1.6;
}

/* Form Control Wrapper */
.page-id-20 .wpcf7-form-control-wrap {
    display: block;
    width: 100%;
}

/* Submit Button - Premium Gradient Style */
.page-id-20 .btn-gradient {
    background: linear-gradient(135deg, #89110c 0%, #c01510 50%, #89110c 100%);
    background-size: 200% 100%;
    border: none;
    color: #ffffff;
    /*padding: 18px 36px;*/
    border-radius: 10px;
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 0.5px;
    cursor: pointer;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    box-shadow: 0 4px 15px rgba(137, 17, 12, 0.2);
}

/* Button Hover Effect */
.page-id-20 .btn-gradient:hover {
    background-position: 100% 0;
    transform: translateY(-3px);
    box-shadow: 0 8px 25px rgba(137, 17, 12, 0.35);
}

/* Button Active State */
.page-id-20 .btn-gradient:active {
    transform: translateY(-1px);
    box-shadow: 0 4px 15px rgba(137, 17, 12, 0.25);
}

/* Button Label */
.page-id-20 .btn_label {
    position: relative;
    z-index: 2;
    text-transform: uppercase;
}

/* Button Icon Animation */
.page-id-20 .btn_icon {
    position: relative;
    z-index: 2;
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    display: inline-flex;
    align-items: center;
}

.page-id-20 .btn-gradient:hover .btn_icon {
    transform: translate(5px, -5px) rotate(0deg);
}

/* Button Ripple Effect (Optional Enhancement) */
.page-id-20 .btn-gradient::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0;
    height: 0;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.1);
    transform: translate(-50%, -50%);
    transition: width 0.6s, height 0.6s;
}

.page-id-20 .btn-gradient:hover::before {
    width: 300px;
    height: 300px;
}

/* Validation Styling - Error State */
.page-id-20 .wpcf7-not-valid {
    border-color: #ef4444 !important;
    background-color: #fef2f2;
    animation: shake 0.4s;
}

@keyframes shake {
    0%, 100% { transform: translateX(0); }
    25% { transform: translateX(-5px); }
    75% { transform: translateX(5px); }
}

.page-id-20 .wpcf7-not-valid-tip {
    color: #dc2626;
    font-size: 13px;
    margin-top: 8px;
    display: block;
    font-weight: 500;
}

/* Success Message */
.page-id-20 .wpcf7-response-output {
    margin: 24px 0 0;
    padding: 18px 24px;
    border-radius: 10px;
    font-size: 15px;
    font-weight: 600;
    border: none;
}

.page-id-20 .wpcf7-mail-sent-ok {
    background: linear-gradient(135deg, #d4edda 0%, #c3e6cb 100%);
    color: #155724;
    box-shadow: 0 4px 12px rgba(21, 87, 36, 0.15);
}

/* Error Messages */
.page-id-20 .wpcf7-validation-errors,
.page-id-20 .wpcf7-mail-sent-ng {
    background: linear-gradient(135deg, #f8d7da 0%, #f5c6cb 100%);
    color: #721c24;
    box-shadow: 0 4px 12px rgba(114, 28, 36, 0.15);
}

/* Spinner/Loading State */
.page-id-20 .wpcf7-spinner {
    margin-left: 12px;
    vertical-align: middle;
}

/* Form Submitting State */
.page-id-20 .wpcf7-form.submitting .btn-gradient {
    opacity: 0.7;
    pointer-events: none;
    cursor: not-allowed;
}

.page-id-20 .wpcf7-form.submitting .btn-gradient::after {
    content: '';
    position: absolute;
    width: 20px;
    height: 20px;
    border: 3px solid rgba(255, 255, 255, 0.3);
    border-top-color: #ffffff;
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
    right: 20px;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* Input Autofill Styling */
.page-id-20 .wpcf7-form-control:-webkit-autofill,
.page-id-20 .wpcf7-form-control:-webkit-autofill:hover,
.page-id-20 .wpcf7-form-control:-webkit-autofill:focus {
    -webkit-box-shadow: 0 0 0 1000px #ffffff inset;
    -webkit-text-fill-color: #2c3e50;
    border: 2px solid #e8ecef;
    transition: background-color 5000s ease-in-out 0s;
}

.page-id-20 .wpcf7-form-control:-webkit-autofill:focus {
    border-color: #89110c;
}

/* Disabled State */
.page-id-20 .wpcf7-form-control:disabled {
    background-color: #f3f4f6;
    cursor: not-allowed;
    opacity: 0.6;
    border-color: #e5e7eb;
}

/* Row & Column Spacing */
.page-id-20 .row {
    margin-left: -12px;
    margin-right: -12px;
}

.page-id-20 .row [class*="col-"] {
    padding-left: 12px;
    padding-right: 12px;
}

/* Accessibility - Focus Visible */
.page-id-20 .wpcf7-form-control:focus-visible {
    outline: 3px solid rgba(137, 17, 12, 0.4);
    outline-offset: 2px;
}

/* Responsive Design */
@media (max-width: 991px) {
    .page-id-20 .cs_form_item {
        margin-bottom: 24px;
    }
    
    .page-id-20 .btn-gradient {
        padding: 16px 32px;
        font-size: 15px;
    }
    
    .page-id-20 .wpcf7-form-control {
        padding: 14px 18px;
    }
}

@media (max-width: 767px) {
    .page-id-20 .cs_form_item {
        margin-bottom: 20px;
    }
    
    .page-id-20 .row [class*="col-"] {
        padding-left: 8px;
        padding-right: 8px;
    }
}

@media (max-width: 576px) {
    .page-id-20 .wpcf7-form-control {
        padding: 13px 16px;
        font-size: 14px;
    }
    
    .page-id-20 .cs_form_item label {
        font-size: 14px;
        margin-bottom: 8px;
    }
    
    .page-id-20 .btn-gradient {
        padding: 14px 28px;
        font-size: 14px;
        gap: 10px;
    }
    
    .page-id-20 .wpcf7-textarea {
        min-height: 130px;
    }
}

/* Print Styles */
@media print {
    .page-id-20 .btn-gradient {
        display: none;
    }
}/* End custom CSS */