


/* ----------------------
  Header - logo and cta 
---------------------- */

body.scroll .header {
  width: 100%;
  max-width: 100%;
  top: 0;
}
body.scroll .header:before {
  border-radius: 0;
}

.header {
    position: fixed;
    width: 94%;
    max-width: 100rem;
    z-index: 1000;
    padding: .3rem 1rem;
    background-color: var(--primary-color);
    border-radius: clamp(0.75rem, 2vw, 1.5rem);
    opacity: 90%;
    top: 2rem;
    left: 50%;
    transform: translateX(-50%);
    transition: top 0.3s, border-radius 0.3s, width 0.3s, max-width 0.3s;
}

.header:before {
  content: "";
  width: 100%;
  height: 100%;
  background: var(--primary-color);
  box-shadow:
    rgba(169, 184, 155, 0.15) 0px 5px 12px,
    rgba(169, 184, 175, 0.1) 0px 8px 24px;
  opacity: 1;
  border-radius: clamp(0.75rem, 2vw, 1.5rem);
  display: block;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  transition: transform 0.2s, border-radius 0.3s ease-in-out;
}

.header-container {
    display: flex;
    margin: 0 auto;
    max-width: 100rem;
    padding: .4rem 1rem;
    justify-content: space-between;
    align-content: center;
    align-items: center;
}

.logo {
    max-width: 3rem;
    height: auto !important;
}

[data-theme="dark"] {
    .logo {
        transition: filter var(--animation-timing);
    }
}

.logo-a {
    display: flex;
    align-items: center;
    height: 100%;
    z-index: 2;
}

[data-theme="dark"] .logo-a:hover .logo {
    filter: 
        drop-shadow(0 0 16px var(--glow-color))
        drop-shadow(0 0 60px var(--glow-color));
}

.logo-light {
    display: none;
}

[data-theme="dark"] {
    .logo-light { display: block; }
    .logo-dark { display: none; }
}


.cta-btn {
    border-radius: 1000px;
    background-color: var(--cta-color);
    color: var(--font-color-cta);
    font-family: var(--primary-font);
    font-weight: 500;
    font-size: .8rem;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: -.5px;
    padding: .3rem 1.2rem;
    z-index: 2;
    transition: box-shadow var(--animation-timing);
    &:hover {
        box-shadow: inset 0 0 0 100px rgba(0, 0, 0, 0.1); /* Creates a shading overlay */
    }
}

[data-theme="dark"] .cta-btn {
    transition: 
        transform var(--animation-timing),
        box-shadow var(--animation-timing);
    
    &:hover {
        box-shadow: 
            0 0 30px var(--glow-color),
            0 4px 8px rgba(0, 0, 0, 0.1);
    }
}

.cta-btn--nav {
    padding: .3rem .7rem;
}

@media (min-width: 450px) {
    .header {
        padding: .3rem 2rem;
    }
    .cta-btn {
        font-weight: 600;
        padding: .4rem 1.22rem;
        font-size: 1rem;
        letter-spacing: 0;
    }
    .cta-btn--nav {
        font-size: .75em;
        padding: .3rem .6rem;
    }
    .logo {        
        max-width: clamp(4.25rem, 5.5vw, 6rem);
    }
}
@media only screen and (min-width: 1024px) {
  body.scroll #cs-navigation {
    border-radius: 0;
  }
    .cta-btn--nav {
        padding: .4rem 1.3rem;
        font-size: 1rem;
    }
}

/* ----------------------
        Navigation
---------------------- */

.navbar {
    display: flex;
    align-items: center;
    margin-left: auto;
}
.nav-links .nav-a {
    text-decoration: none;
    color: var(--font-color);
    font-family: var(--primary-font);
    font-size: 2rem;
    font-weight: 400;
    padding: .5rem .75rem;
    transition: color var(--animation-timing);
    position: relative;
    display: inline-block;
}

.nav-links {
    display: none;
    margin-right: 2rem;
}

.nav-links-li {
    list-style: none;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
}

.nav-links .nav-a:before {
    /* underline */
    content: "";
    width: 0%;
    height: 0.125rem;
    background: var(--link-underline-color);
    opacity: 1;
    position: absolute;
    display: block;
    bottom: .4rem;
    transition: width 0.3s;
}

[data-theme="dark"] .nav-links .nav-a:hover {
    text-shadow:
        0 0 8px var(--glow-color),
        0 0 20px var(--glow-color),
        0 0 40px var(--glow-color),
        0 0 80px var(--glow-color);
}
.nav-links .nav-a:hover:before {
    width: calc(100% - 1.5rem);
}

