/*Base stuff */

:root {
    --arrow-bg: rgba(255, 255, 255, 0.3);
    --arrow-icon: url(https://upload.wikimedia.org/wikipedia/commons/9/9d/Caret_down_font_awesome_whitevariation.svg);
    --option-bg: rgb(193, 230, 219);
    --select-bg: rgba(226, 238, 233, 0.37);
}

html {
    scroll-behavior: smooth;
    overflow-x: clip;
}

body {
    background: rgb(4, 11, 20);
    height: 100%;
    width: 100%;
    margin-bottom: 0;
}

footer {
    background: #040b15;
}

footer a {
    display: inline-block;
}

footer h4 {
    display: inline-block;
}

footer nav a img {
    margin-top: 1em;
    max-width: 2em;
    max-height: 2em;
}

nav {
    position: relative;
}

body,
input,
select,
textarea {
    color: #555f66;
    font-family: "Roboto", Helvetica, sans-serif;
    font-size: 14pt;
    font-weight: 300;
    line-height: 1.75em;
    margin-left: auto;
    margin-right: auto;
}

a {
    color: #629DD1;
    text-decoration: underline;
}

a:hover {
    text-decoration: none;
}

strong,
b {
    color: #666f77;
    font-weight: 500;
}

em,
i {
    font-style: italic;
}

p {
    margin: 0 0 2em 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    color: #fcfffe;
    font-weight: 300;
    line-height: 1em;
    margin: 0 0 1em 0;
    text-transform: uppercase;
    letter-spacing: 0.125em;
}

h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a {
    color: inherit;
    text-decoration: none;
}

h2 {
    font-size: 1.5em;
    line-height: 1.5em;
}

h3 {
    font-size: 1.25em;
    line-height: 1.5em;
}

h4 {
    font-size: 1em;
    line-height: 1.5em;
}

h5 {
    font-size: 0.9em;
    line-height: 1.5em;
}

h6 {
    font-size: 0.7em;
    line-height: 1.5em;
}

sub {
    font-size: 0.8em;
    position: relative;
    top: 0.5em;
}

sup {
    font-size: 0.8em;
    position: relative;
    top: -0.5em;
}

hr {
    border: 0;
    border-bottom: solid 1px rgba(144, 144, 144, 0.25);
    margin: 3em 0;
}

hr.major {
    margin: 2em 0 5em 0;
}

blockquote {
    border-left: solid 4px rgba(144, 144, 144, 0.25);
    font-style: italic;
    margin: 0 0 2em 0;
    padding: 0.5em 0 0.5em 2em;
}

code {
    background: rgba(144, 144, 144, 0.075);
    border-radius: 6px;
    border: solid 1px rgba(144, 144, 144, 0.25);
    font-family: "Courier New", monospace;
    font-size: 0.9em;
    margin: 0 0.25em;
    padding: 0.25em 0.65em;
}

pre {
    -webkit-overflow-scrolling: touch;
    font-family: "Courier New", monospace;
    font-size: 0.9em;
    margin: 0 0 2em 0;
    overflow-x: auto;
}

pre code {
    display: block;
    line-height: 1.75em;
    padding: 1em 1.5em;
}

.align-left {
    text-align: left;
}

.align-center {
    text-align: center;
}

.align-right {
    text-align: right;
}

/*Header stuff */

ul.actions {
    cursor: default;
    list-style: none;
    padding-left: 0;
}

ul.actions li {
    display: inline-block;
    padding: 0 1em 0 0;
    vertical-align: middle;
}

ul.actions li:last-child {
    padding-right: 0;
}

ul.actions.small li {
    padding: 0 0.5em 0 0;
}

ul.actions.vertical li {
    display: block;
    padding: 1em 0 0 0;
}

ul.actions.vertical li:first-child {
    padding-top: 0;
}

ul.actions.vertical li>* {
    margin-bottom: 0;
}

ul.actions.vertical.small li {
    padding: 0.5em 0 0 0;
}

ul.actions.vertical.small li:first-child {
    padding-top: 0;
}

ul.actions.fit {
    display: table;
    margin-left: -1em;
    padding: 0;
    table-layout: fixed;
    width: calc(100% + 1em);
}

ul.actions.fit li {
    display: table-cell;
    padding: 0 0 0 1em;
}

ul.actions.fit li>* {
    margin-bottom: 0;
}

ul.actions.fit.small {
    margin-left: -0.5em;
    width: calc(100% + 0.5em);
}

ul.actions.fit.small li {
    padding: 0 0 0 0.5em;
}


header p {
    color: rgb(160, 204, 189);
    position: relative;
    margin: 0 0 1.5em 0;
}

header h2+p {
    font-size: 1.25em;
    margin-top: -1em;
    line-height: 1.5em;
}

header h3+p {
    font-size: 1.1em;
    margin-top: -0.85em;
    line-height: 1.5em;
}

header h4+p,
header h5+p,
header h6+p {
    font-size: 0.9em;
    margin-top: -0.75em;
    line-height: 1.5em;
}

header.major {
    text-align: center;
    margin: 0 0 4em 0;
}

header.major.timeline {
    margin-bottom: 0;
    padding-bottom: 0;
}

header.major.timeline h3 {
    margin-bottom: 0;
    padding-bottom: .5em;
}

header.major h2 {
    font-size: 2em;
}

header.major h2+p {
    font-size: 1.5em;
    margin: -1em 0 2em 0;
}

#heading {
    background: #000307;
    padding-bottom: 2em; 
    color: #f1f8f3;
    cursor: default;
    height: 2em;
    left: 0;
    line-height: 3em;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 10000;
    box-shadow: 0 0 0.1em 0 rgba(0, 0, 0, 0.25);
    font-family:museo-sans, sans-serif;
    font-weight: 700;
    align-items: center;
}

