@import 'variables.css';

.banner {
  background: radial-gradient(at 10% 10%, var(--color-primary-2), var(--color-primary) 30%);
  margin: -80px 30px 30px;
  padding: 80px 0 60px;
  position: relative;
  max-width: -webkit-fill-available;
  display: flex !important;
  flex-direction: row !important;
  gap: auto !important;
  justify-content: space-between !important;
  align-items: stretch !important;
  flex-wrap: wrap;
  clip-path: polygon(0% 0%, 34% 0%, 37% 8%, 63% 8%, 66% 0%, 100% 0%, 100% 90%, 100% 100%, 0% 100%, 0% 90%);
  border-radius: 40px;
}

.banner .banner-content {
  color: var(--white);
  padding: 0 30px;
}

.banner .banner-content h1 {
  font-size: 52px;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 20px;
}

.banner .banner-content p {
  color: var(--light-text);
  max-width: 520px;
  margin-bottom: 30px;
}

.banner .banner-content .banner-actions {
  display: flex;
  align-items: center;
  gap: 30px;
}

.banner .banner-content .banner-actions .primary-btn {
  background: var(--color-secondary);
  color: #fff;
  padding: 12px 28px;
  border-radius: 30px;
  text-transform: none;
}

.banner .banner-content .banner-actions .primary-btn:hover {
  background: var(--white);
  color: var(--color-primary-2);
  font-weight: 700;
}

.banner .banner-content .banner-actions .call-info {
  display: flex;
  align-items: center;
  gap: 8px;
}

.banner .banner-content .banner-actions .call-info span {
  color: var(--white) !important;
  font-weight: 500 !important;
}

.banner .banner-content .banner-actions .call-info svg {
  fill: var(--white) !important;
}

.banner .banner-image .image-wrapper {
  position: relative;
  border-radius: 30px;
  overflow: visible;
}

