/**
 * Site footer redesign (Elementor footer template 222).
 *
 * Pure CSS override on top of the Elementor-generated styles: dark theme to
 * match the rest of the site, green brand accents, clustered social icons,
 * always-visible footer nav (no hamburger), inverted white logo.
 * Loaded site-wide from wpforms-custom-module-dg/plugin.php.
 */

/* ==========================================================================
   Main footer section — dark with a green accent edge
   ========================================================================== */

.elementor-222 .elementor-element.elementor-element-13f3694e {
    background: linear-gradient(180deg, rgba(101, 188, 70, 0.07) 0%, rgba(101, 188, 70, 0) 160px), #0b0b10 !important;
    border-top: 1px solid rgba(101, 188, 70, 0.45);
    padding: 52px 24px 44px !important;
}

/* Stack and reorder the inner blocks: brand/contact -> nav -> social. */
.elementor-222 .elementor-element-a05e29a > .elementor-widget-wrap {
    display: flex;
    flex-direction: column;
    align-items: stretch;
}

.elementor-222 .elementor-element-a05e29a > .elementor-widget-wrap > .elementor-element-884ef4f {
    order: 1;
    margin-bottom: 28px;
}

.elementor-222 .elementor-element-a05e29a > .elementor-widget-wrap > .elementor-element-8a7e14e {
    order: 2;
    margin-bottom: 26px;
}

.elementor-222 .elementor-element-a05e29a > .elementor-widget-wrap > .elementor-element-4407edc {
    order: 3;
}

/* ==========================================================================
   Brand block — white logo + contact lines
   ========================================================================== */

.elementor-222 .elementor-element.elementor-element-93e0159 {
    margin-bottom: 16px;
}

.elementor-222 .elementor-element-93e0159 img {
    width: 180px;
    max-width: 60vw;
    height: auto;
    /* The source logo artwork is black; render it white on the dark bg. */
    filter: brightness(0) invert(1);
    opacity: 0.95;
}

.elementor-222 .elementor-element.elementor-element-7c714b9 {
    margin-bottom: 10px;
}

.elementor-222 .elementor-element.elementor-element-7c714b9 .elementor-heading-title {
    color: #65bc46 !important;
    font-family: Lato, sans-serif !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    letter-spacing: 0.01em;
}

.elementor-222 .elementor-element.elementor-element-9ce44ae .elementor-heading-title {
    color: #8e8e96 !important;
    font-family: Lato, sans-serif !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    line-height: 1.7 !important;
}

/* ==========================================================================
   Footer nav — always-visible inline links (no hamburger)
   ========================================================================== */

.elementor-222 .elementor-element-9b8463a .elementor-menu-toggle,
.elementor-222 .elementor-element-9b8463a .elementor-nav-menu--dropdown {
    display: none !important;
}

.elementor-222 .elementor-element-9b8463a .elementor-nav-menu--main {
    display: block !important;
}

.elementor-222 .elementor-element-9b8463a .elementor-nav-menu--main .elementor-nav-menu {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 2px 8px;
    margin: 0;
    padding: 0;
}

.elementor-222 .elementor-element-9b8463a .elementor-nav-menu--main .elementor-nav-menu li {
    margin: 0;
}

.elementor-222 .elementor-element-9b8463a .elementor-nav-menu--main a.elementor-item {
    font-family: Lato, sans-serif !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #b6b6be !important;
    padding: 7px 12px !important;
    background: none !important;
    transition: color 0.15s ease;
}

.elementor-222 .elementor-element-9b8463a .elementor-nav-menu--main a.elementor-item:hover,
.elementor-222 .elementor-element-9b8463a .elementor-nav-menu--main a.elementor-item:focus-visible,
.elementor-222 .elementor-element-9b8463a .elementor-nav-menu--main a.elementor-item.elementor-item-active {
    color: #65bc46 !important;
}

/* Recolor the underline pointer animation to brand green. */
.elementor-222 .elementor-element-9b8463a .e--pointer-underline .elementor-item:before,
.elementor-222 .elementor-element-9b8463a .e--pointer-underline .elementor-item:after {
    background-color: #65bc46 !important;
    height: 2px !important;
}