/*-- -------------------------- -->
<---      Dark Mode Toggle      -->
<--- -------------------------- -*/
.dark-mode-toggle {
    background: transparent;
    border: none;
    border-radius: 6px;
    padding: 0.5rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    position: relative;
    margin-right: .3rem;
    transition: transform 0.3s ease;
}

[data-theme="dark"] .dark-mode-toggle {
    transition: 
        transform 0.3s ease,
        filter 0.3s ease;
    
    &:hover {
        filter: 
            drop-shadow(0 0 1px var(--glow-color))
            drop-shadow(0 0 8px var(--glow-color))
            drop-shadow(0 0 20px var(--glow-color));
    }
}

.dark-mode-toggle svg {
    width: 30px;
    height: 30px;
    transition: all 0.3s ease;
    position: absolute;
}

.moon {
    opacity: 1;
    transform: rotate(10deg);
    stroke: var(--font-color);
    fill: none;
}

.sun {
    opacity: 0;
    transform: rotate(180deg);
    stroke: var(--font-color);
    fill: none;
}

[data-theme="dark"] .moon {
    opacity: 0;
    transform: rotate(-180deg);
}

[data-theme="dark"] .sun {
    opacity: 1;
    transform: rotate(0deg);
}

/* Mobile hamburger menu */
.hamburger-menu {
    --x-width: calc(var(--hamburger-height)*1.41421356237);
    display: flex;
    flex-direction: column;
    gap: var(--hamburger-gap);
    width: max-content;
    color: var(--font-color);
    z-index: 2;
    cursor: pointer;
    position: relative;
    margin-left: 1.15rem;
}

.hamburger-menu:has(input:checked)::before {
    rotate: 45deg;
    width: var(--x-width);
    translate: 0 calc(var(--bar-height) / -2);
}

.hamburger-menu:has(input:checked)::after {
    rotate: -45deg;
    width: var(--x-width);
    translate: 0 calc(var(--bar-height) / 2);
}

.hamburger-menu input {
    appearance: none;
    padding: 0;
    margin: 0;
    outline: none;
    pointer-events: none;

    &:checked {
        opacity: 0;
        width: 0;
    }
}

.hamburger-menu::before,
.hamburger-menu::after,
.hamburger-menu input {
    content: "";
    width: var(--bar-width);
    height: var(--bar-height);
    background-color: var(--font-color);
    border-radius: 100px;
    transform-origin: left center;
    transition: opacity var(--animation-timing), width var(--animation-timing),
        rotate var(--animation-timing), translate var(--animation-timing),
        background-color var(--animation-timing);
}

/* Mobile sidebar */
.sidebar {
    transition: translate var(--animation-timing);
    translate: 100%;
    padding: 0.5rem 1rem;
    padding-top: calc(var(--hamburger-height) + var(--hamburger-margin) + 4rem);
    background-color: var(--primary-color);
    color: var(--font-color);
    width: 80%;
    min-height: 100vh;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 1;
}

.navbar .hamburger-menu:has(input:checked) ~ .sidebar {
    translate: 0;
}

.navbar .hamburger-menu:has(input:checked) {
    --foreground: var(--font-color);
    --background: var(--font-color);
}

.sidebar .nav-links {
    display: flex;
    flex-direction: column;
}

/* ---------------------- */
/* Desktop Navigation */
/* ---------------------- */

@media (min-width: 768px) {
    .header-container {
        padding: 0 1rem;
    }

    .dark-mode-toggle {
        margin-right: .55rem;
    }

    .hamburger-menu {
        display: none;
    }
    
    .sidebar {
        display: none;
    }
    
    .nav-links {
        display: flex;
        margin-right: auto;
        align-items: center;
    }
    
    .nav-links .nav-a {
        font-size: 1.2rem;
        border-radius: 5px;
        transition: all var(--animation-timing);
    }
}


/* ---------------------- */
/*          Hero          */
/* ---------------------- */

.hero {
    display: flex;
    flex-direction: column;
    position: relative;
    overflow: hidden;
    background-color: var(--primary-color);
    color: var(--font-color);
    font-family: var(--primary-font);
}

.hero-content {
    max-width: 1400px;
    margin: 10rem auto 3rem;
    text-align: center;
    padding: 0 1.5rem;
}

.hero-text {
    max-width: 450px;
    margin: 0 auto;
}

.hero-kicker {
    text-transform: uppercase;
    font-weight: 500;
    font-size: 1.2rem;
    letter-spacing: 2px;
    line-height: 1.1;
    margin: 0 auto .75rem;
    max-width: 14ch;
}

.hero-title {
    line-height: 1.2;
    font-size: 3.1em;
    font-weight: 700;
    text-transform: uppercase;
    margin: 0 auto;
    letter-spacing: -0.1rem;
    position: relative;
    z-index: 1;
}

