*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
    --dark:        #1b2133;
    --input-bg:    #141d2e;
    --input-bd:    #2a3650;
    --input-hover: #1e2a40;
    --green:       #28FF52;
    --green-dim:   #1e3122;
    --white:       #fff;
    --label:       rgba(255,255,255,0.48);
    --placeholder:  #212E3E;;
    --value-color: rgba(255,255,255,0.88);
    --dd-bg:       #1e2a3e;
    --dd-hover:    #263348;
    --dd-selected: #1a3a24;
    --text-body:   #1c1c1c;
    --text-muted:  #999;
    --bg-light:    #f6f6f6;
    --border-line: #e8e8e8;
    --g-green:     #28FF52;
    --blue: #212E3E;
}

body {
    font-family: 'FT Base';
    background: #fff;
    color: var(--text-body);
    -webkit-font-smoothing: antialiased;
    width: 100vw;
    overflow-x: hidden;
}
.container{
    max-width: 1400px;
    width: calc(100% - 50px);
    margin: auto;
    position: relative;

}

.anim-item{
    opacity: 1;
    transition: all 1000ms cubic-bezier(0.250, 0.460, 0.450, 0.940);

    transform: translate3d(0, 0,0) scale(1);
}
/* ================================================
   HERO
================================================ */
.hero {
    background: #6D32FF;


    height: 100vh;
    width: 100%;
    overflow: hidden;
    position: relative;

    padding: 50px 0;

    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.hero .container{
    display: flex;
    justify-content: space-between;
    padding: 0;
    margin: 0 auto;

/*
    &:nth-child(1){
        height: 100px;
    }

    &:nth-child(2){
      //  height: calc(100% - 100px);
    }

    &:nth-child(1){
        height: 100px;
    }
*/

    &:nth-child(3){
     flex-direction: row-reverse;
    }

}

.hero .container .col-1,
.hero .container .col-2{
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    height: 100%;
    position: relative;

}





.hero .logo{
    width:120px;
    height: auto;
}


.hero::before{
    border-radius:50%;
    background: linear-gradient(180deg, #6D32FF 0%, #263CC8 55%);
    filter: blur(20px);
    content: '';
    display: block;
    position: absolute;
    width: 100%;
    height: 120%;
    transform: translate3d(0, 30%, 0) scale(1.1);


}



 h1 {
    color: #fff;
    font-size: clamp(30px, 8vw, 72px);
    font-weight: 600;
    line-height: 100%;
    margin-bottom: 30px;

    transition-delay: 100ms;

}



h2 {
    color: #fff;
    font-size: clamp(26px, 5vw, 45px);
    font-weight: 600;
    line-height: 100%;
    margin-bottom: 30px;

    transition-delay: 100ms;

}

 h3{
    color: #FFF;
    font-size: clamp(16px, 4vw, 21px);
    font-weight: 600;

    margin-bottom: 30px;

    transition-delay: 200ms;

}
@media (max-width: 800px) {
    h3{

        margin-bottom: 20px;



    }
}
.common-cta{
    font-size: clamp(14px, 3vw, 18px);
    font-weight: 600;
    width: fit-content;
    padding: 10px 30px;
    background: var(--green);
    border-radius: 10px;

    transition-delay: 300ms;
    cursor: pointer;

    &:hover{
        transition: all 200ms cubic-bezier(0.250, 0.460, 0.450, 0.940);
        box-shadow:0 0 15px #28FF52;
    }

}
.leg{
    font-size: clamp(12px, 3vw, 16px);
    color: #FFF;
    display: flex;

    div:nth-child(2){
        margin-left: 4px;
    }



    transition-delay: 400ms;
}


.hero.init-element{

    h1,h3,.common-cta,.leg{
        opacity: 0;
        transform: translate3d(-100px, 0,0);
        transition-delay: 0ms!important;
        transition: all 1ms cubic-bezier(0.250, 0.460, 0.450, 0.940);
    }

    .compramosasuanave,
    .oferta{
        opacity: 0;
        transform: translate3d(100px, 0,0);
        transition-delay: 0ms!important;
        transition: all 1ms cubic-bezier(0.250, 0.460, 0.450, 0.940);
    }

    .nave{
        opacity: 0;
        transform: translate3d(-45%, 30%,0) scale(0.8);
        transition-delay: 0ms!important;
        transition: all 1ms cubic-bezier(0.250, 0.460, 0.450, 0.940);
    }

}




.nave{

    width: clamp(300px, 50vw, 700px);
    transform: translate3d(-20%, 00%,0) scale(1.05);
    transition-delay: 200ms;

    img{
        width: 100%;
        display: block;
        pointer-events: none;


    }
}



.compramosasuanave{
    font-size: clamp(14px, 3vw, 18px);
    font-weight: 600;
    color: #FFF;
    text-align: right;
    line-height: 100%;
    transition-delay: 100ms;
}

.oferta{
    color: #FFF;
    font-size: clamp(14px, 3vw, 18px);
    font-weight: 600;
     text-align: center;
    width: fit-content;

    border: 2px solid #FFF;
    border-radius: 10px;
    padding: 5px;
    line-height: 100%;
    transition-delay: 100ms;

}



@media (max-width: 800px) {
    .hero {
        height: auto;
        padding: 25px 0;
    }
    .hero .container{

        height: auto;
        width: calc(100% - 40px);

        &:nth-child(2){
            margin-top: 30px;
            display: block;


            .nave{
                margin-top: 20px;
                margin-left: 20px;;
            }
        }

        &:nth-child(3){
            margin-top: 30px;
            display: block;

            .leg{
                margin-top: 20px;
            }
        }
    }

    .hero .container .col-1,
    .hero .container .col-2{
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        height: 100%;
        position: relative;

    }
    .hero .logo{
        width:100px;
        height: auto;
    }

}









/* ================================================
   Carrossel
================================================ */

.carrossel{

    width: 100vw;
    overflow-x: hidden;


.carrossel-row{
    max-width: 1400px;
    width: calc(100% - 40px);
    margin: 20px auto;
    display: flex;

    justify-content: space-between;
}

    .carrossel-col{
        width: calc(50% - 10px);
        border-radius: 10px;
        overflow: hidden;

        text-align: center;
        position: relative;
        display: flex;
        align-items: center;
        justify-content: center;

        .circle{
            display: block;
            position: absolute;
            bottom:-60%;
            left: -50%;
            width: 100%;
            transform: rotate(25deg);
            border-radius: 50%;



        }

        .info{
            position: relative;

            width: 70%;
        }


        h2{
            color: var(--blue);
        }

        .common-cta{
            background: var(--blue);
            color: #FFF;
            margin: auto;
        }



        &._green{
            background: var(--green);
        }
    }


    .carousel-wrapper{
        position:relative;
        width:100%;
    }

    .carousel img{
        width:100%;
        display:block;

    }

    /* BOTÕES */

    .slick-btn{
        position:absolute;
        top:50%;
        transform:translateY(-50%);
        width:70px;
        height:70px;
        border-radius:50%;
        border:2px solid #28FF52;
        background:rgba(0,0,0,0.25);
        backdrop-filter:blur(8px);
        -webkit-backdrop-filter:blur(8px);
        display:flex;
        align-items:center;
        justify-content:center;
        cursor:pointer;
        z-index:10;
        transition:all .3s ease;
    }

    /* glow */

    .slick-btn:hover{
        box-shadow:0 0 15px #28FF52;
    }

    /* setas */

    .slick-btn::after{
        content: '';
        display: block;
        width: 25%;
        aspect-ratio: 1/1;

        transform: rotate(45deg);
        border-top: 2px solid #FFF;
        border-right: 2px solid #FFF;
        position: absolute;
        right: 42.5%;

    }

    .slick-btn:nth-child(1)::after{
        border-bottom: 2px solid #FFF;
        border-left: 2px solid #FFF;
        border-top: 2px solid rgb(0,0,0,0);
        border-right: 2px solid rgb(0,0,0,0);
        transform: rotate(45deg) ;
        left:  42.5%;
        right: auto;
    }


    .slick-btn span{
        color:#FFF;
        font-size:28px;
        line-height:1;
        font-weight: 100;
        display: none


    }

    /* posições */

    .prev{
        left:20px;
    }

    .next{
        right:20px;
    }
}



@media (max-width: 800px) {
    .carrossel{




        .carrossel-row{
            display: block;
        }
        .carrossel-col{
            width:100%;

            &:nth-child(1){
                padding: 50px 0;
                margin-bottom: 20px;
            }



            .circle{
                bottom:-60%;  left: -60%;
            }

            .info{
                position: relative;
                width: 80%;
            }




            &._green{
                background: var(--green);
            }
        }


        .carousel-wrapper{
            position:relative;
            width:100%;
        }



        /* BOTÕES */

        .slick-btn{
            width:40px;
            height:40px;
        }



        .slick-btn span{
            color:#FFF;
        }

        /* posições */


    } 
    
}



/* ================================================
   FORM
================================================ */



.form{
    background: #212E3E;
    max-width: 1400px;
    width: calc(100% - 40px);
    margin: 20px auto 0 auto;

    position: relative;
    border-radius: 10px;
    padding: 50px 0;
    h2{
        text-align: center;
    }


    position: relative;
    z-index: 3;

}



.form-label{
    font-size: clamp(15px, 3vw, 16px);
    font-weight: 500;
}


.box-form{
    background: rgba(40, 255, 82, 0.10);
    border-radius: 10px;
    border: 1px solid var(--green);
    padding: 10px 0;
    text-align: center;
    color: #FFF;

    margin-bottom: 30px;

    .value{
        padding-top: 10px;
        font-size: clamp(28px, 7vw, 70px);
        line-height: 100%;
        font-weight: 500;
    }

    display: none;

}




.form-wrap { max-width: 830px; margin: 30px auto;  width: calc(100% - 30px)}





.form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-bottom: 18px;
}


@media (max-width: 800px) {

    .form-grid { grid-template-columns: 1fr; gap: 10px; }
}


.field label {
    display: block;


    color: #FFF;
    margin-bottom: 3px;
}

/* ================================================
   CUSTOM DROPDOWN
================================================ */
.cd {
    position: relative;
    user-select: none;
}

.cd-trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: #FFF;
    border: 1px solid var(--input-bd);
    border-radius: 8px;
    padding: 10px 14px;
    cursor: pointer;
    transition: border-color .18s, background .18s;
    min-height: 42px;

    color: #212E3E;
}

