.gx-ella,
.gx-ella * {
    box-sizing: border-box;
}

.gx-ella {
    --gx-ella-size: 128px;
    --gx-ella-bottom: 24px;
    --gx-ella-final-right: 260px;
    --gx-ella-target-top: 50vh;
    --gx-ella-target-right: 80px;
    --gx-ella-z: 999998;
    --gx-ella-primary: #2563EB;
    --gx-ella-secondary: #14B8A6;
    --gx-ella-dark: #00163D;
    --gx-ella-walk-duration: 4200ms;
    --gx-pointer-angle: -35deg;
    --gx-pointer-width: 180px;
    --gx-pointer-left: calc(var(--gx-ella-size) * .22);
    --gx-pointer-top: calc(var(--gx-ella-size) * .98);
    --gx-ella-wave-interval: 5500ms;

    position: fixed;
    left: 0;
    bottom: var(--gx-ella-bottom);
    width: var(--gx-ella-size);
    height: calc(var(--gx-ella-size) * 1.5);
    z-index: var(--gx-ella-z);
    pointer-events: none;
    transform: translateX(calc(-1 * var(--gx-ella-size) - 42px));
    opacity: 0;
    transition: transform var(--gx-ella-walk-duration) cubic-bezier(.22,.78,.22,1), opacity 360ms ease;
    font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.gx-ella.gx-ella--ready {
    opacity: 1;
}

.gx-ella.gx-ella--walk,
.gx-ella.gx-ella--arrived {
    transform: translateX(calc(100vw - var(--gx-ella-size) - var(--gx-ella-final-right)));
}

.gx-ella.gx-ella--screen-disabled {
    display: none !important;
}

.gx-ella__hotspot {
    position: absolute;
    left: 0;
    bottom: 0;
    width: var(--gx-ella-size);
    height: calc(var(--gx-ella-size) * 1.28);
    border: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    background-color: transparent !important;
    box-shadow: none !important;
    color: inherit !important;
    cursor: pointer;
    pointer-events: auto;
    -webkit-tap-highlight-color: transparent;
    appearance: none;
    -webkit-appearance: none;
}

.gx-ella .gx-ella__hotspot:hover,
.gx-ella .gx-ella__hotspot:focus,
.gx-ella .gx-ella__hotspot:active,
.gx-ella button.gx-ella__hotspot:hover,
.gx-ella button.gx-ella__hotspot:focus,
.gx-ella button.gx-ella__hotspot:active {
    background: transparent !important;
    background-color: transparent !important;
    box-shadow: none !important;
    border-color: transparent !important;
    color: inherit !important;
}

.gx-ella .gx-ella__hotspot::before,
.gx-ella .gx-ella__hotspot::after {
    content: none !important;
    display: none !important;
}

.gx-ella__hotspot:focus:not(:focus-visible) {
    outline: none !important;
}

.gx-ella__hotspot:focus-visible {
    outline: 3px solid var(--gx-ella-secondary) !important;
    outline-offset: 8px;
    border-radius: 22px;
    background: transparent !important;
}

.gx-ella__mascot {
    position: absolute;
    inset: 0;
    display: block;
    transform-origin: 50% 100%;
}

.gx-ella--walk .gx-ella__mascot {
    animation: gxEllaWalkBob .48s ease-in-out infinite alternate;
}

.gx-ella--arrived .gx-ella__mascot,
.gx-ella--point .gx-ella__mascot,
.gx-ella--rest .gx-ella__mascot {
    animation: gxEllaIdleBob 2.5s ease-in-out infinite;
}

.gx-ella__shadow {
    position: absolute;
    left: 13%;
    bottom: 0;
    width: 74%;
    height: 11%;
    border-radius: 999px;
    background: rgba(0, 12, 32, .32);
    filter: blur(5px);
}

.gx-ella__antenna {
    position: absolute;
    left: 50%;
    top: 0;
    width: 4%;
    height: 16%;
    transform: translateX(-50%);
    background: linear-gradient(180deg, rgba(255,255,255,.88), var(--gx-ella-primary));
    border-radius: 999px;
    z-index: 4;
}

.gx-ella__antenna span {
    position: absolute;
    left: 50%;
    top: -12%;
    width: 270%;
    aspect-ratio: 1;
    transform: translateX(-50%);
    border-radius: 50%;
    background: radial-gradient(circle at 35% 30%, #fff 0 8%, #74ddff 15%, var(--gx-ella-primary) 58%, var(--gx-ella-dark) 100%);
    box-shadow: 0 0 15px rgba(20,184,166,.86);
}

.gx-ella__ear {
    position: absolute;
    top: 25%;
    width: 14%;
    height: 23%;
    border-radius: 999px;
    background: linear-gradient(180deg, #f6fbff, #b9d3f7 48%, var(--gx-ella-primary));
    box-shadow: inset 0 0 0 2px rgba(255,255,255,.55), 0 8px 18px rgba(0, 29, 81, .22);
    z-index: 2;
}

.gx-ella__ear::after {
    content: "";
    position: absolute;
    inset: 25%;
    border-radius: inherit;
    background: radial-gradient(circle, #56e6ff 0 25%, var(--gx-ella-primary) 55%, var(--gx-ella-dark) 100%);
    box-shadow: 0 0 13px rgba(20,184,166,.72);
}

.gx-ella__ear--left {
    left: 1%;
}

.gx-ella__ear--right {
    right: 1%;
}

.gx-ella__head {
    position: absolute;
    left: 9%;
    top: 12%;
    width: 82%;
    height: 48%;
    border-radius: 42% 42% 38% 38%;
    background: linear-gradient(145deg, #ffffff 0%, #e6efff 45%, #b8d1f8 100%);
    box-shadow: inset 0 3px 8px rgba(255,255,255,.95), inset 0 -8px 18px rgba(31,98,220,.2), 0 14px 30px rgba(0, 24, 70, .23);
    z-index: 3;
}

.gx-ella__face {
    position: absolute;
    left: 12%;
    top: 23%;
    width: 76%;
    height: 48%;
    border-radius: 36px;
    background: radial-gradient(circle at 50% 0%, rgba(37,99,235,.35), transparent 40%), linear-gradient(180deg, #001a49, #020716 100%);
    box-shadow: inset 0 0 0 2px rgba(94, 197, 255, .26), 0 0 22px rgba(37, 99, 235, .34);
}

.gx-ella__eye {
    position: absolute;
    top: 36%;
    width: 18%;
    height: 22%;
    border: calc(var(--gx-ella-size) * .027) solid #35e3ff;
    border-bottom: 0;
    border-left-color: transparent;
    border-right-color: transparent;
    border-radius: 999px 999px 0 0;
    filter: drop-shadow(0 0 6px rgba(20,184,166,.85));
}

.gx-ella__eye--left {
    left: 24%;
}

.gx-ella__eye--right {
    right: 24%;
}

.gx-ella__smile {
    position: absolute;
    left: 42%;
    top: 61%;
    width: 16%;
    height: 8%;
    border-bottom: 2px solid rgba(53, 227, 255, .78);
    border-radius: 0 0 999px 999px;
}

.gx-ella__body {
    position: absolute;
    left: 22%;
    top: 55%;
    width: 56%;
    height: 34%;
    border-radius: 28% 28% 32% 32%;
    background: linear-gradient(145deg, #ffffff 0%, #dfebff 54%, #b6d3ff 100%);
    box-shadow: inset 0 3px 7px rgba(255,255,255,.88), inset 0 -8px 13px rgba(37,99,235,.24), 0 13px 23px rgba(0, 31, 76, .16);
    z-index: 2;
}

.gx-ella__body::after {
    content: "";
    position: absolute;
    left: 14%;
    right: 14%;
    bottom: 9%;
    height: 5px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--gx-ella-primary), var(--gx-ella-secondary));
    box-shadow: 0 0 12px rgba(20,184,166,.48);
}

.gx-ella__badge {
    position: absolute;
    left: 50%;
    top: 35%;
    transform: translate(-50%, -50%);
    color: var(--gx-ella-primary);
    font-size: calc(var(--gx-ella-size) * .22);
    font-weight: 900;
    line-height: 1;
    letter-spacing: -.05em;
    text-shadow: 0 1px 0 #fff, 0 0 12px rgba(20,184,166,.35);
}

.gx-ella__arm {
    position: absolute;
    top: 61%;
    width: 13%;
    height: 34%;
    border-radius: 999px;
    background: linear-gradient(180deg, #f9fcff, #b4cdf7 56%, var(--gx-ella-primary));
    transform-origin: 50% 12%;
    box-shadow: inset 0 0 0 2px rgba(255,255,255,.42), 0 7px 12px rgba(0,31,76,.14);
    z-index: 1;
}

.gx-ella__arm--left {
    left: 12%;
    transform: rotate(24deg);
}

.gx-ella__arm--right {
    right: 11%;
    transform: rotate(-18deg);
    z-index: 4;
}

.gx-ella--point .gx-ella__arm--right {
    animation: gxEllaRightPointArm .7s ease both;
    z-index: 4;
}

.gx-ella--arrived.gx-ella--wave .gx-ella__arm--left,
.gx-ella--rest.gx-ella--wave .gx-ella__arm--left {
    animation: gxEllaLeftWave var(--gx-ella-wave-interval) ease-in-out infinite;
    z-index: 4;
}

.gx-ella--hover-wave .gx-ella__arm--left {
    animation: gxEllaLeftQuickWave .95s ease-in-out 2;
    z-index: 4;
}

.gx-ella__hand {
    position: absolute;
    left: 50%;
    bottom: -11%;
    width: 142%;
    aspect-ratio: 1;
    transform: translateX(-50%);
    border-radius: 50%;
    background: linear-gradient(145deg, #fff, #bdd6ff 70%, var(--gx-ella-primary));
    box-shadow: inset 0 0 0 2px rgba(255,255,255,.62);
}

.gx-ella__leg {
    position: absolute;
    top: 85%;
    width: 15%;
    height: 17%;
    border-radius: 999px 999px 26% 26%;
    background: linear-gradient(180deg, #d9e8ff, #8eb8ff 52%, var(--gx-ella-primary));
    transform-origin: 50% 0;
    z-index: 1;
}

.gx-ella__leg--left {
    left: 34%;
}

.gx-ella__leg--right {
    right: 34%;
}

.gx-ella--walk .gx-ella__leg--left {
    animation: gxEllaLegLeft .48s ease-in-out infinite alternate;
}

.gx-ella--walk .gx-ella__leg--right {
    animation: gxEllaLegRight .48s ease-in-out infinite alternate;
}

.gx-ella__pointer {
    position: absolute;
    left: var(--gx-pointer-left);
    top: var(--gx-pointer-top);
    width: var(--gx-pointer-width);
    height: 3px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--gx-ella-secondary), rgba(20,184,166,.42), rgba(20,184,166,0));
    box-shadow: 0 0 14px rgba(20, 184, 166, .75);
    transform-origin: 0 50%;
    transform: translateY(-50%) rotate(var(--gx-pointer-angle)) scaleX(0);
    opacity: 0;
    pointer-events: none;
    transition: transform 520ms ease, opacity 260ms ease;
    z-index: 2;
}

.gx-ella__pointer::after {
    content: "";
    position: absolute;
    right: -2px;
    top: 50%;
    width: 12px;
    height: 12px;
    border-right: 3px solid var(--gx-ella-secondary);
    border-top: 3px solid var(--gx-ella-secondary);
    transform: translateY(-50%) rotate(45deg);
    filter: drop-shadow(0 0 8px rgba(20,184,166,.9));
}

.gx-ella--show-pointer .gx-ella__pointer,
.gx-ella--bubble .gx-ella__pointer {
    transform: translateY(-50%) rotate(var(--gx-pointer-angle)) scaleX(1);
    opacity: 1;
}

.gx-ella__bubble {
    position: absolute;
    right: calc(var(--gx-ella-size) * -1.05);
    bottom: calc(var(--gx-ella-size) * 1.05);
    width: min(330px, calc(100vw - 32px));
    padding: 16px 44px 16px 18px;
    border-radius: 22px;
    background: rgba(255,255,255,.97);
    color: #07152d;
    box-shadow: 0 22px 55px rgba(0, 20, 56, .24), 0 0 0 1px rgba(37,99,235,.12);
    opacity: 0;
    transform: translateY(12px) scale(.96);
    transition: opacity 300ms ease, transform 300ms ease;
    pointer-events: none;
    z-index: 5;
}

.gx-ella__bubble::before {
    content: "";
    position: absolute;
    left: 28px;
    bottom: -9px;
    width: 18px;
    height: 18px;
    background: inherit;
    transform: rotate(45deg);
    box-shadow: 1px 1px 0 rgba(37,99,235,.08);
}

.gx-ella__bubble-title {
    display: block;
    margin-bottom: 5px;
    color: var(--gx-ella-primary);
    font-size: 14px;
    font-weight: 900;
    letter-spacing: .02em;
}

.gx-ella__bubble-text {
    display: block;
    color: #0a1832;
    font-size: 15px;
    line-height: 1.42;
    font-weight: 600;
}

.gx-ella__close {
    position: absolute;
    top: 9px;
    right: 11px;
    width: 26px;
    height: 26px;
    border: 0;
    border-radius: 50%;
    background: #edf5ff;
    color: #274061;
    cursor: pointer;
    font-size: 19px;
    line-height: 24px;
    pointer-events: auto;
}

.gx-ella__close:hover,
.gx-ella__close:focus-visible {
    background: var(--gx-ella-primary);
    color: #fff;
}

.gx-ella--bubble .gx-ella__bubble {
    opacity: 1;
    transform: translateY(0) scale(1);
    pointer-events: auto;
}

.gx-ella__mascot--image {
    display: flex;
    align-items: flex-end;
    justify-content: center;
}

.gx-ella__image {
    display: block;
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    filter: drop-shadow(0 18px 24px rgba(0,20,56,.25));
}

@media (max-width: 720px) {
    .gx-ella {
        --gx-ella-size: min(108px, 27vw);
        --gx-ella-final-right: 22px;
        --gx-ella-bottom: 16px;
    }

    .gx-ella__bubble {
        position: fixed;
        left: 14px;
        right: 14px;
        bottom: calc(var(--gx-ella-bottom) + var(--gx-ella-size) + 18px);
        width: auto;
    }

    .gx-ella__bubble::before {
        left: auto;
        right: 55px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .gx-ella {
        transition: opacity 200ms ease;
        transform: translateX(calc(100vw - var(--gx-ella-size) - var(--gx-ella-final-right)));
    }

    .gx-ella__mascot,
    .gx-ella__leg,
    .gx-ella__arm--left,
    .gx-ella__arm--right {
        animation: none !important;
    }
}

@keyframes gxEllaWalkBob {
    from { transform: translateY(0) rotate(-1deg); }
    to { transform: translateY(-7px) rotate(1deg); }
}

@keyframes gxEllaIdleBob {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-4px); }
}

@keyframes gxEllaRightPointArm {
    0% { transform: rotate(-18deg); }
    58% { transform: rotate(-128deg); }
    100% { transform: rotate(-118deg); }
}

@keyframes gxEllaLeftWave {
    0%, 48%, 100% { transform: rotate(24deg); }
    56% { transform: rotate(116deg); }
    63% { transform: rotate(82deg); }
    70% { transform: rotate(124deg); }
    77% { transform: rotate(86deg); }
    84% { transform: rotate(24deg); }
}

@keyframes gxEllaLeftQuickWave {
    0%, 100% { transform: rotate(24deg); }
    20% { transform: rotate(122deg); }
    40% { transform: rotate(82deg); }
    60% { transform: rotate(118deg); }
    80% { transform: rotate(84deg); }
}

@keyframes gxEllaLegLeft {
    from { transform: rotate(-15deg); }
    to { transform: rotate(15deg); }
}

@keyframes gxEllaLegRight {
    from { transform: rotate(15deg); }
    to { transform: rotate(-15deg); }
}
