/* ==========================================================
   YOGA WITH SHUBHAM
   GLOBAL STYLES
========================================================== */

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{

    font-family:'Poppins',sans-serif;

    background:linear-gradient(

180deg,

#18263D 0%,

#314766 12%,

#D9A25B 24%,

#F8F6F2 45%,

#F8F6F2 100%

);

background-attachment:fixed;

transition:background .3s;
;

    color:#2E2E2E;

    overflow-x:hidden;

    line-height:1.7;

}

/* ==========================================================
TYPOGRAPHY
========================================================== */

h1,h2,h3,h4{

    font-family:'Cormorant Garamond',serif;

    color:#2C241B;

    font-weight:600;

}

h1{

    font-size:72px;

    line-height:1.1;

    margin-bottom:25px;

}

h2{

    font-size:54px;

    text-align:center;

    margin-bottom:25px;

}

h3{

    font-size:30px;

    margin-bottom:15px;

}

p{

    font-size:18px;

    color:#565656;

}

/* ==========================================================
COMMON
========================================================== */

.container{

    width:min(1180px,90%);

    margin:auto;

}

section{

    padding:120px 0;

}

img{

    width:100%;

    display:block;

}

/* ==========================================================
BUTTON
========================================================== */

.btn{

    display:inline-block;

    padding:18px 38px;

    margin-top:40px;

    border-radius:50px;

    text-decoration:none;

    background:#D6A24A;

    color:white;

    font-weight:600;

    transition:.35s;

    letter-spacing:.5px;

}

.btn:hover{

    background:#B68633;
}

/* ==========================================================
HERO
========================================================== */

#hero{

    position:relative;

    height:100vh;

    display:flex;

    align-items:center;

    justify-content:center;

    overflow:hidden;

}

/* Background Image */

#hero::before{

    content:"";

    position:absolute;

    inset:0;

    background:url("assets/hero.jpg") center center/cover no-repeat;

    filter:brightness(1.05) contrast(.92) saturate(.95);

    z-index:-3;

}

/* Overlay */

.hero-overlay{

    position:absolute;

    inset:0;

    background:linear-gradient(
        rgba(245,248,250,.55),
        rgba(248,242,230,.35),
        rgba(248,246,242,.75)
    );

    z-index:-2;


}

/* Hero Content */

.hero-content{

    width:min(900px,90%);

    text-align:center;

}

.eyebrow{

        display:inline-block;

    padding:10px 24px;

    margin-bottom:20px;

    border-radius:40px;

    background:rgba(255,255,255,.75);

    color:#8B6D3B;

    border:1px solid rgba(214,162,74,.35);

    backdrop-filter:blur(10px);

    font-size:15px;

    font-weight:500;


}

#hero h1{
 color:#2C241B;

    text-shadow:none;

}

#hero p{

   color:#4E4E4E;

    max-width:720px;

    margin:auto;

    font-size:20px;

}

/* Scroll */

.scroll-indicator{

        position:absolute;

    bottom:35px;

    left:50%;

    transform:translateX(-50%);

    color:#7B6B52;

    font-size:15px;

    opacity:.8;

}



/* ==========================================
RISING SUN
========================================== */

.sun{

position:absolute;

width:180px;

height:180px;

border-radius:50%;

left:50%;

bottom:-120px;

transform:translateX(-50%);

background:radial-gradient(circle,#FFD56A,#F6B93B,#F29F05);

box-shadow:

0 0 80px rgba(255,210,90,.6),

0 0 150px rgba(255,180,0,.35);

z-index:-1;

transition:transform .15s linear;

}

/* Warm Glow */



/* ==========================================================
SECTION TITLE
========================================================== */

blockquote{

    width:min(800px,90%);

    margin:50px auto;

    text-align:center;

    font-size:34px;

    font-family:'Cormorant Garamond',serif;

    color:#8b6d3b;

    font-style:italic;

}

/* ==========================================================
CARD
========================================================== */

.card{

    background:white;

    border-radius:20px;

    padding:35px;

    box-shadow:0 20px 50px rgba(0,0,0,.06);

    transition:.35s;

}

.card:hover{

    transform:translateY(-10px);

}

.card ul{

    margin-top:20px;

    padding-left:18px;

}

.card li{

    margin-bottom:12px;

}

/* ==========================================================
GRID
========================================================== */

.benefit-grid{

    display:grid;

    grid-template-columns:repeat(2,1fr);

    gap:35px;

    margin-top:70px;

}

.support-grid{

    display:grid;

    grid-template-columns:repeat(3,1fr);

    gap:25px;

    margin-top:60px;

}

.support-card{

    background:white;

    border-radius:18px;

    padding:40px 30px;

    text-align:center;

    font-size:22px;

    box-shadow:0 15px 40px rgba(0,0,0,.05);

    transition:.35s;

}

.support-card:hover{

    transform:translateY(-8px);

}

/* ==========================================================
RESPONSIVE
========================================================== */

@media(max-width:992px){

h1{

font-size:54px;

}

h2{

font-size:42px;

}

.support-grid{

grid-template-columns:repeat(2,1fr);

}

}

@media(max-width:768px){

#hero{

height:auto;

padding:140px 0;

}

h1{

font-size:42px;

}

h2{

font-size:36px;

}

.benefit-grid{

grid-template-columns:1fr;

}

.support-grid{

grid-template-columns:1fr;

}

.btn{

  background:#C99843;

}

blockquote{

font-size:28px;

}

}
/* ==========================================================
JOURNEY SECTION
========================================================== */

