body.loading {
    overflow: hidden;
}

.scroll-anchor {
    display: block;
    height: 70px; /* equal to sticky header height */
    margin-top: -70px;
    visibility: hidden;
}

/* Fullscreen loader */
#loader {
    position: fixed !important;
    inset: 0 !important;
    background: rgba(255, 255, 255, 0.9) !important; /* test with white */
    z-index: 9999999 !important;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Simple spinner */
.spinner {
    width: 40px;
    height: 40px;
    border: 4px solid #961e24;
    border-top-color: #961e24;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* Page fade-in animation */
/* body.loaded {
    opacity: 1;
    transition: opacity .4s ease-in;
}

body.loading {
    opacity: 0;
} */

#page {
    opacity: 0;
    transition: opacity 0.4s ease-in;
}

body.loaded #page {
    opacity: 1;
}

.header .header-container {
    background: var(--surface-color);
    border-radius: 50px;
    padding: 12px 25px;
    box-shadow: 0px 2px 15px rgba(0, 0, 0, 0.1);
}

.service-sublist{
    display: none;
}

/* h2 a{
    color: var(--heading-color);
}

h2 a:hover{
    color: color-mix(in srgb, var(--accent-color), transparent 0%);
    text-decoration: none;
    transition: color 0.3s ease;
} */


.infra_image_01, .infra_image_02, .infra_image_03, .infra_image_04{
    margin: 0 15px 15px 15px; width: 400px;
    display: block;
}


.hero-about{
    padding-bottom: 0;
} 


.bred_c_a{
    margin-top: -44px;
    margin-bottom: 61px;
}


.bred_c_a .breadcrumb-item, .bred_c_a .breadcrumb-item.active {
    color: #921a23 !important;
    font-size: 14px;
}


.bg-primary {
    --bs-bg-opacity: 1;
    background-color: #921a23 !important;
}


.bred_c_a.breadcrumb-item+.breadcrumb-item::before {
    float: left;
    padding-right: var(--bs-breadcrumb-item-padding-x);
    color: #921a23 !important;
    content: var(--bs-breadcrumb-divider, "/");
}

.rounded-5{
    display: none;
}


.about-description a{
    font-weight: 300;
}

.bottom_m_100{
    margin-bottom: 200px;
}

.font-weight-400{
    font-weight: 400;
} 

.margin-top-30{
    margin-top: 100px;
}


.header .logo img {
    max-height: 70px;
    margin-right: 8px;
}

.red_txt{
    color: color-mix(in srgb, var(--accent-color), transparent 0%);
}


.about .about-title {
    font-size: 2.5rem;
    margin-bottom: 1rem;
    line-height: 1.2;
    font-weight: 400;
}

.hero-content p{
    font-size: 20px;
    font-weight: 300;
}

.about-description{
    font-size: 18px;
    font-weight: 300;
}

.bi-check-circle-fill::before {
    content: "\f26a";
    color: var(--accent-color);
    font-size: 1.25rem;
}


.features-cards .feature-box p {
    font-size: 17px;
    margin-bottom: 0;
    font-weight: 300;
}


.social-links a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1px solid #fff;
    font-size: 16px; 
    color: 
color-mix(in srgb, var(--default-color), transparent 20%);
    margin-right: 10px;
    transition: 0.3s;
}


.footer .copyright {
    padding: 25px 0;
    border-top: 0px solid 
color-mix(in srgb, var(--default-color), transparent 90%);
}

.desc{
    font-size: 19px;
    font-weight: 300;
}

.tec_desc{
    font-size: 16px !important; 
    font-weight: 300;
}


.features-2 .feature-item .feature-icon i {
    font-size: 33px;
    color: var(--accent-color);
}

.hero .stat-item .stat-icon i {
    font-size: 2rem;
    color: var(--accent-color);
}

.error {
    color: #ef8080;
    font-size: 13px;
}

.success_input {
    border-color: #c4f0c4 !important;
    color: #6c757d !important;
    background: #e2f9e2 !important;
}

