h1, h2, h3, h4, h5, h6 {
    font-family: 'Heebo'!important;
}

.w-75-100 {
	width: 100% !important;
}

/* Container padding to make room for external arrows */
.event-carousel {
    padding: 0 60px; 
}

.navbar-light {
    background-color: #FFF5F3 !important;
}

/*.contact-bubble {
    background-color: rgb(220 53 69) !important;
}*/

/* Make images larger and uniform */
.event-carousel .event-item img {
    height: 300px; /* Set a fixed height to make them look larger */
    object-fit: cover;
    border-radius: 15px;
}

/* Fix Overlapping Arrows */
.event-carousel .owl-nav .owl-prev,
.event-carousel .owl-nav .owl-next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 50px;
    height: 50px;
    background: rgb(220 53 69) !important;
    color: #ffffff !important;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 100;
}


#gallery-tabs .nav-link.active {
    background: rgb(220 53 69) !important;
}

.testimonial-carousel .owl-nav .owl-prev, .testimonial-carousel .owl-nav .owl-next {
    background: rgb(220 53 69) !important;
}

.about-img img:hover{
    background: rgb(220 53 69) !important;
}



.tab-btn.active, .tab-btn:hover {
    background: rgb(220 53 69) !important;
    color: #fff;
}
.testimonial-card .quote {
    color: rgb(220 53 69) !important;
}

.timing-section .section-title::after {
    background: rgb(220 53 69) !important;
}


/* Move arrows away from the images */
.event-carousel .owl-nav .owl-prev {
    left: 0px; 
}

.event-carousel .owl-nav .owl-next {
    right: 0px;
}

/* Style the navigation dots */
.event-carousel .owl-dots {
    margin-top: 25px;
}

.event-carousel .owl-dot.active span {
    background: #FE5D37 !important;
    width: 25px;
}

.contact-bubble {
    position: fixed;
    bottom: 20px;
    right: 20px;
    /*background-color: rgb(55, 167, 157) !important;*/
    background-color: rgb(220 53 69) !important;
    color: white;
    border-radius: 50%;
    width: 55px;
    height: 55px;
    display: flex;
    justify-content: center;
    align-items: center;
    text-decoration: none;
    z-index: 1000;
    box-shadow: 0 4px 10px rgba(0,0,0,0.2);
    transition: background-color 0.3s ease;
  }

  .contact-bubble:hover {
    background-color: #0056b3;
  }

  .contact-bubble img {
    width: 28px;
    height: 28px;
  }

  @media (max-width: 600px) {
    .contact-bubble {
      width: 48px;
      height: 48px;
    }

    .contact-bubble img {
      width: 24px;
      height: 24px;
    }
  }

  /*contact*/
 .whatsapp-float {   
  position: fixed;
  bottom: 90px;
  right: 20px;
  z-index: 1000;
  background-color: #25d366;
  padding: 12px;
  border-radius: 50%;
  box-shadow: 0 2px 10px rgba(0,0,0,0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.2s ease-in-out;
}
.whatsapp-float:hover {
  transform: scale(1.1);
}
.whatsapp-float img {
  width: 32px;
  height: 32px;
}

.preschool-logo {
	width: 15%;
}

.navbar-brand {
    width: 41%;
}


.patronage {
   width: 30% !important;
}

.rounded-circle {
    border-radius: 20% !important;
}


.team-item .team-text {
    position: absolute;
    width: 180px !important;
    height: 180px !important;
}


.teacher-text {
    text-align: center;
}

.teacher-home {
    text-align: center;
}


.classes-section {
    padding: 60px 0;
    /*font-family: 'Poppins', sans-serif;*/
    background-color: #fcfcfc;
}

.section-header {
    text-align: center;
    max-width: 800px;
    margin: 0 auto 50px auto;
}

.section-header h2 {
    color: #1e3a8a;
    /*font-size: 36px;*/
    margin-bottom: 10px;
}

.tagline {
    color: #FE5D37;
    font-weight: 600;
    font-size: 20px;
    margin-bottom: 20px;
}

.classes-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    justify-content: center;
}