#heading h1 {
    color: #69eea0;
    font-weight: 500;
    height: inherit;
    left: 1.25em;
    line-height: inherit;
    margin: 0;
    padding: 0;
    position: absolute;
    top: 0;
}


#heading h1 a {
    font-size: 1.25em;
}

#heading nav {
    height: inherit;
    display: flex;
    line-height: inherit;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    justify-content: center;
    align-items: center;
    vertical-align: middle;
    text-align: center;
}

#heading nav>ul {
    list-style: none;
    margin: 0;
    padding-left: 0;
}

#heading nav>ul>li {
    border-radius: 6px;
    display: inline-block;
    margin-left: 2em;
    padding-left: 0;
}

#heading nav>ul>li a {
    -moz-transition: color 0.2s ease-in-out;
    -webkit-transition: color 0.2s ease-in-out;
    -o-transition: color 0.2s ease-in-out;
    -ms-transition: color 0.2s ease-in-out;
    transition: color 0.2s ease-in-out;
    color: #e5f1ee;
    display: inline-block;
    text-decoration: none;
}
#heading div>a.button {
    position: absolute;
    right: 2%;
    top: 23%;
    font-weight: 600;
}

#heading nav>ul>li a:hover {
    color: #acefc2;
}

#heading nav>ul>li:first-child {
    margin-left: 0;
}

#heading nav>ul>li .button {
    height: 2.25em;
    line-height: 2.25em;
    margin-bottom: 0;
    padding: 0 1em;
    position: relative;
    top: -0.075em;
    vertical-align: middle;
}

.container {
    position: relative;
}

#heading .container {
    position: relative;
}

#heading .container h1 {
    left: 0;
}

#heading .container nav {
    right: 0;
}

#heading img {
    top:0;
    left:0;
    height: 12vw;
    width: auto;
    transform: translate(0%,-35%);
    display: block;
    margin-left: 2%;
    object-fit: contain;
 
}
  @media screen and (min-width: 768px) {
    #heading img {
        height: 200px;
        transform: translate(0%,-35%);
    }

    #heading div>a.button {
        font-size: .85em;
        top: 30%;
    }
}

#heading h3 {
    display: inline-block;
    position: absolute;
    left: 3em;
    top: 0.15em;
    font-weight: 600;
}

#banner {
    background-color: rgba(0, 0, 0, 0.5);
    background-position: center center;
    background-repeat: no-repeat;
    color: #d8d8d8;
    padding: 14em 0;
    text-align: center;
    position: relative;
}

#banner::before {
    content: "";
    position: absolute;
    inset: 0;
    /* shorthand for top:0; right:0; bottom:0; left:0 */
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.701), rgba(255, 255, 255, 0)), linear-gradient(45deg, rgba(78, 221, 142, 0.589), transparent 70%), linear-gradient(to right, rgba(0, 0, 0, 0.201), rgba(255, 255, 255, 0)), url("images/Generator.avif"), linear-gradient(to bottom, rgba(255, 255, 255, 0), rgba(10, 25, 47, 1));
    width: 100%;
    height: 100%;
    pointer-events: none;
    /* lets clicks pass through */
    z-index: 1;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-blend-mode: color-burn;
}