.error_input {
    border-color: #f6c4c4 !important;
    color: red !important;
    background: #ffeded !important;
}


.contact .info-item .icon-box i {
  font-size: 1.1rem;
}

.contact .info-item .icon-box {
  width: 2.5rem;
  height:2.5rem;  
}

.info-item{
    border-bottom: 1px solid #ffffff;
}

.info-box{
    background: url(../img/v2/bottom_Ima_01.png) center center no-repeat; 
    background-size: cover; padding: 15px 50px;
}


.boxservice_background{
    background: url(../img/v2/Base_01.jpg) center center no-repeat; 
    background-size: cover; padding: 40px 50px;
    min-height: 400px;
}

.background_hero{
    border-bottom: 0px solid #faf4f4;
    background: url(../img/v2/Banner_Image_02.png) center center no-repeat; 
    background-size: cover;
}


.about-hero-header {
    margin-top: -75px;
    background: url(../img/v2/banne_About_01.png) center center no-repeat;
    background-size: cover;
}

.about_h1{
    margin-top: 51px;
}

.breadcrumb-item.active {
    color: #ffffff !important;
}

.accordion-button{
    color: #fff;
    background: #921a23;
}

.accordion-button::after {
    color: #fff;
}

.accordion-button::after {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23ffffff'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
  }

  .accordion-button:not(.collapsed)::after {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23ffffff'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
    transform: rotate(-180deg);
  }

  .accordion-button:not(.collapsed) {
    color: var(--bs-accordion-active-color) !important;
    background-color: var(--bs-accordion-active-bg) !important;
    box-shadow: inset 0 calc(-1 * var(--bs-accordion-border-width)) 0 var(--bs-accordion-border-color);
}

.accordion-button:not(.collapsed) {
    color: var(--bs-accordion-active-color) !important;
    background-color: var(--bs-accordion-active-bg) !important;
    box-shadow: inset 0 calc(-1 * var(--bs-accordion-border-width)) 0 var(--bs-accordion-border-color);
}


