:root {
    --c2-black: #191921;
    --c2-black-90: #303037; /* 90% */
    --c2-black-80: #47474D; /* 80% */
    --c2-black-70: #5e5e64; /* 70% */
    --c2-black-60: #75757A; /* 60% */
    --c2-black-50: #8C8C90; /* 50% */
    --c2-black-40: #A3A3A6; /* 40% */
    --c2-black-30: #BABABC; /* 30% */
    --c2-black-20: #D1D1D3; /* 20% */
    --c2-black-10: #E8E8E9; /* 10% */
    --c2-black-6: #F1F1F2; /* 6% */
    --c2-black-3: #F8F8F8; /* 3% */
    --c2-yellow: #fff000;
    --c2-action-blue: #0085FF;
}

body {
    font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
    margin: 0;
    padding: 0;
    height: 100%;
    border: none;
    display: flex;
    flex-direction: column;
    -webkit-font-smoothing: antialiased;
}

.body-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
}

.inline-text-link {
    color: var(--c2-action-blue);
    cursor: pointer;
    letter-spacing: -0.015em;
    transition: all 0.15s ease;
    white-space: nowrap;
    text-decoration: none;
}

.inline-text-link:any-link {
    color: var(--c2-action-blue);
}

.inline-text-link:hover {
    filter: brightness(70%);
}

.content {
    display: flex;
    flex-direction: column;
    height: 100vh;
    gap: 20px;
    justify-content: center;
    min-width: 400px;
}

.content-comingsoon {
    display: flex;
    flex-direction: column;
    height: 100vh;
    gap: 20px;
    align-items: center;
    justify-content: flex-start;
    margin-top: 25vh;
}

.content-block {
    display: flex;
    flex-direction: column;
    align-items: left;
    width: 514px;
}

@media (max-width: 600px) {
    .content-block {
        width: auto;
    }
}

.content-block-img {
    width: 250px;
    display: flex;
    justify-content: center;
}

@media (max-width: 600px) {
    .content-block-img {
        width: 150px;
    }
}

.content-block-img img {
    width: 100%;
    height: auto;
}

.header-main {
    display: flex;
    flex-direction: row;
    width: 100vw;
    height: 60px;
    background-color: #fcfcfcd2;
    border-bottom: 0.75px solid #f1f1f2;
    align-items: center;
    justify-content: center;
    position: fixed;
    z-index: 1000;
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
}

.header-main-logo {
    display: flex;
    align-items: center;
    width: 95px;
    overflow: hidden;
}

.header-main-logo img {
    width: 100%;
    height: auto;
}

.content-home {
    display: flex;
    flex-direction: column;
    gap: 3.5vh;
    align-items: center;
    padding: 100px 30px 90px 30px;
}

.splash-heading {
    display: flex;
    flex-direction: row;
    gap: 12px;
    font-size: 44px;
    font-weight: 900;
    letter-spacing: -0.02em;
    text-align: center;
    color: var(--c2-black);
    align-items: center;
    justify-content: center;
}

.heading2 {
    display: flex;
    font-size: 36px;
    line-height: 36px;
    font-weight: 900;
    letter-spacing: -0.02em;
    text-align: center;
    color: var(--c2-black);
    align-items: center;
    justify-content: center;
}

@media (max-width: 600px) {
    .heading2 { 
        font-size: 24px;
        line-height: 25px;
    }
}

@media (max-width: 800px) {
    .splash-heading { 
        flex-direction: column;
        gap: 0px;
        font-size: 40px;
    }
}

@media (max-width: 300px) {
    .splash-heading { 
        font-size: 30px;
    }
}

.splash-heading1, .splash-heading2, .splash-heading3 {
    display: flex;
    width: fit-content;
}

.getapp-badges {
    display: flex;
    flex-direction: row;
    gap: 20px;
    width: 80vw;
    max-width: 360px;
    align-items: center;
}

@media (max-width: 300px) {
    .getapp-badges {
        flex-direction: column;
    }
}

@media (min-width: 800px) {
    .getapp-badges-cta {
        display: none;
    }
}

.getapp {
    display: flex;
    align-items: center;
    overflow: hidden;
    cursor: pointer;
    transition: all 0.15s ease;
}

.getapp:hover {
    scale: 1.02;
}

.getapp img {
    width: 100%;
    height: auto;
}

