:root {
    --color-bg1: #12181f;
    --color-bg2: #0b0f14;
    --color-bg3: #202933;
    --color-bg4: #29303a;
    --color-primary: #131a22;
    --color-primary-hover: #0f141a;
    --color-fg1: white;
    --color-fg2: rgb(224, 224, 224);
    --color-border: #666;
    --padding-large: 2rem
}

body {
    font-family: Inter, sans-serif;
    background-image: linear-gradient(to bottom right, #0b0f14, #192330, #0b0f14);
    padding: 0;
    margin: 0;
    color: var(--color-fg2);
    max-width: 100vw;
    overflow: hidden;
    font-size: 17px
}

.container {
    display: flex;
    flex-direction: column;
    overflow: hidden
}

.footer {
    padding: 10px;
    text-align: center
}

.tabs {
    border-radius: 10px;
    overflow: hidden
}

.tab,
.tabs {
    display: flex
}

.tab {
    cursor: pointer;
    flex: 1 1;
    padding: 15px;
    text-align: center;
    color: #ccc;
    background-color: rgba(31, 41, 55, .5);
    align-items: center;
    justify-content: center;
    gap: 5px;
    white-space: nowrap
}

@media (max-width:450px) {
    .tab {
        font-size: .9em
    }
}

.navbar {
    background-color: rgba(0, 0, 0, .2);
    -webkit-backdrop-filter: blur(24px);
    backdrop-filter: blur(24px);
    border-bottom: 1px solid rgba(168, 85, 247, .2);
    padding: .8rem 1rem;
    justify-content: space-between;
    flex-direction: row;
    align-items: center;
    z-index: 999
}

.navbar,
.top_right {
    display: flex
}

@media (max-width:450px) {
    .top_right {
        align-items: center;
        flex-direction: row;
        gap: 8px
    }
}

@media (min-width:451px) {
    .top_right {
        flex-direction: row;
        align-items: center;
        gap: 12px
    }
}

.btn {
    all: unset;
    font-weight: 700;
    cursor: pointer;
    padding: .7rem 1rem;
    border-radius: .5rem;
    font-weight: 500;
    display: flex;
    justify-content: center;
    gap: 5px;
    align-items: center;
    border: 1px solid var(--color-border);
    transition: all .3s ease
}

.btn-linear {
    background-image: linear-gradient(90deg, #2563eb, #9333ea)
}

.btn-underline {
    color: #ccc;
    text-decoration: underline
}

.btn-plain span {
    color: #ccc;
    text-decoration: none
}

.btn-plain:hover span {
    color: white;
    transform: scale(1.02)
}

.btn-opacity {
    opacity: .6
}

.btn-opacity:hover {
    opacity: .7
}

.btn-primary {
    color: #333;
    font-weight: 700;
    background-image: linear-gradient(135deg, rgb(188, 204, 218) 20%, rgb(121, 169, 207), rgb(188, 204, 218), rgb(121, 169, 207));
    background-size: 200% auto;
    background-position: 100%;
    transition: background-position .5s ease;
    cursor: pointer;
    text-align: center;
    font-size: 16px;
    border-radius: 8px;
    border: 1px solid #d0f0ff
}

.btn-primary:hover {
    background-position: 0
}

.btn-primary-submitting {
    color: #333;
    font-weight: 700;
    background-image: repeating-linear-gradient(135deg, rgb(127, 171, 207), rgb(188, 204, 218) 25%, rgb(127, 171, 207) 50%);
    background-size: 200% 200%;
    animation: marquee-effect .8s linear infinite;
    cursor: wait;
    text-align: center;
    font-size: 16px;
    border-radius: 8px
}

@keyframes marquee-effect {
    0% {
        background-position: 100% 100%
    }

    to {
        background-position: 0 0
    }
}

.btn-dark {
    background-color: var(--color-primary);
    border-color: #1f2b38
}

.btn-dark:hover {
    background-color: var(--color-primary-hover);
    border-color: #16a34a
}

.btn-red {
    background-color: #dc2626
}

.btn span {
    white-space: nowrap
}

.btn-lg {
    padding: .8rem 1.5rem
}

.btn-sm {
    font-weight: 400;
    padding: .3rem 1rem
}

.btn-sm span {
    font-size: 14px
}

.btn-sm .icon {
    width: 16px;
    height: 16px
}

.btn-block {
    width: 100%;
    box-sizing: border-box
}

.btn-lg span {
    font-size: 1.1rem;
    font-weight: 700
}

.icon {
    display: flex;
    justify-content: center;
    align-items: center
}

.icon svg {
    width: 20px;
    height: 20px
}

.icon_sm svg {
    width: 16px;
    height: 16px
}

.icon_btn {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 28px;
    height: 28px;
    background-color: rgba(255, 255, 255, .1);
    color: rgba(255, 255, 255, .6);
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, .8);
    transition: background-color .2s ease;
    cursor: pointer
}

.icon_btn:hover {
    background-color: rgba(255, 255, 255, .3);
    color: rgba(255, 255, 255, .8)
}

.input {
    width: 100%;
    box-sizing: border-box;
    background-color: rgba(31, 41, 55, .5);
    border: 1px solid #4b5563;
    border-radius: .5rem;
    padding: .75rem 1rem;
    color: white;
    transition: color .3s, border-color .3s;
    font-size: 17px
}

.input::placeholder {
    color: #9ca3af
}

.input:focus {
    border-color: #bebebe;
    outline: none
}

.card {
    background: linear-gradient(to bottom right, var(--color-bg3), var(--color-bg2));
    -webkit-backdrop-filter: blur(24px);
    backdrop-filter: blur(24px);
    border-radius: 1rem;
    padding: 1.5rem 1.5rem 0;
    border: 1px solid #414955;
    box-sizing: border-box
}

@media (max-width:450px) {
    .card {
        width: calc(100% - 2rem);
        margin: 1rem
    }
}

@media (min-width:451px) {
    .card {
        width: 430px
    }
}

.spinner-container {
    display: flex;
    justify-content: center;
    align-items: center
}

.spinner {
    width: 40px;
    height: 40px;
    border: 4px solid rgba(0, 0, 0, .2);
    border-top-color: #bde5ff;
    border-radius: 50%;
    animation: spin 1s linear infinite
}

@keyframes spin {
    to {
        transform: rotate(1turn)
    }
}

.withdraw_max {
    color: white;
    background-color: #000000;
    font-size: 12px;
    border-radius: 4px;
    padding: 2px 7px;
    cursor: pointer
}

.withdraw_max:hover {
    background-color: #888888
}

.user_panel_btn {
    display: flex;
    align-items: center;
    border-radius: 20px;
    background-color: rgba(0, 0, 0, .5);
    border: 1px solid rgba(0, 0, 0, .5);
    padding: 5px;
    font-weight: 700;
    font-size: 12px
}

.user_panel_btn:hover {
    border-color: rgba(145, 255, 163, .5)
}

.btn-plain {
    border: none
}

.btn-plain .disconnect_btn,
.btn-plain .disconnect_btn:hover {
    color: #ff8d8d
}

.btn-outline {
    border-radius: 4px;
    border-color: #8b928c;
    box-sizing: border-box;
    background-color: var(--color-primary)
}

.btn-outline:hover {
    background-color: var(--color-primary-hover);
    border-color: #16a34a
}

.hover-zoomin:hover {
    transform: scale(1.2)
}

.wallet-item {
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    padding: 10px;
    border-radius: 6px
}

.wallet-item:hover {
    background-color: #11151b
}

.tooltip-container {
    position: relative;
    display: inline-block
}

.tooltip {
    position: absolute;
    bottom: 120%;
    left: 50%;
    transform: translateX(-50%) translateY(10px);
    padding: 8px 15px;
    background: black;
    color: #ccc;
    border-radius: 4px;
    font-size: 12px;
    white-space: nowrap;
    z-index: 9000;
    background-image: linear-gradient(175deg, #18181a, #323338);
    box-shadow: 10px 5px 5px black;
    opacity: 0;
    visibility: hidden;
    transition: opacity .3s ease, transform .3s ease, visibility .3s ease
}

.tooltip-container:hover .tooltip {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0)
}

.tooltip:after {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: 6px solid transparent;
    border-top-color: #323338
}

.faq {
    font-size: .9em;
    color: #ccc;
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 30px
}

.faq_q {
    color: #999999;
    margin-bottom: 3px
}

.info {
    padding: 10px;
    border-radius: 6px;
    font-size: .85em;
    background-color: #222c31;
    border: 1px solid #484c50
}

* {
    -webkit-tap-highlight-color: transparent
}

.input_opt {
    position: absolute;
    right: 5px;
    top: 8px;
    display: flex;
    gap: 6px;
    align-items: center
}

.token_switch_option {
    display: flex;
    gap: 5px;
    align-items: center
}

.token_switch_option img {
    width: 20px;
    height: 20px
}

.token_switch {
    padding: 5px;
    border-radius: 15px;
    border: 1px solid rgba(31, 41, 55, .5);
    display: flex;
    align-items: center
}

.swap-image {
    width: 30px;
    filter: invert();
    margin-left: auto;
    margin-right: auto;
}

.blurred {
    filter: blur(100);
}