/* ===== SERVICE OVERVIEW CARDS ===== */
.svc-overview { background: var(--color-white); }

.svc-overview-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; }

.svc-overview-card {
  padding: clamp(20px, 2.5vw, 32px); border: 1px solid var(--color-border); text-align: center;
  transition: all 0.35s ease; position: relative; overflow: hidden;
  cursor: pointer; text-decoration: none; color: var(--color-text); display: block;
}

.svc-overview-card::before {
  content: '';
  position: absolute; top: 0; left: 0; width: 100%; height: 2px;
  background: var(--color-accent); transform: scaleX(0); transform-origin: left; transition: transform 0.4s ease;
}

.svc-overview-card:hover::before { transform: scaleX(1); }
.svc-overview-card:hover { box-shadow: 0 8px 30px rgba(27,79,114,0.08); transform: translateY(-4px); }

.svc-overview-icon {
  width: 48px; height: 48px; border-radius: 50%; background: var(--color-cream);
  display: flex; align-items: center; justify-content: center; margin: 0 auto 14px;
}

.svc-overview-icon svg { width: 22px; height: 22px; stroke: var(--color-primary); fill: none; stroke-width: 1.5; }
.svc-overview-en { font-family: var(--font-serif-en); font-size: 10px; letter-spacing: 0.12em; color: var(--color-accent); text-transform: uppercase; margin-bottom: 4px; }
.svc-overview-title { font-family: var(--font-serif-jp); font-size: 14px; font-weight: 500; color: var(--color-primary); letter-spacing: 0.04em; }

/* ===== SERVICE DETAIL BLOCK ===== */
.svc-block { position: relative; }

.svc-block-inner {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 6vw, 80px); align-items: center;
}

.svc-block-inner.reverse { direction: rtl; }
.svc-block-inner.reverse > * { direction: ltr; }

.svc-visual { position: relative; }

.svc-visual-main {
  width: 100%; aspect-ratio: 4/3; border-radius: 4px; overflow: hidden; position: relative;
  display: flex; align-items: center; justify-content: center;
}

.svc-visual-icon-wrap {
  width: 80px; height: 80px; border-radius: 50%; background: var(--color-white);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 20px rgba(0,0,0,0.06); position: relative; z-index: 2;
}

.svc-visual-icon-wrap svg { width: 36px; height: 36px; stroke: var(--color-primary); fill: none; stroke-width: 1.5; }

.svc-num {
  position: absolute; top: 16px; left: 16px;
  font-family: var(--font-serif-en); font-size: 60px; font-weight: 300; color: rgba(27,79,114,0.06); line-height: 1;
}

.svc-en { font-family: var(--font-serif-en); font-size: 12px; letter-spacing: 0.2em; color: var(--color-accent); text-transform: uppercase; margin-bottom: 8px; }
.svc-title { font-family: var(--font-serif-jp); font-size: clamp(22px, 2.4vw, 30px); font-weight: 500; color: var(--color-primary); margin-bottom: 20px; letter-spacing: 0.06em; line-height: 1.6; }
.svc-desc { font-size: 14px; color: var(--color-text-light); line-height: 2.2; margin-bottom: 28px; }

.svc-features { list-style: none; display: flex; flex-direction: column; gap: 12px; }

.svc-features li {
  display: flex; align-items: flex-start; gap: 12px;
  font-size: 13px; color: var(--color-text); line-height: 1.8;
}

.svc-features li::before {
  content: '';
  flex-shrink: 0; width: 18px; height: 18px; margin-top: 3px;
  border-radius: 50%; background: var(--color-cream);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235B8FA8' stroke-width='2'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");
  background-size: 11px; background-repeat: no-repeat; background-position: center;
}

/* ===== SERVICE DETAIL BACKGROUNDS ===== */
.svc-detail-1 { background: var(--color-bg); }
.svc-detail-2 { background: var(--color-white); }
.svc-detail-3 { background: var(--color-bg); }
.svc-detail-4 { background: var(--color-cream); }
.svc-detail-5 { background: var(--color-white); }

.svc-visual-1 { background: linear-gradient(145deg, #dce6ed 0%, #c5d3de 100%); }
.svc-visual-2 { background: linear-gradient(145deg, #e3e9ee 0%, #d0dce5 100%); }
.svc-visual-3 { background: linear-gradient(145deg, #dae4ec 0%, #c8d8e4 100%); }
.svc-visual-4 { background: linear-gradient(145deg, #dee8ef 0%, #cdd9e2 100%); }
.svc-visual-5 { background: linear-gradient(145deg, #e0eaf0 0%, #d2dee7 100%); }

/* ===== RESPONSIVE ===== */
@media (max-width: 1024px) {
  .svc-block-inner { grid-template-columns: 1fr; }
  .svc-block-inner.reverse { direction: ltr; }
  .svc-overview-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 640px) {
  .svc-overview-grid { grid-template-columns: 1fr 1fr; }
}