#journey{

    background:#FDFBF8;

}

#journey p{

    max-width:820px;

    margin:0 auto 70px;

    text-align:center;

}

.timeline{

    position:relative;

    width:100%;

    max-width:950px;

    margin:auto;

}

.timeline::before{

    content:"";

    position:absolute;

    left:50%;

    top:0;

    width:3px;

    height:100%;

    background:#D6A24A;

    transform:translateX(-50%);

}

.step{

    position:relative;

    width:45%;

    background:white;

    padding:35px;

    border-radius:20px;

    margin-bottom:50px;

    box-shadow:0 20px 45px rgba(0,0,0,.06);

}

.step:nth-child(odd){

    margin-right:auto;

}

.step:nth-child(even){

    margin-left:auto;

}

.step::after{

    content:"";

    position:absolute;

    top:45px;

    width:22px;

    height:22px;

    border-radius:50%;

    background:#D6A24A;

    border:5px solid #FDFBF8;

}

.step:nth-child(odd)::after{

    right:-55px;

}

.step:nth-child(even)::after{

    left:-55px;

}

/* ==========================================================
ABOUT SECTION
========================================================== */

/* ==========================================================
ABOUT SECTION
========================================================== */

#about{
    background: #ffffff;
    padding: 120px 0;
}

.about-wrapper{
    display: grid;
    grid-template-columns: 420px 1fr;
    gap: 80px;
    align-items: center;
}

/* ==========================
IMAGE / VIDEO
========================== */

.about-image img,
.about-image video{
    width: 100%;
    display: block;
    border-radius: 24px;
    box-shadow: 0 20px 50px rgba(0,0,0,0.12);
    object-fit: cover;
}

/* ==========================
CONTENT
========================== */

.about-content{
    max-width: 700px;
}

.section-tag{
    display: inline-block;
    background: #F6EFE2;
    color: #9C6B1F;
    padding: 8px 18px;
    border-radius: 30px;
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 20px;
}

.about-content h2{
    text-align: left;
    margin-bottom: 25px;
    font-size: 52px;
    line-height: 1.1;
}

.about-content p{
    font-size: 18px;
    line-height: 1.9;
    color: #555;
    margin-bottom: 20px;
}

/* ==========================
QUOTE
========================== */

.about-content blockquote{
    margin: 35px 0;
    padding-left: 25px;
    border-left: 4px solid #D6A24A;
    font-size: 30px;
    font-family: "Cormorant Garamond", serif;
    font-style: italic;
    color: #8B6D3B;
    text-align: left;
}

/* ==========================
VISION BOX
========================== */

.mission-box{
    background: #FCF8F2;
    border-left: 5px solid #D6A24A;
    padding: 25px;
    border-radius: 16px;
    margin: 35px 0;
}

.mission-box h4{
    margin-bottom: 12px;
    font-size: 24px;
}

.mission-box p{
    margin: 0;
    font-size: 17px;
    line-height: 1.8;
}

/* ==========================
SIGNATURE
========================== */

.signature{
    margin-top: 40px;
}

.signature p{
    font-size: 20px;
    font-weight: 500;
    color: #8B6D3B;
    margin-bottom: 10px;
}

.signature h3{
    font-size: 30px;
    font-family: "Cormorant Garamond", serif;
    color: #2E2E2E;
    margin: 0;
}

/* ==========================
RESPONSIVE
========================== */

@media (max-width: 992px){

    .about-wrapper{
        grid-template-columns: 1fr;
        gap: 50px;
    }

    .about-image{
        max-width: 500px;
        margin: 0 auto;
    }

    .about-content{
        text-align: center;
        margin: 0 auto;
    }

    .about-content h2{
        text-align: center;
        font-size: 42px;
    }

    .about-content blockquote{
        text-align: center;
        border-left: none;
        border-top: 4px solid #D6A24A;
        padding: 20px 0 0;
    }

}