.hero-p {
    font-family: var(--secondary-font);
    margin: 1.25rem auto 2.75rem;
    max-width: 80%;
    line-height: 1.25rem;
    letter-spacing: .55px;
}

.cta-btn--hero {
    display: inline-block;
    font-size: 1.3rem;
    padding: .55rem 2.15rem;
    z-index: 2;
}

.hero-img-container {
    position: relative;
    display: block;
    filter: drop-shadow(0 0 2px var(--tertiary-color));
    margin: 6rem auto 0;
}

.hero-img-container::before {
    content: "";
    position: absolute;
    top: 45%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 80%;
    aspect-ratio: 1;
    background-color: var(--primary-color);
    border-radius: 50%;
    z-index: -1;
    box-shadow: 
        10px -8px 15px var(--secondary-color);
}

[data-theme="dark"] {
    .hero-img-container::before {
        box-shadow: 
            10px -8px 15px var(--gradient-color);
        }
}

.hero-img {
    margin: 5rem auto 6rem;
    width: 100%;
    height: auto;
    display: block;
}

.hero-waves {
    position: absolute;
    bottom: -8px;
    left: -70px;
    width: clamp(300px, 110vw, 550px); 
    object-fit: cover;
    object-position: bottom left;
    padding: 0;
    margin: 0;
    z-index: 1;
}

.hero-waves-dark {
    display: none;
}

[data-theme="dark"] {
    .hero-waves-light {
        display: none;
    }

    .hero-waves-dark {
        display: block;
    }
}

.hero-content,
.hero-img-container,
.hero-kicker,
.hero-p {
    position: relative;
    z-index: 1;
}

@media (min-width: 385px) {
    .hero-kicker {
        max-width: 50ch;
    }
}

@media (min-width: 450px) {
    .hero-waves {
        left: -100px;
    }
    .hero-img-container {
        max-width: 80%;
        margin: 8rem auto;
        padding-right: 2rem;
    }
}

@media (min-width: 775px) {
    .hero {
        padding: 4rem 1rem 0;
    }

    .hero-content {
        display: flex;
        flex-direction: row;
        justify-content: space-between;
        padding: 0 2rem;
        text-align: left;
        width: 100%;
        max-width: 1300px;
    }

    .hero-title {
        margin: 0;
        max-width: 15ch;
    }

    .hero-p {
        margin: 1.25rem 0 2.75rem;
    }

    .hero-text {
        flex: 1 1 0;
        max-width: 600px;
        flex: 0 0 50%;
    }

    .hero-img-container {
        flex: 0 0 50%;
        margin: 0 0 auto 1rem;
    }

    .hero-waves {
        width: clamp(300px, 100vw, 580px); 
        height: auto;
        z-index: 0;
    }

    .waves-background {
        content: "";
        background-color: var(--tertiary-color);
        border-radius: 0 100% 0 0;
        position: absolute;
        bottom: 0;
        left: 0;
        height: 120%;
        width: 65vw;
        opacity: 50%;
        z-index: 0;
    }

    [data-theme="dark"] {
        .waves-background {
            background-color: var(--gradient-color);
        }
    }
}
@media (min-width: 1024px) {
    .hero-content {
        margin-bottom: 0;
    }
    .hero-text {
        margin-top: 3rem;
    }
}

@media (min-width: 1400px) {
    .hero {
        padding-top: 5rem;
        padding-left: 3rem;
        padding-right: 3rem;
    }
    .hero-content {
        margin-top: 7rem;
    }
    .hero-img-container {
        margin-left: 2.5rem;
    }
    .waves-background {
        height: 130%;
        width: 60vw;
    }
}

@media (min-width: 1700px) {
    .hero-waves {
        display: none;
    }

    .hero-img-container {
        margin-left: 4rem;
    }
    
    html[data-theme="dark"] {
        .hero-waves-dark {
            display: none;
        }
    }
}

/* ----------------------
       Benefits       
---------------------- */

.benefits {
    position: relative;
    display: grid;
    padding: 40px;
    margin: 0;
    background: linear-gradient(
        to bottom,
        #8CE2C5D9 0%,
        #B6F4DFD9 40%,
        var(--primary-color) 76%
    );
    color: var(--font-color);
    font-family: var(--secondary-font);
    overflow: hidden;
}

[data-theme="dark"] .benefits {
       background: linear-gradient(
        to bottom,
        #00348CF2 0%,
        #012057F2 40%,
        var(--primary-color) 76%
    ); 
}

.benefits-title {
    margin: 0 auto 3rem;
    font-family: var(--primary-font);
    font-weight: 400;
    font-size: var(--title-size);
    text-align: center;
}

.benefits-title-em {
    font-weight: 700;
}

