/* ============================================================
   SERVICES.CSS — asymmetric gradient-border cards w/ expand-on-hover
   ============================================================ */

.services-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: minmax(220px, auto);
  gap: 1.2rem;
}

/* Asymmetric spans — deliberately uneven layout */
.s-seo     { grid-column: span 3; }
.s-ads     { grid-column: span 3; }
.s-brand   { grid-column: span 2; }
.s-social  { grid-column: span 2; }
.s-content { grid-column: span 2; }
.s-web     { grid-column: span 3; }
/* make one card breathe wider */
.s-seo { grid-column: span 4; }
.s-ads { grid-column: span 2; }

.service-card {
  position: relative;
  padding: 1.8rem;
  border-radius: var(--radius);
  background: var(--bg-2);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  transition: transform 0.3s var(--ease);
  transform-style: preserve-3d;
  will-change: transform;
}

/* Animated gradient border via pseudo-element mask */
.service-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: var(--radius);
  padding: 1.4px;
  background: var(--grad);
  background-size: 200% 200%;
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity: 0.35;
  transition: opacity 0.4s var(--ease);
  animation: borderFlow 6s linear infinite;
}
.service-card:hover::before { opacity: 1; }
@keyframes borderFlow {
  to { background-position: 200% 200%; }
}

/* Soft glow wash that appears on hover */
.service-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(120% 80% at 50% 120%, rgba(124,58,237,0.25), transparent 70%);
  opacity: 0;
  transition: opacity 0.45s var(--ease);
}
.service-card:hover::after { opacity: 1; }

.svc-icon {
  width: 54px; height: 54px;
  border-radius: 14px;
  display: grid; place-items: center;
  background: var(--grad-soft);
  border: 1px solid var(--glass-brd);
  margin-bottom: auto;
  position: relative; z-index: 1;
  transition: transform 0.4s var(--ease);
}
.svc-icon svg {
  width: 26px; height: 26px;
  fill: none; stroke: var(--neon); stroke-width: 1.8;
  stroke-linecap: round; stroke-linejoin: round;
  transition: stroke 0.4s var(--ease);
}
.service-card:hover .svc-icon { transform: translateY(-4px) rotate(-6deg) scale(1.05); }
.service-card:hover .svc-icon svg { stroke: var(--pink); }

.service-card h3 {
  position: relative; z-index: 1;
  font-size: 1.5rem;
  margin: 1.4rem 0 0.5rem;
}
.svc-short { position: relative; z-index: 1; color: var(--muted); font-size: 0.95rem; }

/* Expand-on-hover detail text */
.svc-more {
  position: relative; z-index: 1;
  color: var(--muted);
  font-size: 0.9rem;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transform: translateY(8px);
  transition: max-height 0.5s var(--ease), opacity 0.4s var(--ease), transform 0.4s var(--ease), margin 0.4s var(--ease);
}
.service-card:hover .svc-more {
  max-height: 120px;
  opacity: 1;
  margin-top: 0.7rem;
  transform: translateY(0);
}

.svc-index {
  position: absolute;
  top: 1.4rem; right: 1.6rem;
  font-family: var(--font-mono);
  font-size: 0.8rem;
  color: rgba(255,255,255,0.25);
  z-index: 1;
}