#banner .inner {

    background-color: rgba(0, 0, 0, 0);
    position: relative;
    z-index: 1;
}

#banner .inner p {
    color: #fff;
}

#banner .inner :last-child {
    margin-bottom: 0;
}

#banner h2,
#banner h3,
#banner h4,
#banner h5,
#banner h6 {
    color: #ffffff;
}

#banner .button.alt {
    box-shadow: inset 0 0 0 1px rgba(144, 144, 144, 0.75);
    color: #ffffff !important;
}

#banner .button.alt:hover {
    background-color: rgba(144, 144, 144, 0.275);
}

#banner .button.alt:active {
    background-color: rgba(144, 144, 144, 0.4);
}

#banner .button.alt.icon:before {
    color: #c1c1c1;
}

#banner .button {
    min-width: 12em;
}

#banner h2 {
    font-size: 3.5em;
    line-height: 1em;
    margin: 0 0 0.5em 0;
    padding: 0;
}

#banner p {
    font-size: 1.5em;
    margin-bottom: 2em;
}

#banner p a {
    color: #ffffff;
    text-decoration: none;
}

.\34 u {
    position: relative;
    width: 25%;
}

.\33 u {
    position: relative;
    width: 33.3333333%;
}

.\32 u {
    position: relative;
    width: 50%;
}


/* Icon */

.icon {
    text-decoration: none;
    border-bottom: none;
    position: relative;
}

.icon:before {
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    font-family: FontAwesome;
    font-style: normal;
    font-weight: normal;
    text-transform: none !important;
}

.icon>.label {
    display: none;
}

.icon.major {
    margin: 0 0 1.25em 0;
    padding: 0;
    color: #ffffff;
    width: 2.7vmax;
    height: 2.7vmax;
    font-size: 1.3vmax;
    text-align: center;
    line-height: 2.7vmax;
    border-radius: 100%;
    box-shadow: 0 0 0 .25vmax #fff, 0 0 0 .4vmax rgba(144, 144, 144, 0.25);
}

.icon.major.first {
    background-image: url("images/The_Build_Icon.png");
}

.icon.major.second {
    background-image: url("images/The_Fuel.png");
}

.icon.major.third {
    background-image: url("images/The_Result_Icon.png");
}

.icon.major.fourth {
    background-image: url("images/The_Reward_Icon.png");
}

/* Box */

.box {
    height: auto;
    width: auto;
    position: relative;
    border-radius: 6px;
    border: solid 2px rgba(8, 17, 44, 0.384);
    margin-bottom: 2em;
    padding: 1em 1em;
    text-align: center;
}

.box> :last-child,
.box> :last-child> :last-child,
.box> :last-child> :last-child> :last-child {
    margin-bottom: 0;
}

.box.alt {
    background: transparent;
    border: solid 2px rgba(255, 255, 255, 0.775);
    box-shadow: 0 .02em .3em .25vmax rgba(85, 97, 89, 0.3);
    border-radius: 2em;
    padding: 0;
}

.box.darkGradient {
    background: #0a192f, linear-gradient(rgba(4, 9, 15, 1), rgba(10, 25, 48, 0)), #fff;
    border-image: linear-gradient(rgba(4, 9, 15, 1), rgba(4, 11, 22, 0.9), rgba(10, 25, 48, 0));
    border-image-slice: 1;
}

.box h3 {
    color: #000;
}

.box.alt h3 {
    color: #fff
}




/* Rows */

.row>* {
    float: left;
}

.row:after {
    content: '';
    display: block;
    clear: both;
    height: 0;
}


.circleless {
    list-style-type: none;
}

.button.big {
    font-size: 1.2em;
    height: 2.65em;
    line-height: 2.65em;
}

.button.medium {
    font-size: 1em;
    height: 2em;
    line-height: 2em;
}

.button.small {
    font-size: 0.6em;
    height: 2em;
    line-height: 2em;
}

.button.special {
    background-color: #629DD1;
    color: #ffffff !important;
}