/* .breadcrumb-item+.breadcrumb-item::before {
    float: left;
    padding-right: var(--bs-breadcrumb-item-padding-x);
    color: #ffffff;
    content: var(--bs-breadcrumb-divider, "/");
} */






  
  /* 
    ##Device = Most of the Smartphones Mobiles (Portrait)
    ##Screen = B/w 320px to 479px
  */
  
  @media (min-width: 320px) and (max-width: 480px) {
    
    /* CSS */

    .infra_image_01, .infra_image_02, .infra_image_03, .infra_image_04{
        margin: 0 15px 15px 0px;
        width: 98%;
    }


    .infra_image_03{
        display: none;
    }

    .margin-top-30{
        margin-top: 0;
    }

    .bottom_m_100{
        margin-bottom: 50px;
    }

    .hero .hero-content h1 {
        font-size: 1.6rem;
    }

    .hero-content p {
        font-size: 16px;
        font-weight: 300;
    }

    .desc {
        font-size: 15px;
        font-weight: 300;
    }

    .boxservice_background {    
        padding: 40px 20px;
    }

    .boxservice_background container{
        padding: 0px;
    }

    .about .about-title {
        font-size: 1.5rem;
        margin-top: 49px;
    }

    .about .about-description {
        margin-bottom: 0.5rem;
    }


    .about .about-description a{
        display: inline-block;
        margin-left: 3px;
        color: var(--accent-color);
    }

    .footer{
        padding: 10px;
    }


    .about .image-wrapper {
        padding-left: 0;
        margin-top: 1rem;
    }    

    .services .service-card .icon {
        width: 37px;
        height: 38px;
        margin-right: 12px;
    }

    .services .service-card h3 {
        font-size: 19px;
    }

    .services .service-card {
        padding: 15px;
    }

    .paddRight{
        padding-right: 0px;
    }
    
    .pad-lft{
        padding-left: 5px;
        margin-top: 11px;
    }

    .btn-pad-lft{
        padding-left: 5px;
        text-align: center;
    }

    .mrgn-m{
        margin-left: 5px;
    }

    .mrgntp-m{
        margin-top: 55px;
        padding-left: 28px;
    }

    .mrgimbottom{
        margin-bottom: 35px;
    }

    .hero-txt{
        margin-top: 46px;
        padding-left: 36px;
        color: #ffffff;
    }

    .hero-txt h1{       
        color: #ffffff;
    }

    .about_m {
        margin-top: 0;
        margin-bottom: 0;
    }

    .section-title h2 {
        font-size: 25px;
        font-weight: 700;
    }  
    
    .navmenu ul {        
        inset: 60px 20px 110px 20px !important;       
    }
    .mission_v{
        margin-bottom: 25px;
    }

    .pad-lft-about{
        padding-left: 16px;
        margin-top: 11px;
    }

    
  }


  /* 
    ##Device = Low Resolution Tablets, Mobiles (Landscape)
    ##Screen = B/w 481px to 767px
  */
  
  @media (min-width: 481px) and (max-width: 767px) {
    
    /* CSS */

    .rounded-5{
        display: block;
    }

    .infra_image_01{
        margin: 0 15px 15px 15px; width: 98%;
    }

    .margin-top-30{
        margin-top: 0;
    }

    .bottom_m_100{
        margin-bottom: 50px;
    }

    .hero .hero-content h1 {
        font-size: 1.6rem;
    }

    .hero-content p {
        font-size: 17px;
        font-weight: 300;
    }

    .boxservice_background{
        background-color: #961E24;
    }

    .paddRight{
        padding-right: 0px;
    }

    .pad-lft{
        padding-left: 8px;
        margin-top: 11px;
    }

    .btn-pad-lft{
        padding-left: 8px;
        text-align: center;
    }

    .mrgn-m{
        margin-left: 8px;
    }

    .mrgntp-m{
        margin-top: 55px;
        padding-left: 28px;
    }

    .mrgimbottom{
        margin-bottom: 35px;
    }

    .hero-txt{
        margin-top: 46px;
        padding-left: 36px;
        color: #ffffff;
    }

    .hero-txt h1{       
        color: #ffffff;
    }


    .about_m {
        margin-top: 0;
        margin-bottom: 0;
    }

    .section-title h2 {
        font-size: 25px;
        font-weight: 700;
    } 

    .navmenu ul {        
        inset: 60px 20px 110px 20px;       
    }

    .mission_v{
        margin-bottom: 25px;
    }

    .pad-lft-about{
        padding-left: 16px;
        margin-top: 11px;
    }

  }

/*
    Small (sm)


*/



/*
    Medium (md)
*/
@media only screen and (min-width: 768px) {

    
    .bottom_m_100{
        margin-bottom: 50px;
    }

    .pad-lft{
        padding-left: 8px;
    }

    .btn-pad-lft{
        padding-left: 8px;
        text-align: left;
    }
    
    .mrgn-m{
        margin-left: 8px;
    }

    .mrgimbottom{
        margin-bottom: 60px;
    }

    .hero-txt{
        margin-top: 46px;
        padding-left: 36px;
        color: #ffffff;
    }

    .hero-txt h1{       
        color: #ffffff;
    }

    .about_m {
        margin-top: 0;
        margin-bottom: 0;
    }


    .section-title h2 {
        font-size: 25px;
        font-weight: 700;
    } 

    /* .navmenu ul {        
        inset: 60px 20px 110px 20px ;       
    } */

    .mission_v{
        margin-bottom: 25px;
    }

    .pad-lft-about{
        padding-left: 16px;
        margin-top: 11px;
    }

}


