.elementor-130 .elementor-element.elementor-element-30889dd{--display:flex;}.elementor-130 .elementor-element.elementor-element-30889dd:not(.elementor-motion-effects-element-type-background), .elementor-130 .elementor-element.elementor-element-30889dd > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#000000;}.elementor-130 .elementor-element.elementor-element-5363d8d{--display:flex;}:root{--page-title-display:none;}/* Start custom CSS for shortcode, class: .elementor-element-55e03fd *//* ==========================================================================
   MASTER GRID & LAYOUT HUB
   ========================================================================== */
.contact-grid {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1.2fr;
    gap: 60px;
    align-items: start;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    color: #0f172a;
    padding: 60px 20px;
}

/* ==========================================================================
   LEFT COLUMN: CONTACT INFO ARCHITECTURE
   ========================================================================== */
.contact-info h2 {
    font-size: 34px;
    font-weight: 800;
    margin: 0 0 16px 0;
    letter-spacing: -1.2px;
    color: #0f172a;
    line-height: 1.2;
}

.contact-info p {
    font-size: 16px;
    line-height: 1.6;
    color: #64748b;
    margin: 0 0 48px 0;
}

/* Premium Icon-Driven Contact Meta List Fixes */
.contact-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 0 48px 0 !important;
}

.contact-list li {
    display: flex !important;
    align-items: center !important; 
    gap: 20px !important;
    margin-bottom: 32px !important;
    font-size: 16px !important;
    color: #334155 !important;
    line-height: 1.5 !important;
    padding: 0 !important; /* Strips theme padding overrides */
}

.contact-list li strong {
    color: #0f172a;
    font-weight: 600;
}

/* ABSOLUTE POSITIONING ENGINE PATCH
   Locks containers and centers vectors precisely on their pixel center
*/
.contact-icon-badge {
    width: 44px !important;
    height: 44px !important;
    background: rgba(255, 122, 0, 0.06) !important;
    border: 1px solid rgba(255, 122, 0, 0.2) !important;
    border-radius: 10px !important;
    flex-shrink: 0 !important;
    position: relative !important; /* Establishes absolute anchor */
    box-sizing: border-box !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Forces SVGs to freeze dead center inside the badge frame */
.contact-icon-badge svg {
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important; /* Perfect pixel translation */
    width: 20px !important;
    height: 20px !important;
    margin: 0 !important;
    padding: 0 !important;
    display: block !important;
}

/* Bottom Callout Info Banner Styling */
.contact-note {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-left: 4px solid #FF7A00;
    padding: 24px;
    border-radius: 0 12px 12px 0;
    font-size: 15px;
    line-height: 1.6;
    color: #475569 !important;
    margin: 0;
}

/* ==========================================================================
   RIGHT COLUMN: CARD & FORM FIELDS
   ========================================================================== */
.contact-form-card {
    background: #ffffff;
    border: 1px solid #e2e8f0;
    border-radius: 20px;
    padding: 48px;
    box-shadow: 0 12px 40px -12px rgba(15, 23, 42, 0.06);
}

.contact-form-card h2 {
    font-size: 34px;
    font-weight: 800;
    margin: 0 0 36px 0;
    letter-spacing: -1.2px;
    color: #0f172a;
}

/* Form Row Layout Splitting */
.form-row-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

.form-group {
    margin-bottom: 24px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    width: 100%;
}

.form-group label {
    font-size: 14px;
    font-weight: 600;
    color: #475569;
    letter-spacing: -0.1px;
}

/* Clean Contact Form 7 Native Input Constraints */
.contact-form-card .wpcf7-form-control-wrap {
    display: block;
    width: 100% !important;
}

.contact-form-card input[type="text"],
.contact-form-card input[type="email"],
.contact-form-card textarea {
    width: 100% !important;
    background: #f8fafc;
    border: 1px solid #cbd5e1;
    border-radius: 10px;
    padding: 14px 18px;
    color: #0f172a;
    font-size: 15px;
    font-family: inherit;
    outline: none;
    box-sizing: border-box !important;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Fields Micro-Interactions States */
.contact-form-card input:focus, 
.contact-form-card textarea:focus {
    background: #ffffff;
    border-color: #FF7A00;
    box-shadow: 0 0 0 4px rgba(255, 122, 0, 0.1);
}

.contact-form-card input::placeholder, 
.contact-form-card textarea::placeholder {
    color: #94a3b8;
    opacity: 1;
}

/* High-Converting Accent Button Component */
.contact-form-card .btn-submit {
    width: 100% !important;
    background-color: #FF7A00 !important;
    border: 1px solid #FF7A00 !important;
    border-radius: 10px !important;
    color: #ffffff !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    padding: 16px !important;
    cursor: pointer;
    transition: all 0.2s ease-in-out;
    margin-top: 12px;
    -webkit-appearance: none;
}

.contact-form-card .btn-submit:hover {
    background-color: #e06c00 !important;
    border-color: #e06c00 !important;
    box-shadow: 0 12px 24px -6px rgba(255, 122, 0, 0.3) !important;
    transform: translateY(-1px);
}

.contact-form-card .btn-submit:active {
    transform: translateY(0);
}

/* Clean Alert Status Containers for CF7 Hooks */
.wpcf7-response-output {
    margin: 24px 0 0 0 !important;
    padding: 14px !important;
    border-radius: 10px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    text-align: center !important;
}
.wpcf7-status-mail-sent {
    background: #f0fdf4 !important;
    color: #166534 !important;
    border: 1px solid #bbf7d0 !important;
}
.wpcf7-status-validation-errors, 
.wpcf7-status-aborted {
    background: #fef2f2 !important;
    color: #991b1b !important;
    border: 1px solid #fecaca !important;
}

/* ==========================================================================
   RESPONSIVE LAYOUT ENGINE BREAKPOINTS
   ========================================================================== */
@media (max-width: 992px) {
    .contact-grid { 
        grid-template-columns: 1fr; 
        gap: 50px; 
    }
}
@media (max-width: 576px) {
    .form-row-split { 
        grid-template-columns: 1fr; 
        gap: 0; 
    }
    .contact-form-card { 
        padding: 28px 20px; 
    }
    .contact-info h2, 
    .contact-form-card h2 { 
        font-size: 28px; 
    }
}/* End custom CSS */