

@media screen and (min-width: 1366px) {
    .container{max-width: 1250px;}
}
@media screen and (max-width: 1365px) and (min-width: 1200px) {
    .iconContentWrp{
        left: -80px;
    }
    .iconContentWrp.leftMiddle {
        left: 50px;
    }
    .iconContentWrp.rightMiddle{
        right: 90px;
    }
    .iconContentWrp.rightbottom{
        right: -60px;
    }
}
@media screen and (max-width: 1365px) and (min-width: 992px) {

    .bannerContent h1{
        font-size: 48px;
    }
}
@media screen and (max-width: 1199px) and (min-width: 992px) {
    .halfCircle img{
        max-width: 850px;
    }
    .circleImg img{
        max-width: 300px;
    }
    .iconContentWrp{
        max-width: 230px;
        left: -40px;
    }
    .iconContentWrp.leftMiddle, .iconContentWrp.rightMiddle{
        top: 20%;
    }
    .iconContentWrp.leftMiddle{
        left: 40px;
    }
    .iconContentWrp.rightMiddle{
        right: 80px;
    }
    .iconContentWrp.rightbottom {
        right: -50px;
    }
}
@media only screen and (max-width: 991px){
    body{padding-top: 0px; overflow-x: hidden;}
    section{
        overflow: hidden;
    }
    .bx {
        width: calc(100% / 1 - 0px);
    }
    .mp-0{
        padding-right: 15px !important;
    }
    .mobile{display: block  !important;}
    .desktop{display: none !important;}
    .mainHeader .container {
        padding: 0;
    }
    .navbar-toggler i {
        color: #ffffff;
        font-size: 28px;
    }
    .navbar-brand img {
        height: 55px;
        width: auto;
    }
    nav#mainNav .nav-item > a {
        padding: 14px 0;
        display: flex;
        align-items: center;
        font-size: 16px;
        letter-spacing: 0.3px;
        color: #ffffff !important;
    }

    nav#mainNav .nav-item > a.nav-contact-link {
        width: 100%;
        justify-content: center;
        margin-top: 18px;
        height: 48px;
        color: var(--home-red) !important;
        background: var(--home-cream) !important;
        border-color: var(--home-cream) !important;
    }
    .serviceDetailHero2 {
        padding: 210px 0 120px;
        height: 560px;
    }

    .positionCenter {
        margin-left: 0px;
    }
    
   nav#mainNav .nav-item{
    padding: 0;
    color: #fff !important;
    position: static;
    border-bottom: dashed 1px rgba(255, 255, 255, 0.28);
   }
   nav#mainNav{
    padding: 5px 15px;
    /* background: #ffffff !important; */
   }
    .navbar-light .navbar-toggler {
        border: none;
        padding: 0;
        outline: none;
        box-shadow: none;
    }
    div#navbarSupportedContent {
        position: fixed;
        top: 0;
        width: 320px;
        left: -0px;
        background: #7c1c11;
        height: 100vh;
        padding: 20px;
        z-index: 9;
        display: block;
        transform: translateX(-320px);
        transition: all 400ms ease;
        padding-top: 60px;
        z-index: 999;
    }
    .cross-toggler {
        background: #fff;
        border: none;
        color: #000;
        padding: 0;
        width: 30px;
        height: 30px;
        border-radius: 50%;
        margin-bottom: 10px;
        position: absolute;
        right: 20px;
        top: 20px;
        z-index: 9999;
    }
    ul.navbar-nav.ml-auto {
        height: calc(100vh - 60px);
        overflow: auto;
    }
    div#navbarSupportedContent.active{
        left: 320px;
        transition: all 400ms ease;
    }
    .overLay {
        position: fixed;
        width: 100%;
        height: 100vh;
        background: rgb(0 0 0 / 51%);
        top: 0;
        left: 0;
        display: none;
    }
    .overLay.active {
        display: block;
    }
    /* Services = inline accordion on mobile (opens on tap, no slide-in panel) */
    li.dropmenu.nav-item {
        flex-wrap: wrap;
        justify-content: space-between;
        align-items: center;
        position: relative;
    }
    li.dropmenu > a.nav-link {
        flex: 1 1 auto;
    }
    .dropmenu .dropArrow {
        color: #ffffff;
        font-size: 18px;
        padding: 14px 6px;
        margin: 0;
        cursor: pointer;
        transition: transform 300ms ease;
    }
    .dropmenu.active .dropArrow {
        transform: rotate(180deg);
    }
    .dropmenuWrp {
        position: static;
        height: auto;
        width: 100%;
        min-width: 0;
        margin-top: 0;
        padding: 0 0 6px 14px;
        transform: none;
        transition: none;
        background: transparent;
        box-shadow: none;
        border-radius: 0;
        display: none;
    }
    .dropmenuWrp::before {
        display: none;
    }
    .dropmenuWrp li a {
        color: rgba(255, 255, 255, 0.88);
        padding: 11px 0;
        text-transform: none;
        font-size: 15px;
        border-bottom: dashed 1px rgba(255, 255, 255, 0.22);
    }
    .dropmenu:hover .dropmenuWrp {
        display: none;
    }
    .dropmenu.active .dropmenuWrp {
        display: block;
    }
   
    .bannerContent h1 {
        font-size: 36px;
    }
    .bannerContent h1 br{
        display: none;
    }
    .aboutSec p.d-flex{
        gap: 20px;
    }
    .sectionHeading h2 {
        font-size: 32px;
    }
    .redCircle{
        position: static;
        transform:translateY(0);
        margin: 20px auto;
        width: 200px;
        height: 200px;
    }
    .redCircle h5 {
        font-size: 80px;
    }
    .redCircle h6 {
        font-size: 15px;
    }
    .contentBx img{
        margin: 30px 0;
    }
    .whatWeDoSec .contentBx {
        flex-direction: column-reverse;
    }
    
    .sectionBorder{
        margin-bottom: 30px;
    }
    .iconContent h3 {
        font-size: 15px;
    }

    .iconContentWrp {
        position: static;
        transform: translateX(0%) !important;
        max-width: 50%;
        width: 50%;
    }

    .cicleThumb {
        position: static;
        transform: translateX(0%);
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        margin: 0 auto;
        width: 100%;
    }
    .iconContent h3 br{
        display: none;
    }

    .contetWithCircle {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
    }

    .halfCircle {
        display: none;
    }

    .circleImg img {
        width: 300px;
    }
    .footerLogo img{
        width: 150px;
    }
    .footerLinks {
        margin-bottom: 30px;
    }
    .footerLinks ul li a {
        font-size: 13px;
    }

    .footerLinks ul li {
        margin: 0 0 5px;
    }

    .footerLinks h3 {
        font-size: 14px;
        margin: 0 0 10px;
    }
    .solutionCard h4{
        font-size: 20px;
    }
    .solutionCard p{
        font-size: 18px;
    }
}
@media only screen and (max-width: 767px){
    section.banner {
        padding: 150px 0 100px !important;
        background-position: top center;
        min-height: 1px;
    }
    section.whyTopSec {
        padding-bottom: 100px;
    }
    
   
   .footerLink{
        margin-top: 30px;
   }
   
    .copyright{
        flex-wrap: wrap;
        justify-content: center !important;
    }
    .copyright span{
        display: block;
        width: 100%;
        text-align: center;
    }
   
    .footerLogo{
        margin-bottom: 30px;
        text-align: center;
    }
}
@media only screen and (max-width: 460px){


}

