:root {
    --primary-text-color: #FFFFFF;
    --secondary-text-color: #FFFFFF;
    --tertiary-text-color: #FFFFFF;
    --text-on-dark-color: #232322;
    --highlight-color: #7763DB;
    --white-background-color: #FFFFFF;
    --highlight-color2: #F9F871;
}

@font-face {
  font-family: 'Geist';
  src: url('/fonts/GeistVF.woff2') format('woff2');
  font-weight: 100 900; /* Assuming it covers a range of weights */
  font-style: normal; /* Change to 'italic' if the font is italic */
  font-display: swap; /* This helps with displaying text while the font is loading */
}

@font-face {
  font-family: 'Oddval';
  src: url('/fonts/oddval.woff2') format('woff2');
  font-weight: 700; /* Assuming it covers a range of weights */
  font-style: normal; /* Change to 'italic' if the font is italic */
  font-display: swap; /* This helps with displaying text while the font is loading */
}

* {
    font-family: 'Geist', sans-serif;
}

p {
    color: var(--primary-text-color);
}

h1 {
    font-family: 'Oddval', sans-serif;
}

h2.odd {
    font-family: 'Oddval', sans-serif;
    color: var(--primary-text-color);
    font-size: 24px;
}

h4.odd {
    font-family: 'Oddval', sans-serif;
    color: var(--primary-text-color);
}

.navbar-brand img {
    margin-left: 32px;
}

ul.navbar-nav {
    padding-right: 32px;
}

#navbarNav {
    justify-content: end;
}

html,
body {
    height: 100%;
    padding: 0px;
    margin: 0px;
    background-color: #7763DB;
    overflow-x: hidden;
}

span.high {
    color: var(--highlight-color2);
    font-weight: 500;
}

.mockshot {
    border-radius: 8px;
    box-shadow: 0 6px 18px 0 rgba(0, 0, 0, 0.18);
    border: 1px solid var(--highlight-color);
    cursor: pointer;
}

div.mockshot-container {
    background-color: rgba(255, 255, 255, 0.1);
    border-radius: 16px;
    margin-left: 32px;
    margin-right: 32px;
    padding: 32px;
}

#mock-image {
    box-shadow: 0 6px 18px 0 rgba(0, 0, 0, 0.18);
    width: 550px; border-radius: 16px; z-index: 9;
}

#super-section {
    margin-top: 70px;
}

#mock-image-headline-large {
    display: block;
}

#mock-image-headline-small {
    display: none;
    text-align: center;
    font-size: 14px;
    color: var(--primary-text-color);
    padding: 4px;
}

.how-it-works-desktop {
    display: flex;
}

.how-it-works-mobile {
    display: none;
}

.le-animation {
    width: 500px;
}

.cta-mid-signup {
    text-align: right;
}

.cta-mid-sample {
    text-align: center;
}

.cta-mid-listen {
    text-align: left;
}

.image-headline {
    background-color: var(--text-on-dark-color);
    color: var(--primary-text-color);
    padding: 4px;
    border-radius: 32px;
    font-size: 14px;
    width: 300px;
    height: 30px;
    transform: translate(25%, 15%);
    text-align: center;
}


.bg-container {
    width: 100%;
    background-repeat: no-repeat;
    vertical-align: top;
    padding: 8px;
    margin: 0px;
    z-index: 2;
    position: relative;
}

/* Menubar */

.menu-item {
    color: var(--primary-text-color);
    font-size: 16px;
    font-weight: 300;
    padding: 4px 4px;
    display: block;
    text-decoration: none;
    margin-top: 5px;
}

.nav-item .active {
    font-weight: 600;
    color: var(--highlight-color2);
}

.menu-item:hover {
    color: rgba(255, 255, 255, 0.7);
}

.menu-button {
    border-radius: 32px;
    font-weight: 600;
    font-size: 16px;
    color: var(--text-on-dark-color);
    letter-spacing: 0;
    padding: 8px 32px;
    display: block;
    text-decoration: none;
    background-color: var(--white-background-color);
}

