
.rts-course-details-area{
    position: relative;
    overflow: hidden;
}

.rts-course-details-area .shape-image{
    position:absolute;
    inset:0;
    pointer-events:none;
    z-index:0;
}

.rts-course-details-area .container{
    position:relative;
    z-index:5;
}

.rts-course-details-area .shape.one{
    top:180px;
    left:180px;
}

.rts-course-details-area .shape.two{
    top:230px;
    right:220px;
}

.rts-course-details-area .shape.three{
    top:520px;
    left:220px;
}

.rts-course-details-area .shape.six{
    top:420px;
    right:150px;
}
.rts-course-details-area .shape.seven{
    top:620px;
    right:140px;
}

.joy-interaction-hint,
.joy-kit-hint{
    font-size:1.4rem;
    font-weight:700;
    text-align:center;
    color:#555;
    margin-bottom:15px;
    animation:pulseHint 2s infinite;
}

.joy-kit-hint{
    margin-top:15px;
}

.descripcion-special-kit {
     margin-top:20px;
    padding:12px 16px;
    border-radius:12px;
    background:#fff6e6;
    font-size:1.4rem;
    line-height:1.4;
    color:#555;
}

.descripcion-special-kit P {
    font-size:1.2rem;
    font-weight:700;
    text-align:center;
    color:#555;
    margin-bottom:15px;
}
.special-kit-hidden{
    display:none !important;
}
@keyframes pulseHint{
    0%,100%{transform:scale(1);}
    50%{transform:scale(1.05);}
}

@media (max-width: 1024px) {
    .rts-course-details-area .shape-image {
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
    }
}

@media (max-width: 768px) {
    .rts-course-details-area .shape-image {
        display: none;
    }
}

.joy-experiencia-wrapper{
    display:flex;
    align-items:center;
    gap:50px;
}
.joy-aula-img{
    flex:0 0 55%;
    position:relative;
}

.joy-aula-img .video-btn-area{
    position:absolute;
    top:50%;
    left:50%;
    transform:translate(-50%, -50%);
    z-index:10;
}

.joy-experiencia-info{
    flex:1;
}

.joy-aula-img img{
    width:100%;
    box-shadow:6px 7px 5px #0000003b;
    border-radius:20px;
}

.joy-experiencia-banner{
    text-align:center;
    margin-bottom:25px;
}

.joy-experiencia-banner img{
    width:70%;
    max-width:520px;
    height:auto;
    display:block;
    margin:auto;
} 


.joy-experiencia-subtitle{
    margin-bottom:30px;
    font-size:2.6rem;
    line-height:1.3;
    font-weight:900;
}

.joy-experiencia-subtitle .subrayado-2{
    display:inline-block;
}

.joy-experiencia-info{
    flex:1;
} 

.joy-experiencia-title{
    font-size:4rem;
    line-height:0.95;
    font-weight:900;
    margin-bottom:20px;
}

.joy-card div{
    display:flex;
    flex-direction:column;
}

.joy-card p{
    margin:8px 0 0;
    font-size:1.4rem;
    line-height:1.4;
    font-weight:500;
    color:#fff;
}

.joy-presencial-box{
    background:#ff74a7;
    box-shadow:6px 7px 6px #00000052;
    border: 3px solid #fff;
    border-radius:20px;
    text-align:center;
    padding:15px;
    font-size:3.5rem;
    font-weight:900;
    margin-bottom:20px;
}
.joy-online-box{
    background:#74f6ff;
    box-shadow:6px 7px 6px #00000052;
    border: 3px solid #fff;
    border-radius:20px;
    text-align:center;
    padding:15px;
    font-size:3.5rem;
    font-weight:900;
    margin-bottom:20px;
}
.joy-ventajas-section{
    position: relative;
    margin-top:10px;
}

.joy-ventajas-title{
    position:absolute;
    top:-20px;
    left:60px;
    background:#ffb03a;
    border: 3px solid #fff;
    box-shadow:6px 7px 6px #00000052;

    padding:25px 40px;
    font-size:4rem;
    font-weight:900;
    border-radius:15px;
    z-index:10;
}

.joy-ventajas-container{
    background:#47d5df47;
    padding: 90px 180px 70px;
    display:flex;
    align-items: flex-end;
    justify-content:space-between;
    gap:100px;
}

.joy-cards{
    flex:1;
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:20px;
}

.joy-card{
    height: 180px;
    border: 3px solid #fff;
    border-radius:20px;
    display:flex;
    align-items:center;
    gap:25px;
    padding:25px 30px;
    color:#fff;
    box-shadow:3px 7px 6px #0000005b;
    transition:.25s ease;
    cursor:pointer;
}