@media only screen and (max-width: 991px) {
    .careerHero {
        padding: 120px 0 40px;
    }

    .careerHeroContent h1 {
        font-size: 42px;
        margin-bottom: 20px;
    }

    .careerHeroText p {
        font-size: 15px;
    }

    .galleryThumb img {
        height: 180px;
    }

    .whyJoinCard h3 {
        font-size: 24px;
    }

    .positionRow {
        grid-template-columns: 1fr;
        gap: 15px;
    }

    .positionLeft h3 {
        font-size: 28px;
    }

    .positionRight {
        text-align: left;
    }
}

@media only screen and (max-width: 767px) {
    .careerHero {
        padding: 130px 0 30px;
    }

    .careerHeroContent h1 {
        font-size: 34px;
        line-height: 1.1;
    }

    /* Show one gallery image at a time on mobile (single-file marquee) */
    .careerGallery .marquee-content .row {
        flex-wrap: nowrap;
        width: max-content;
    }

    .careerGallery .marquee-content .row > [class*="col-"] {
        flex: 0 0 88vw;
        width: 88vw;
        max-width: 88vw;
    }

    .galleryThumb img {
        height: 220px;
    }

    .whyJoinCard {
        min-height: auto;
        padding: 22px 18px;
    }

    .whyJoinCard h3 {
        font-size: 22px;
    }

    .lifeCard img {
        height: 190px;
    }

    .positionLeft h3 {
        font-size: 24px;
    }

    .positionCenter p {
        font-size: 14px;
    }
}