.benefits-content {
    display: grid;
    row-gap: 2rem;
    max-width: 1300px;
    margin: 0 auto;
    align-items: start;
    justify-items: center;
}

.benefit-group {
    display: grid;
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
    align-items: center;
    max-width: 500px;
}

.benefit-group-content {
    max-width: none;
    min-width: 0;
    line-height: 1.4;
    font-size: .875rem;
    padding: 0 16px;
}

.benefit-group-title {
    font-family: var(--primary-font);
    font-size: 1.5rem;
    font-weight: 700;
    margin: 0;
    padding-bottom: 8px;
}

.benefit-group-icon {
    width: 72px;
    height: 72px;
    flex-shrink: 0;
    transition: transform var(--animation-timing), color var(--animation-timing);
}
.benefit-group:hover .benefit-group-icon {
    transform: scale(1.15);
    color: var(--icon-hover-color);
}



@media (min-width: 760px) {
    .benefits-content {
        grid-template-columns: repeat(2, 1fr);
        gap: 2rem;
        width: 100%;
    }

    .benefit-group-icon {
        width: 96px;
        height: 96px;
        justify-items: start;
    }

    .benefit-group {
        display: grid;
        grid-template-columns: auto 1fr;
        text-align: left;
        align-items: start;
    }
}
@media (min-width: 1024px) {
    .benefit-text {
        padding-top: 3px;
    }
}

@media (min-width: 1700px) {
    .benefits {
        background: linear-gradient(
            to bottom,
            #8CE2C580 0%,
            var(--primary-color) 76%
        );
    }

    [data-theme="dark"] .benefits {
        background: linear-gradient(
            to bottom,
            #00348C80 0%,
            var(--primary-color) 76%
        ); 
    }
}

/* ----------------------
       Pricing       
---------------------- */
.pricing {
    background-color: var(--primary-color);
    color: var(--font-color);
    font-family: var(--primary-font);
    font-size: 1.15rem;
    display: grid;
    margin: 0;
    padding: var(--sectionPadding);
}

.pricing-content {
    max-width: 1400px;
    margin: 0 auto;
    width: 100%;
}

.pricing-title {
    margin: 0 auto 2rem;
    font-weight: 700;
    font-size: var(--title-size);
    text-align: center;
    position: relative;
}

.pricing-title::after {
    content: '';
    position: absolute;
    bottom: -10px;
    left: 50%;
    transform: translateX(-50%);
    width: 160px;
    height: 2px;
    background-color: var(--gradient-color);
    border-radius: 2px;
}

.pricing-highlight {
    background-color: var(--card-color);
    margin: 2rem auto;
    padding: .5rem;
    display: grid;
    border-radius: var(--card-border-radius);
    box-shadow: -2px 2px 24px var(--gradient-color);
}

.premium-highlight {
    background-color: var(--tertiary-color);
}
.pricing-highlight-benefits-item svg {
    stroke: var(--font-color);
}

.pricing-highlight-cost {
    display: grid;
    justify-items: center;
    align-items: center;
}

.pricing-highlight-title {
    font-weight: 700;
    font-size: 1.75rem;
    margin: 1rem 0 0.5rem;
    text-align: center;
}

.pricing-highlight-dollar {
    font-weight: 400;
    font-size: 3.5rem;
    margin: 0;
}

.pricing-highlight-freq {
    margin: 0;
    line-height: 30px;
}

.pricing-highlight-cta-btn {
    margin: 1.5rem auto;
}

.pricing-highlight-benefits {
    display: grid;
    justify-items: center;
}

.pricing-highlight-benefits-title, .pricing-addons-title {
    font-weight: 500;
    font-size: 1.5rem;
    line-height: 36px;
    margin: 1rem auto 0;
    text-align: center;
}
.pricing-highlight-benefits-title {
    margin-top: .5rem;
}

