/* ==============================
   css/services.css
   ============================== */
.services-section { background: var(--color-bg-primary); }
.services-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 20px;
}
.service-card {
  background: linear-gradient(145deg, var(--color-bg-card), var(--color-bg-card2));
  border: 1px solid var(--color-border-card);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: var(--transition);
  position: relative;
}
.service-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--color-blue), var(--color-blue-dark));
  transform: scaleX(0);
  transition: transform 0.3s;
  transform-origin: left;
}
.service-card:hover { border-color: rgba(79,163,232,0.35); transform: translateY(-4px); }
.service-card:hover::before { transform: scaleX(1); }
.service-icon {
  width: 100%; height: 180px;
  overflow: hidden;
  background: var(--color-bg-card);
}
.service-icon img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}
.service-card:hover .service-icon img { transform: scale(1.05); }
.service-card h3 {
  font-size: 16px;
  font-weight: 700;
  color: var(--color-text-primary);
  margin: 18px 20px 8px;
}
.service-card p {
  font-size: 13px;
  color: var(--color-text-faint);
  line-height: 1.6;
  margin: 0 20px;
}
.service-link {
  display: inline-block;
  font-size: 13px;
  font-weight: 600;
  color: var(--color-blue);
  margin: 14px 20px 20px;
  transition: var(--transition);
}
.service-link:hover { letter-spacing: 0.5px; }