.button {
    -moz-appearance: none;
    -webkit-appearance: none;
    -o-appearance: none;
    -ms-appearance: none;
    appearance: none;
    -moz-transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
    -webkit-transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
    -o-transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
    -ms-transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
    transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
    background-color: #232d33;
    border-radius: 6px;
    border: 0;
    color: #ffffff !important;
    cursor: pointer;
    display: inline-block;
    font-weight: 300;
    text-transform: uppercase;
    letter-spacing: 0.125em;
    font-size: 0.9em;
    height: 2.85em;
    line-height: 2.85em;
    padding: 0 1.75em;
    text-align: center;
    text-decoration: none;
    white-space: nowrap;
    text-indent: 0.25em;
}

.button:hover {
    background-color: #232d33;
}


.wrapper {
    padding: 6em 0 4em 0;
}

.wrapper.underlined {
    text-decoration: underline;
    text-decoration-style: dotted;
    text-decoration-thickness: 2px;
    text-decoration-color: #fff;
    margin-bottom: 0px;
}

.wrapper.style1 {
    background: linear-gradient(to bottom, rgba(1, 1, 1, 1), rgba(10, 25, 48, 0));
    color: #fff;
    padding: 0;
}

.wrapper.style2 {
    background: #020b07;
    color: #c5c7c8;
}

.wrapper.style2 h2,
.wrapper.style2 h3,
.wrapper.style2 h4,
.wrapper.style2 h5,
.wrapper.style2 h6 {
    color: #ffffff;
}

.wrapper.style2 header p {
    color: #a3a5a7;
}

.wrapper.style2 .button.alt {
    box-shadow: inset 0 0 0 1px rgba(144, 144, 144, 0.75);
    color: #ffffff !important;
}

.wrapper.style2 .button.alt:hover {
    background-color: rgba(144, 144, 144, 0.275);
}

.wrapper.style2 .button.alt:active {
    background-color: rgba(144, 144, 144, 0.4);
}

.wrapper.style2 .button.alt.icon:before {
    color: #a3a5a7;
}

.compare {
    display: inline-flex;
}

.compare div {
    text-align: center;
}

.compare ul {
    display: inline-block;
    text-align: center;
    margin: 0 1em 0 1em;
    padding: 0;
}

/* Create a Parallax Effect */

/* First image (Logo. Full height) */
.parallax-1 {
    background-image: linear-gradient(to bottom, rgba(9, 24, 45, 1), rgba(255, 255, 255, 0)), url(images/hvacStockImage1.jpg);
    height: 100%;
    background-attachment: fixed;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

@media only screen and (max-device-width: 767px) {

    #banner::before {
        background-blend-mode: overlay;
    }

    .parallax-1 {
        background-attachment: scroll;
        height: inherit;
        
    }
}

.circle {
    background: #020b07;
    border: solid 5px #020b07;
    border-radius: 100%;
    border-top: 120%;
    text-align: center;
    width: 100%;
    height: 100%;
    line-height: 4em;
    margin-top: 1em;
    margin-bottom: 2em;
    animation: complexMove;
    animation-timeline: scroll();
}


.answerBox {
    background: linear-gradient(to bottom, rgba(233, 237, 238, 0.158), rgb(4, 11, 21));
    width: 100%;
    height: 10em;
    color: #cff0ea;
}

.imageIcon {
    display: block;
    margin-left: auto;
    margin-right: auto;
    height: 100%;
    max-width: 9em;
    max-height: 9em;
    width: 100%;
}

.triangle {
    position: absolute;
    width: 0;
    height: 0;
    border-left: 10vmax solid rgba(3, 10, 18, .9);
    border-top: 10vmax solid transparent;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    rotate: 90deg;
}

#whatYouGet {
    background-color: #0f172a;
    color: #fff;
    border-radius: 0%;
    margin-bottom: 0;
}

#whatYouGet h3 {
    color: #dae4df;
}

#qualityControl {
    background-color: rgba(255, 255, 255, .7);
    color: #000;
    margin-bottom: 0;
}

#qualityControl h2, #qualityControl h3, #qualityControl p {
    color:#000;
    font-weight: 600;
}

#fourThingsContainer {
    color: #000;
    font-weight: 600;
    background-color: rgba(255, 255, 255, .7);
}

#fourThingsContainer h3{
    font-weight: 900;
}



.roundedBackground {
    color: #000;
    font-weight: 700;
    position: relative;
    margin: auto auto;
    border-radius: 2em;
    width: 45%;
}

