/* Card */
.service-card {
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  background: #353535;
}

/* Media wrapper */
.service-media {
  position: absolute;
  inset: 0;
}

/* Image – visible top-left */
.service-media img {
  width: 380px;
  height: 288px;
  object-fit: cover;
  border-bottom-right-radius: 100%;
  transition: all 0.5s ease;
}

/* Image expands on hover */
.service-card:hover .service-media img {
  width: 100%;
  height: 100%;
  border-bottom-right-radius: 0;
}

/* Dark curved overlay */
.service-media::before,
.service-media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom right, rgb(0 0 0 / 0%), rgb(0 0 0 / 43%), #000000);
  transform: scale(0);
  transform-origin: top left;
  transition: transform 0.45s ease;
  pointer-events: none;
}

/* Second layer for depth */
.service-media::after {
  background: linear-gradient(to bottom right, rgb(48 161 61 / 24%), transparent);
}

/* Reveal overlay on hover */
.service-card:hover .service-media::before,
.service-card:hover .service-media::after {
  transform: scale(1);
}

/* Content – bottom right */
.service-content {
  position: relative;
  z-index: 2;
  height: 100%;
  padding: 260px 15px 16px 15px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-end;
  text-align: right;
  color: #fff;
}
 
.service-icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

/* Title */
.service-title {
  margin: 0 0 10px;
  font-size: 21px;
  color: #fff;
  font-weight: bold;
}

.service-title a {
  color: #fff;
  text-decoration: none;
}

/* Description */
.service-desc {
  font-size: 12px;
  max-width: 260px;
  /* opacity: 0.75; */
  margin-bottom: 0;
  transition: opacity 0.3s ease;
}

.service-card:hover .service-desc {
  opacity: 1;
}
 

.service-card:hover .service-btn {
  opacity: 1;
  transform: translateY(0);
}