.pricing-aside {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.pricing-addons-title {
    font-weight: 700;
    font-size: 1.75rem;
}

.pricing-addons, .pricing-other {
    width: 100%;
    margin: 0 auto;
    padding: 1rem;
    border: 2px solid var(--gradient-color);
    border-radius: var(--card-border-radius);
}

.pricing-highlight-benefits-list, .pricing-addons-list {
    font-family: var(--secondary-font);
    display: grid;
    list-style: none;
    align-content: start;
    padding: 0;
}

.pricing-highlight-benefits-item, .pricing-addons-item{
    display: flex;
    word-wrap: break-word;
    align-items: flex-start;
    margin-bottom: .7rem;
}
.pricing-addons-item {
    border-bottom: 1px solid var(--gradient-color);
    padding-bottom: 0.5rem;
}
/* .request-line {
    text-align: right;
} */

.pricing-highlight-benefits-item {
    display: flex;
    align-items: flex-start;
}

.pricing-highlight-benefits-item svg {
    width: 24px;
    height: 24px;
    margin-right: 12px;
    flex-shrink: 0;
}

.pricing-price {
    margin-left: auto;
    font-weight: 400;
}

.pricing-other-title {
    font-weight: 300;
    font-size: 2rem;
    margin: 40px 0 0;
    line-height: 1.2;
}

.pricing-addons-p {
    font-family: var(--secondary-font);
    font-size: 1rem;
    font-weight: 400;
    margin: 0 auto;
    padding: 8px 0;
    max-width: 400px;
    text-align: center;
}

.pricing-addons-cta-btn {
    display: flex;
    max-width: 12rem;
    justify-content: center;
    color: var(--font-color);
    background-color: var(--primary-color); 
    border: 2px solid var(--cta-color);
    margin: 0 auto 1rem;
}

[data-theme="dark"] .pricing-addons-cta-btn {
    color: var(--font-color);
}

@media (min-width: 500px) {
    .pricing-highlight, .pricing-addons {
        margin: 2rem auto;
        padding: 1rem 2rem;
        max-width: 500px;
    }
    
    .pricing-aside {
        gap: 0;
    }
}

@media (min-width: 760px) {

    .pricing-title::after {
        width: 220px;
        height: 3px;
    }

    .pricing-other-cta-btn {
        margin: 1rem auto;
    }
}

@media (min-width: 1024px) {
    .pricing-title::after {
        width: 284px;
    }

    .pricing-highlight-wrapper {
        display: flex;
        gap: 1rem;
        max-width: 65rem;
        margin: 0 auto;
    }

    .pricing-highlight {
        width: 95%;
    }

    .pricing-highlight-container {
        margin: auto 0;
    }

    .pricing-highlight-benefits-item svg {
        margin-top: 4px;
    }

    .pricing-aside {
        flex-direction: row;
        gap: 1.5rem;
    }

    .pricing-addons {
        max-width: 65rem;
    }

    .pricing-highlight-benefits-title {
        margin-bottom: .5rem;
    }
}

/*-- -------------------------- -->
<---    Side By Side SBS    -->
<--- -------------------------- -*/
#sbs {
    padding: var(--sectionPadding);
    margin: 0 auto;
    position: relative;
    z-index: 1;
    font-family: var(--secondary-font);
    font-size: 1.1rem;
    color: var(--font-color);
    align-items: center;
    background-color: var(--section-shade-color);
}
.sbs-container {
    margin: 0 auto;
    max-width: 40rem;
}

.sbs-title {
    font-family: var(--primary-font);
    font-size:  var(--title-size);
    margin: 2rem 0 1rem;
    line-height: 1.2;
}

.sbs-ul {
    width: 100%;
    list-style: none;
    margin: 0 0 2rem 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.5rem;
}

.sbs-li {
    font-size: var(--bodyFontSize);
    line-height: 1.5em;
    text-align: left;
    font-weight: 700;
    letter-spacing: .5px;
    width: 100%;
    margin: 0;
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    position: relative;
} 

.sbs-li-icon {
    fill: #8ce2c5;
    width: 1rem;
    height: auto;
    flex: none;
    display: block;
    position: relative;
    padding-top: 6px;
}

[data-theme="dark"] {
    fill: #27e6da;
}

.sbs-cta-btn {
    border-radius: 1000px;
    font-family: var(--primary-font);
    font-weight: 500;
    font-size: .8rem;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: -.5px;
    padding: .3rem 1.2rem;
    z-index: 2;
    display: flex;
    max-width: 14.25rem;
    justify-content: center;
    color: var(--font-color);
    background-color: var(--section-shade-color); 
    border: 2px solid var(--cta-color);
    margin-bottom: 1rem;
        transition: box-shadow var(--animation-timing);
    &:hover {
        box-shadow: inset 0 0 0 100px rgba(0, 0, 0, 0.1); /* Creates a shading overlay */
    }
}

[data-theme="dark"] .sbs-cta-btn {
    transition: 
        transform var(--animation-timing),
        box-shadow var(--animation-timing);
    
    &:hover {
        box-shadow: 
            0 0 30px var(--glow-color),
            0 4px 8px rgba(0, 0, 0, 0.1);
    }
}
.sbs-content {
    text-align: left;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    z-index: 100;
}

.sbs-image-group {
    position: relative;
    max-width: 40rem;
    /* margin-top: auto; */
}
.sbs-blob {
    width: 100%;
    height: auto;
    position: absolute;
    z-index: -1;
}
.cs-picture {
    position: relative;
}
#sbs .cs-picture img {
    width: 100%;
    height: auto;
}
.sbs-text {
    margin-top: 0;
    line-height: 1.3;
}

