/*-- -------------------------- -->
<---          Landing           -->
<--- -------------------------- -*/

#hero {
    background-color: var(--backgroundYellow);
    color: var(--primaryGray);
    padding: clamp(3.75em, 7.82vw, 6.25em) clamp(1rem, 1.5vw, 2rem);
    position: relative;
}

.circle-graphic-1, .circle-graphic-3 {
    position: absolute;
    display: none;
}

.circle-graphic-1 {
    right: -10px;
    bottom: -70px;
}

.circle-graphic-3 {
    top: -110px;
    left: -105px;
}

.hero-content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin: auto;
    gap: 3rem;
    max-width: 1300px;
}

.hero-text {
    display: flex;
    flex-direction: column;
    align-items: center;
    max-width: 550px;
    position: relative;
}

#hero h1 {
    line-height: 3rem;
    margin-bottom: 1.75rem;
    text-align: center;
}
#hero .cs-text {
    color: var(--primaryGray);
    text-align: center;
    opacity: 1;
}

#hero p {
    line-height: 34px;
    font-size: 20px;
    margin-bottom: 2rem;
}

.youtube-video {
    aspect-ratio: 16 / 9;
    width: 100%;
    max-width: 600px;
    box-shadow: rgba(149, 157, 165, 0.2) 0px 8px 24px;
}

#hero .two-buttons {
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
    flex-shrink: 0;
    gap: 1rem;
}

@media screen and (min-width: 1024px) {
    #hero {
        padding-top: 32px;
    }

    #hero .two-buttons {
        flex-direction: row;
        z-index: 5;
    }
    .clip-path {
        clip-path: polygon(100% 13%, 100% 81%, 0 68%, 0 32%);
        background: #E6F2F2;
        width: 100%;
        height: 40rem;
        position: absolute;
        bottom: -30rem;
        left: 0;
        z-index: 0;
    }

    .clip-path-top {
        clip-path: polygon(100% 0, 100% 10%, 0 100%, 0 0);
        background: var(--backgroundYellow);
        width: 100%;
        height: 5rem;
        position: absolute;
        bottom: -4.75rem;
        left: 0;
        z-index: 0;
    }
    
    
    .hero-content {
        flex-direction: row;
        gap: clamp(60px, 4vw, 125px);
    }

    #hero h1 {
        line-height: 67px;
        margin-bottom: 1.75rem;
        text-align: start;
    }

    #hero .cs-text {
        text-align: start;
    }
    .hero-text {
        align-items: start;
    }

    .circle-graphic-1, .circle-graphic-3 {
        position: absolute;
        display: block;
    }


}


/*-- -------------------------- -->
<---          WHO           -->
<--- -------------------------- -*/
#who .cs-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    z-index: 1;
}

#who .cs-container {
    display: flex;
    flex-direction: column;
    align-items: center;
}

#who .cs-ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
}

.bullets {
    display: flex;
    flex-direction: column;
}
.who-icon {
    width: 61px;
    height: 61px;
    margin: auto;
    margin-top: 1.5rem;
    margin-bottom: 1rem;
    border-radius: 50%;
    background-color: #ECAA12;
    display: flex;
    justify-content: center;
    align-items: center;
    align-self: start;
    flex-shrink: 0;
}

.who-item .cs-h3 {
    color: inherit; 
    opacity: 0.8
}

.who-icon-1 {
    background-color: var(--primaryGreen);
}
.who-icon-2 {
    background-color: var(--primaryOrange);
}
.who-icon-3 {
    background-color: #ECAA12;
}


.cs-images {
    margin-top: 3rem;
    width: 355px;
    height: 376px;
    position: relative;
}

.who-img {
    border: 10.24px solid #fff;
    filter: drop-shadow(0px 4px 25px rgba(0,0,0,0.25));
    border-radius: 10px;
    box-sizing: content-box;
    object-fit: cover;
}

#top-left-who {
    position: absolute;
    top: 0;
    left: 0;
}
#bottom-right-who {
    position: absolute;
    bottom: 0px;
    right: 0px;
    
}

#bird {
    position: absolute;
    z-index: 2;
    right: 37px;
    top: 35px;
    right: 0px;
    top: 0px;
}

