@media (max-width: 1440px) {
  .services {
    padding: 140px 0;
  }
  .focus-intro .focus-card {
    height: 521px;
  }
  .team-section {
    padding: 80px 20px;
  }

  .our-team-section {
    padding: 80px 20px 0;
  }
  .pb-100 {
    padding-bottom: 80px !important;
  }

  .services-section {
    padding: 80px 0;
  }
  .zigzag {
    padding: 0 0 80px 0;
  }
  .service-detail {
    padding: 80px 0px;
  }
  .content h2 {
    font-size: 40px;
    margin-bottom: 30px;
    line-height: 55px;
  }

  .content h3 {
    font-size: 35px;
    margin-top: 20px;
  }
  .content p {
    margin-top: 20px;
  }
  .contact-section {
    padding: 80px 0px;
  }
}

@media (max-width: 1366px) {
  .services {
    padding: 120px 0;
  }
  .testimonial-section {
    padding: 70px 20px;
  }
  .heading h2 {
    font-size: 45px;
    margin-bottom: 20px;
  }
  .footer-col h4 {
    font-size: 22px;
  }
  .values-section h2 {
    font-size: 45px;
  }
  .service-detail {
    padding: 60px 0px;
  }
}

@media (max-width: 1024px) {
  .services {
    padding: 100px 0;
  }
  .focus-intro .focus-card {
    height: 515px;
  }
  .focus {
    padding: 60px 0px 30px 0px;
  }
  .focus-intro h2 {
    font-size: 40px;
  }
  .overlay h4 {
    font-size: 22px;
  }

  .no-scroll {
    overflow: hidden;
    height: 100vh;
  }

  .menu {
    position: fixed; /* instead of absolute */
    top: 70px;
    left: 0;
    width: 100%;
    height: calc(100vh - 70px);
    background: #fff;
    display: none;
    z-index: 999;
  }

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

  .right {
    display: none;
  }

  .hamburger {
    display: flex;
  }

  .menu.active {
    display: block;
  }

  .dropdown {
    position: static;
    box-shadow: none;
    display: none;
  }

  .has-dropdown.open .dropdown {
    display: block;
  }

  .call-mob {
    display: none;
  }
  .mob-btn {
    background: var(
      --bg,
      linear-gradient(
        90deg,
        rgba(0, 165, 157, 1) 0%,
        rgba(30, 109, 182, 1) 100%
      )
    );
    border-radius: 37px;
    padding: 10px 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: var(
      --shadow-xs-box-shadow,
      0px 1px 2px 0px rgba(16, 24, 40, 0.05)
    );
    cursor: pointer;
    color: #ffffff;
    font-size: 16px;
    line-height: 24px;
    font-weight: 400;
    border: none;
    width: fit-content;
  }
  .testimonial-card {
    margin: 0 auto 60px;
  }
  .values-section h2 {
    font-size: 40px;
  }
  .values-section .subtitle {
    font-size: 18px;
    margin-bottom: 40px;
  }
  .value-item h4 {
    font-size: 24px;
  }
  .value-item img {
    width: 48px;
    height: 48px;
  }
  .values-section {
    padding: 60px 20px;
    text-align: center;
  }
  .team-section {
    padding: 60px 20px;
  }
  .team-intro h2 {
    font-size: 40px;
  }
  .team-intro p {
    font-size: 18px;
  }
  .team-info h4 {
    font-size: 24px;
  }
  .team-info span {
    font-size: 18px;
  }
  .team-container {
    grid-template-columns: 1fr;
  }

  .team-intro {
    text-align: center;
  }

  .team-intro p {
    margin: 0 auto;
  }

  .team-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .about-intro h2 {
    font-size: 40px;
    max-width: 100%;
  }

  .about-intro p {
    max-width: 100%;
  }

  .mv-box h2 {
    font-size: 40px;
  }

  .our-team-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .our-team-section {
    padding: 60px 20px 0;
  }
  .pb-100 {
    padding-bottom: 60px !important;
  }

  .services-section {
    padding: 60px 0;
  }
  .services-section h2 {
    font-size: 40px;
  }
  .services-section .subtitle {
    font-size: 16px;
    max-width: 90%;
  }
  .service-card {
    padding: 60px 15px 40px;
  }
  .service-card img {
    width: 40px;
    height: 40px;
  }
  .service-card h4 {
    font-size: 20px;
  }
  .zigzag {
    padding: 0 0 60px 0;
  }
  .zigzag-content h3 {
    font-size: 35px;
  }

  .zigzag-images img {
    height: 450px;
  }

  .zigzag-content p {
    margin-top: 20px;
  }
  .service-btn {
    padding: 10px 30px;
    font-size: 16px;
  }
  .service-detail-wrapper {
    grid-template-columns: 1fr;
  }

  .sidebar {
    order: 2;
  }
  .zigzag-row {
    grid-template-columns: 1fr;
  }

  .zigzag-row.reverse {
    direction: ltr;
  }

  .zigzag-content {
    text-align: center;
  }
  .services-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .wrapper {
    grid-template-columns: 1fr;
  }

  .sidebar {
    margin-top: 10px;
    width: 100%;
  }
  .services-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }
  .service-detail {
    padding: 50px 0px;
  }
  .content h2 {
    font-size: 35px;
    margin-bottom: 20px;
    line-height: 45px;
  }

  .content h3 {
    font-size: 30px;
    margin-top: 10px;
  }
  .content p {
    margin-top: 20px;
    font-size: 14px;
  }
  blockquote {
    margin-top: 20px;
    padding-left: 14px;
    font-size: 16px;
  }
  .sidebar h4 {
    font-size: 20px;
    margin-bottom: 30px;
  }

  .service-item span {
    font-size: 20px;
  }
  .wrapper {
    gap: 40px;
  }
  .contact-section {
    padding: 60px 0px;
  }
  .contact-section h2 {
    font-size: 40px;
    margin-bottom: 30px;
  }
  .form-area h3 {
    font-size: 35px;
    margin-bottom: 10px;
  }
  .info-area p {
    font-size: 22px;
  }
  .map iframe {
    height: 400px;
  }
  .contact-box {
    margin-bottom: 30px;
  }
}

