.footer-capability-note,
.prt-about-footer p.footer-capability-note {
    color: rgba(255, 255, 255, 0.72);
    font-size: 14px;
    line-height: 24px;
}

.fixed-callout {
    bottom: 96px !important;
}

.copyright .footer-nav-menu .powered-by-subtle {
    color: var(--base-white);
    font-size: 16px;
    line-height: 26px;
    font-weight: 400;
    opacity: 1;
}

.powered-by-subtle .powered-by-name {
    color: var(--base-white);
    font-weight: 600;
}

.contact-global-presence {
    padding: 86px 0 72px;
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at 50% 48%, rgba(19, 115, 186, 0.34), transparent 28%),
        radial-gradient(circle at 10% 28%, rgba(19, 115, 186, 0.2), transparent 24%),
        radial-gradient(circle at 92% 76%, rgba(19, 115, 186, 0.22), transparent 28%),
        linear-gradient(180deg, rgba(4, 11, 26, 0.58), rgba(19, 20, 35, 0.96)),
        var(--base-dark);
}

.contact-global-presence:before {
    content: "";
    position: absolute;
    inset: 0;
    opacity: 0.1;
    background-image:
        radial-gradient(circle, rgba(19, 115, 186, 0.38) 1px, transparent 2px),
        linear-gradient(rgba(255, 255, 255, 0.2) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.2) 1px, transparent 1px);
    background-size: 54px 54px, 86px 86px, 86px 86px;
}

.contact-global-presence:after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 210px;
    opacity: 0.32;
    background:
        radial-gradient(ellipse at center bottom, rgba(19, 115, 186, 0.72), transparent 58%),
        linear-gradient(90deg, transparent, rgba(19, 115, 186, 0.18), transparent);
    pointer-events: none;
}

.contact-global-presence .container {
    position: relative;
    z-index: 1;
}

.contact-global-header {
    max-width: 930px;
    margin: 0 auto 22px;
    text-align: center;
}

.contact-global-header h2 {
    margin-bottom: 12px;
    color: var(--base-white);
    font-size: 50px;
    line-height: 60px;
    font-weight: 600;
}

.contact-global-header p {
    color: rgba(255, 255, 255, 0.78);
    font-size: 18px;
    line-height: 30px;
}

.global-title-accent {
    width: 48px;
    height: 3px;
    display: block;
    margin: 16px auto 20px;
    border-radius: 99px;
    background: var(--base-skin);
    box-shadow: 0 0 18px rgba(19, 115, 186, 0.68);
}

.contact-global-header .global-presence-summary {
    max-width: 760px;
    margin: 0 auto;
    color: rgba(255, 255, 255, 0.84);
}

.global-presence-visual {
    min-height: 540px;
    position: relative;
    margin: 0 auto;
}

.global-network-globe {
    width: min(420px, 70vw);
    height: min(420px, 70vw);
    position: absolute;
    left: 50%;
    top: 52%;
    transform: translate(-50%, -50%);
    border-radius: 50%;
    background:
        radial-gradient(circle at 35% 32%, rgba(255, 255, 255, 0.22), transparent 10%),
        radial-gradient(circle at 62% 46%, rgba(76, 184, 255, 0.28), transparent 9%),
        radial-gradient(circle at center, rgba(19, 115, 186, 0.48), rgba(19, 115, 186, 0.12) 52%, rgba(3, 9, 24, 0.34) 72%),
        linear-gradient(135deg, rgba(19, 115, 186, 0.92), rgba(6, 14, 34, 0.86));
    border: 1px solid rgba(107, 190, 255, 0.36);
    box-shadow:
        0 0 34px rgba(19, 115, 186, 0.48),
        inset 0 0 55px rgba(123, 213, 255, 0.28),
        inset 0 0 95px rgba(2, 8, 23, 0.7);
    overflow: hidden;
}

.global-network-globe:before {
    content: "";
    position: absolute;
    inset: 13%;
    border-radius: 50%;
    opacity: 0.48;
    background-image:
        linear-gradient(rgba(255, 255, 255, 0.34) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.34) 1px, transparent 1px);
    background-size: 28px 28px;
    transform: rotate(-15deg);
}

.global-network-globe:after {
    content: "";
    position: absolute;
    inset: -18%;
    border-radius: 50%;
    background:
        repeating-radial-gradient(ellipse at center, transparent 0 29px, rgba(117, 206, 255, 0.26) 30px 31px),
        linear-gradient(110deg, transparent 44%, rgba(255, 255, 255, 0.32) 50%, transparent 56%);
    opacity: 0.72;
}