@media (max-width: 768px){

    #about{
        padding: 80px 0;
    }

    .about-wrapper{
        gap: 35px;
    }

    .about-content h2{
        font-size: 34px;
    }

    .about-content p{
        font-size: 16px;
    }

    .about-content blockquote{
        font-size: 24px;
    }

    .mission-box{
        padding: 20px;
    }

}

/* ==========================================================
TESTIMONIALS
========================================================== */

/* ==========================================================
TESTIMONIALS
========================================================== */

#testimonials{

    background:#fff;

}

.testimonial-intro{

    text-align:center;

    max-width:700px;

    margin:0 auto 70px;

}

.testimonial-grid{

    display:grid;

    grid-template-columns:repeat(2,1fr);

    gap:35px;

}

.testimonial-card{

    background:#FDFBF8;

    padding:35px;

    border-radius:22px;

    box-shadow:0 15px 35px rgba(0,0,0,.06);

    transition:.35s;

    position:relative;

}

.testimonial-card:hover{

    transform:translateY(-8px);

}

.quote{

    font-size:55px;

    color:#D6A24A;

    line-height:1;

    margin-bottom:15px;

}

.testimonial-card h3{

    font-size:28px;

    margin-bottom:18px;

}

.testimonial-card p{

    line-height:1.8;

    margin-bottom:30px;

}

.testimonial-footer{

    border-top:1px solid #e5e5e5;

    padding-top:20px;

}

.testimonial-footer h4{

    margin-bottom:5px;

    font-size:22px;

}

.testimonial-footer span{

    color:#888;

    font-size:15px;

}

@media(max-width:768px){

.testimonial-grid{

grid-template-columns:1fr;

}

}
/* ==========================================================
FAQ
========================================================== */

/* ==========================================================
FAQ
========================================================== */

#faq{

    background:#F8F6F2;

}

.faq-intro{

    text-align:center;

    max-width:650px;

    margin:0 auto 60px;

}

.faq-container{

    max-width:850px;

    margin:auto;

}

.faq-item{

    background:white;

    border-radius:18px;

    margin-bottom:18px;

    box-shadow:0 10px 25px rgba(0,0,0,.05);

    overflow:hidden;

}

.faq-question{

    width:100%;

    background:none;

    border:none;

    padding:25px 30px;

    display:flex;

    justify-content:space-between;

    align-items:center;

    cursor:pointer;

    font-size:18px;

    font-weight:600;

    text-align:left;

}

.faq-question span{

    font-size:28px;

    transition:.3s;

}

.faq-answer{

    max-height:0;

    overflow:hidden;

    transition:max-height .4s ease;

    padding:0 30px;

}

.faq-answer p{

    margin:18px 0;

}

.faq-answer ul{

    margin:15px 0 20px;

    padding-left:20px;

}

.faq-answer li{

    margin-bottom:10px;

}

.faq-item.active .faq-answer{

    max-height:500px;

}

.faq-item.active .faq-question span{

    transform:rotate(45deg);

}

@media(max-width:768px){

.faq-question{

font-size:16px;

padding:20px;

}

.faq-answer{

padding:0 20px;

}

}

/* ==========================================================
CTA
========================================================== */

/* ==========================================================
CTA
========================================================== */

#cta{

position:relative;

overflow:hidden;

}

#cta::before{

content:"";

position:absolute;

width:700px;

height:700px;

border-radius:50%;

left:50%;

top:50%;

transform:translate(-50%,-50%);

background:radial-gradient(

rgba(255,214,106,.28),

transparent 70%

);

animation:pulseGlow 6s infinite;

}

@keyframes pulseGlow{

0%{

transform:translate(-50%,-50%) scale(.9);

opacity:.4;

}

50%{

transform:translate(-50%,-50%) scale(1.1);

opacity:.8;

}

100%{

transform:translate(-50%,-50%) scale(.9);

opacity:.4;

}

}

#cta{

    position:relative;

    padding:180px 20px;

    background:url("assets/sunrise.jpg") center/cover no-repeat;

    overflow:hidden;

}

.cta-overlay{

    position:absolute;

    inset:0;

    background:rgba(25,20,15,.55);

    backdrop-filter:blur(2px);

}

.cta-content{

    position:relative;

    z-index:2;

    max-width:850px;

    margin:auto;

    text-align:center;

    color:white;

}

.cta-icon{

    font-size:60px;

    margin-bottom:25px;

}