#bee {
    position: absolute;
    z-index: 2;
    left: -77px;
    bottom: 68px;
}
@media screen and (min-width: 1024px) {
    #who .cs-container {
        flex-direction: row;
        justify-content: space-evenly;
        gap: clamp(2rem, 4vw, 4rem);
    }

    #who .cs-content {
        order: 2;
        max-width: 500px;
        text-align: start;
        align-items: start;
    }

    .who-img {
        border-width: 15px;
        z-index: 1;
        position: relative;
        width: 269px;
        height: 297px;
    }

    .cs-images {
        width: 519px;
        height: 549px;
    }

    #bird {
        right: 37px;
        top: 35px;
    }
    .bullets {
        flex-direction: row;
    }

    .who-icon {
        margin-top: 0.5rem;
        margin-right: 0.75rem;
    }
    
    .who-item {
        margin-bottom: 1.5rem;
    }
    .who-item .cs-h3 {
        margin-bottom: 0.75rem;
    }
    .who-item .cs-text {
        line-height: 1rem;
    }
}

@media screen and (min-width: 1300px) {
    #who .cs-content {
        max-width: 700px;
    }
}
/*-- -------------------------- -->
<---      CURRICULUM           -->
<--- -------------------------- -*/


#curriculum {
    background: #02B890;
}

#curriculum .cs-title {
    color: #fff;
}
#curriculum .cs-text {
    color: #fff;
    opacity: 1;
}

#curriculum .cs-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.cs-img-content {
    display: none;
}

#curriculum .cs-picture {
    box-sizing: content-box;
}

#top-left {
    box-sizing: content-box;
}

.dotted-circle {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 0;
}

#candy-cane {
    position: absolute;
    right: -23px;
    top: 18px;
}

#beach-ball {
    position: absolute;
    left: -15px;
    bottom: 77px;
}

#curriculum #top-left {
    object-fit: cover;
}

@media screen and (min-width: 1024px) {

    #slant-section-curriculum-top{
        height: 100px;
        background: var(--primaryGreen);
        clip-path: polygon(0% 100%, 100% 0%, 100% 100%);
        margin-bottom: -1px;
    }


    #curriculum .cs-container {
        display: flex;
        justify-content: space-evenly;
        align-items: center;
    }

    #curriculum .cs-content {
        text-align: start;
        align-items: start;
        max-width: 530px;
        
    }
    .cs-img-content {
        position: relative;
        width: 427px;
        height: 427px;
        display: block;
    }

    #curriculum #top-left {
        position: absolute;
        top: 8px;
        left: -6px;
        border: 15px solid #fff;
        border-radius: 10px;
        filter: drop-shadow(0px 4px 25px rgba(0,0,0,0.25));
        transform: rotate(4.12deg);
        z-index: 3;
    }

    #curriculum #bottom-right {
        position: absolute;
        bottom: 0px;
        right: 28px;
        border: 15px solid #fff;
        border-radius: 10px;
        filter: drop-shadow(0px 4px 25px rgba(0,0,0,0.25));
        transform: rotate(-8.38deg);
        z-index: 3;
    }

}


@media screen and (min-width: 1300px) {

    #curriculum .cs-content {
        max-width: 600px;
    }

}

/*-- -------------------------- -->
<---      SPANISH               -->
<--- -------------------------- -*/

#spanish .cs-content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;

}

#spanish {
    position: relative;
    z-index: 1;
    background-color: var(--primaryOrange);

}

#spanish .image-container {
    position: relative;
}
#spanish .child-in-tunnel {
    border: 10.76px solid #fff;
    filter: drop-shadow(0px 2.86px 17.93px rgba(0,0,0,0.25));
    border-radius: 7.13px;
    box-sizing: content-box;
    object-fit: cover;   
}

#bottom-right-edge {
    position: absolute;
    bottom: -16px;
    right: -21px;
}

#circle-graphic-small-green {
    position: absolute;
    top: -30px;
    left: -35px;
}

#spanish .cs-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(2rem, 4vw, 4rem);
    position: relative;
}

#circle-graphic-small-orange {
    position: absolute;
    top: -50px;
    left: -115px;
}