.globe-ring {
    position: absolute;
    inset: 18%;
    border: 1px solid rgba(91, 184, 255, 0.45);
    border-radius: 50%;
    z-index: 2;
}

.ring-one {
    transform: rotateX(68deg) rotateZ(-18deg);
}

.ring-two {
    transform: rotateX(68deg) rotateZ(36deg);
}

.ring-three {
    transform: rotateY(68deg) rotateZ(10deg);
}

.globe-pulse {
    width: 18px;
    height: 18px;
    position: absolute;
    z-index: 3;
    border-radius: 50%;
    background: var(--base-white);
    border: 5px solid var(--base-skin);
    box-shadow: 0 0 0 8px rgba(19, 115, 186, 0.24), 0 0 26px rgba(93, 201, 255, 0.9);
}

.pulse-one {
    top: 17%;
    left: 30%;
}

.pulse-two {
    top: 44%;
    right: 15%;
}

.pulse-three {
    left: 18%;
    top: 55%;
}

.pulse-four {
    left: 48%;
    bottom: 12%;
}

.pulse-five {
    right: 27%;
    bottom: 24%;
}

.presence-callout {
    width: 270px;
    min-height: 112px;
    padding: 20px 22px;
    position: absolute;
    display: flex;
    align-items: center;
    gap: 16px;
    border-radius: var(--base-border-radius-15);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.045));
    border: 1px solid rgba(255, 255, 255, 0.22);
    box-shadow: 0 22px 52px rgba(0, 0, 0, 0.2);
    backdrop-filter: blur(12px);
    transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease;
}

.presence-callout:hover {
    transform: translateY(-6px);
    border-color: rgba(19, 115, 186, 0.58);
    box-shadow: 0 0 25px rgba(19, 115, 186, 0.22), 0 24px 56px rgba(0, 0, 0, 0.24);
}

.presence-callout:before {
    content: "";
    position: absolute;
    top: 50%;
    width: 96px;
    border-top: 2px dashed rgba(255, 255, 255, 0.68);
}

.presence-callout:after {
    content: "";
    width: 7px;
    height: 7px;
    position: absolute;
    top: calc(50% - 3px);
    border-radius: 50%;
    background: var(--base-skin);
    box-shadow: 0 0 16px rgba(19, 115, 186, 0.86);
}

.callout-uk {
    left: 2%;
    top: 18%;
}

.callout-usa {
    left: 0;
    top: 56%;
}

.callout-india {
    right: 2%;
    top: 28%;
}

.callout-netherlands {
    right: 1%;
    top: 61%;
}

.callout-australia {
    left: 50%;
    bottom: 2%;
    transform: translateX(-50%);
}

.callout-uk:before,
.callout-usa:before {
    left: 100%;
}

.callout-uk:after,
.callout-usa:after {
    right: -101px;
}

.callout-india:before,
.callout-netherlands:before {
    right: 100%;
}

.callout-india:after,
.callout-netherlands:after {
    left: -101px;
}

.callout-australia:before {
    width: 2px;
    height: 86px;
    left: 50%;
    top: -86px;
    border-top: 0;
    border-left: 2px dashed rgba(255, 255, 255, 0.68);
}

.callout-australia:after {
    left: calc(50% - 3px);
    top: -91px;
}

.callout-australia:hover {
    transform: translateX(-50%) translateY(-6px);
}

.presence-callout .global-icon {
    width: 58px;
    height: 58px;
    flex: 0 0 58px;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: linear-gradient(135deg, #1a83d4, #135fb4);
    color: var(--base-white);
    font-size: 24px;
    box-shadow: 0 12px 30px rgba(19, 115, 186, 0.28);
}

.presence-callout h3 {
    margin: 0 0 5px;
    color: var(--base-white);
    font-size: 22px;
    line-height: 30px;
    font-weight: 600;
}

.presence-callout p {
    margin: 0;
    color: rgba(255, 255, 255, 0.84);
    font-size: 15px;
    line-height: 23px;
}

.global-presence-metrics {
    max-width: 1120px;
    margin: 34px auto 0;
    padding-top: 28px;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
    border-top: 1px solid rgba(255, 255, 255, 0.14);
}

.presence-metric {
    min-height: 76px;
    display: flex;
    align-items: center;
    gap: 16px;
    color: var(--base-white);
}

.presence-metric i {
    flex: 0 0 auto;
    color: var(--base-skin);
    font-size: 42px;
    line-height: 1;
    text-shadow: 0 0 20px rgba(19, 115, 186, 0.48);
}

.presence-metric strong {
    display: block;
    color: var(--base-white);
    font-size: 17px;
    line-height: 24px;
    font-weight: 600;
}

.presence-metric:first-child strong {
    color: var(--base-skin);
    font-size: 30px;
    line-height: 34px;
}

.presence-metric span {
    display: block;
    color: rgba(255, 255, 255, 0.78);
    font-size: 15px;
    line-height: 24px;
}

.global-presence-card {
    height: 100%;
    padding: 30px;
    border-radius: var(--base-border-radius-15);
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.16);
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.18);
    transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease;
}

