/* ============================================
   Service Detail Page (SDP) Styles
   ============================================ */

/* Hero Section */
.sdp-hero-section { background: var(--color-white); }
.sdp-hero-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-12); align-items: center; }
.sdp-hero-image { border-radius: var(--radius-xl); overflow: hidden; box-shadow: var(--shadow-lg); }
.sdp-hero-image img { width: 100%; height: 400px; object-fit: cover; display: block; }
.sdp-hero-content h2 { color: var(--color-primary-800); margin-bottom: var(--space-4); font-size: var(--text-2xl); }
.sdp-hero-content p { color: var(--color-neutral-600); line-height: var(--leading-relaxed); margin-bottom: var(--space-4); }

/* Highlights */
.sdp-highlights { display: flex; flex-direction: column; gap: var(--space-4); margin-top: var(--space-6); }
.sdp-highlight-item { display: flex; align-items: center; gap: var(--space-4); padding: var(--space-4); background: var(--color-primary-50); border-radius: var(--radius-lg); border-left: 4px solid var(--color-primary-500); }
.sdp-highlight-icon { font-size: 28px; flex-shrink: 0; }
.sdp-highlight-item div { display: flex; flex-direction: column; }
.sdp-highlight-item strong { color: var(--color-neutral-800); font-size: var(--text-base); }
.sdp-highlight-item span:last-child { color: var(--color-neutral-500); font-size: var(--text-sm); }

/* Process Section */
.sdp-process-section { background: var(--color-nature-bg); }
.sdp-process-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-6); }
.sdp-process-step { background: var(--color-white); border-radius: var(--radius-xl); padding: var(--space-8); text-align: center; box-shadow: var(--shadow-card); position: relative; transition: transform var(--transition-base), box-shadow var(--transition-base); }
.sdp-process-step:hover { transform: translateY(-4px); box-shadow: var(--shadow-card-hover); }
.sdp-process-number { font-size: var(--text-4xl); font-weight: var(--font-extrabold); color: var(--color-primary-200); margin-bottom: var(--space-3); }
.sdp-process-step h3 { color: var(--color-primary-800); font-size: var(--text-lg); margin-bottom: var(--space-2); }
.sdp-process-step p { color: var(--color-neutral-600); font-size: var(--text-sm); line-height: var(--leading-relaxed); }

/* Places Section */
.sdp-places-section { background: var(--color-white); }
.sdp-places-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: var(--space-4); }
.sdp-place-card { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-4) var(--space-5); background: var(--color-primary-50); border-radius: var(--radius-lg); font-weight: var(--font-medium); color: var(--color-primary-800); transition: all var(--transition-fast); border: 1px solid var(--color-primary-100); }
.sdp-place-card:hover { background: var(--color-primary-100); transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.sdp-place-card span { font-size: 20px; }

/* FAQ Section */
.sdp-faq-section { background: var(--color-nature-bg); }
.sdp-faq-list { max-width: 800px; margin: 0 auto; }

/* Related Section */
.sdp-related-section { background: var(--color-white); }
.sdp-related-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
.sdp-related-card { display: block; background: var(--color-white); border: 1px solid var(--color-primary-100); border-radius: var(--radius-xl); padding: var(--space-8); text-align: center; text-decoration: none; transition: all var(--transition-base); }
.sdp-related-card:hover { border-color: var(--color-primary-400); box-shadow: var(--shadow-card-hover); transform: translateY(-4px); }
.sdp-related-icon { font-size: 36px; display: block; margin-bottom: var(--space-3); }
.sdp-related-card h3 { color: var(--color-primary-800); font-size: var(--text-lg); margin-bottom: var(--space-2); }
.sdp-related-card p { color: var(--color-neutral-500); font-size: var(--text-sm); }

/* ── Responsive ── */
@media (max-width: 1024px) {
  .sdp-hero-grid { grid-template-columns: 1fr; }
  .sdp-process-grid { grid-template-columns: repeat(2, 1fr); }
  .sdp-related-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  .sdp-hero-image img { height: 280px; }
  .sdp-process-grid { grid-template-columns: 1fr; }
  .sdp-related-grid { grid-template-columns: 1fr; }
  .sdp-places-grid { grid-template-columns: repeat(2, 1fr); }
}