.joy-card span {
    font-size: 2.4rem;
    font-weight: 900;
    line-height: 1.2;
}

.joy-card i{
    font-size:4rem;
    flex-shrink:0;
    color:#fff;
    opacity:.95;
}

.joy-card:hover{
    transform:translateY(-6px);
    box-shadow:3px 14px 6px #00000036;
}

.joy-card.pink{
    background:#fe2491;
}

.joy-card.purple{
    background:#47d5df;
}

.joy-card.yellow{
    background:#ff7300;
}

.joy-card.blue{
    background:#4BCF61;
}

.joy-girl{
    flex:0 0 350px;
    transform: scale(1.5);
    transform-origin: bottom center;
    margin-bottom: -40px;
}

.joy-girl img{
    width:100%;
    max-width: 800px;
    height: auto;
    display: block;
}

.joy-planes-section{
    position:relative;
    overflow:hidden;

    padding:100px 0;
    background:#fff;
}

.joy-grid-bg{
    position:absolute;
    inset:0;
    background:url('../../images/banner/bg-grid.png');
    background-repeat:repeat;
    background-size:cover;
    z-index:0;
}

.joy-planes-title, 
.joy-planes-wrapper {
    position: relative;
    z-index: 2;
    text-align:center;
    font-size:4rem;
    font-weight:900;
    margin-bottom:60px;
}

.joy-planes-wrapper{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:80px;
        width: 1600px;
    max-width: 95%;
    margin: auto;
}

.joy-selector-box{
    width:440px;
}

.joy-selector-header{
    background:#ff74a7;
    border: 3px solid #fff;
    box-shadow:6px 6px 6px #cf09092c;
    padding:20px;
    border-radius: 15px;
    text-align:center;
    font-weight:900;
    font-size: 2.5rem;
}

.joy-selector-content{
    border: 3px solid #fff;
    box-shadow:6px 7px 6px #00000052;
    border-radius:20px;
    padding:35px;
    margin-top:40px;
    background: #fff;
}

.joy-selector-content h4 {
    font-size: 3rem;
    font-weight: 900;
    line-height: 1.1;
    margin-bottom: 25px;
}
.joy-selector-content p {
    font-size: 1.4rem;
}

.joy-selector-content select{
    width:100%;
    height:45px;
    border: 3px solid #fff;
    box-shadow:6px 7px 6px #00000052;
    border-radius: 25px;
    background:#eab74e;
    font-size:2.3rem;
    font-weight:700;
    padding: 0px 15px 0px 20px;
    margin-bottom: 7%;
}

.joy-plan-card{
    width:380px;
    height:520px;
    background:linear-gradient(
        180deg,
        #73d7ef,
        #4cb9d2
    );
    border: 3px solid #fff;
    box-shadow:7px 7px 6px #00000042;
    border-radius:150px 150px 0 0;
    display:flex;
    justify-content:center;
    align-items:center;
}

.joy-plan-image{
    transform-origin: bottom center;
    margin-bottom: 30px;
    max-width: 85%;
    width: none;
    display: block;

    transition: opacity .30s ease, transform .30s ease;
}

.joy-plan-image.fade{
    opacity: 0;
    transform:  scale(.95);
}

.joy-plan-card ul {
    margin-top: 40px;
}

.joy-plan-card li {
    font-size: 2rem;
    margin-bottom: 20px;
    font-weight: 700;
}


.joy-extra-card{
    /* width:330px; */
    min-height:150px;
    background:#fff;

    border:3px solid #fff;
    border-radius:20px;
    padding:20px;
    position:relative;
    box-shadow:5px 5px 10px rgba(0,0,0,.12);
}


.joy-extras{
    width:340px;
}

.joy-kit-card{
    width:100%;
    min-height:530px;

    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
}

.joy-kit-hint.hidden{
    opacity:0;
    visibility:hidden;
}

.joy-kit-card .box-wrapper{
    margin-top:30px;
}

.joy-kit-card .items-area{
    margin-top:0px;
}

.joy-extra-body{
    margin-top:35px;
    font-size:1.6rem;
    line-height:1.4;
    text-align:center;
    font-weight:700;
}


.joy-toggle{
    position:relative;
    display:flex;
    width:180px;
    height:55px;
    margin:0 auto 50px;
    border: 3px solid #fff;
    box-shadow:6px 7px 6px #00000052;
    border-radius:50px;
    background:#fff;
    overflow:hidden;
    
}