/*
    Large (lg)
*/
@media only screen and (min-width: 992px) {

    .pad-lft{
        padding-left: 8px;
    }
    .btn-pad-lft{
        padding-left: 8px;
        text-align: left;
    }

    .mrgn-m{
        margin-left: 8px;
    }

    .mrgimbottom{
        margin-bottom: 160px;
    }

    .hero-txt{
        margin-top: 0;
        padding-left: 0;
        color: #ffffff;
    }

    .hero-txt h1{       
        color: #ffffff;
    }

    .about_m {
        margin-top: 0px;
        margin-bottom: 0px;
    }

    .section-title h2 {
        font-size: 32px;
        font-weight: 700;
    } 

    /* .navmenu ul {        
        inset: 60px 20px 110px 20px !important;       
    } */

    .mission_v{
        margin-bottom: 25px;
    }

    .pad-lft-about{
        padding-left: 16px;
        margin-top: 11px;
    }
}


@media (max-width: 991px) {
  nav[aria-label="breadcrumb"] {
    display: none;
  }
}


/*
    Extra-large (xl)
*/
@media only screen and (min-width: 1200px) {
    .pad-lft{
        padding-left: 57px;
    }
    .btn-pad-lft{
        padding-left: 57px;
        text-align: left;
    }

    .mrgn-m{
        margin-left: 0px;
    }

    .mrgimbottom{
        margin-bottom: 160px;
    }

    .hero-txt{
        margin-top: 0;
        padding-left: 0;
        color: #ffffff;
    }

    .hero-txt h1{       
        color: #ffffff;
    }


    .about_m {
        margin-top: 0px;
        margin-bottom: 0px;
    }


    .section-title h2 {
        font-size: 32px;
        font-weight: 700;
    } 

    .mission_v{
        margin-bottom: 25px;
    }

    .pad-lft-about{
        padding-left: 16px;
        margin-top: 11px;
    }
}



    /* === MOBILE: Custom Accordion Behavior === */
  @media (max-width: 768px) {
    /* 1. Hide all panels initially */
    .accordion-collapse {
      height: 0;
      overflow: hidden;
      transition: height 0.35s ease;
    }

    /* 2. When panel is open (Bootstrap adds .show via JS) */
    .accordion-collapse.show {
      height: auto;
      overflow: visible;
    }

    /* 3. Reset header styles for mobile */
    .accordion-button {
      background: #961E24;
      color: #fff !important;
    }
    .accordion-button:not(.collapsed) {
      background-color: #961E24 !important;
      color: #ffffff !important;
    }

    /* 4. White arrow (same for open/closed) */
    /* .accordion-button::after,
    .accordion-button:not(.collapsed)::after {
      background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23666666'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e") !important;
    } */
    .accordion-button:not(.collapsed)::after {
      transform: rotate(-180deg);
    }
  }

  /* === DESKTOP: Normal Bootstrap behavior === */
  @media (min-width: 769px) {
    .accordion-button::after {
      background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23ffffff'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
    }
    .accordion-button:not(.collapsed)::after {
      transform: rotate(-180deg);
    }
    .accordion-button:not(.collapsed) {
      background-color: #961E24 !important;
      color: #ffffff !important;
    }
  }


 @media (max-width: 767px) {

    .service-item {
        width: 100%;
        margin-bottom: 15px;   /* prevents overlap with next category */
    }

    
    .service-sublist {
        display: block; /* override desktop hidden */
        max-height: 0;
        overflow: hidden;
        transition: max-height 0.4s ease;
        background: #ffffff10;
        border-left: 3px solid #fff;
        margin-left: -48px;
        margin-top: 10px;
        border-radius: 5px;
    }


    .service-sublist a{
        /* display: block; */
        padding: 5px 5px;
        border-bottom: 1px solid #ffffff20;
        text-decoration: none;
    }

    .service-item.active .service-sublist {
        max-height: 450px;
        padding-top: 10px;
        padding-bottom: 10px;
    }

    .toggle-category {
        cursor: pointer;
    }

    .service_s_cat{
        color: #fff;
        background: #921a23;
        list-style: none;
        border-radius: 8px;
        display: block;
        margin-bottom: 15px;
    }

    .service_s_cat a{
        color: #fff;
        padding: 10px;
        display: block;
        text-decoration: none;
    }

    .service-item h3{
        color: var(--accent-color);
    }    

    /* .read-more-service {
        display: none !important;
    } */

}