.banner .banner-image .image-wrapper img {
  width: 100%;
  border-radius: 30px;
  --r: 20px;
  --s: 40px;
  --p: 50%;
  background: transparent;
  border-radius: var(--r);
  --_d: calc((var(--s) + var(--r)) * 0.93969);
  mask: radial-gradient(var(--r) at var(--r) calc(var(--p) + var(--_d)), #000 calc(100% - 1px), #0000), radial-gradient(var(--r) at var(--r) calc(var(--p) - var(--_d)), #000 calc(100% - 1px), #0000), radial-gradient(var(--s) at calc(-0.34202 * var(--s)) var(--p), #0000 100%, #000 calc(100% + 1px)) calc(var(--r) * 0.65798) 0 no-repeat, linear-gradient(#000 calc(var(--p) - var(--_d)), #0000 0 calc(var(--p) + var(--_d)), #000 0);
  -webkit-mask: radial-gradient(var(--r) at var(--r) calc(var(--p) + var(--_d)), #000 calc(100% - 1px), #0000), radial-gradient(var(--r) at var(--r) calc(var(--p) - var(--_d)), #000 calc(100% - 1px), #0000), radial-gradient(var(--s) at calc(-0.34202 * var(--s)) var(--p), #0000 100%, #000 calc(100% + 1px)) calc(var(--r) * 0.65798) 0 no-repeat, linear-gradient(#000 calc(var(--p) - var(--_d)), #0000 0 calc(var(--p) + var(--_d)), #000 0);
}

.banner .banner-image .image-wrapper .play-btn {
  position: absolute;
  inset: 0;
  left: -30px;
  top: 43.5%;
  width: 60px;
  height: 60px;
  background: #0aa6a6;
  color: #fff;
  border-radius: 50%;
  transition: all 0.3s ease;
}

.banner .banner-image .image-wrapper .play-btn:hover {
  background: #089191;
  transform: scale(1.1);
}

.banner .banner-image .image-wrapper .play-btn .logo-icon {
  font-size: 36px !important;
  color: #fff !important;
  animation: logo-icon-animate 2s ease-in-out infinite;
  fill: url(#logo-icon-gradient) !important;
}

.banner .banner-image .image-wrapper .play-btn .logo-icon path {
  fill: url(#logo-icon-gradient) !important;
}

@media (max-width: 992px) {
  .banner {
    clip-path: none;
    border-radius: 24px;
    padding: 100px 20px 50px;
  }

  .banner h1 {
    font-size: 38px !important;
  }

  .banner .row {
    gap: 30px;
  }

  .banner .row .banner-content .banner-actions {
    flex-direction: column;
    align-items: flex-start;
  }

  .banner .row .banner-image {
    padding: 0 30px;
    width: 100%;
  }

  .banner .row .banner-image .image-wrapper img {
    mask: none;
    -webkit-mask: none;
  }

  .banner .row .banner-image .image-wrapper .play-btn {
    top: 44%;
    display: none;
    left: -30px;
  }
}

@media (max-width: 560px) {
  .banner {
    margin: -80px 15px 0px !important;
  }
}

@keyframes logo-icon-animate {
  0%, 100% {
    transform: scale(1) translateY(0) rotate(0deg);
    opacity: 1;
    filter: drop-shadow(0 0 0 rgba(255, 255, 255, 0));
  }
  25% {
    transform: scale(1.1) translateY(-2px) rotate(-5deg);
    opacity: 0.95;
    filter: drop-shadow(0 2px 8px rgba(255, 255, 255, 0.3));
  }
  50% {
    transform: scale(1.15) translateY(-3px) rotate(0deg);
    opacity: 1;
    filter: drop-shadow(0 4px 12px rgba(255, 255, 255, 0.4));
  }
  75% {
    transform: scale(1.1) translateY(-2px) rotate(5deg);
    opacity: 0.95;
    filter: drop-shadow(0 2px 8px rgba(255, 255, 255, 0.3));
  }
}

.featured-service {
  padding: 100px 0;
  background: var(--bg-light);
}

.featured-service .section-head {
  text-align: center;
  margin-bottom: 60px;
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  justify-content: center !important;
  align-items: stretch !important;
}

.featured-service .section-head .sub-title {
  color: var(--color-primary-2);
  font-weight: 600;
  letter-spacing: 1px;
  display: inline-block;
}

.featured-service .section-head .title {
  color: var(--white) !important;
}

.featured-service .section-head h2 {
  font-size: 38px;
  font-weight: 700;
  color: var(--color-primary);
  line-height: 1.3;
  width: 70%;
  align-self: center;
}

.featured-service .card_container {
  display: flex !important;
  flex-direction: row !important;
  gap: 30px 25px !important;
  justify-content: center !important;
  align-items: stretch !important;
  flex-wrap: wrap;
}

.featured-service .card_container .card {
  position: relative;
  padding: 40px 28px 60px;
  border-radius: 24px;
  border: 1px solid var(--color-secondary);
  align-self: stretch;
  background-color: transparent;
  transition: all 0.3s ease;
  width: 320px;
}

.featured-service .card_container .card .icon {
  width: 60px;
  height: 60px;
  color: var(--color-secondary);
  display: flex !important;
  flex-direction: row !important;
  gap: 5px !important;
  justify-content: center !important;
  align-items: stretch !important;
  margin-bottom: 20px;
}

.featured-service .card_container .card .icon span {
  font-size: 50px;
}

.featured-service .card_container .card:hover .number::before {
  content: '';
  position: absolute;
  left: 0px;
  right: 0px;
  top: 22px;
  margin: 0 auto;
  width: 8px;
  height: 8px;
  background: var(--color-secondary);
  border-radius: 50%;
}

.featured-service .card_container .card:hover .number .text {
  transform: translateY(20px);
}

.featured-service .card_container .card h5 {
  font-size: 18px;
  font-weight: 600;
  color: #083c3c;
  margin-bottom: 14px;
}

.featured-service .card_container .card p {
  font-size: 14px;
  color: #6f8f8e;
  line-height: 1.6;
}

.featured-service .card_container .card .number {
  position: absolute;
  bottom: -16px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--bg-light) !important;
  padding: 16px 44px 17px;
  border-radius: 50%;
  border: 1px solid var(--color-secondary);
  border-bottom: 0px;
  border-bottom: solid;
  border-bottom-color: var(--bg-light);
}

.featured-service .card_container .card .number .text {
  font-weight: 600;
  color: var(--color-secondary);
  margin-bottom: 0px;
}

@media (max-width: 992px) {
  .featured-service {
    padding: 70px 20px;
  }

  .featured-service .section-head {
    margin-bottom: 30px !important;
  }

  .featured-service .section-head h2 {
    font-size: 30px;
  }

  .featured-service .card_container {
    flex-wrap: wrap;
    gap: 30px !important;
  }

  .featured-service .card_container .card:nth-child(even) {
    margin-top: 0px;
  }
}

.solution-section {
  background: var(--color-primary);
  padding: 80px 80px;
  margin: 0 20px;
  position: relative;
  text-align: center;
  z-index: 0;
  border-radius: 20px;
  color: var(--white) !important;
}

.top-notch {
  position: absolute;
  top: -40px;
  left: 50%;
  transform: translateX(-50%) rotate(180deg);
  width: 140px;
  height: 70px;
  background: var(--color-primary);
  border-radius: 0 0 70px 70px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.close-icon {
  background: var(--color-secondary);
  width: 50px;
  height: 50px;
  border-radius: 50%;
  color: #fff;
  font-size: 18px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.close-icon svg {
  fill: var(--white) !important;
  font-size: 30px;
}

.close-icon .ac-unit-icon {
  font-size: 42px !important;
  animation: ac-unit-spin 4s ease-in-out infinite;
  fill: url(#ac-unit-gradient) !important;
}

.close-icon .ac-unit-icon path {
  fill: url(#ac-unit-gradient) !important;
}

@keyframes ac-unit-spin {
  0%, 100% { transform: rotate(0deg); }
  25% { transform: rotate(-15deg); }
  75% { transform: rotate(15deg); }
}

.subtitle {
  font-size: 14px !important;
  letter-spacing: 1px !important;
  margin-bottom: 12px !important;
  opacity: 0.9;
  color: var(--white) !important;
}

.solution-section .title {
  font-size: 36px !important;
  font-weight: 600 !important;
  margin-bottom: 60px !important;
  color: var(--white) !important;
}

.cards-wrapper {
  display: flex;
  gap: 50px;
  justify-content: center;
  flex-wrap: wrap;
  position: relative;
}

.solution-card {
  background: var(--color-secondary) !important;
  border-radius: 16px !important;
  width: 300px;
  overflow: visible !important;
  text-align: left;
  position: relative;
  z-index: 0;
  text-decoration: none;
  display: block;
  cursor: pointer;
  color: inherit;
}

.solution-card::before {
  content: '';
  position: absolute;
  left: -20px;
  right: 20px;
  top: -20px;
  height: 190px;
  z-index: -1;
  border-radius: 16px;
  background-color: var(--color-secondary) !important;
}

.solution-card img {
  height: 200px;
  width: 100%;
  object-fit: cover;
  border-top-left-radius: 16px;
  border-top-right-radius: 16px;
}

.solution-card .MuiCardContent-root,
.solution-card .card-content {
  padding: 24px;
}

.MuiCardContent-root,
.solution-card .card-content {
  position: relative;
  overflow: hidden;
  background: var(--color-secondary) !important;
  transition: color 0.3s ease;
  padding: 24px;
  z-index: 1;
  border-bottom-left-radius: 16px;
  border-bottom-right-radius: 16px;
}

.MuiCardContent-root::before,
.solution-card .card-content::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--white) !important;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s ease;
  z-index: -1;
}

.solution-card .card-title,
.solution-section .card-title {
  font-size: 18px;
  font-weight: 600 !important;
  margin-bottom: 20px;
  color: var(--white) !important;
  transition: color 0.3s ease;
}

.solution-card .arrow,
.solution-section .arrow {
  font-size: 22px;
  cursor: pointer;
  color: var(--white) !important;
}

.solution-card .arrow svg,
.solution-section .arrow svg {
  transform-origin: left;
}

.solution-card:hover .arrow {
  color: var(--color-primary);
}

.solution-card:hover .arrow svg {
  transform: scaleX(2);
}

.solution-card:hover .MuiCardContent-root::before,
.solution-card:hover .card-content::before {
  transform: scaleX(1);
}

.solution-card:hover .MuiCardContent-root .card-title,
.solution-card:hover .MuiCardContent-root .arrow,
.solution-card:hover .card-content .card-title,
.solution-card:hover .card-content .arrow {
  color: var(--color-primary) !important;
}

@media (max-width: 992px) {
  .solution-section {
    padding: 80px 30px;
  }

  .solution-section .title,
  .title {
    font-size: 28px;
  }
}

.marquee-wrapper {
  overflow: hidden;
  max-width: 100%;
  background: #fff;
  padding: 80px 0;
  margin: 0 20px;
}

.marquee-wrapper .marquee-track {
  display: flex;
  width: max-content;
  animation: scroll-left 25s linear infinite;
}

.marquee-wrapper .marquee-text {
  font-size: 120px !important;
  font-weight: 800 !important;
  white-space: nowrap !important;
  margin: 0 25px 0 25px !important;
  color: var(--color-secondary) !important;
}

.marquee-wrapper .marquee-text:nth-child(even) {
  color: transparent !important;
  -webkit-background-clip: text;
  -webkit-text-stroke-width: 0.5px !important;
  -webkit-text-stroke-color: var(--color-secondary) !important;
  -webkit-mask-image: linear-gradient(-75deg, var(--color-secondary) 50%, var(--color-secondary) 50%, var(--color-secondary));
  -webkit-mask-size: 200%;
  transition: 0.5s;
}

@media (max-width: 992px) {
  .marquee-wrapper {
    padding: 60px 0px !important;
  }

  .marquee-wrapper .marquee-text {
    font-size: 80px !important;
  }
}

@media (max-width: 560px) {
  .marquee-wrapper {
    margin: 0 15px !important;
  }

  .marquee-wrapper .marquee-text {
    font-size: 50px !important;
  }
}

@keyframes scroll-left {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

.about-section {
  background: var(--bg-light);
  padding: 100px 80px;
  margin: 0 20px;
  border-radius: 20px;
}

.about-section .about-heading {
  text-align: center;
  font-size: 40px !important;
  font-weight: 700 !important;
  color: var(--color-primary) !important;
  margin-bottom: 80px !important;
}

.about-section .about-content {
  display: flex !important;
  flex-direction: row !important;
  gap: 60px !important;
  justify-content: center !important;
  align-items: flex-start !important;
  position: relative;
  flex-wrap: wrap;
}

.about-section .image-wrapper {
  position: relative;
  width: 35%;
}

.about-section .main-image {
  width: 100%;
  height: 520px;
  object-fit: cover;
  border-radius: 24px;
  position: relative;
  z-index: 1;
  --r: 30px;
  --s: 50px;
  --x: 30px;
  --y: 20px;
  border-radius: var(--r);
  --_m: / calc(2 * var(--r)) calc(2 * var(--r)) radial-gradient(#000 70%, #0000 72%);
  --_g: conic-gradient(at calc(100% - var(--r)) var(--r), #0000 25%, #000 0);
  --_d: calc(var(--s) + var(--r));
  mask: calc(100% - var(--_d) - var(--x)) 0 var(--_m), 100% calc(var(--_d) + var(--y)) var(--_m), radial-gradient(var(--s) at 100% 0, #0000 99%, #000 calc(100% + 1px)) calc(-1 * var(--r) - var(--x)) calc(var(--r) + var(--y)), var(--_g) calc(-1 * var(--_d) - var(--x)) 0, var(--_g) 0 calc(var(--_d) + var(--y));
  -webkit-mask: calc(100% - var(--_d) - var(--x)) 0 var(--_m), 100% calc(var(--_d) + var(--y)) var(--_m), radial-gradient(var(--s) at 100% 0, #0000 99%, #000 calc(100% + 1px)) calc(-1 * var(--r) - var(--x)) calc(var(--r) + var(--y)), var(--_g) calc(-1 * var(--_d) - var(--x)) 0, var(--_g) 0 calc(var(--_d) + var(--y));
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
}

.about-section .badge-circle {
  position: absolute;
  top: -20px;
  right: -20px;
  width: 100px;
  height: 100px;
  border-radius: 50%;
  background: var(--color-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: visible;
  z-index: 2;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
}

.about-section .badge-circle svg {
  width: 100%;
  height: 100%;
  animation: rotateText 10s linear infinite;
}

.about-section .badge-circle text {
  fill: var(--white);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 1.5px;
}

.about-section .badge-circle circle {
  fill: var(--white);
}

@keyframes rotateText {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.about-section .text-content {
  width: 45%;
}

.about-section .check-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 30px;
}

.about-section .check-item {
  display: flex;
  align-items: center;
  gap: 10px;
  color: #0a3b3b;
}

.about-section .check-item svg {
  color: #0c6e6d;
}

.about-section .actions {
  display: flex;
  align-items: center;
  gap: 30px;
}

.about-section .about-btn {
  background: var(--color-secondary) !important;
  color: var(--white) !important;
  padding: 10px 26px !important;
  border-radius: 30px !important;
  text-transform: none !important;
  white-space: nowrap;
}

.about-section .email {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #0a3b3b;
  font-weight: 500;
}

.about-section .email svg {
  color: #0c6e6d;
}

.about-section .small-image {
  display: flex;
}

.about-section .small-image img {
  width: 180px;
  height: 220px;
  object-fit: cover;
  border-radius: 16px;
}

@media (max-width: 992px) {
  .about-section .about-content {
    flex-direction: column !important;
    align-items: center !important;
  }

  .about-section .about-content .image-wrapper {
    width: 100%;
  }

  .about-section .text-content {
    width: 100%;
  }

  .about-section .small-image {
    display: none;
  }
}

@media (max-width: 560px) {
  .about-section {
    padding: 30px 20px;
  }

  .about-section .text-content .row {
    flex-direction: column;
  }

  .about-section .text-content .row .col {
    width: 100%;
  }

  .about-section .check-list {
    width: 100%;
  }

  .about-section .actions {
    flex-wrap: wrap;
  }
}
