body.mobile-auth-page-prime {
    background:
        radial-gradient(circle at 15% 12%, rgba(29, 127, 157, 0.24), transparent 20rem),
        radial-gradient(circle at 86% 18%, rgba(11, 70, 88, 0.18), transparent 18rem),
        linear-gradient(145deg, #eaf2f6 0%, #f8fbfd 48%, #edf3f7 100%);
}

.auth-mobile-card {
    max-width: 500px;
}

body.mobile-auth-page-prime .card {
    border-color: rgba(11, 70, 88, 0.2);
    border-radius: 1rem;
    box-shadow: 0 1rem 2.4rem rgba(11, 70, 88, 0.14) !important;
    overflow: hidden;
}

body.mobile-auth-page-prime .card-header {
    background: linear-gradient(135deg, #0b3548 0%, #126b85 64%, #70a8bd 100%) !important;
    border-color: rgba(11, 70, 88, 0.2);
    font-weight: 700;
}

.auth-mobile-logo {
    height: auto;
    max-width: 60%;
    position: relative;
    z-index: 1;
    -webkit-mask-image: radial-gradient(circle at center, #000 70%, rgba(0, 0, 0, 0.94) 82%, rgba(0, 0, 0, 0.5) 92%, transparent 100%);
    mask-image: radial-gradient(circle at center, #000 70%, rgba(0, 0, 0, 0.94) 82%, rgba(0, 0, 0, 0.5) 92%, transparent 100%);
}

body.mobile-auth-page-prime .auth-mobile-logo {
    filter: drop-shadow(0 0.75rem 1.25rem rgba(11, 70, 88, 0.12));
    max-width: 72% !important;
}

.auth-mobile-logo-wrap {
    border-radius: 1.35rem;
    display: inline-block;
    isolation: isolate;
    margin: 0 auto 0.5rem;
    padding: 0.8rem 0.95rem;
    position: relative;
    width: fit-content;
}

.mobile-shell-logo-frame {
    padding: 0.9rem 1rem;
}

.mobile-shell-logo-frame::before {
    inset: 0.8rem 10% 0.7rem;
}

.mobile-shell-logo-frame::after {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.82) 0%, rgba(244, 249, 255, 0.62) 100%);
    border-color: rgba(255, 255, 255, 0.74);
    box-shadow:
        0 1.1rem 2rem rgba(53, 95, 152, 0.18),
        inset 0 1px 0 rgba(255, 255, 255, 0.54);
}

.auth-mobile-logo-wrap::before {
    background: radial-gradient(circle at center, rgba(255, 255, 255, 0.96) 0%, rgba(255, 255, 255, 0.72) 48%, rgba(255, 255, 255, 0) 78%);
    content: "";
    filter: blur(1rem);
    inset: 1rem 12% 0.8rem;
    pointer-events: none;
    position: absolute;
    z-index: 0;
}

.auth-mobile-logo-wrap::after {
    backdrop-filter: blur(16px);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.74) 0%, rgba(255, 255, 255, 0.56) 100%);
    border: 1px solid rgba(255, 255, 255, 0.72);
    border-radius: inherit;
    box-shadow:
        0 1rem 1.8rem rgba(122, 146, 175, 0.16),
        inset 0 1px 0 rgba(255, 255, 255, 0.42);
    content: "";
    inset: 0;
    position: absolute;
    -webkit-backdrop-filter: blur(16px);
    z-index: 0;
}

body.mobile-auth-page-prime .auth-mobile-logo-wrap::after {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.78) 0%, rgba(245, 250, 255, 0.58) 100%);
    border-color: rgba(151, 182, 219, 0.38);
    box-shadow:
        0 1.1rem 2rem rgba(53, 95, 152, 0.16),
        inset 0 1px 0 rgba(255, 255, 255, 0.5);
}

.auth-mobile-link {
    color: var(--gps-primary);
    font-weight: 500;
}

.auth-mobile-link:hover,
.auth-mobile-link:focus {
    color: var(--gps-primary-dark);
}

.auth-section-divider {
    border-top-color: rgba(91, 108, 134, 0.18);
    opacity: 1;
}

.auth-provider-btn {
    display: inline-flex;
    justify-content: center;
    text-decoration: none;
    width: 100%;
}

.auth-provider-logo {
    height: 24px;
    margin-right: 8px;
    width: auto;
}