/* ==========================================================================
   Social icons — centered cluster of ghost circles
   ========================================================================== */

.elementor-222 .elementor-element-4407edc > .elementor-container {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 14px;
}

.elementor-222 .elementor-element-4407edc .elementor-column {
    width: auto !important;
    flex: 0 0 auto;
}

.elementor-222 .elementor-element-4407edc .elementor-column > .elementor-widget-wrap {
    padding: 0 !important;
}

.elementor-222 .elementor-element-4407edc .elementor-icon-wrapper {
    text-align: center;
}

.elementor-222 .elementor-element-4407edc .elementor-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.03);
    color: #e6e6ea !important;
    fill: #e6e6ea;
    font-size: 19px !important;
    transition: color 0.15s ease, border-color 0.15s ease, transform 0.15s ease, background 0.15s ease;
}

.elementor-222 .elementor-element-4407edc .elementor-icon i {
    font-size: 19px;
    line-height: 1;
}

.elementor-222 .elementor-element-4407edc .elementor-icon svg {
    width: 17px !important;
    height: 17px !important;
}

.elementor-222 .elementor-element-4407edc .elementor-icon svg,
.elementor-222 .elementor-element-4407edc .elementor-icon svg * {
    fill: currentColor !important;
}

.elementor-222 .elementor-element-4407edc .elementor-icon:hover,
.elementor-222 .elementor-element-4407edc .elementor-icon:focus-visible {
    color: #65bc46 !important;
    fill: #65bc46;
    border-color: rgba(101, 188, 70, 0.7);
    background: rgba(101, 188, 70, 0.08);
    transform: translateY(-2px);
}

/* ==========================================================================
   Copyright bar
   ========================================================================== */

.elementor-222 .elementor-element.elementor-element-e86e937 {
    background-color: #07070b !important;
    border-top: 1px solid rgba(255, 255, 255, 0.08) !important;
}

.elementor-222 .elementor-element.elementor-element-272bc049 .elementor-heading-title {
    color: #6c6c75 !important;
    font-family: Lato, sans-serif !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    letter-spacing: 0.05em;
}

/* ==========================================================================
   reCAPTCHA attribution (replaces the hidden floating badge; printed via
   wp_footer so it sits directly under the copyright bar)
   ========================================================================== */

.dg-recaptcha-attribution {
    background: #07070b;
    color: #55555e;
    font-family: Lato, sans-serif;
    font-size: 11px;
    line-height: 1.5;
    text-align: center;
    padding: 0 20px 16px;
}

.dg-recaptcha-attribution a {
    color: #7a7a84;
    text-decoration: underline;
}

.dg-recaptcha-attribution a:hover {
    color: #65bc46;
}

/* ==========================================================================
   Mobile
   ========================================================================== */

@media (max-width: 767px) {
    .elementor-222 .elementor-element.elementor-element-13f3694e {
        padding: 40px 20px 34px !important;
    }

    .elementor-222 .elementor-element-a05e29a > .elementor-widget-wrap > .elementor-element-884ef4f {
        margin-bottom: 22px;
    }

    .elementor-222 .elementor-element-a05e29a > .elementor-widget-wrap > .elementor-element-8a7e14e {
        margin-bottom: 20px;
    }

    .elementor-222 .elementor-element-93e0159 img {
        width: 150px;
    }

    .elementor-222 .elementor-element-9b8463a .elementor-nav-menu--main .elementor-nav-menu {
        gap: 0 2px;
    }

    .elementor-222 .elementor-element-9b8463a .elementor-nav-menu--main a.elementor-item {
        font-size: 11px !important;
        padding: 6px 9px !important;
    }

    .elementor-222 .elementor-element-4407edc > .elementor-container {
        gap: 12px;
    }

    .elementor-222 .elementor-element-4407edc .elementor-icon {
        width: 40px;
        height: 40px;
        font-size: 17px !important;
    }
}