.global-presence-card:hover {
    transform: translateY(-6px);
    border-color: rgba(19, 115, 186, 0.42);
    box-shadow: 0 0 28px rgba(19, 115, 186, 0.2), 0 22px 52px rgba(0, 0, 0, 0.22);
}

.global-presence-card .global-icon {
    width: 56px;
    height: 56px;
    margin-bottom: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 15px;
    background: var(--base-skin);
    color: var(--base-white);
    font-size: 24px;
}

.global-presence-card h3 {
    margin-bottom: 10px;
    color: var(--base-white);
    font-size: 24px;
    line-height: 32px;
}

.global-presence-card p {
    margin: 0;
    color: rgba(255, 255, 255, 0.76);
    font-size: 16px;
    line-height: 27px;
}

.enterprise-contact-strip {
    padding: 80px 0;
    background: linear-gradient(180deg, rgba(19, 115, 186, 0.06), rgba(255, 255, 255, 0)), var(--base-white);
}

.enterprise-contact-card {
    height: 100%;
    padding: 30px;
    border-radius: var(--base-border-radius-15);
    background: var(--base-grey);
    border: 1px solid rgba(19, 115, 186, 0.12);
    box-shadow: 0 14px 40px rgba(19, 20, 35, 0.06);
}

.enterprise-contact-card h3,
.enterprise-contact-form h3 {
    margin-bottom: 14px;
    color: var(--base-headingfont-color);
}

.enterprise-contact-card p {
    margin-bottom: 8px;
}

.enterprise-contact-form {
    padding: 40px;
    border-radius: var(--base-border-radius-15);
    background: var(--base-grey);
    box-shadow: 0 14px 40px rgba(19, 20, 35, 0.06);
}

@media (max-width: 991px) {
    .contact-global-presence,
    .enterprise-contact-strip {
        padding: 64px 0;
    }

    .contact-global-header h2 {
        font-size: 42px;
        line-height: 52px;
    }

    .global-presence-visual {
        min-height: auto;
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 18px;
        margin-top: 34px;
    }

    .global-network-globe {
        width: min(360px, 78vw);
        height: min(360px, 78vw);
        position: relative;
        left: auto;
        top: auto;
        grid-column: 1 / -1;
        margin: 0 auto 12px;
        transform: none;
    }

    .presence-callout,
    .callout-uk,
    .callout-usa,
    .callout-india,
    .callout-netherlands,
    .callout-australia {
        width: auto;
        min-height: 118px;
        position: relative;
        left: auto;
        right: auto;
        top: auto;
        bottom: auto;
        transform: none;
    }

    .presence-callout:before,
    .presence-callout:after {
        display: none;
    }

    .callout-australia:hover {
        transform: translateY(-6px);
    }

    .global-presence-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        margin-top: 28px;
    }
}

@media only screen and (min-width: 320px) and (max-width: 768px) {
    .small-screen-call-to-action {
        bottom: 64px;
        box-shadow: 0 -8px 24px rgba(19, 20, 35, 0.14);
    }
}

@media (max-width: 575px) {
    .contact-global-header h2 {
        font-size: 36px;
        line-height: 44px;
    }

    .contact-global-header p {
        font-size: 16px;
        line-height: 27px;
    }

    .global-presence-visual,
    .global-presence-metrics {
        grid-template-columns: 1fr;
    }

    .global-network-globe {
        width: min(300px, 82vw);
        height: min(300px, 82vw);
    }

    .presence-callout {
        padding: 18px;
    }

    .global-presence-metrics {
        gap: 12px;
    }
}