.joy-toggle-slider{
    position:absolute;
    top:4px;
    left:4px;
    width:calc(50% - 4px);
    height:calc(100% - 8px);
    background:#5d7cff;
    border-radius:40px;
    transition:.3s ease;
    z-index:1;
}

.toggle-option{
    flex:1;
    border:none;
    background:none;
    font-size:1.6rem;
    font-weight:900;
    cursor:pointer;
    position:relative;
    z-index:2;
    color:#000;
}

.toggle-option.active{
    color:#fff;
}

#studentsSection {
    overflow: hidden;
}

.joy-students-section{
    margin-top:40px;
    margin-bottom:30px;
}

.joy-students-header{
    text-align:center;
    margin-bottom:40px;
}

.joy-students-header h3{
    font-size:2.5rem;
    font-weight:800;
}

.joy-students-header p{
    font-size: 2.5rem;
    margin-top:10px;
    opacity:.8;
}

.joyStudentsSwiper{
    overflow:hidden;
    padding:20px 0;
}

.joy-student-card{
    width: 70%;

    margin: 0px;
    position: relative;
    border-radius:240px;
    overflow:visible;
    box-shadow:0 10px 30px rgba(0,0,0,.12);
    transition:.3s ease;
}

.joy-student-card:hover{
    transform:translateY(-8px);
}

.joy-student-card img{
    width:100%;
    aspect-ratio:1/1;

    display:block;
    
}

.swiper-slide {
    display: flex;
    justify-content: center;
}

.joyTestimonialsSwiper {
    width: 1200px;
    max-width: 90%;
    margin: auto;
    padding: 20px 20px;
}

.joyTestimonialsSwiper .swiper-slide {
    display: flex;
    justify-content: center;
}

.joy-testimonials-section{
    padding:100px 0 60px;
}

.joy-testimonials-header{
    text-align:center;
    margin-bottom:60px;
}

.joy-testimonials-header h2{
    font-size:4rem;
    font-weight:900;
}

.joy-testimonials-header p{
    font-size:2rem;
    opacity:.8;
}

.joy-testimonial-card{
    overflow:hidden;
    background:#fff;
    border-radius:25px;
    box-shadow:0 8px 20px rgba(0,0,0,.15);
}

.joy-testimonial-image{
    height:240px;
}

.joy-testimonial-image img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}

.joy-testimonial-content{
    padding:25px;
}

.joy-testimonial-content p{
    font-size:1.4rem;
    line-height:1.6;
    font-style:italic;
    margin-bottom:20px;
}

.joy-author{
    display:flex;
    align-items:center;
    gap:10px;
    margin-top:15px;
    font-weight:800;
}

.joy-author img{
    width:24px;
    height:24px;
    object-fit:contain;
}

.joy-testimonial-card:hover{
    transform:translateY(-8px);
}


.pink-border{
    border:4px solid #fe2491;
}

.blue-border{
    border:4px solid #5dd1ff;
}

.orange-border{
    border:4px solid #ffb03a;
}

.joy-stars{
    list-style: none;
    margin: 0 0 0 20px 0;
    display:flex;
    gap:5px;

    margin-bottom:5px;
    justify-content: flex-start;
}

.joy-stars i {
    color: #ffb03a;
}

.joy-testimonial-card p{
    font-size:1.4rem;
    line-height:1.6;
    margin-bottom:25px;
    font-style: italic;
}

.joy-testimonial-card p::before{
    content: '"';
}

.joy-testimonial-card p::after{
    content: '"';
}

.joy-testimonial-card h4{
    font-size:2rem;
    font-weight:900;
    margin-bottom:5px;
    justify-content: left;
}

.joy-author {
    text-align: right;
    margin-top: auto;
}
@media (max-width: 1400px){

    .joy-ventajas-container{
        padding: 80px 100px 60px;
        gap: 40px;
    }

    .joy-girl{
        flex: 0 0 280px;
        transform: scale(1.7);
        margin-bottom: -30px;
        margin-left: 20px;
    }

    .joy-card{
        height: auto;
        min-height: 160px;
    }

    .joy-card span{
        font-size: 2rem;
    }

    .joy-card p{
        font-size: 1.3rem;
    }
}

    .joy-experiencia-wrapper{
        flex-direction:column-reverse;
        gap:30px;
    }

    .joy-aula-img{
        flex:none;
        width:100%;
    }

    .joy-experiencia-info{
        width:100%;
    }

    .joy-experiencia-title{
        font-size:5rem;
        text-align:center;
    }

    .joy-presencial-box{
        font-size:3rem;
    }

    .joy-info{
        text-align:center;
        font-size:1.8rem;
    }


