/* Global newsletter section style: mirrors homepage newsletter design */

.newsletter-section {
    background: linear-gradient(90deg, #014994 0%, #45b876 100%) !important;
    padding: 30px !important;
    border-radius: 8px !important;
    margin: 0 auto 40px !important;
    color: #ffffff !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 30px !important;
    align-items: center !important;
    width: 95% !important;
    box-sizing: border-box !important;
}

.newsletter-left {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
}

.newsletter-title {
    font-size: 20px !important;
    margin: 0 !important;
    font-weight: 700 !important;
    line-height: 1.35 !important;
    color: #ffffff !important;
}

.newsletter-text {
    font-size: 14px !important;
    margin: 0 !important;
    opacity: 0.95 !important;
    line-height: 1.5 !important;
    color: #ffffff !important;
}

.newsletter-right {
    display: flex !important;
    justify-content: flex-end !important;
    width: 100% !important;
    align-items: center !important;
}

.newsletter-section .wpcf7 {
    width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
}

.newsletter-section .wpcf7-form {
    display: flex !important;
    flex-direction: row !important;
    gap: 9px !important;
    padding: 4px !important;
    border-radius: 5px !important;
    width: 100% !important;
    align-items: center !important;
}

.newsletter-section .wpcf7-form p {
    margin: 0 !important;
    padding: 0 !important;
    display: contents !important;
}

.newsletter-section .wpcf7-form .wpcf7-email {
    flex: 1 !important;
    padding: 12px 16px !important;
    border: none !important;
    border-radius: 4px !important;
    font-size: 14px !important;
    outline: none !important;
    background: #ffffff !important;
    color: #333333 !important;
    min-width: 0 !important;
    width: auto !important;
}

.newsletter-section .wpcf7-form .wpcf7-submit {
    padding: 12px 24px !important;
    background: #2abf60 !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 4px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    font-family: inherit !important;
    cursor: pointer !important;
    white-space: nowrap !important;
    flex-shrink: 0 !important;
    width: auto !important;
}

.newsletter-section .wpcf7-form .wpcf7-submit:hover {
    background: #0f4028 !important;
}

.newsletter-section .wpcf7-response-output {
    border: none !important;
    background: rgba(255, 255, 255, 0.2) !important;
    color: #ffffff !important;
    padding: 10px !important;
    border-radius: 4px !important;
    margin: 0 !important;
    font-size: 14px !important;
    width: 100% !important;
    align-self: flex-start !important;
    box-sizing: border-box !important;
}

.newsletter-section .wpcf7-mail-sent-ok {
    background: rgba(255, 255, 255, 0.3) !important;
    color: #ffffff !important;
}

.newsletter-section .wpcf7-not-valid-tip {
    color: #ffffff !important;
    font-size: 12px !important;
}

@media (max-width: 768px) {
    .newsletter-section {
        grid-template-columns: 1fr !important;
        gap: 20px !important;
        padding: 20px !important;
    }

    .newsletter-left,
    .newsletter-right {
        width: 100% !important;
        align-items: flex-start !important;
    }

    .newsletter-right {
        justify-content: flex-start !important;
    }

    .newsletter-section .wpcf7-form {
        flex-direction: column !important;
        gap: 10px !important;
    }

    .newsletter-section .wpcf7-form .wpcf7-email,
    .newsletter-section .wpcf7-form .wpcf7-submit {
        width: 100% !important;
        min-width: 0 !important;
    }

    .newsletter-section .wpcf7-form .wpcf7-submit {
        padding: 12px 16px !important;
    }

    .newsletter-title {
        font-size: 18px !important;
    }

    .newsletter-text {
        font-size: 14px !important;
    }
}

@media (max-width: 480px) {
    .newsletter-section {
        padding: 20px !important;
    }

    .newsletter-title {
        font-size: 16px !important;
    }
}