.hero-container {
    display: flex;
    flex-direction: row;
    gap: 0.75vw;
    justify-content: center;
    margin-top: 15px;
    max-width: 90vw;
}

@media (max-width: 800px) {
    .hero-container {
        flex-direction: column;
        gap: 3vh;
        max-width: 60vw;
    }
}

@media (max-width: 600px) {
    .hero-container {
        flex-direction: column;
        gap: 5vw;
        max-width: 80vw;
    }
}

.app-screenshot {
    aspect-ratio: 6 / 13;
    overflow: hidden;
    width: 100%;
}

@media (max-width: 800px) {
    .app-screenshot img {
        border-radius: 4vw;
    }
}

@media (max-width: 600px) {
    .app-screenshot img {
        border-radius: 3.5vw;
    }
}

@media (min-width: 801px) {
    .app-screenshot img {
        border-radius: 0.5vw;
    }
}

.app-screenshot img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.cta-m {
    display: flex;
    flex-direction: column;
    gap: 20px;
    align-items: center;
}

@media (min-width: 800px) {
    .cta-m {
        display: none;
    }
}

.cta-heading {
    font-size: 30px;
    font-weight: 900;
    letter-spacing: -0.02em;
    text-align: center;
    color: var(--c2-black);
}

.main-section-subheading-sm {
    letter-spacing: -0.01em;
    font-size: 12px;
    font-weight: 700;
    color: var(--c2-black);
    text-align: left;
    margin-top: 20px;
}

.main-bodytext-sm {
    text-align: left;
    font-size: 12px;
    color: var(--c2-black-70);
    letter-spacing: -0.01em;
    font-weight: 400;
    line-height: 16px;
    margin-top: 15px;
}

ul.aligned-bullets-main-noindent {
    margin-left: 15px;
    padding: 0px;
    text-align: left;
    font-size: 12px;
    line-height: 16px;
    color: var(--c2-black-70);
    letter-spacing: -0.01em;
    font-weight: 400;
}

ul.aligned-bullets-main-noindent li {
    margin-bottom: 3px;
}


/* ----------------------------------------------------------------------------------
    VIPs
------------------------------------------------------------------------------------- */


/* ----------------------------------------------------------------------------------
    Footer
------------------------------------------------------------------------------------- */

.footer {
    position: fixed;
    bottom: 0;
    width: 100vw;
    height: 50px;
    min-width: 400px;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    color: var(--c2-black-70);
    font-size: 10px;
    font-weight: 300;
    text-align: center;
    margin-top: 30px;
    gap: 12px;
    background-color: #fff;
}

.footer-text {
    display: flex;
    width: fit-content;
}

.footer-text-link {
    display: flex;
    width: fit-content;
    color: inherit; 
    text-decoration: none;
}

.footer-text-link:hover {
    text-decoration: underline;
}


/* ----------------------------------------------------------------------------------
    Docs Content (privacy policy, terms etc)
------------------------------------------------------------------------------------- */

.docs-content-container {
    display: flex;
    flex-direction: column;
    flex-shrink: 1;
    align-items: center;
    padding: 30px 30px 60px 30px;
}

.docs-content-container-header {
    display: flex;
    flex-direction: column;
    flex-shrink: 1;
    align-items: center;
    padding: 90px 30px;
}

.docs-content {
    display: flex;
    flex-direction: column;
    min-width: 230px;
    max-width: 700px;
}

.docs-heading {
    letter-spacing: -0.01em;
    font-size: 18px;
    font-weight: 700;
    color: var(--c2-black);
    text-align: left;
}

.docs-bodytext {
    text-align: left;
    font-size: 12px;
    color: var(--c2-black-70);
    letter-spacing: -0.01em;
    font-weight: 400;
    line-height: 16px;
    margin-top: 15px;
}

.docs-subsection {
    text-align: left;
    font-size: 12px;
    color: var(--c2-black-70);
    letter-spacing: -0.01em;
    font-weight: 400;
    line-height: 16px;
    margin-top: 10px;
}

.docs-section-heading {
    letter-spacing: -0.01em;
    font-size: 14px;
    font-weight: 700;
    color: var(--c2-black);
    text-align: left;
    margin-top: 30px;
}

.docs-section-subheading {
    letter-spacing: -0.01em;
    font-size: 12px;
    font-weight: 700;
    color: var(--c2-black);
    text-align: left;
    margin: 15px 0px 7px 0px;
}

