/* ============================================================
   DIFO — service.css  研修プログラム一覧ページ専用スタイル
   共通スタイルは common.css を参照
   ============================================================ */

/* ============================================================
   SECTION
   ============================================================ */
.svc-section {
  background: var(--neutral-light);
}

.svc-section .section-title {
  text-align: center;
  margin-bottom: 12px;
}

.svc-section__desc {
  text-align: center;
  font-size: 0.92rem;
  color: var(--neutral-medium);
  margin: 0 auto 52px;
  line-height: 1.75;
}

/* ============================================================
   GRID
   ============================================================ */
.svc-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 28px;
}

/* ============================================================
   SERVICE CARD
   ============================================================ */
.svc-card {
  background: var(--white);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  border: 1px solid rgba(47, 122, 182, 0.1);
  display: flex;
  flex-direction: column;
  transition: box-shadow 0.35s var(--ease), transform 0.35s var(--ease);
}

.svc-card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-6px);
}

/* ── Image area ── */
.svc-card__image {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  flex-shrink: 0;
}

.svc-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s var(--ease);
}

.svc-card:hover .svc-card__image img {
  transform: scale(1.06);
}

.svc-card__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(10, 34, 54, 0.78) 0%,
    rgba(10, 34, 54, 0.15) 50%,
    transparent 100%
  );
}

.svc-card__image-footer {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 18px 22px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.svc-card__eyebrow {
  font-family: var(--font-display);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--accent-color);
  background: rgba(35, 214, 201, 0.18);
  border: 1px solid rgba(35, 214, 201, 0.38);
  padding: 3px 10px;
  border-radius: var(--radius-pill);
}

.svc-card__badge {
  font-family: var(--font-display);
  font-size: 0.72rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.85);
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.22);
  padding: 3px 11px;
  border-radius: var(--radius-pill);
  white-space: nowrap;
}

/* ── Body ── */
.svc-card__body {
  padding: 28px 28px 26px;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.svc-card__body h3 {
  font-family: var(--font-display);
  font-size: clamp(1.1rem, 2vw, 1.3rem);
  font-weight: 700;
  color: var(--neutral-dark);
  letter-spacing: -0.02em;
  line-height: 1.3;
}

.svc-card__body p {
  font-size: 0.9rem;
  color: var(--neutral-medium);
  line-height: 1.85;
  flex: 1;
}

/* Tags */
.svc-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.svc-card__tags span {
  font-family: var(--font-display);
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--primary-color);
  background: var(--primary-bg);
  border: 1px solid var(--primary-light);
  padding: 3px 11px;
  border-radius: var(--radius-pill);
  white-space: nowrap;
  transition: background 0.2s, color 0.2s;
}

.svc-card:hover .svc-card__tags span {
  background: var(--primary-light);
}

/* CTA */
.svc-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: var(--font-display);
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--primary-color);
  padding-top: 4px;
  border-top: 1px solid rgba(47, 122, 182, 0.1);
  transition: gap 0.2s var(--ease), color 0.2s;
}

.svc-card__cta svg {
  width: 17px;
  height: 17px;
  flex-shrink: 0;
  transition: transform 0.2s var(--ease);
}

.svc-card:hover .svc-card__cta {
  gap: 12px;
  color: var(--primary-hover);
}

.svc-card:hover .svc-card__cta svg {
  transform: translateX(4px);
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 860px) {
  .svc-grid {
    grid-template-columns: 1fr;
    max-width: 580px;
    margin: 0 auto;
  }
}

@media (max-width: 560px) {
  .svc-card__body {
    padding: 22px 20px 20px;
    gap: 12px;
  }

  .svc-card__image-footer {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }
}