@media (min-width: 1024px) {
    .sbs-container {
        max-width: 1400px;
        display: flex;
        align-items: center;
    }
    .sbs-image-group {
        width: 80%;
    }
    .sbs-content {
        padding-left: 1.5rem;
    }
}        
@media (min-width: 1300px) {
    #sbs {
        padding-bottom: 0;
    }
    .sbs-container {
        align-items: flex-end;
    }
    .sbs-image-group {
        top: 4px;
    }
    .sbs-content {
        padding-bottom: var(--sectionPadding);
    }
}                

/* ---------------------- */
/*        CTA            */
/* ---------------------- */

.cta {
    position: relative;
    background-color: var(--tertiary-color);
    font-family: var(--primary-font);
    color: var(--font-color);
    display: flex;
    flex-direction: column;
    justify-content: start;
    align-items: center;
    margin: 0;
    padding: 40px;
    min-height: 370px;
    overflow: hidden;
}

.cta-content {
    padding-top: 2rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 1rem;
}

.cta-title {
    text-align: center;
    font-weight: 700;
    font-size: var(--title-size);
}

.cta-waves-left {
    display: none;
}

.cta-waves-right {
    position: absolute;
    bottom: -1px;
    right: 0;
    width: clamp(365px, 40vw, 580px);
    padding: 0;
    margin: 0;
}

@media (min-width: 770px) {
    .cta-title {
        font-size: var(--title-size);
        margin: 2rem;
    }
    .cta-cta-btn {
        font-size: 1.25rem;
        padding: .5rem 2.1rem;
    }
    .cta-waves-left {
        display: inline;
        position: absolute;
        left: 0;
        bottom: -1px;
        width: clamp(365px, 40vw, 580px);
        padding: 0;
        margin: 0;
    }
}

@media (min-width: 2500px) {
    .cta-waves-left,
    .cta-waves-right {
        visibility: hidden;
    }
}

/* -- -------------------------- -->
<---          Footer            -->
<--- -------------------------- - */

.footer {
    font-family: var(--secondary-font);
    font-size: .85rem;
    color: var(--font-color);
    background: linear-gradient(
        to bottom,
        var(--gradient-color) 0%,
        var(--primary-color) 20%
    );
    padding: 2rem 1rem 1.25rem;
    z-index: 10;
}

.footer-container-outer {
    max-width: 1600px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
}

.footer-nav {
    display: flex;
    flex-direction: column;
    list-style: none;
    padding: 0;
    margin: 2rem 0;
    max-width: 20rem;
    justify-content: center;
    align-items: flex-start;
    gap: 1rem;
}
.footer-nav-li {
    list-style: none;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
}

.footer-nav-link {
    color: var(--font-color);
    font-family: var(--primary-font);
    font-weight: 400;
    position: relative;
    display: inline-block;
    text-decoration: none;
    transition: color var(--animation-timing);
}

.footer-nav-link::before {
    /* underline */
    content: "";
    width: 0%;
    height: 0.1rem;
    background: var(--link-underline-color);
    opacity: 1;
    position: absolute;
    display: block;
    bottom: -0.125rem;
    left: 0;
    transition: width var(--animation-timing);
}

.footer-nav-link:hover::before {
    width: 100%;
}

[data-theme="dark"] .footer-nav-link:hover {
    text-shadow:
        0 0 8px var(--glow-color),
        0 0 20px var(--glow-color),
        0 0 40px var(--glow-color),
        0 0 80px var(--glow-color);
}

.footer-bottom {
    margin: 0 auto;
    align-items: center;
    text-align: center;
    line-height: 1.75rem;
}

.footer-copyright-link {
    text-decoration: none;
    color: var(--font-color);
    transition: color 0.3s;
}
.footer-copyright-link:hover {
    color: var(--secondary-color);
}

.footer-policies {
    display: flex;
    justify-content: center;
    gap: 2rem;
}

@media (min-width: 760px) {
    .footer-nav {
        flex-direction: row;
        margin-right: auto;
        justify-content: flex-start;
        gap: 3rem;
    }

    .footer-container {
        display: flex;
        flex-direction: row;
        align-items: flex-start;
    }

    .footer-logo-group{
        margin-top: 4px;
        margin-right: 4rem;
    }

    .footer-bottom {
        margin: 6rem 0 0;
        display: flex;
        flex-direction: row;
        justify-content: space-between;
    }
}

@media (min-width: 1700px) {
    .footer {
        background: linear-gradient(
            to bottom,
            var(--primary-color) 0%
            );
    }
}

/* ---------------------------------------
            Inner Pages
--------------------------------------- */