@media (max-width: 900px) {
  .hero-images {
    display: none;
    gap: 16px;
  }
  .hero-wrapper {
    grid-template-columns: 1fr;
  }

  .hero-content h1 {
    font-size: 38px;
    line-height: 110%;
  }

  .hero-content p {
    line-height: 150%;
    font-size: 14px;
  }

  .services-container {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .services-images img {
    height: 160px;
  }

  .services-content h2 {
    font-size: 28px;
  }

  .focus-container {
    grid-template-columns: 1fr;
  }

  .focus-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .focus-card.tall {
    grid-row: auto;
  }
  .bg-style {
    display: none;
  }
  .counter-wrapper {
    grid-template-columns: repeat(2, 1fr);
  }
  .footer-wrapper {
    grid-template-columns: repeat(2, 1fr);
  }
  .hero {
    padding: 60px 20px;
  }
  .services {
    padding: 80px 0;
  }
  .services-content {
    order: 1;
  }
  .services-wrapper {
    grid-template-columns: 1fr;
  }

  .services-images {
    order: 2;
  }

  .testimonial-section {
    padding: 60px 20px;
  }
  .heading h2 {
    font-size: 40px;
    margin-bottom: 15px;
  }
  .testimonial-card {
    margin: 0 auto 50px;
  }
  .counter-box h3 {
    font-size: 36px;
  }
  .about-content h1 {
    font-size: 34px;
  }

  .img-box {
    width: 280px;
    height: 320px;
  }
  .mv-container {
    grid-template-columns: 1fr;
    gap: 50px;
  }

  .mv-box h2 {
    font-size: 26px;
  }
  .values-box {
    grid-template-columns: repeat(2, 1fr);
  }
  .mv-box h2 br {
    display: none;
  }
  .contact-box {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .offer-list {
    gap: 14px;
  }

  .offer-item {
    padding: 10px 18px;
    font-size: 13px;
  }
  .cta-content h2 {
    font-size: 26px;
  }
  .hero {
    padding: 50px 20px;
  }
  .services {
    padding: 50px 0;
  }
  .services-wrapper {
    gap: 30px;
  }
  .focus-wrapper {
    flex-direction: column;
  }
  .focus-intro {
    width: 100%;
  }
  .focus-grid {
    width: 100%;
  }
  .focus-intro h2 {
    font-size: 30px;
    margin-bottom: 10px;
  }
  .focus-intro p {
    font-size: 16px;
    margin-top: 0px;
  }
  .overlay h4 {
    font-size: 18px;
  }
  .testimonial-section {
    padding: 50px 20px;
  }
  .testimonial-card p {
    font-size: 18px;
  }

  .footer-col h4 {
    font-size: 20px;
  }
  .footer-col p {
    font-size: 18px;
  }
  .footer-col ul li a {
    font-size: 18px;
  }
  .footer-bottom {
    font-size: 18px;
  }
  .mob-btn {
    width: 100%;
  }
  .testimonial-card {
    margin: 0 auto 40px;
  }

  .about-intro {
    padding: 70px 20px;
  }

  .about-intro h2 {
    font-size: 28px;
  }

  .about-intro p {
    font-size: 14px;
  }
  .about-intro h2 {
    max-width: 100%;
  }

  .about-intro p {
    max-width: 100%;
  }
  .mission-vision {
    padding: 30px 0;
  }
  .about-hero {
    padding: 30px 0px 50px;
  }

  .values-section {
    padding: 30px 0px;
  }
  .team-section {
    padding: 30px 0px;
  }
  .our-team-section {
    padding: 30px 0px 0;
  }
  .pb-100 {
    padding-bottom: 30px !important;
  }
  .services-section {
    padding: 50px 0;
  }
  .services-section h2 {
    font-size: 35px;
  }
  .services-section .subtitle {
    max-width: 100%;
  }
  .zigzag {
    padding: 0 0 50px 0;
  }
  .zigzag-content h3 {
    font-size: 35px;
  }

  .zigzag-images img {
    height: 350px;
  }

  .zigzag-content p {
    margin-top: 20px;
  }
  .service-item img {
    width: 35px;
    height: 35px;
  }
  .service-item span {
    font-size: 18px;
  }
  .contact-bg-style {
    display: none;
  }

  .contact-section {
    padding: 50px 0px;
  }
  .contact-section h2 {
    font-size: 35px;
    margin-bottom: 20px;
  }
  .form-area h3 {
    font-size: 30px;
  }
  .info-area p {
    font-size: 20px;
  }
  .map iframe {
    height: 350px;
  }
  .contact-box {
    padding: 40px;
  }
  .contact-button {
    padding: 10px 40px;
    font-size: 14px;
  }
  .focus-intro .focus-card {
    height: 463px;
  }
  .about-bg-style {
    display: none;
  }
}

@media (max-width: 600px) {
  .about-content h1 {
    font-size: 26px;
  }

  .about-images {
    gap: 20px;
  }

  .img-box {
    width: 100%;
    height: 280px;
  }

  .values-box {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .value-item {
    align-items: center;
  }

  .value-item img {
    margin-bottom: 10px;
    width: 38px;
    height: 38px;
  }
  .values-section h2 {
    font-size: 35px;
  }
  .values-section .subtitle {
    font-size: 16px;
    margin-bottom: 30px;
  }
  .values-box {
    padding: 30px 20px;
    gap: 30px 20px;
  }
  .value-item h4 {
    font-size: 22px;
  }
  .team-intro h2 {
    font-size: 30px;
  }
  .team-intro p {
    font-size: 16px;
  }
  .team-container {
    gap: 40px;
  }
  .team-info h4 {
    font-size: 22px;
  }
  .team-info span {
    font-size: 16px;
  }
  .team-grid {
    grid-template-columns: 1fr;
  }
  .our-team-grid {
    grid-template-columns: 1fr;
  }

  .our-team-card img {
    height: 250px;
  }
  .service-detail {
    padding: 30px 0px;
  }
  .content h2 {
    font-size: 30px;
    margin-bottom: 10px;
    line-height: 40px;
  }
  .main-img {
    margin-bottom: 20px;
  }
  .content h3 {
    font-size: 25px;
    line-height: 34px;
  }
  .wrapper {
    gap: 20px;
  }
}

@media (max-width: 540px) {
  .hero-buttons {
    flex-direction: column;
    gap: 16px;
  }
  .hero {
    padding: 30px 0;
  }
  .hero-content h1 {
    font-size: 30px;
    margin-bottom: 10px;
  }
  .btn.primary {
    width: 100%;
  }
  .offer-title {
    font-size: 30px;
  }
  .offer {
    padding: 30px 20px;
  }
  .services {
    padding: 30px 0;
  }
  .btn-outline {
    width: 100%;
  }
  .focus {
    padding: 30px 0px;
  }
  .focus-grid {
    grid-template-columns: repeat(1, 1fr);
  }
  .testimonial-section {
    padding: 30px 20px;
  }
  .heading h2 {
    font-size: 30px;
    margin-top: 10px;
    margin-bottom: 10px;
  }
  .services-section {
    padding: 30px 0;
  }
  .services-section h2 {
    font-size: 30px;
  }
  .services-section .subtitle {
    font-size: 14px;
    margin-bottom: 20px;
  }
  .service-card {
    padding: 60px 15px 40px;
  }
  .service-card img {
    width: 40px;
    height: 40px;
  }
  .service-card h4 {
    font-size: 20px;
  }
  .zigzag {
    padding: 0 0 30px 0;
  }
  .zigzag-content h3 {
    font-size: 30px;
    line-height: 46px;
  }

  .zigzag-images img {
    height: 300px;
  }

  .zigzag-content p {
    margin-top: 20px;
  }
  .service-btn {
    padding: 10px 30px;
    font-size: 16px;
  }
  .services-list {
    grid-template-columns: repeat(1, 1fr);
  }
  .contact-button {
    width: 100%;
  }
  .contact-section {
    padding: 30px 0px;
  }
  .contact-section h2 {
    font-size: 30px;
    margin-bottom: 10px;
  }
  .form-area h3 {
    font-size: 25px;
  }
  .form-area p {
    margin-bottom: 20px;
    font-size: 16px;
  }
  .info-area h4 {
    font-size: 14px;
  }
  .info-area p {
    font-size: 18px;
  }

  .contact-box {
    padding: 20px;
  }
  .contact-button {
    padding: 10px 40px;
    font-size: 14px;
  }

  .contact-form input,
  .contact-form textarea {
    font-size: 14px;
  }
  .pill{
    width: 100%;
  }
  .cta-btn{
    width: 100%;
  }
}

@media (max-width: 500px) {
  .services-images {
    grid-template-columns: 1fr;
  }

  .services-images img {
    height: 200px;
  }
  .offer-item {
    width: 100%;
  }
  .counter-box h3 {
    font-size: 30px;
  }
  .services-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 480px) {
  .focus-grid {
    grid-template-columns: 1fr;
  }

  .focus-grid {
    grid-auto-rows: 200px;
  }
  .cta-content h2 {
    font-size: 22px;
  }

  .cta-btn {
    padding: 11px 20px;
  }
  .counter-wrapper {
    grid-template-columns: 1fr;
  }
  .footer-wrapper {
    grid-template-columns: 1fr;
    padding: 30px;
  }

  .about-intro h2 {
    font-size: 22px;
  }
  .mission-vision {
    padding: 70px 20px;
  }

  .mv-box h2 {
    font-size: 22px;
  }

  .mv-box p {
    font-size: 14px;
  }
}