#spanish .cs-title {
    color: #fff;
}
#spanish .cs-text {
    color: #fff;
    opacity: 1;
}
#int-hero:before {
    content: '';
    position: absolute;
    height: 100%;
    width: 100%;
    background: #ff3c11;
    opacity: .7;
    top: 0;
    left: 0;
    z-index: 0;
}
.background-picture {
    position: absolute;
    height: 100%;
    width: 100%;
    top: 0;
    left: 0;
    z-index: -1;
}
.background-img {
    position: absolute; 
    height: 100%;
    width: 100%;
    top: 0;
    left: 0;
    object-fit: cover;
    opacity: 0.3;
}

@media screen and (min-width: 1024px) {


    #spanish .cs-container {
        flex-direction: row;
    }

    #spanish .image-container {
        order: 2;
    }

    #spanish .cs-content {
        text-align: start;
        align-items: start;
    }
    #bottom-right-edge {
        bottom: -13px;
        right: -17px;
    }

    .child-in-tunnel {
        width: 400px;
        height: 346.96px;
    }
}


/*-- -------------------------- -->
<---      SUMMER CAMP           -->
<--- -------------------------- -*/

#summer {
    background-color: var(--backgroundYellow);
}

#summer .cs-container {
    display: flex;
    flex-direction: column;
    gap: clamp(2rem, 4vw, 4rem);
    align-items: center;
    justify-content: center;
    text-align: center;
    margin: auto;
}

#summer .cs-content {
    max-width: 600px;
}

#summer .container-for-branch {
    position: relative;
}

#summer #tree-branch {
    position: absolute;
    top: -70px;
    right: -55px;
    display: none;
    transform: matrix(-0.87, 0.5, 0.5, 0.87, 0, 0);
    z-index: 1;
}
#summer .child-animals {
    width: 100%;
    max-width: 475px;
    height: auto;
    border: 10.76px solid #fff;
    filter: drop-shadow(0px 2.86px 17.93px rgba(0,0,0,0.25));
    border-radius: 7.13px;
}

#summer .cs-picture {
    z-index: 2;
    position: relative;
}



@media screen and (min-width: 1024px) {

    #summer #tree-branch {
        display: inline;
    }

    #slant-section-summer-camp-bottom{
        height: 100px;
        background: var(--backgroundYellow);
        clip-path: polygon(0 100%, 0 0, 100% 0);
        margin-top: -1px;
    }
    #summer .cs-container {
        flex-direction: row;
        text-align: start;
    }
}



/*-- -------------------------- -->
<---        Discover        -->
<--- -------------------------- -*/

.discover-bg-color {
    background-color: #e6f2f2;
}

#discover {
    background-color: #e6f2f2;
}

#discover .cs-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 1rem;
}
#discover .cs-content {
    max-width: 500px;
}

#discover .discover-cards {
    display: flex;
    flex-direction: column;
    gap: clamp(1rem, 1.75vw, 2rem);
}

#discover .discover-top, .discover-bottom {
    display: flex;
    flex-direction: column;
    gap: clamp(1rem, 1.75vw, 2rem);
}

#discover .activity {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 1rem;
}

#discover .activity .content {
    max-width: 240px;
}


#discover .activity span {
    font-size: 1.25rem;
    color: var(--headingText)
}   

#discover .activity picture {
    display: block;
    height: 230px;
    width: 230px;
    margin: auto;
}
#discover .discover-img img {
    
    height: 100%;
    width: 100%;
    border: 10.76px solid #fff;
    filter: drop-shadow(0px 2.86px 17.93px rgba(0,0,0,0.25));
    border-radius: 7.13px;
}

@media screen and (min-width: 750px) {

    #discover .discover-cards {
        flex-direction: row;
    }

}

@media screen and (min-width: 1024px) {

    #discover .discover-top, .discover-bottom {
        flex-direction: row;
    }
    #discover .activity span {
        font-size: 1.5rem;
    }

    #discover .activity .cs-text {
        line-height: 22px;
    }
}

@media screen and (min-width: 1250px) {
    #discover .activity picture {
        height: 275px;
        width: 275px;
    }

}
/*-- -------------------------- -->
<---        FOOD                -->
<--- -------------------------- -*/
.slant-food {
    background: #FAF5E6;
}


#food {
    background-color: #FAF5E6;
    position: relative;
}


#food .cs-container {
    display: flex;
    flex-direction: column;
    gap: clamp(2rem, 4vw, 4rem);
    align-items: center;
    justify-content: center;
    text-align: center;
    margin: auto;
    position: relative;
    z-index: 1;
}