.nav-links .current-tab:before {
    /* underline */
    content: "";
    width: calc(100% - 1.5rem);
    height: 0.125rem;
    background: var(--link-underline-color);
    opacity: 1;
    position: absolute;
    display: block;
    bottom: .4rem;
    transition: width 0.3s;
}

.underlined-title{
    position: relative;
    margin: 2rem auto 4rem;
    text-align: center;
    font-family: var(--primary-font);
    font-size: var(--title-size);
    font-weight: 700;
}

.underlined-title::after {
    content: '';
    position: absolute;
    bottom: -16px;
    left: 50%;
    transform: translateX(-50%);
    width: clamp(80px, 24vw, 116px);
    height: 2px;
    background-color: var(--secondary-color);
    border-radius: 2px;
}

.pricing-page, .about-page, .contact-page, .services-page, .tos-page, .privacy-page{
    position: relative;
    margin: 5rem auto 2rem;
    color: var(--font-color);
    font-family: var(--secondary-font);
    padding: 2rem 1.5rem;
}

/* --------------------------------------
            About Page                  
-------------------------------------- */
.contact-upper {
    max-width: 500px;
    margin: 0 auto;
    text-align: center;
}

.flow-steps {
    display: flex;
    flex-direction: column;
    padding: 2rem;
    padding-bottom: 3rem;
    text-align: center;
    background-color: var(--tertiary-color-80);
    border-radius: var(--card-border-radius);
    max-width: 500px;
    margin: 0 auto;
}

.flow-title {
    font-family: var(--primary-font);
    font-size: 1.75rem;
    font-weight: 300;
    text-transform: uppercase;
    margin-bottom: 2rem;
}

.flow-list {
    padding: 0;
}

.flow-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    list-style: none;
    line-height: 1.25;
    max-width: 450px;
    margin: 0 auto;
}