.roundedBackground.green {
    background-color: #acefc2;
}

.roundedBackground.grey {
    background-color: #abafb1;
    width: 55%;
}

.checkmarkCircles {
    display: inline-block;
    list-style-type: none;
    list-style: none;
    padding-left: 0;
}

.checkmarkCircles.whiteCircle li::before {
    background-image: url('images/Checkmark_V2.png');
}

.checkmarkCircles.crossedOut li::before {
    background-image: url('images/X_Icon.png');
}

.checkmarkCircles li {
    text-align: left;
    position: relative;
    padding-left: 2em;
    padding-bottom: .5em;
}

.checkmarkCircles li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translate(-10%,-60%);
    width: 2em;
    height: 2em;
    background-image: url('images/Checkmark_V1.png');
    background-size: contain;
    background-repeat: no-repeat;
}


.underline {
    text-decoration: underline;
    text-decoration-color: #000;
    /* Optional: custom underline color */
    text-decoration-thickness: 2px;
    /* Optional: thicker underline */
}


.mouseHover {
    /* Initial position */
    transform: translateX(0);
    /* Smooth transition for transform changes */
    transition: transform 0.3s ease-in-out;
}

.buy {
    margin-bottom: 2em;
}

.mouseHover:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 30px rgba(102, 126, 234, .2);
    border-color: #667eea;
}

.seperator {
    width: 100%;
    height: 1em;
    position: relative;
    background: rgba(82, 87, 90, 0.5);
    border-radius: 3%;
}

#End .box {
    background: linear-gradient(135deg, rgba(20, 41, 75, 0.9) 0%, rgba(10, 25, 48, 0.7) 100%);
    border: 1px solid rgba(112, 230, 190, 0.3);
    box-shadow: 0 8px 32px rgba(112, 230, 190, 0.1), inset 0 1px 0 rgba(112, 230, 190, 0.2);
    transition: all 0.3s ease;
    font-weight: 1000;
}

#End .box:hover {
    border-color: rgba(112, 230, 190, 0.6);
    box-shadow: 0 12px 40px rgba(112, 230, 190, 0.2), inset 0 1px 0 rgba(112, 230, 190, 0.3);
    transform: translateY(-2px);
}

#End h3 {
    color: #fff;
}


.compareBoxes {
    margin: 0 1em 0 1em;
}

/*---------------------------------new-------------------------------*/


#spinThingBackground {
    background: linear-gradient(180deg, rgba(4, 11, 20, 1) 0%, rgba(10, 25, 48, 0.95) 50%, rgba(4, 11, 20, 1) 100%);
    padding: 4rem 1rem 6rem;
    position: relative;
    overflow: hidden;
}


#spinThingBackground::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, rgba(112, 230, 190, 0.1) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
    animation: pulse 4s ease-in-out infinite;
}

@keyframes pulse {

    0%,
    100% {
        opacity: 0.3;
        transform: translate(-50%, -50%) scale(.8);
    }

    50% {
        opacity: 0.8;
        transform: translate(-50%, -50%) scale(1);
    }
}

.centerThis {
    text-align: center;
    margin-bottom: 1rem;
}

/* Container for entire carousel */
.cards-container {
    --base-rotation: 0deg;
    --full-circle: 360deg;
    --radius: 20vw;
    --duration: 400ms;
    --cards-container-size: calc(var(--radius) * 2);
    --cards-container-padding: 2vw;
    --label-offset: calc(var(--radius) * -1 - 1.5vw);
    --label-size: 1.1vw;
    --label-color: rgba(255, 255, 255, 0.6);
    --label-color-hover: rgb(112, 230, 190);
    --label-line-h: 0;
    --label-line-h-current: 1.5vw;
    --label-dot-size: 1vw;

    box-sizing: content-box;
    position: relative;
    margin: 3rem auto 2rem;
    width: var(--cards-container-size);
    height: var(--cards-container-size);
    padding: var(--cards-container-padding);
    aspect-ratio: 1;
}

/* Mobile responsive adjustments */
@media (max-width: 1024px) {
    .cards-container {
        --radius: 28vw;
        --label-size: 2vw;
        --label-offset: calc(var(--radius) * -1 - 2vw);
        --label-dot-size: 1.5vw;
        --label-line-h-current: 2vw;
    }
}