@media (max-width:1024px){

    .joy-ventajas-container{
        flex-direction:column;
        align-items:center;
        gap:40px;
        padding:80px 40px 40px;
    }

    .joy-cards{
        width:100%;
        grid-template-columns:repeat(2,1fr);
    }

    .joy-girl{
        flex:none;
        width:460px;

        transform:none;
        margin-bottom:0;
    }
}


@media (max-width:1024px){

    .joy-planes-wrapper{
        width:95%;

        display:grid;
        grid-template-columns:1fr 1fr;
        gap:40px;
        align-items:start;
    }

    .joy-selector-box{
        width:100%;
    }

    .joy-plan-principal{
        width:100%;
        display:flex;
        flex-direction:column;
        align-items:center;
    }

    .joy-plan-card{
        width:280px;
        height:400px;
    }

    .joy-plan-image{
        max-width:95%;
    }

    .joy-extras{
        grid-column:1 / span 2;

        display:flex;
        justify-content:center;
    }

    .joy-extra-card{
        /* width:280px; */
        min-height:120px;
    }

    .joy-plus{
        font-size:4rem;
        margin:0;
    }

    .joy-kit-card{
        min-height: auto;
    }

    .items-area.kit-horizontal {
        display: grid;
        grid-template-columns: repeat(2,1fr);
        gap: 20px;
    }

    .joy-card{
        flex-direction: column;
        justify-content: center;
        text-align: center;
        gap: 15px;
        padding: 20px;
    }

    .joy-card div{
        align-items: center;
    }

    .joy-card i{
        font-size: 3.5rem;
    }

    .joy-card span{
        font-size: 2rem;
    }

    .joy-card p{
        font-size: 1.2rem;
        margin-top: 0;
    }
    .special-kit-hidden{
    display:none !important;
}
}

@media (max-width:1024px){

    .joy-selector-header{
        font-size:2rem;
    }

    .joy-selector-content h4{
        font-size:2.4rem;
    }

    .joy-selector-content select{
        font-size:1.5rem;
    }

    .joy-selector-content p{
        font-size:1.2rem;
    }

    .joy-extra-title{
        font-size:1.4rem;
    }

    .joy-extra-body{
        font-size:1.3rem;
    }
}

@media (max-width:575px){
    .joy-ventajas-title{
        position:absolute;
        top:-40px;
        left:60px;
        background:#ffb03a;
        border: 3px solid #fff;
        box-shadow:6px 7px 6px #00000052;

        padding:25px 40px;
        font-size:2.8rem;
        font-weight:900;
        border-radius:15px;
        z-index:10;
    }
    .joy-planes-title{
        max-width: 90%;
        margin-left:auto;
        margin-right:auto;
    }
    
    .joy-experiencia-banner img{
        max-width:320px;
    } 

    .joy-planes-wrapper{
        display:flex;
        flex-direction:column;
        align-items:center;
        gap:60px;
    }

    .joy-selector-box,
    .joy-plan-principal,
    .joy-extras{
        width:100%;
    }

    .joy-selector-content h4{
        font-size:2.8rem;
        line-height:1.2;
    }

    .joy-extras{
        flex-direction:column;
        gap:25px;
    }

    .joy-extra-card{
        width:100%;
        max-width:320px;
    }

    .joy-plus{
        display:block;
        font-size: 4rem;
        margin: 10px;
    }

    .joy-planes-title{
        font-size:3.5rem;
        line-height:1.1;
        padding:0 20px;
    }

    .joy-cards{
        grid-template-columns:1fr;
    }

    .joy-card{
        flex-direction:column;
        justify-content:center;
        text-align:center;
        gap:15px;
        padding:25px 20px;
    }

    .joy-card div{
        align-items:center;
    }

    .joy-card i{
        font-size:3.5rem;
        margin-bottom:5px;
    }

    .joy-card span{
        font-size:2rem;
    }

    .joy-card p{
        font-size:1.4rem;
        margin-top:0;
    }
    .joy-selector-box{
        width:100%;
    }

    .joy-plan-card{
        width:100%;
        max-width:280px;
    }

    .joy-ventajas-title{
        left:0;
        right:0;
        margin:auto;
        width:90%;
        text-align:center;
    }

    .joy-ventajas-container{
        padding:80px 20px 40px;
    }

    .joy-students-header p{
        font-size: 1.8rem;
        margin-top:10px;
        opacity:.8;
    }

    .joy-experiencia-title{
        font-size:3.5rem;
        text-align:center;
    }
        .joy-selector-content p{
        font-size:1.5rem;
    }
    .joy-plan-image{
        max-width:94%;
    }

    .joy-students-section{
    margin-top:0px;
    margin-bottom:10px;
}

}