.docs-section-subsubheading {
    letter-spacing: -0.01em;
    font-size: 11px;
    font-weight: 600;
    color: var(--c2-black);
    text-align: left;
    margin: 15px 0px 5px 0px;
}

.docs-section-subtitle {
    letter-spacing: -0.01em;
    font-size: 12px;
    font-weight: 700;
    color: var(--c2-black);
    text-align: left;
    margin: 15px 0px 0px 0px;
}

ol li, ul li {
    margin-bottom: 10px;
}

ul.aligned-bullets, ul.aligned-bullets-faq {
    list-style-position: outside;
}

ul.aligned-bullets li {
    margin-bottom: 4px;
}

ul.aligned-bullets-faq li {
    margin-bottom: 4px;
    text-align: left;
    font-size: 16px;
    color: var(--c2-black-70);
    letter-spacing: -0.01em;
    font-weight: 400;
    line-height: 20px;
}

ul.aligned-bullets-faq-noindent {
    margin: 15px;
    padding: 0px;
    text-align: left;
    font-size: 16px;
    line-height: 20px;
    color: var(--c2-black-70);
    letter-spacing: -0.01em;
    font-weight: 400;
    line-height: 20px;
}

ul.aligned-bullets-faq-noindent li {
    margin-bottom: 3px;
}

.faq-section-heading {
    letter-spacing: -0.01em;
    font-size: 16px;
    font-weight: 700;
    color: var(--c2-black);
    text-align: left;
    margin-top: 30px;
}

.faq-section-heading-subgroup {
    letter-spacing: -0.01em;
    font-size: 16px;
    font-weight: 700;
    color: var(--c2-black);
    text-align: left;
    margin-top: 5px;
    margin-bottom: -5px;
}

.faq-section-heading2 {
    letter-spacing: -0.01em;
    font-size: 17px;
    line-height: 22px;
    font-weight: 300;
    color: var(--c2-black-70);
    text-align: left;
    margin-top: 20px;
}

.faq-section-heading3 {
    letter-spacing: -0.01em;
    font-size: 14px;
    font-weight: 900;
    color: white;
    text-align: center;
    text-transform: uppercase;
}

.faq-bodytext {
    text-align: left;
    font-size: 16px;
    color: var(--c2-black-70);
    letter-spacing: -0.01em;
    font-weight: 400;
    line-height: 20px;
    margin-top: 10px;
}

.faq-bodytext-list-container {
    display: flex;
    flex-direction: column;
    width: 100%;
    margin-top: 10px;
    gap: 2px;
}

.faq-bodytext--list {
    margin-top: 1px;
}

.badge-container-top {
    display: flex;
    width: fit-content;
    height: fit-content;
    padding: 5px 8px 6px 8px;
    background-color: #debc1e;
    border-radius: 3px;
    color: white;
    margin-top: 30px;
}

.badge-container-elite {
    display: flex;
    width: fit-content;
    height: fit-content;
    padding: 5px 8px 6px 8px;
    background-color: #000000;
    border-radius: 3px;
    color: white;
    margin-top: 30px;
}


/* ----------------------------------------------------------------------------------
    Interstitials
------------------------------------------------------------------------------------- */

.content-interstitial {
    display: flex;
    flex-direction: column;
    gap: 30px;
    height: 100vh;
    align-items: center;
    padding: 50px 30px;
}

.c2-icon-small {
    display: flex;
}

.c2-icon-small img {
    width: 13vw;
    max-width: 100px;
    min-width: 30px;
}

.c2-icon-medium {
    display: flex;
}

.c2-icon-medium img {
    width: 18vw;
    max-width: 100px;
    min-width: 50px;
}

.avatar-interstitial {
    display: flex;
    cursor: pointer;
}

.avatar-interstitial img {
    width: 66vw;
    aspect-ratio: 1 / 1;
    max-width: 400px;
    border-radius: 10px;
    object-fit: cover;
}

.heading1 {
    display: flex;
    font-size: 22px;
    font-weight: 800;
    letter-spacing: -0.02em;
    text-align: center;
    color: var(--c2-black);
}