#food .cs-content {
    max-width: 600px;
    position: relative;
}


#food .cs-picture {
    width: 90%;
    max-width: 340px;
    display: block;
}

#food .child-behind-tree {
    width: 100%;
    height: auto;
    border: 10.76px solid #fff;
    filter: drop-shadow(0px 2.86px 17.93px rgba(0,0,0,0.25));
    border-radius: 7.13px;
}

#food #sun, #circle-graphic-small-orange-2, #rocket {
    position: absolute;
    display: none;

}

#food .picture-container {
    display: flex;
    justify-content: center;
    position: relative;
}

@media screen and (min-width: 480px) {
    #food #rocket {
        display: inline;
        top: 40px;
        left: -80px;
    }
}


@media screen and (min-width: 570px) {
    #food #sun {
        display: inline;
    }
    
    #food #sun {
        height: 30%;
        top: -50px;
        right: 0;
    }
}


@media screen and (min-width: 1024px) {

    #food .cs-container {
        flex-direction: row;
        text-align: start;
    }

    #food #sun, #circle-graphic-small-orange-2, #rocket {
        display: inline;
    }

    #food #sun {
        height: auto;
    }

    #food #circle-graphic-small-orange-2 {
        bottom: -80px;
        left: -50px;
    }
    
}


/*-- -------------------------- -->
<---      GALLERY               -->
<--- -------------------------- -*/

#gallery .cs-title{
    text-align: center;
    padding-bottom: 20px;
}

#gallery .img-container .cs-title{
    margin-top: 10px;
    font-size: clamp(1.5rem, 2.5vw, 2rem);
}

.gallery {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

.scroll-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(255, 255, 255, 0.7); /* semi-transparent white */
    border: none;
    font-size: 2em;
    color: var(--primaryOrange); /* change arrow color */
    width: 50px; /* adjust as needed */
    height: 50px; /* adjust as needed */
    border-radius: 50%; /* makes the button circular */
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 1;
}

#prev {
    left: 15px; /* adjust as needed */
}

#next {
    right: 15px; /* adjust as needed */
}

#gallery-container {
    display: flex;
    overflow-x: scroll;
    scroll-snap-type: x mandatory;
    width: 100%;
    -ms-overflow-style: none;  /* for Internet Explorer and Edge */
    scrollbar-width: none;  /* for Firefox */
}

#gallery-container::-webkit-scrollbar {
    display: none; /* for Chrome, Safari and Opera */
}

.gallery-images {
    width: 297px;  /* set your preferred width */
    height: 291px; /* set your preferred height */
    object-fit: cover; /* this will make sure the image covers the whole area of the img tag */
}

/*-- -------------------------- -->
<---            FAQ           -->
<--- -------------------------- -*/

#faq {
    background-color: #F0BB41;
    position: relative;
}