.class-card {
    background: #fff;
    padding: 30px;
    border-radius: 20px;
    width: calc(33.33% - 20px);
    text-align: center;
    box-shadow: 0 10px 30px rgba(0,0,0,0.05);
    transition: transform 0.3s ease;
    border-bottom: 5px solid #ddd;
}

.class-card:hover {
    transform: translateY(-10px);
}

.class-icon {
    font-size: 50px;
    margin-bottom: 15px;
}

.age-badge {
    display: inline-block;
    padding: 5px 15px;
    border-radius: 50px;
    font-size: 14px;
    font-weight: 700;
    color: #fff;
    margin-bottom: 15px;
}

/* Group Colors matching preschool themes */
.color-1 { border-color: #3b82f6; } .color-1 .age-badge { background: #3b82f6; }
.color-2 { border-color: #10b981; } .color-2 .age-badge { background: #10b981; }
.color-3 { border-color: #f59e0b; } .color-3 .age-badge { background: #f59e0b; }
.color-4 { border-color: #ec4899; } .color-4 .age-badge { background: #ec4899; }
.color-5 { border-color: #8b5cf6; } .color-5 .age-badge { background: #8b5cf6; }

.admission-banner {
    /*margin-top: 60px;*/
    /*background: #1e3a8a;*/
    /*color: white;*/
    padding: 40px;
    border-radius: 25px;
    text-align: center;
}

.btn-enroll {
    display: inline-block;
    margin-top: 20px;
    /*background: #FE5D37;*/
    background: rgb(220 53 69);
    color: white;
    padding: 12px 35px;
    border-radius: 50px;
    text-decoration: none;
    font-weight: bold;
    transition: background 0.3s;
}

.btn-primary {
    color: #000;
    background-color: rgb(220 53 69) !important;
    border-color: rgb(220 53 69) !important;
}


.text-primary {
    color: rgb(220 53 69) !important;
}

.tagline {
    color: rgb(220 53 69) !important;
}

.btn-enroll:hover {
    background: #FE5D37;
    color: #ffffff;
}

/* Responsive Fixes */
@media (max-width: 992px) {
    .class-card { width: calc(50% - 20px); }
}
@media (max-width: 600px) {
    .class-card { width: 100%; }
}

.team-text {
    color: #f9cfc7 !important;
}

.yellow {
    border-color: #f59e0b !important;
}

.pink {
    border-color: #ec4899 !important;
}

.blue {
    border-color: #8b5cf6 !important;
}

.banner-text-box{
/*background: rgba(220, 53, 69, 0.65); /* light transparent red */
background: rgb(220 53 69 / 30%);
padding: 20px;
border-radius: 12px;
backdrop-filter: blur(4px);
max-width: 600px;
}

.banner-text-box h1{
font-size: 42px;
font-weight: 700;
line-height: 1.2;
}

.banner-text-box p{
font-size: 16px;
}

/* mobile */
@media (max-width:768px){

.banner-text-box{
/*padding:20px;*/
margin-top: 30%;
}

.banner-text-box h1{
font-size:26px;
}

}

/*curriculum card*/
.classes-grid{
display:flex;
justify-content:space-between;
gap:20px;
flex-wrap:nowrap;
}

.class-card{
flex:1;
min-width:180px;
background:#fff;
border-radius:12px;
padding:25px 15px;
text-align:center;
box-shadow:0 8px 20px rgba(0,0,0,0.08);
transition:0.3s;
}

.class-card:hover{
transform:translateY(-6px);
box-shadow:0 12px 25px rgba(0,0,0,0.15);
}

.class-icon{
font-size:36px;
}

.age-badge{
display:inline-block;
background:#ff6b6b;
color:white;
padding:4px 10px;
border-radius:20px;
font-size:13px;
margin-bottom:10px;
}

/* Mobile responsive */
@media (max-width:991px){

.classes-grid{
flex-wrap:wrap;
justify-content:center;
}

.class-card{
flex:0 0 45%;
margin-bottom:20px;
}

}

@media (max-width:576px){

.class-card{
flex:0 0 100%;
}

}

.navbar .navbar-nav .nav-link:hover, .navbar .navbar-nav .nav-link.active {
    color: rgb(220 53 69) !important;
}

/* GRID FIX - FORCE ONE ROW */
.timing-grid{
    display:flex;
    justify-content:center;
    gap:25px;
    flex-wrap:nowrap; /* prevents second row */
    max-width:1400px;
    margin:auto;
}

/* CARD WIDTH */
.batch-card{
    flex:1;
    min-width:220px;
}


/* =========================
   TESTIMONIAL SECTION
========================= */

.testimonial-section{
    background:#f5f7fc;
    overflow:hidden;
}

.testimonial-carousel{
    padding:10px 5px;
}

/* CARD */
.testimonial-card{
    background:#fff;
    border-radius:24px;
    padding:28px 22px;
    text-align:center;
    box-shadow:0 8px 25px rgba(0,0,0,0.06);

    /* SAME SIZE */
    height:320px;

    display:flex;
    flex-direction:column;
    justify-content:flex-start;
    align-items:center;

    transition:0.3s ease;
    margin:10px;
}

.testimonial-card:hover{
    transform:translateY(-5px);
}

/* QUOTE */
.testimonial-card .quote{
    font-size:52px;
    line-height:1;
    color:#e63946;
    font-weight:700;
    margin-bottom:14px;
}

/* TEXT */
.testimonial-card p{
    font-size:15px;
    line-height:1.7;
    color:#555;

    /* FIX LONG TEXT */
    overflow:hidden;
    display:-webkit-box;
    -webkit-line-clamp:6;
    -webkit-box-orient:vertical;

    margin-bottom:18px;
}

/* NAME */
.testimonial-card h5{
    margin-top:auto;
    font-size:18px;
    font-weight:700;
    color:#333;
}

/* OWL NAV */
.testimonial-carousel .owl-nav{
    margin-top:25px;
    text-align:center;
}

.testimonial-carousel .owl-nav button{
    width:48px;
    height:48px;
    border-radius:50% !important;
    background:#e63946 !important;
    color:#fff !important;
    font-size:22px !important;
    margin:0 8px;
    transition:0.3s ease;
}

.testimonial-carousel .owl-nav button:hover{
    background:#111 !important;
}

/* DESKTOP */
@media(min-width:992px){

    .testimonial-card{
        height:300px;
    }

    .testimonial-card p{
        font-size:14px;
        -webkit-line-clamp:5;
    }
}

/* TABLET */
@media(max-width:991px){

    .testimonial-card{
        height:290px;
        padding:24px 18px;
    }

    .testimonial-card p{
        font-size:14px;
        line-height:1.6;
        -webkit-line-clamp:5;
    }

    .testimonial-card h5{
        font-size:16px;
    }
}

/* MOBILE */
@media(max-width:767px){

    .testimonial-section{
        padding:50px 0;
    }

    .testimonial-card{
        height:auto;
        min-height:260px;
        padding:22px 16px;
        border-radius:18px;
        margin:6px;
    }

    .testimonial-card .quote{
        font-size:42px;
        margin-bottom:10px;
    }

    .testimonial-card p{
        font-size:13px;
        line-height:1.6;

        /* SMALLER TEXT ON MOBILE */
        -webkit-line-clamp:6;
    }

    .testimonial-card h5{
        font-size:15px;
    }

    .testimonial-carousel .owl-nav button{
        width:42px;
        height:42px;
        font-size:18px !important;
    }
}


@media (max-width: 768px) {
    .header-carousel .owl-carousel-item h1 {
        font-size: 20px !important;
        font-weight: 600;
    }
}