.button1 {
    width: fit-content;
    min-width: 100px;
    padding: 12px 22px 14px 22px;
    background-color: var(--c2-yellow);
    border-radius: 10px;
    cursor: pointer;
    font-size: 22px;
    font-weight: 800;
    letter-spacing: -0.02em;
    color: var(--c2-black);
    text-align: center;
}

.subheading1 {
    display: flex;
    font-size: 20px;
    font-weight: 400;
    text-align: center;
    color: var(--c2-black);
}


/* ----------------------------------------------------------------------------------
    Promo content
------------------------------------------------------------------------------------- */

.content-promo {
    display: flex;
    flex-direction: column;
    flex-shrink: 1;
    align-items: center;
    padding: 15px 30px 60px 30px;
    margin-bottom: 110px;
    gap: 10px;
    max-width: 600px;
}

.promo-text-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 5px;
}

.promo-heading1 {
    display: flex;
    font-size: 27px;
    line-height: 110%;
    font-weight: 1000;
    letter-spacing: -0.02em;
    text-align: center;
    color: var(--c2-black);
}

.promo-subheading1 {
    display: flex;
    font-size: 23px;
    font-weight: 500;
    letter-spacing: -0.02em;
    text-align: center;
    color: var(--c2-black);
}

.promo-titleblock {
    display: flex;
    justify-content: center;
    width: 100%;
    height: fit-content;
    padding: 4px 0px 6px 0px;
    background-color: var(--c2-black-10);
    border-radius: 3px;
    margin-top: 10px;
    box-sizing: border-box;
}

.promo-titleblock-text {
    font-size: 15px;
    font-weight: 1000;
    letter-spacing: -0.02em;
    text-align: center;
    color: var(--c2-black);
}

.promo-list-numbered {
    display: flex;
    flex-direction: column;
    gap: 8px;
    width: 100%;
}

.promo-list-numbered-group {
    display: flex;
    flex-direction: row;
}

.promo-list-number {
    display: flex;
    width: 25px;
    font-size: 17px;
    font-weight: 1000;
    letter-spacing: -0.02em;
    text-align: left;
    color: var(--c2-black);
}

.promo-list-text {
    font-size: 17px;
    font-weight: 400;
    line-height: 125%;
    letter-spacing: -0.015em;
    text-align: left;
    color: var(--c2-black);
    width: 100%;
}

.promo-chart {
    display: flex;
    flex-direction: column;
    gap: 5px;
    width: 100%;
    margin-top: 20px;
    align-items: center;
}

.promo-chart-title-group {
    display: flex;
    flex-direction: row;
    width: 100%;
    font-size: 14px;
    font-weight: 1000;
    letter-spacing: -0.02em;
    text-align: center;
    color: var(--c2-black)
}

.promo-chart-title {
    display: flex;
    width: 100%;
    justify-content: center;
}

.promo-chart-row {
    display: flex;
    flex-direction: row;
    gap: 5px;
    width: 100%;
    padding: 4px;
    background-color: var(--c2-black-6);
    border-radius: 3px;
    box-sizing: border-box;
    margin-top: 6px;
}

.promo-chart-row-group {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    width: 100%;
    gap: 5px;
}

.promo-chart-row-group-left {
    display: flex;
    flex-direction: row;
    width: 100%;
    gap: 5px;
    margin-left: 28%;
    align-items: center;
}

@media (min-width: 600px) {
    .promo-chart-row-group-left {
        margin-left: 35%;
    }
}

.promo-chart-row-group-right {
    display: flex;
    flex-direction: row;
    width: 100%;
    gap: 5px;
    margin-left: 12%;
    align-items: center;
}

@media (min-width: 600px) {
    .promo-chart-row-group-right {
        margin-left: 23%;
    }
}

.promo-chart-row-group-image {
    display: flex;
}

.promo-chart-row-group-image img {
    width: 24px;
    margin-bottom: 1px;
    object-fit: cover;
    object-position: center;
}

.separator {
    display: flex;
    width: 1px;
    margin: 3px 0;
    background-color: var(--c2-black-30);
    flex-shrink: 0;
}