.flow-badge {
    margin-top: 2rem;
    width: 56px;
    height: 56px;
    aspect-ratio: 1;
    background: 
        /* Main bubble gradient */
        radial-gradient(circle at 70% 30%, 
            #DBF6F1 100%),
        /* Highlight on top-right */
        radial-gradient(circle at 75% 25%, 
            #f2fffd 0%,
            #A2D8C6 50%,
            transparent 50%);
    box-shadow: 
        3px -3px 10px var(--secondary-color);
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;

}

[data-theme="dark"] .flow-badge {
    background: 
        /* Main bubble gradient */
        radial-gradient(circle at 70% 30%, 
            #000714 100%);
    box-shadow: 
        2px -2px 10px var(--secondary-color);
}

[data-theme="dark"] .flow-badge-number {
    color: var(--font-color)
}

.flow-badge-number {
    font-size: 1.75rem;
    font-weight: bold;
    color: #001E4E;
    font-family: var(--primary-font);
    font-weight: 400;
    line-height: 1;
    user-select: none;
}

.flow-item-title {
    font-family: var(--primary-font);
    font-size: 1.25rem;
}

.about-content {
    padding: 2rem;
}

.about-content-title {
    font-size: 2rem;
    font-family: var(--primary-font);
    font-weight: 500;
}

@media (min-width: 820px) {
    .about-page {
        max-width: 1350px;
    }

    .about-page-upper {
        display: flex;
        align-items: flex-start;
    }

    .flow-steps {
        width: 40%;
        text-align: left;
        padding-top: .75rem;
        margin-top: 0;
        max-width: 700px;
    }

    .flow-badge {
        margin: 0;
    }

    .flow-title {
        text-align: center;
    }

    .flow-list {
        margin: 0;
    }

    .flow-item {
        display: flex;
        flex-direction: row;
        align-items: start;
        margin-top: 2rem;
    }

    .flow-item-text {
        margin-left: 1.5rem;
    }

    .flow-item-title {
        margin: 0;
        padding: 0;
        line-height: 1.1;
    }

    .about-content {
        width: 60%;
        line-height: 1.3;
        padding-top: 0;
    }
}

/* --------------------------------------
            TOS Page                  
-------------------------------------- */
.tos-page {
    line-height: 1.25;
    max-width: 800px;
}

.tos-table-of-contents li {
    list-style: none;
    padding-bottom: .4rem;
}

.address {
    line-height: .25;
}

.legal-strong {
    text-transform: uppercase;
}

.tos-page a, .privacy-page a {
    color: var(--font-color);
    text-decoration: none;
    transition: color 0.3s, font-weight 0.3s;

    &:hover {
        color: var(--icon-hover-color);
        font-weight: 700;
    }
}
/* --------------------------------------
        Privacy Policy Page                  
-------------------------------------- */
.privacy-page {
    line-height: 1.25;
    max-width: 800px;
}

.last-updated {
    background-color: var(--gradient-color);
    padding: 10px;
    border-radius: 5px;
    margin-bottom: 30px;
    font-weight: bold;
}


/* --------------------------------------
        Contact Page                  
-------------------------------------- */
.contact-form-title {
    font-size: 1.5rem;
    text-align: center;
    margin: 0;
}

.submit-form {
    background-color: var(--card-color);
    border-radius: var(--card-border-radius);
    margin-bottom: 2.5rem;
    padding: 1.2rem;
    min-height: 450px;
    align-content: center;
}

.contact-form-instructions {
    letter-spacing: .5px;
}

.sneaky-field {
    display:none;
}

.form-group {
    display: flex;
    flex-direction: column;
    text-align: start;
    margin: 1rem auto;
}

.required-label {
    text-transform: uppercase;
    font-weight: 600;
    font-size: .85rem;
    letter-spacing: .05rem;
    margin: .25rem 0;
}

.required-label::after {
    content: " *";
}

.form-input {
    outline: none;
    min-height: 28px;
    border: 1px solid var(--secondary-color);
    border-radius: 3px;
    background: transparent;
    padding: 8px 0 8px 5px;
    caret-color: var(--font-color);
    color: var(--font-color);
    font-size: 1rem;
    font-family: var(--secondary-font);
}

.message {
    min-height: 150px;
}

.submit-btn {
    display: flex;
    margin-right: auto;
    border: none;
    border-radius: 1000px;
    background-color: var(--cta-color);
    color: var(--font-color-cta);
    font-family: var(--primary-font);
    font-weight: 500;
    font-size: .9rem;
    text-transform: uppercase;
    justify-content: center;
    transition: 
        transform var(--animation-timing),
        filter var(--animation-timing),
        box-shadow var(--animation-timing);
}

[data-theme="dark"] .submit-btn {
    transition: 
        transform var(--animation-timing),
        filter var(--animation-timing),
        box-shadow var(--animation-timing);
}

[data-theme="dark"] .submit-btn:hover {
    background-color: var(--cta-color);
}

[data-theme="dark"] .contact-flow {
    background-color: var(--tertiary-color-80);
}

.contact-info-container {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
    margin: 2rem auto;
}

.contact-info-group {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    background-color: var(--tertiary-color-80);
    border-radius: var(--card-border-radius);
    margin: 1rem auto;
    padding: 2rem;
    max-width: 400px;
    width: 100%;
    text-decoration: none;
    color: inherit;
    cursor: pointer;
    transition: box-shadow var(--animation-timing);
}

.contact-info-group:hover {
    box-shadow: 
        0 0 30px var(--glow-color);
}

.contact-icon {
    width: 64px;
    height: 64px;
}

[data-theme="dark"] {
    .contact-icon {
        transition: color var(--animation-timing);
    }

    .contact-info-group:hover .contact-icon {
        color: var(--glow-color);
    }
}

@media (min-width: 800px) {
    .contact-page {
        max-width: 1400px;
    }

    .contact-upper {
        display: flex;
        flex-direction: row;
        width: 100%;
        gap: 2rem;
        margin: 0 auto;
        padding: 2rem 0;
        max-width: 100%;
    }
    .contact-container {
        width: 70%;
        max-width: 650px;
    }

    .contact-page-title {
        margin-bottom: 3rem;
    }
    .contact-form-title {
        font-size: 1.75rem;
        margin: .2rem;
    }
    .contact-form-instructions {
        margin: 1rem auto 1.5rem;
        max-width: 33rem;
    }
    .contact-info-container {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
    }
    .submit-form {
        text-align: left;
        padding-top: .75rem;   
        margin: 0;     
    }
    .submit-btn {
        width: 26%;
    }
}

/* --------------------------------------
        Thank You Page                  
-------------------------------------- */
.thank-you-page {
    display: flex;
    flex-direction: column;
    font-family: var(--secondary-font);
    color: var(--font-color);
    text-align: center;
    min-height: 80vh;
    line-height: 1;
    align-items: center;
}

.thank-you-page-title {
    margin: 10rem auto 0;
    font-family: var(--primary-font);
    font-size: var(--title-size);
    font-weight: 300;
    text-transform: uppercase;
}

.thank-you-page-content {
    font-size: 1.1rem;
}

.return-home-btn {
    margin-top: 2rem;
    color: inherit;
    text-decoration: none;
    text-transform: uppercase;
    font-size: .8rem;
    border: 2px solid var(--cta-color);
    border-radius: 200px;
    padding: .5rem 1.2rem;
    transform-origin: center;
    will-change: transform, box-shadow;
    box-shadow: 0 0 0 transparent;
    transition: 
        transform var(--animation-timing), 
        box-shadow var(--animation-timing);

    &:hover {
        transform: translateY(-1px);
        box-shadow: 
            0 0 30px var(--glow-color);
    }
}