.menu-button.active {
    background: rgba(255, 255, 255, 1.0);
    color: var(--text-on-dark-color);
}

.menu-button:hover {
    background: rgba(255, 255, 255, 0.27);
    cursor: pointer;
    text-align: center;
}

.menu-button-secondary {
    border-radius: 32px;
    font-weight: 400;
    font-size: 16px;
    color: var(--primary-text-color);
    letter-spacing: 0;
    padding: 8px 32px;
    text-decoration: none;
    border: 1px solid var(--white-background-color);
    text-align: center;
    display: block;
}

.menu-button-inline {
    display: inline-block;
}

.menu-button.active {
    background: rgba(255, 255, 255, 1.0);
    color: var(--text-on-dark-color);
}

.menu-button:hover {
    background: rgba(255, 255, 255, 0.27);
    cursor: pointer;
}

.navbar {
    margin-top: 24px;
}

.navbar-nav {
    gap: 16px;
    padding-right: 32px;
}

h1.headline {
    font-size: 36px;
    line-height: 45px;
    color: var(--primary-text-color);
    letter-spacing: 0;
    text-shadow: 0 2px 23px rgba(197, 165, 243, 0.42);
}

h1.headline strong {
    color: var(--highlight-color);
    font-family: inherit;
}

p.headline {
    font-size: 16px;
    color: var(--primary-text-color);
    letter-spacing: 0;
    line-height: 32.2px;
    margin-top: 16px;
}

/* Make sure our container stays at 960px */
.custom-container {
    max-width: 1020px;
    margin-right: auto;
    margin-left: auto;
}

a.headline-button,
a.features-button {
    font-size: 18px;
    font-weight: 600;
    color: var(--primary-text-color);
    letter-spacing: 0;
    padding: 8px 32px;
    text-decoration: none;
    border-radius: 8px;
    display: block;
    width: 100%;
    margin-bottom: 15px;
    text-align: center;
}

a.headline-button.secondary,
a.features-button.secondary {
    background-color: var(--highlight-color);
    box-shadow: 0 6px 18px 0 rgba(0, 0, 0, 0.18);
}

a.headline-button.primary,
a.features-button.primary {
    background: black;
    box-shadow: 0 6px 18px 0 rgba(0, 0, 0, 0.18);
}

/* The how it works section */

.how-work-box {
    background-color: var(--primary-text-color);
    color: var(--text-on-dark-color);
    padding: 16px;
    border-radius: 16px;
    margin-bottom: 16px;
    text-align: center;
    border: 1px solid var(--highlight-color);
}

.how-work-box:hover {
    box-shadow: 0 0px 18px 0 rgba(255.0, 255.0, 255.0, 0.78);
    border: 1px solid var(--highlight-color);
}

.how-work-arrow {
  display: table;
  width: 100%;
  text-align: center; /* Center text horizontally */
}

.center-cell {
  display: table-cell;
  vertical-align: middle;
}

/* The image icon section */

div.imageicon-container {
    margin-top: 20px;
}


img.imageicon {
    border-radius: 16px;
    width: 133px;
    border-radius: 8px;
}

h2.image-section {
    font-family: 'DM Serif Display', serif;
    font-size: 27px;
    color: var(--primary-text-color);
    letter-spacing: 0;
    line-height: 26.12px;
    margin-top: 25px;
}

p.image-section {
    font-size: 16px;
    color: var(--secondary-text-color);
    letter-spacing: 0;
    line-height: 20px;
    padding-left: 20px;
    padding-right: 20px;
}


.sources {
    margin-top: 80px;
    margin-bottom: 60px;
    position: relative;
}

#anim2 {
     opacity: 0;
    transition: opacity 1s ease-in-out;
}

#anim3 {
     opacity: 0;
    transition: opacity 1s ease-in-out;
}

#anim4 {
     opacity: 0;
    transition: opacity 1s ease-in-out;
}