@media only screen and (max-width: 991px) {
    .jobHero {
        padding: 120px 0 30px;
    }

    .jobHeroTop h1 {
        font-size: 40px;
    }

    .jobMetaRow {
        align-items: flex-start;
        gap: 18px;
    }

    .jobMetaList {
        gap: 12px;
    }

    .jobMetaList li {
        font-size: 13px;
        padding-right: 14px;
    }

    .jobContentWrap p,
    .jobList li {
        font-size: 15px;
    }

    .jobInfoBlock h3 {
        font-size: 24px;
    }

    .applyJobHead h2 {
        font-size: 32px;
    }

    /* Contact hero stacks on tablet/mobile */
    .contactHero {
        padding: 120px 0 50px;
    }

    .contactHeroGrid {
        grid-template-columns: 1fr;
        gap: 36px;
    }

    .contactHeroInfo h1 {
        font-size: 40px;
        margin-bottom: 30px;
    }

    .contactDetail a {
        font-size: 20px;
    }
}

@media only screen and (max-width: 767px) {
    .jobHero {
        padding: 115px 0 24px;
    }

    .contactHero {
        padding: 110px 0 40px;
    }

    .contactHeroInfo h1 {
        font-size: 32px;
        margin-bottom: 24px;
    }

    .contactFormCard {
        padding: 24px 20px 28px;
    }

    .jobHeroTop h1 {
        font-size: 32px;
        margin-bottom: 15px;
    }

    .whiteApplyBtn {
        padding: 9px 18px;
        font-size: 12px;
    }

    .jobMetaList {
        flex-direction: row;
        flex-wrap: wrap;
        align-items: center;
        gap: 8px 16px;
        row-gap: 8px;
    }

    .jobMetaList li {
        font-size: 13px;
        padding-right: 16px;
    }

    .jobMetaList li:not(:last-child)::after {
        display: block;
    }

    .jobDetailSec {
        padding: 35px 0 60px;
    }

    .jobContentWrap {
        margin-bottom: 40px;
    }

    .jobContentWrap p,
    .jobList li {
        font-size: 14px;
        line-height: 1.75;
    }

    .jobInfoBlock h3 {
        font-size: 22px;
    }

    .applyJobHead h2 {
        font-size: 28px;
    }

    .resumeUploadInner {
        flex-direction: column;
        padding: 20px;
    }
}

@media only screen and (max-width: 991px) {
    .contactHeroSec {
        padding: 120px 0 0;
    }

    .contactHeroBox {
        padding: 32px 28px;
        margin-bottom: 25px;
    }

    .contactHeroContent h1 {
        font-size: 44px;
        margin-bottom: 18px;
    }

    .contactHeroText p {
        font-size: 15px;
    }

    .contactInfoCard h3 {
        font-size: 28px;
    }

    .contactInfoItem a {
        font-size: 21px;
    }
}