@media (max-width: 768px) {
    .cards-container {
        --radius: 35vw;
        --label-size: 2.5vw;
        --label-offset: calc(var(--radius) * -1 - 3vw);
        --label-dot-size: 2vw;
        --label-line-h-current: 2.5vw;
    }

    #spinThingBackground {
        padding: 3rem 0.5rem 4rem;
    }
}

/* Center decoration - simplified */
.cardCenter {
    position: absolute;
    content: '';
    border-radius: inherit;
    width: 65%;
    height: 65%;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: radial-gradient(circle, rgba(16, 185, 129, 0.05) 0%, rgba(10, 25, 48, 0.6) 40%, rgba(0, 0, 0, 0) 70%);
    z-index: 1;
}

/* Rotating border animation - simplified */
.cards-container::before,
.cards-container::after {
    z-index: -1;
    position: absolute;
    content: '';
    border-radius: 50%;
    width: var(--cards-container-size);
    height: var(--cards-container-size);
    background: conic-gradient(from 0deg,
            rgba(112, 230, 190, 0.6) 0%,
            rgba(60, 185, 137, 0.4) 25%,
            rgba(66, 167, 111, 0.3) 50%,
            rgba(112, 230, 190, 0.6) 100%);
    inset: -2px;
    margin: auto;
    animation: rotate 8s linear infinite;
    aspect-ratio: 1;
}

.cards-container::after {
    filter: blur(10px);
    opacity: 0.4;
}

@keyframes rotate {
    to {
        rotate: 360deg;
    }
}

/* Cards list */
.cards {
    position: absolute;
    inset: var(--cards-container-padding);
    aspect-ratio: 1;
    border-radius: 50%;
    border: 1px solid rgba(112, 230, 190, 0.2);
    transition: transform var(--duration) cubic-bezier(0.4, 0, 0.2, 1);
    list-style: none;
    margin: 0;
    padding: 0;
    background: rgba(15, 23, 42, 0.3);
    backdrop-filter: blur(8px);
}

/* Individual card items */
.cards li {
    position: absolute;
    inset: 0;
    margin: 0;
    padding: 0;
    transform-origin: center;
    display: grid;
    place-content: center;
    transform: rotate(calc(var(--i) * 360deg / var(--items)));
    pointer-events: none;
}

/* Phase labels (PHASE 1, PHASE 2, etc.) - COMPACT VERSION */
.cards li>label {
    position: absolute;
    inset: 0;
    margin: auto;
    transform: translateY(var(--label-offset));
    height: var(--label-size);
    cursor: pointer;
    pointer-events: initial;
    text-align: center;
    color: var(--label-color);
    font-size: var(--label-size);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    transition: all var(--duration) cubic-bezier(0.4, 0, 0.2, 1);
    padding: 0;
    border-radius: 1rem;
    background: rgba(15, 23, 42, 0.85);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(112, 230, 190, 0.25);
    white-space: nowrap;
    width: fit-content;
    display: inline-block;
    padding: 0.25rem 0.5rem;
}

.cards li>label>p {
    float: center;
    display: block;
    padding-bottom: 1em !important;
    width: fit-content;
    transform: translate(0%, -12%);
}

.cards li>label:hover {
    color: var(--label-color-hover);
    background: rgba(15, 23, 42, 0.95);
    border-color: rgba(112, 230, 190, 0.5);
    transform: translateY(var(--label-offset)) scale(1.05);
}

/* Dot indicator */
.cards li>label::before {
    content: '';
    position: absolute;
    top: calc(var(--cards-container-padding) + 0.5rem);
    left: 50%;
    translate: -50% 0;
    width: var(--label-dot-size);
    height: var(--label-dot-size);
    aspect-ratio: 1;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(112, 230, 190, 0.8), rgba(60, 185, 137, 0.8));
    box-shadow: 0 0 8px rgba(112, 230, 190, 0.4);
    transition: all var(--duration) cubic-bezier(0.4, 0, 0.2, 1);
    border: 2px solid rgba(15, 23, 42, 0.9);
}

/* Connecting line from dot to label - SIMPLIFIED */
.cards li>label::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 50%;
    translate: -50% 0;
    width: 2px;
    height: var(--label-line-h);
    background: linear-gradient(to bottom, rgba(112, 230, 190, 0.6), transparent);
    transition: height 250ms cubic-bezier(0.4, 0, 0.2, 1) var(--label-line-delay, 0ms);
}