.white-button {
    border-radius: 32px;
    font-weight: 600;
    font-size: 16px;
    color: var(--text-on-dark-color);
    letter-spacing: 0;
    padding: 8px 32px;
    display: inline;
    text-decoration: none;
    background-color: var(--white-background-color);
    text-align: center;
}

/* .sources::after { */
/*     content: ""; */
/*     position: absolute; */
/*     left: 50%; */
/*     top: 60px; */
/*     /* Position directly at the bottom of the element */ */
/*     transform: translate(-50%, 10px); */
/*     /* Center the circle and move it below the element */ */
/*     width: 200px; */
/*     /* Circle size */ */
/*     height: 200px; */
/*     /* Circle size */ */
/*     background-color: white; */
/*     border-radius: 50%; */
/*     /* Make it round */ */
/*     box-shadow: 0 0 15px 15px white; */
/*     /* Blurry white shadow */ */
/*     z-index: -1; */
/*     /* Ensure it's behind the parent element */ */
/*     filter: blur(64px); */
/* } */

h2.source-section {
    font-size: 35px;
    line-height: 34px;
    font-family: 'DM Serif Display', serif;
    color: var(--primary-text-color);
    letter-spacing: 0;
    margin-bottom: 20px;
    margin-top: 20px;
}

p.source-section {
    font-size: 16px;
    color: var(--secondary-text-color);
    letter-spacing: 0;
    line-height: 30px;
    padding-left: 20px;
    padding-right: 20px;
}

div.podcast-container {
    margin-bottom: 30px;
}

div.podcast-section {
    position: relative;
    z-index: 5;
}

h3.podcast {
    font-size: 20px;
    color: var(--text-on-dark-color);
    letter-spacing: 0;
    text-align: center;
    line-height: 28px;
}

.podcast-info-box {
    background: #FFFFFF;
    box-shadow: 0 6px 18px 0 rgba(0, 0, 0, 0.18);
    border-radius: 8px;
    padding: 16px;
    height: 100%;
}

.podcast-sample-box {
    max-width: 230px;
    margin-right: 32px;
    margin-top: 32px;
    background: #061923;
    border: 2px solid rgba(167, 164, 165, 0.19);
    box-shadow: 0 0 32px 0 rgba(4, 166, 251, 0.17);
    border-radius: 16px;
    padding: 25px;
}

/* Images / Headline Sections */

/* img.image-headline {
    width: 340px;
} */

h1.image-headline {
    font-size: 40px;
    color: var(--primary-text-color);
    letter-spacing: 0;
    line-height: 40px;
    text-shadow: 0 2px 23px rgba(197, 165, 243, 0.42);
}

h1.image-headline strong {
    color: var(--highlight-color);
    font-family: inherit;
}

/* Features Section */

div.features-container {
    background: #FFFFFF;
    /* border: 2px solid #7663DB; */
    box-shadow: 0 6px 18px 0 rgba(0, 0, 0, 0.18);
    border-radius: 16px;
    margin-left: 32px;
    margin-right: 32px;
    padding: 32px;
}

h3.features {
    font-family: 'Oddval', sans-serif;
    font-size: 24px;
    font-weight: 600;
    color: var(--text-on-dark-color);
    letter-spacing: 0;
    line-height: 28px;
}

ul.features {
    padding: 0px;
    margin: 0px;
    margin-left: 16px;
    margin-top: 16px;
}

ul.features li {
    /* list-style: none; */
    margin-bottom: 16px;
    color: var(--text-on-dark-color);

}

h4.features {
    font-family: 'Oddval';
    font-size: 36px;
    color: var(--highlight-color);
    letter-spacing: 0;
    line-height: 46px;
}

.features-per-year {
    font-family: 'Oddval';
    font-size: 22px;
    color: var(--text-on-dark-color);
    letter-spacing: 0;
    margin-left: 20px;
}

.your-choice-block {
    width: 70%; 
    color: var(--primary-text-color) !important;
}

h4.features span {
    font-family: inherit;
    color: var(--secondary-text-color);
}

a.features-button.primary,
a.features-button.secondary {
    display: block;
}

