/* ===========================================
   NEXACOM THEME — services.css
=========================================== */

.services {
  background: var(--bg);
}

.services-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 52px;
  flex-wrap: wrap;
  gap: 20px;
}

.services-all {
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid var(--border);
}

.services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border);
}

.services-grid-row2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: var(--border);
  border-top: 1px solid var(--border);
  max-width: calc(66.66% + 1px);
  margin: 0 auto;
}

/* ── CARD ── */
.service-card {
  background: var(--bg-card);
  padding: 44px 36px;
  position: relative;
  overflow: hidden;
  transition: background var(--tr);
  cursor: default;
}

.service-card::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--violet), var(--accent));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .4s ease;
}
.service-card:hover::after { transform: scaleX(1); }

[data-theme="dark"]  .service-card:hover { background: #16151f; }
[data-theme="light"] .service-card:hover { background: #f7f6ff; }

.service-num {
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .15em;
  color: var(--text-f);
  margin-bottom: 24px;
}

.service-icon {
  width: 70px;
  height: 70px;
  background: rgba(91,33,245,.1);
  border: 1px solid rgba(91,33,245,.18);
  border-radius: 13px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
  transition: background .3s, border-color .3s;
}
.service-card:hover .service-icon {
  background: rgba(91,33,245,.22);
  border-color: rgba(91,33,245,.4);
}

.service-title {
  font-size: 1.05rem;
  font-weight: 700;
  margin-bottom: 12px;
  line-height: 1.3;
  color: var(--text);
}

.service-desc {
  font-size: .86rem;
  line-height: 1.75;
  color: var(--text-m);
  font-weight: 300;
}

.service-arrow {
  margin-top: 24px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .04em;
  color: var(--violet-mid);
  opacity: 0;
  transform: translateX(-8px);
  transition: opacity .3s, transform .3s;
}
.service-card:hover .service-arrow {
  opacity: 1;
  transform: translateX(0);
}

/* ── RESPONSIVE ── */
@media (max-width: 768px) {
  .services-grid      { grid-template-columns: 1fr 1fr; }
  .services-grid-row2 { grid-template-columns: 1fr; max-width: 100%; }
}
@media (max-width: 540px) {
  .services-grid { grid-template-columns: 1fr; }
}