/* Title (e.g., "Initial Consultation") - CENTERED */
.cards>li>h2 {
    position: absolute;
    left: 50%;
    top: 32%;
    transform: translateX(-50%);
    text-align: center;
    z-index: 23;
    font-size: clamp(1.2rem, 2.5vw, 2rem);
    opacity: var(--title-opacity, 0);
    transition: all var(--duration) cubic-bezier(0.4, 0, 0.2, 1) var(--title-delay, 0ms);
    color: #70e6be;
    text-shadow: 0 2px 10px rgba(112, 230, 190, 0.3);
    font-weight: 600;
    letter-spacing: 0.05em;
    margin: 0;
    padding: 0.5rem 1rem;
    background: rgba(15, 23, 42, 0.95);
    backdrop-filter: blur(10px);
    border-radius: 1rem;
    border: 1px solid rgba(112, 230, 190, 0.3);
    max-width: 80%;
    pointer-events: none;
}

@media (max-width: 768px) {
    .cards>li>h2 {
        font-size: clamp(1rem, 4vw, 1.5rem);
        padding: 0.4rem 0.8rem;
        max-width: 85%;
    }
}

/* Description text - CENTERED BELOW TITLE */
.cards>li>p {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    margin-top: 4rem;
    width: min(85%, 35vw);
    z-index: 22;
    font-size: clamp(0.85rem, 1.5vw, 1rem);
    text-wrap: pretty;
    opacity: var(--info-opacity, 0);
    transition: all var(--duration) cubic-bezier(0.4, 0, 0.2, 1) var(--info-delay, 0ms);
    color: #dbf5ee;
    line-height: 1.7;
    padding: 1.5rem;
    background: rgba(15, 23, 42, .99);
    backdrop-filter: blur(12px);
    border-radius: 1rem;
    border: 1px solid rgba(112, 230, 190, 0.2);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
    pointer-events: none;
}

@media (max-width: 1024px) {
    .cards>li>p {
        width: min(90%, 50vw);
        margin-top: 3.5rem;
    }
}

@media (max-width: 768px) {
    .cards>li>p {
        font-size: clamp(0.8rem, 3.2vw, 0.95rem);
        padding: 1rem;
        line-height: 1.6;
        width: min(92%, 70vw);
        margin-top: 3rem;
    }
}

/* Fine print text */
.cards>li>span {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, calc(-50% + 8.5rem));
    width: min(85%, 35vw);
    text-align: center;
    z-index: 23;
    opacity: var(--info-opacity, 0);
    transition: all var(--duration) cubic-bezier(0.4, 0, 0.2, 1) var(--info-delay, 0ms);
    pointer-events: none;
}

#finePrint {
    color: rgba(192, 192, 192, 1);
    font-size: clamp(0.7rem, 1.3vw, 0.8rem);
    font-style: italic;
    margin-top: 1rem;
    display: block;
    z-index: 25;
}

/* Active state for checked items */
li:has(input:checked) {
    --label-opacity: 1;
    --label-color: var(--label-color-hover);
    --label-line-h: var(--label-line-h-current);
    --label-line-delay: calc(var(--duration) * 1.2);
    --title-opacity: 1;
    --title-delay: calc(var(--duration) * 1.5);
    --info-opacity: 1;
    --info-delay: calc(var(--duration) * 2);
}

/* Active label styling */
li:has(input:checked)>label {
    background: rgba(112, 230, 190, 0.2);
    border-color: rgba(112, 230, 190, 0.8);
    box-shadow: 0 0 15px rgba(112, 230, 190, 0.3);
}

li:has(input:checked)>label::before {
    background: linear-gradient(135deg, #70e6be, #3cb989);
    box-shadow: 0 0 15px rgba(112, 230, 190, 0.7);
    transform: scale(1.2);
}

/* Rotate container based on checked radio */
.cards:has(input:checked) {
    transform: rotate(calc(var(--base-rotation) - (var(--index) * var(--full-circle) / var(--items))));
}

/* Index tracking for rotation */
.cards:has(li:nth-child(1) > input:checked) {
    --index: 0;
}

.cards:has(li:nth-child(2) > input:checked) {
    --index: 1;
}

.cards:has(li:nth-child(3) > input:checked) {
    --index: 2;
}

.cards:has(li:nth-child(4) > input:checked) {
    --index: 3;
}

.cards:has(li:nth-child(5) > input:checked) {
    --index: 4;
}

.cards:has(li:nth-child(6) > input:checked) {
    --index: 5;
}

.cards:has(li:nth-child(7) > input:checked) {
    --index: 6;
}

.cards:has(li:nth-child(8) > input:checked) {
    --index: 7;
}

/* Hide radio inputs */
input[type="radio"] {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
    display: none;
    visibility: hidden;
}

.space {
    height: 20vh;
}

/* Additional mobile optimizations */
@media (max-width: 480px) {
    .cards-container {
        --radius: 60vw;
        --label-size: 3vw;
    }

    #spinThingBackground::before {
        width: 300px;
        height: 300px;
    }

    .cards>li>p {
        width: min(95%, 80vw);
        padding-bottom: 1.1rem;
        min-height: 10rem;
    }
    .space {
        height: 2em;
    }
}