/* Votes Section */

.col.vote-first {
    padding-left: 64px;
}

.col.vote-first h1 {
    margin-top: 50px;
}

/* Newsletter Section */
.newsletter-container {
    background: #FFFFFF;
    box-shadow: 0 6px 18px 0 rgba(0, 0, 0, 0.18);
    border-radius: 8px;
    padding: 16px;
    margin-left: 32px;
    margin-right: 32px;
}

/* How does it work section */
.howdoesitwork-container {
    margin-left: 32px;
    margin-right: 32px;
    margin-bottom: 120px;
}

ol.col1 {
    counter-reset: custom-counter;
}

ol.col2 {
    counter-reset: custom-counter 4;
}

ol {
    /* Initialize custom counter */
    list-style: none;
    /* Remove default list styles */
    padding-left: 0;
    /* Remove default padding */
}

ol li {
    counter-increment: custom-counter;
    /* Increment counter */
    position: relative;
    /* Needed to position the pseudo-element */
    margin-bottom: 20px;
    /* Optional: space between list items */
    padding-left: 40px;
    /* Make room for the circle */
}

ol li:before {
    content: counter(custom-counter);
    font-size: 15px;
    /* Insert counter as content */
    position: absolute;
    left: 0;
    width: 30px;
    /* Circle size */
    height: 30px;
    /* Circle size */
    border-radius: 50%;
    /* Make it round */
    background-color: #3498db;
    /* Circle color */
    color: #fff;
    /* Text color */
    text-align: center;
    /* Center the number */
    line-height: 30px;
    /* Vertically center the number */
}

/* Footer */

.footer {
    background-color: white;
    color: var(--primary-text-color);
    padding: 32px;
    border-top: 2px solid black;
    position: relative;
    z-index: 1;
}

.footer a {
    text-decoration: none;
    ;
}

.footer .row {
    margin-bottom: 32px;
}

/* Gap Player */
.gap-example {
    box-shadow: none !important;
    background-color: transparent !important;
}

.green-audio-player {
    width: auto !important;
    /* width: none !important; */
}

#player-container {
    border-radius: 16px;
    background-color: var(--white-background-color);
}

.mini-button-active {
    border-radius: 8px;
    font-weight: 400;
    font-size: 14px;
    color: var(--highlight-color);
    letter-spacing: 0;
    padding: 4px 16px;
    text-decoration: none;
    background-color: var(--white-background-color);
    display: block;
    border: 1px solid var(--white-background-color);
}

.mini-button {
    border-radius: 8px;
    font-weight: 400;
    font-size: 14px;
    color: var(--white-background-color);
    letter-spacing: 0;
    padding: 4px 16px;
    text-decoration: none;
    border: 1px dashed var(--white-background-color);
    background-color: var(--highlight-color);
    cursor: pointer;
    display: block;
}

#playButton {
            padding: 10px 20px;
            background-color: #4CAF50;
            color: white;
            border: none;
            cursor: pointer;
            border-radius: 5px;
            font-size: 16px;
        }

/* Generic Stuff */

.default-text {
    font-size: 16px;
    color: var(--text-on-dark-color);
    letter-spacing: 0;
    /* line-height: 42.32px; */
}

.default-text-small {
    font-size: 12px;
    color: var(--text-on-dark-color);
    letter-spacing: 0;
    /* line-height: 42.32px; */
}

.primary-text {
    color: var(--primary-text-color);
}

.section {
    margin-top: 100px;
}

@media (min-width: 1020px) {
    .custom-container {
        width: 1020px;
    }
}

.email-big {
    display: flex;
}

.email-small {
    display: none;
}

@media only screen and (max-width: 768px) {
    h1.headline {
        text-align: center;;
    }
}