@media only screen and (max-width: 767px) {
    .contactHeroSec {
        padding: 110px 0 0;
    }

    .contactHeroBox {
        padding: 24px 20px;
        border-radius: 10px;
    }

    .contactHeroContent h1 {
        font-size: 34px;
        line-height: 1.08;
    }

    .contactInfoCard,
    .contactFormBox {
        padding: 20px 16px;
        border-radius: 10px;
    }

    .contactInfoCard h3 {
        font-size: 24px;
    }

    .contactInfoItem a {
        font-size: 18px;
    }

    .contactSubmitBtn {
        width: 100%;
    }
}

@media (max-width: 991px) {

  .serviceHeroContent h1 {
    font-size: 36px;
  }

  .serviceCard {
    padding: 25px;
  }

  .serviceCard .row {
    flex-direction: column !important;
  }

  .partnerGrid {
    grid-template-columns: 1fr;
  }

}

@media (max-width: 991px) {

  .heroContent h1 {
    font-size: 34px;
  }

  .solutionGrid {
    grid-template-columns: 1fr;
  }

  .impactGrid {
    grid-template-columns: 1fr;
  }

}
  @media only screen and (max-width: 991px){
    .timeline-svg {
        display: none;
    }

    .timeline-svg-container {
        position: static;
    }

    .milestone {
        position: static;
        padding: 20px;
        width: 100%;
        opacity: 1;
    }

    .story-shell {
        height: auto !important;
    }

    header.intro {
        position: static;
    }

    div#circleSection {
        display: none;
    }

    .iconContentWrp {
        position: static;
        transform: translateX(0%) !important;
        max-width: 50%;
        width: 50%;
    }

    .cicleThumb {
        position: static;
        transform: translateX(0%);
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        margin: 0 auto;
        width: 100%;
    }

    .contetWithCircle {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
    }

    .halfCircle {
        display: none;
    }
    }

/* ===== About Us responsive ===== */
@media only screen and (max-width: 991px) {
    .story-section .milestone h2,
    .story-section .milestone h3 {
        font-size: 40px;
    }

    .rajaSec {
        padding: 64px 0 70px;
    }

    .rajaFrame {
        padding: 36px 18px 40px;
    }

    .rajaFrame::before,
    .rajaFrame::after {
        width: 74px;
        height: 66px;
    }

    .genRow--three {
        gap: 26px;
    }

    .apartGrid {
        grid-template-columns: repeat(2, 1fr);
        gap: 44px 40px;
    }

    .apartCard,
    .apartCard:first-child {
        padding: 0;
        border-left: none;
    }

    .apartNum {
        margin-bottom: 16px;
    }
}

@media only screen and (max-width: 767px) {
    .story-section .milestone h2,
    .story-section .milestone h3 {
        font-size: 34px;
    }

    .rajaSec {
        padding: 50px 0 60px;
    }

    .rajaHead {
        margin-bottom: 36px;
    }

    .rajaFrame {
        border-radius: 22px 0 22px 0;
        padding: 28px 16px 32px;
    }

    .genRow--three {
        grid-template-columns: 1fr;
        max-width: 320px;
        gap: 34px;
    }

    .genBlock {
        padding: 26px 0;
    }

    .rajaPhoto,
    .genRow--one .rajaPhoto {
        max-width: 200px;
    }

    .apartGrid {
        grid-template-columns: 1fr;
        gap: 0;
    }

    .apartCard,
    .apartCard:first-child {
        padding: 22px 0;
        border-left: none;
        border-top: 1px solid rgba(126, 28, 17, 0.2);
    }

    .apartCard:first-child {
        padding-top: 0;
        border-top: none;
    }

    .apartNum {
        margin-bottom: 12px;
    }
}