.section_faq {
    margin-top: 3rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    padding: 4rem 1rem;
    background: linear-gradient(180deg, rgba(4, 11, 20, 1) 0%, rgba(10, 25, 48, 0.95) 50%, rgba(4, 11, 20, 1) 100%);
}

.section_faq::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 500px;
    height: 500px;
    background: radial-gradient(circle, rgba(112, 230, 190, 0.08) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
    animation: pulse 4s ease-in-out infinite;
}

.section_faq h1 {
    font-size: 3rem;
    position: relative;
    z-index: 2;
    text-shadow: 0 2px 10px rgba(112, 230, 190, 0.3);
}

.section_faq ul {
    margin: 2vw auto;
    width: 75%;
    max-width: 900px;
    position: relative;
    z-index: 2;
}

.section_faq ul li {
    list-style: none;
    margin-bottom: 1rem;
    position: relative;
}

.section_faq ul li::before {
    content: '';
    position: absolute;
    left: -20px;
    top: 50%;
    transform: translateY(-50%);
    width: 8px;
    height: 8px;
    background: linear-gradient(135deg, rgba(112, 230, 190, 0.6), rgba(60, 185, 137, 0.6));
    border-radius: 50%;
    box-shadow: 0 0 10px rgba(112, 230, 190, 0.4);
    opacity: 0;
    transition: opacity 0.3s ease;
}

.section_faq ul li:hover::before {
    opacity: 1;
}

.section_faq .question {
    color: #fff;
    border-radius: 0.75rem;
    margin-bottom: 0px;
    padding: 1.5rem 1.5rem;
    background: rgba(15, 23, 42, 0.85);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(112, 230, 190, 0.25);
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: clamp(1rem, 2vw, 1.25rem);
    font-weight: 500;
    cursor: pointer;
    transition: all 0.45s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
}

.section_faq .question:hover {
    background: rgba(15, 23, 42, 0.95);
    border-color: rgba(112, 230, 190, 0.5);
    transform: scale(1.002);
    box-shadow: 0 6px 20px rgba(112, 230, 190, 0.2);
}

.section_faq .question.open {
    background: rgba(112, 230, 190, 0.15);
    border-color: rgba(112, 230, 190, 0.6);
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
    box-shadow: 0 6px 20px rgba(112, 230, 190, 0.3);
}

.section_faq .faqicon {
    margin-left: 1rem;
    font-size: clamp(1.5rem, 3vw, 2rem);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform .5s ease-in-out;
    color: rgba(112, 230, 190, 0.8);
    min-width: 2rem;
}

.section_faq .answer {
    color: #dbf5ee;
    max-height: 0;
    margin: auto auto;
    background: rgba(15, 23, 42, 0.9);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(112, 230, 190, 0.2);
    border-top: none;
    border-radius: 0 0 0.75rem 0.75rem;
    overflow: hidden;
    font-size: clamp(0.9rem, 1.7vw, 1.1rem);
    line-height: 1.7;
    transition: max-height 0.45s cubic-bezier(0.4, 0, 0.2, 1), padding 0.35s linear;
    width: inherit;
    padding: 0 1.5rem;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
}

.section_faq .answer span {
    display: inline-block;
    padding: 0;
}

.section_faq .question.open+.answer {
    max-height: 1200px;
    padding: 1.5rem;
}

.section_faq .question.open>.faqicon {
    transform: rotate(45deg);
    color: #70e6be;
}

footer nav {
    display: flex;
    justify-content: center;
    align-items: center;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
     vertical-align: middle;
}

footer nav img {
   
}