@media only screen and (max-width: 499px) {

    .navbar-toggler {
        margin-right: 10px;
    }

    .navbar-nav {
        gap: 8px !important;
        padding-right: 0px !important;
    }

    .menu-button.active {
        background-color: transparent !important;
        color: var(--highlight-color2) !important;
        font-weight: bold;
    }

    h1.headline {
        font-size: 35px;
        line-height: 30px;
        margin-top: 30px;
    }

    .source-container {
        margin-top: 50px;
    }

    h2.source-section {
        font-size: 25px;
        line-height: 24px;
    }

    img.image-headline {
        width: 150px;
    }

    .section {
        margin-top: 60px;
    }

    .features-container {
        margin-left: 0px !important;
        margin-right: 0px !important;

        padding: 16px !important;
    }

    .col.vote-first {
        padding-left: 0px;
    }

    .col.vote-first h1 {
        margin-top: 0px;
        text-align: center;
    }

    img.vote-image {
        width: 150px;
        height: 150px;
    }

    .newsletter-container {
        margin-left: 0px !important;
        margin-right: 0px !important;
    }

    .email-big {
        display: none !important;
    }

    .email-small {
        display: block !important;
    }

    #mock-image {
        width: 90% !important;
    }

    #super-section {
        margin-top: 10px !important;;
    }
    #mock-image-headline-large {
        display: none;
    }

    #mock-image-headline-small {
        display: block;
    }

    .how-it-works-desktop {
        display: none !important;
    }

    .how-it-works-mobile {
        display: flex;
    }

    .le-animation {
        width: 90%;
        margin-bottom: 32px;
    }

    .cta-mid-signup {
        text-align: center;
        margin-bottom: 10px;
        display: block;
    }

    .cta-mid-sample {
        text-align: center;
        margin-bottom: 10px;
        display: block;
    }

    .cta-mid-listen {
        text-align: center;
        display: block;
    }

    h4.features {
        font-family: 'Oddval';
        font-size: 26px;
        color: var(--highlight-color);
        letter-spacing: 0;
        line-height: 36px;
    }

    .your-choice-block {
        width: 100%; 
    color: var(--primary-text-color) !important;
    font-size: 16px;
    letter-spacing: 0;
    }
}

.animated-box:after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border-radius: 4px;
  background: linear-gradient(120deg, #00F260, #0575E6, #00F260);
  background-size: 300% 300%;
  clip-path: polygon(0% 100%, 3px 100%, 3px 3px, calc(100% - 3px) 3px, calc(100% - 3px) calc(100% - 3px), 3px calc(100% - 3px), 3px 100%, 100% 100%, 100% 0%, 0% 0%);
}

.animated-box.in:after {
  animation: frame-enter 1s forwards ease-in-out reverse, gradient-animation 4s ease-in-out infinite;
}

/* motion */
@keyframes gradient-animation {
  0% {
    background-position: 15% 0%;
  }
  50% {
    background-position: 85% 100%;
  }
  100% {
    background-position: 15% 0%;
  }
}

@keyframes frame-enter {
  0% {
    clip-path: polygon(0% 100%, 3px 100%, 3px 3px, calc(100% - 3px) 3px, calc(100% - 3px) calc(100% - 3px), 3px calc(100% - 3px), 3px 100%, 100% 100%, 100% 0%, 0% 0%);
  }
  25% {
    clip-path: polygon(0% 100%, 3px 100%, 3px 3px, calc(100% - 3px) 3px, calc(100% - 3px) calc(100% - 3px), calc(100% - 3px) calc(100% - 3px), calc(100% - 3px) 100%, 100% 100%, 100% 0%, 0% 0%);
  }
  50% {
    clip-path: polygon(0% 100%, 3px 100%, 3px 3px, calc(100% - 3px) 3px, calc(100% - 3px) 3px, calc(100% - 3px) 3px, calc(100% - 3px) 3px, calc(100% - 3px) 3px, 100% 0%, 0% 0%);
  }
  75% {
    -webkit-clip-path: polygon(0% 100%, 3px 100%, 3px 3px, 3px 3px, 3px 3px, 3px 3px, 3px 3px, 3px 3px, 3px 0%, 0% 0%);
  }
  100% {
    -webkit-clip-path: polygon(0% 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 0% 100%);
  }
}