.cta-content h2{

    color:white;

    font-size:64px;

    margin-bottom:25px;

}

.cta-content p{

    color:rgba(255,255,255,.92);

    font-size:22px;

    line-height:1.8;

    max-width:720px;

    margin:0 auto;

}

.cta-sub{

    margin-top:20px;

    font-size:18px !important;

    opacity:.92;

}

.cta-btn{

    margin-top:50px;

    padding:20px 55px;

    font-size:18px;

    border-radius:50px;

    box-shadow:0 15px 40px rgba(0,0,0,.25);

}

.cta-features{

    display:flex;

    justify-content:center;

    gap:35px;

    margin-top:40px;

    flex-wrap:wrap;

}

.cta-features span{

    background:rgba(255,255,255,.15);

    backdrop-filter:blur(15px);

    padding:10px 20px;

    border-radius:40px;

    color:white;

    font-size:15px;

}

@media(max-width:768px){

#cta{

padding:120px 20px;

}

.cta-content h2{

font-size:42px;

}

.cta-content p{

font-size:18px;

}

.cta-features{

flex-direction:column;

gap:15px;

align-items:center;

}

}

/* ==========================================================
FOOTER
========================================================== */

/* ==========================================================
FOOTER
========================================================== */

#footer{

    background:#2A241D;

    color:#EDE8DF;

    padding:90px 20px 40px;

}

.footer-content{

    max-width:850px;

    margin:auto;

    text-align:center;

}

.footer-content h2{

    color:white;

    font-size:42px;

    margin-bottom:15px;

}

.footer-tagline{

    color:#D9D3CA;

    font-size:18px;

    line-height:1.8;

    max-width:650px;

    margin:0 auto 35px;

}

.footer-divider{

    width:90px;

    height:3px;

    background:#D6A24A;

    margin:40px auto;

    border-radius:10px;

}

.footer-links{

    display:flex;

    justify-content:center;

    gap:35px;

    flex-wrap:wrap;

    margin-bottom:50px;

}

.footer-links a{

    color:#EDE8DF;

    text-decoration:none;

    font-size:16px;

    transition:.3s;

}

.footer-links a:hover{

    color:#D6A24A;

}

.footer-quote{

    margin:40px 0;

}

.footer-quote p{

    color:#EDE8DF;

    font-size:22px;

    font-family:"Cormorant Garamond",serif;

    font-style:italic;

    margin-top:10px;

}

.footer-bottom{

    margin-top:50px;

    border-top:1px solid rgba(255,255,255,.08);

    padding-top:25px;

}

.footer-bottom p{

    font-size:14px;

    color:#AAA39A;

}

@media(max-width:768px){

.footer-content h2{

font-size:34px;

}

.footer-links{

gap:18px;

}

.footer-tagline{

font-size:16px;

}

.footer-quote p{

font-size:20px;

}

}

/* ==========================================================
SCROLL REVEAL
========================================================== */

.reveal{

    opacity:0;

    transform:translateY(70px);

    transition:1s ease;

}

.reveal.active{

    opacity:1;

    transform:translateY(0);

}

/* ==========================================================
RESPONSIVE
========================================================== */

@media(max-width:992px){

.about-wrapper{

grid-template-columns:1fr;

text-align:center;

}

.about-content h2{

text-align:center;

}

.timeline::before{

left:25px;

}

.step{

width:calc(100% - 70px);

margin-left:70px !important;

}

.step::after{

left:-55px !important;

right:auto;

}

}

@media(max-width:768px){

.testimonial{

min-width:300px;

}

.faq-question{

font-size:17px;

padding:20px;

}

.faq-answer{

padding:0 20px;

}

#cta{

padding:120px 20px;

}

footer{

padding:60px 20px;

}

}
/* Progress */

#progress-bar{

position:fixed;

top:0;

left:0;

height:4px;

background:#D6A24A;

width:0;

z-index:9999;

}


/* Top Button */

#topBtn{

position:fixed;

bottom:35px;

right:35px;

width:55px;

height:55px;

border:none;

border-radius:50%;

background:#D6A24A;

color:white;

font-size:22px;

cursor:pointer;

opacity:0;

transition:.35s;

transform:translateY(30px);

box-shadow:0 15px 30px rgba(0,0,0,.15);

}

#topBtn.show{

opacity:1;

transform:translateY(0);

}


/* Ripple */

.btn{

overflow:hidden;

position:relative;

}

.ripple{

position:absolute;

border-radius:50%;

background:rgba(255,255,255,.4);

transform:scale(0);

animation:ripple .6s linear;

}

@keyframes ripple{

to{

transform:scale(4);

opacity:0;

}

}