.promo-chart-row-text {
    font-size: clamp(1rem, 4vw, 1.4rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    text-align: left;
    color: var(--c2-black);
    display: flex;
    margin-bottom: 1px;
}

.divider {
   width: 30%;
   height: 1px;
   background-color: #d5d5d5;
   margin-top: 5px;
   border-radius: 1px;
}

.promo-chart-footer {
    display: flex;
    justify-content: center;
    font-size: 13px;
    font-weight: 400;
    letter-spacing: -0.01em;
    text-align: center;
    color: var(--c2-black-60);
}

.promo-notes {
    font-size: 13px;
    font-weight: 400;
    line-height: 130%;
    letter-spacing: -0.01em;
    text-align: left;
    color: var(--c2-black-60);
    width: 100%;
    margin-top: 10px;
}

.promo-notes p {
    margin-bottom: -9px;
}

.sticky-footer {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: center;
    box-sizing: border-box;
    background-color: rgba(255, 255, 255, 0.65);
    gap: 20px;
    padding: 20px 0 30px 0;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    justify-content: center;
    z-index: 10;
}

.footer-group {
    display: flex;
    flex-direction: row;
    justify-content: center;
    width: 100%;
}

.footer-group-text {
    font-size: 21px;
    font-weight: 500;
    line-height: 120%;
    letter-spacing: -0.01em;
    text-align: center;
    color: var(--c2-black);
}

.inline-bold-text {
    font-weight: 1000;
}


/* ----------------------------------------------------------------------------------
    Lucky Gifts webview
------------------------------------------------------------------------------------- */

.luckygift-content {
    display: flex;
    flex-direction: column;
    padding: 20px 40px 40px 40px;
    align-items: center;
    width: 100vw;
    box-sizing: border-box;
    gap: 30px;
    max-width: 600px;
    min-width: 350px;
}

.gift-heading {
    text-align: left;
    font-size: 20px;
    color: var(--c2-black);
    letter-spacing: -0.01em;
    font-weight: 700;
    line-height: 120%
}

.giftblock {
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: 100%;
    padding: 20px;
    border: 1px solid var(--c2-black-20);
    box-sizing: border-box;
    border-radius: 10px;
}

.giftsblock-image {
    display: flex;
    justify-content: center;
}

.giftsblock-image img{
    width: 30%;
    height: auto;
    display: block;
}

.horizontal-separator {
    display: flex;
    background-color: var(--c2-black-10);
    width: 100%;
    height: 1px;
}

.horizontal-separator--dark {
    background-color: var(--c2-black-30);
}

.gift-textblock {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.gift-section-heading {
    letter-spacing: -0.01em;
    font-size: 18px;
    font-weight: 800;
    color: var(--c2-black);
    text-align: center;
}

.gift-bodytext {
    text-align: left;
    font-size: 15px;
    color: var(--c2-black-70);
    letter-spacing: -0.01em;
    font-weight: 400;
    line-height: 120%;
}

.gift-chartheader {
    display: flex;
    justify-content: center;
    width: 100%;
    height: fit-content;
    padding: 4px 0px 6px 0px;
    background-color: var(--c2-black-6);
    border-radius: 3px;
    margin-top: 10px;
    box-sizing: border-box;
}

.gift-chartheader-text {
    font-size: 13px;
    font-weight: 700;
    letter-spacing: -0.02em;
    text-align: center;
    color: var(--c2-black);
}

.gifts-chart {
    display: flex;
    flex-direction: column;
    width: 100%;
    gap: 1px;
}

.gifts-chart-row {
    display: flex;
    flex-direction: row;
    width: 100%;
    justify-content: space-between;
    align-items: center;
}

.gifts-chart-row-group-left {
    display: flex;
    flex-direction: row;
    gap: 3px;
    width: fit-content;
    align-items: center;
}

.gifts-chart-row-group-image img {
    height: 25px;
    width: auto;
    display: block;
    padding-bottom: 2px;
}

.gifts-chart-row-text-left {
    text-align: left;
    font-size: 13px;
    color: var(--c2-black-70);
    letter-spacing: -0.01em;
    font-weight: 400;
    line-height: 120%;
}

.gifts-chart-row-text-right {
    text-align: right;
    font-size: 13px;
    color: var(--c2-black-60);
    letter-spacing: -0.01em;
    font-weight: 400;
    line-height: 120%;
}



/* ----------------------------------------------------------------------------------
    Contest and Challenges IG post webview
------------------------------------------------------------------------------------- */

.ig-post-content {
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding: 20px;
    margin-bottom: 50px;
}

.ig-post, 
.ig-post img {
  display: block;
  width: 100%;
  max-width: 800px;
  height: auto;
  box-sizing: border-box;
  
}