.cd-trigger:hover,
.cd.open .cd-trigger {
    background: #FFF;
    border-color: #3d5070;
}

.cd.open .cd-trigger {
    border-color: var(--green);
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
}

.cd-value {
    font-size: 1rem;
    color: #212E3E;
    transition: color .15s;
    text-align: left;
    line-height: 1.3;
}

.cd.has-value .cd-value {
    color: #212E3E;
}

.cd-arrow {
    flex-shrink: 0;
    margin-left: 8px;
    transition: transform .22s cubic-bezier(.4,0,.2,1);
}

.cd.open .cd-arrow {
    transform: rotate(180deg);
}

/* dropdown list */
.cd-list {
    display: none;
    position: absolute;
    top: 100%;
    left: 0; right: 0;
    background: #FFF;
    border: 1px solid var(--green);
    border-top: none;
    border-bottom-left-radius: 8px;
    border-bottom-right-radius: 8px;
    overflow: hidden;
    z-index: 100;
    box-shadow: 0 8px 24px rgba(0,0,0,0.35);
}

.cd.open .cd-list { display: block; }

.cd-list ul {
    list-style: none;
    max-height: 200px;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: #3a4f6e transparent;
}

.cd-list ul::-webkit-scrollbar { width: 4px; }
.cd-list ul::-webkit-scrollbar-thumb { background: #3a4f6e; border-radius: 2px; }

.cd-list li {
    padding: 10px 14px;
    font-size: 1rem;
    color: rgba(255,255,255,0.75);
    cursor: pointer;
    transition: background .12s, color .12s;
    display: flex;
    align-items: center;
    justify-content: space-between;
    color: #212E3E;
}

.cd-list li:hover {
    background:  #fff;
    color: #212E3E;
}

.cd-list li.selected {
    background:  #fff;
    color: #212E3E;
    font-weight: bold;
}

.cd-list li .tick {
    display: none;
    color: #212E3E;
}

.cd-list li.selected .tick { display: block; }

/* ================================================
   CUSTOM TEXT INPUT
================================================ */
.ci input {
    width: 100%;
    background: #FFF;
    border: 1px solid var(--input-bd);
    border-radius: 8px;

    font-family: 'Inter', sans-serif;
    font-size: 1rem;
    padding: 10px 14px;
    min-height: 42px;
    outline: none;
    transition: border-color .18s, background .18s;

    color: #212E3E;
}

.ci input:hover { background: #FFF; border-color: #3d5070; }
.ci input:focus { border-color: var(--green); background: #FFF; }
.ci input::placeholder { color: var(--placeholder); }
.ci input[type=number]::-webkit-inner-spin-button,
.ci input[type=number]::-webkit-outer-spin-button { -webkit-appearance: none; }
.ci input[type=number] { -moz-appearance: textfield; }

/* ================================================
   CTA BUTTON
================================================ */
.cta-btn {
    margin: auto;

    opacity: 0.5;
    pointer-events: none;
}

.cta-btn.active {
    background: var(--green);

    cursor: pointer;
    box-shadow: 0 4px 22px rgba(79,195,90,.4);
    pointer-events: auto;
    opacity: 1;
}

.cta-btn.active:hover { background: #46b852; transform: translateY(-1px); }

/* ================================================
   GARANTIAS
================================================ */
.garantias-section {

    margin: 0 auto;

    max-width: 1400px;
    width: calc(100% - 40px);
    padding: 60px 50px;

    *{
        color: var(--blue);
    }

    h2{
        width: 30%;
    }
}

@media (max-width: 800px) {
    .garantias-section {
        h2{
            width: 80%;
        }
    }

}

.g-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: 56px;
}

.g-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 20px 0;
    border-bottom: 1px solid var(--border-line);
}

.g-grid .g-item:nth-last-child(-n+2) { border-bottom: none; }

.g-icon {
    flex-shrink: 0;
    width: 20px;
    height: 20px;
    margin-top: 1px;
}

.g-text {
    font-size: clamp(15px, 3vw, 18px);

    color: #2a2a2a;
}

/* ================================================
   REVIEWS
================================================ */
.reviews-section {
    max-width: 1400px;
    width: calc(100% - 40px);
    padding: 60px 50px;
    margin: auto;

    *{
        color: var(--blue);
    }
}

.notas{
    margin-top: 80px;
    font-size: clamp(10px, 2vw, 12px);
}

.r-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.r-card {
    background: #fff;
    border-radius: 14px;
    padding: 20px 18px;
    display: flex;
    gap: 20px;
    align-items: flex-start;



    font-size: clamp(15px, 3vw, 18px);
}


.r-av {
    flex-shrink: 0;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    padding: 0;

position: relative;

}

.r-card img{
    flex-shrink: 0;
    width: 100%;
    display: block;
    position: absolute;
    left: 0;
    top:0;

}

.r-text { font-size: 1em; color: var(--blue); margin-bottom: 9px; }
.r-name { font-size: 0.82em; font-weight: 600; color: #111; }
.r-time { font-size: 0.8em; color: var(--text-muted); margin-top: 2px; }

/* ================================================
   RESPONSIVE
================================================ */
@media (max-width: 800px) {



    .garantias-section { padding: 48px 16px; }
    .garantias-section h2 { max-width: 100%; }
    .g-grid { grid-template-columns: 1fr; column-gap: 0; }
    .g-grid .g-item:nth-last-child(-n+2) { border-bottom: 1px solid var(--border-line); }
    .g-grid .g-item:last-child { border-bottom: none; }

    .reviews-section { padding: 48px 16px 60px; }
    .r-grid { grid-template-columns: 1fr; }

    .r-av {
        flex-shrink: 0;
        width: 50px;
        height: 50px;

    }

    .r-card {
        background: #fff;
        border-radius: 14px;
        padding: 20px 0px;
    }
}


.video-section{
    max-width: 1400px;
    width: calc(100% - 40px);
    margin: 30px auto;
    border-radius: 10px;
}

.video-wrapper{
    width:100%;

}

video{
    width:100%;
    height:auto;
    display:block;
    border-radius: 10px;
}


/* estado default (placeholder) */
.cd .cd-value {
    opacity: 0.5;
}

/* quando já existe valor selecionado */
.cd.has-value .cd-value {
    opacity: 1;
}
input::placeholder {
    opacity: 0.5;
}