#faq .cs-container {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    
}
#faq .cs-faq-group {
    padding: 0;
    margin: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    gap: 1rem;
    max-width: 1100px;
}
#faq .cs-faq-item {
list-style: none;
width: 100%;
border-bottom: 1px solid #E8E8E8;
transition: border-bottom 0.3s;
background-color: #fff;
border-radius: 4px;
}
#faq .cs-faq-item.active {
/* border-color: var(--primaryOrange); */
}
#faq .cs-faq-item.active .cs-button {
/* color: var(--primaryOrange); */
}
#faq .cs-faq-item.active .cs-button:before {
background-color: var(--primaryOrange);
transform: rotate(315deg);
}
#faq .cs-faq-item.active .cs-button:after {
background-color: var(--primaryOrange);
transform: rotate(-315deg);
}
#faq .cs-faq-item.active .cs-item-p {
height: auto;
/* 20px - 24px bottom */
/* 16px - 24px left & right */
padding: 0 clamp(1rem, 2vw, 1.5rem) clamp(1.25rem, 1.3vw, 1.5rem);
opacity: 0.6;
}
#faq .cs-button {
font-size: 1rem;
line-height: 1.2em;
text-align: left;
font-weight: bold;
/* 16px - 20px */
padding: clamp(1rem, 1.3vw, 1.25rem);
border: none;
background: transparent;
color: var(--bodyText);
opacity: 1;
display: block;
width: 100%;
position: relative;
transition: background-color 0.3s, color 0.3s;
}
#faq .cs-button:hover {
cursor: pointer;
}
#faq .cs-button:before {
/* left line */
content: '';
width: 0.5rem;
height: 0.125rem;
background-color: var(--bodyText);
opacity: 1;
border-radius: 50%;
position: absolute;
display: block;
top: 45%;
right: 1.5rem;
transform: rotate(45deg);
/* animate the transform from the left side of the x axis, and the center of the y */
transform-origin: left center;
transition: transform .5s;
}
#faq .cs-button:after {
/* right line */
content: '';
width: 0.5rem;
height: 0.125rem;
background-color: var(--bodyText);
opacity: 1;
border-radius: 50%;
position: absolute;
display: block;
top: 45%;
right: 1.3125rem;
transform: rotate(-45deg);
/* animate the transform from the right side of the x axis, and the center of the y */
transform-origin: right center;
transition: transform .5s;
}
#faq .cs-button-text {
    width: 90%;
    display: block;
    font-size: clamp(1rem, 1.5vw, 1.25rem);
}
#faq .cs-item-p {
/* 14px - 16px */
/* font-size: clamp(0.875rem, 1.5vw, 1rem); */
font-size: clamp(1rem, 1.5vw, 1.25rem);
line-height: 1.5em;
width: 90%;
height: 0;
margin: 0;
/* 16px - 24px */
padding: 0 clamp(1rem, 2vw, 1.5rem);
opacity: 0;
color: var(--bodyTextColor);
/* clips the text so it doesn't show up */
overflow: hidden;
transition: opacity 0.3s, padding-bottom 0.3s;
transition: opacity 0.5s, padding-bottom 0.5s;
}

#faq #tree-branch-flipped {
    display: none;
    position: absolute;
    top: -100px;
    left: 0;
    transform: scaleX(-1);
    z-index: 0;
    
}
  @media screen and (min-width: 1024px) {

    #faq #tree-branch-flipped {
        display: inline;
        
    }
    #faq .cs-title {
        margin-bottom: 2rem;
    }

    .slant-section-top-faq {
        height: 100px;
        clip-path: polygon(0 0, 0 100%, 100% 100%);
        margin-bottom: -1px;
        background: #F0BB41;;
    }

    .slant-section-bottom-faq{
        height: 100px;
        clip-path: polygon(0 0, 100% 100%, 100% 0);
        margin-top: -1px;
        background: #F0BB41;
    }

}

/*-- -------------------------- -->
<---      Reviews           -->
<--- -------------------------- -*/

#reviews .cs-title {
    text-align: center;
    padding-bottom: 20px;
}
  
.reviews-container {
display: flex;
flex-direction: column;
align-items: center;
gap: 20px;
margin-top: 40px;
}


.review-item {
width: 357px;
height: 327px;
background: #FFFFFF;
box-shadow: 0px 4px 25px rgba(0, 0, 0, 0.25);
border-radius: 10px;
position: relative; 
padding: 38px;
}

.review-info {
display: flex;
align-items: center;
margin-bottom: 15px;
}

.parent-avatar {
width: 60px;
height: 60px;
border-radius: 50%;
margin-right: 15px;
}

.review-text {
font-size: 16px;
margin-bottom: 10px;
}

.rating {
position: absolute;
bottom: 20px;
left: 38px;
display: flex;
align-items: center;
font-size: 20px;
font-weight: bold;
}

.rating-value {
font-family: 'Amaranth';
font-style: normal;
font-weight: 400;
font-size: 18px;
line-height: 24px;
display: flex;
align-items: center;
color: #FFB717;
opacity: 0.5;
margin-right: 5px;
}

.rating-stars {
    width: 100px; /* Adjust the width to your desired size */
    height: auto; /* Adjust the height proportionally */
  }
  

@media screen and (min-width: 1024px) {

    .reviews-container {
        flex-direction: row;
        display: flex;
        justify-content: space-between;
        margin-top: 40px;
      }

}


/*-- -------------------------- -->
<---      CTA-section           -->
<--- -------------------------- -*/

#CTA-section {
    background: #FE5D37;
}

#CTA-section .cs-text{
    opacity: 0.8;

}

#CTA-section .child-in-tunnel {
    object-fit: cover;
}


.slant-CTA {
    background: #FE5D37;
}


  




