/* Services page styles */
.page-hero { position: relative; overflow: hidden; background: var(--color-gray-50); }
.page-hero .hero-media { position: absolute; inset: 0; z-index: 0; }
.page-hero .hero-media img { width: 100%; height: 100%; object-fit: cover; filter: saturate(0.9) contrast(0.95) brightness(0.98); }
.page-hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(31,26,18,0.25), rgba(247,243,238,0.85)); z-index: 1; }
.page-hero .hero-inner { position: relative; z-index: 2; padding-top: clamp(72px, 14vh, 160px); padding-bottom: clamp(48px, 10vh, 120px); }
.page-hero h1 { max-width: 18ch; }
.page-hero .hero-tagline { font-size: var(--font-size-lg); color: var(--color-muted); max-width: 55ch; }
.page-hero .hero-ctas { display: flex; gap: var(--space-3); margin-top: var(--space-5); flex-wrap: wrap; }

.section { padding-block: var(--space-16); }
.section-header { margin-bottom: var(--space-6); }
.section-figure { border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-md); margin-top: var(--space-6); }

.services-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: var(--space-6); }
.service-card h3 { margin-bottom: var(--space-2); }

.benefits-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: var(--space-3) var(--space-6); list-style: none; padding: 0; }
.benefits-list li { position: relative; padding-left: 28px; }
.benefits-list li::before { content: ""; position: absolute; left: 0; top: 0.55em; width: 14px; height: 14px; border-radius: var(--radius-full); background: radial-gradient(circle at 35% 35%, var(--color-primary-600), var(--color-primary-700)); box-shadow: 0 0 0 2px rgba(200,169,106,0.25); }

.process-steps { counter-reset: step; display: grid; gap: var(--space-5); list-style: none; padding: 0; }
.process-steps > li { position: relative; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-6); box-shadow: var(--shadow-sm); }
.process-steps > li::before { counter-increment: step; content: counter(step); position: absolute; left: -10px; top: -10px; width: 40px; height: 40px; display: grid; place-items: center; background: var(--color-primary-600); color: var(--color-on-primary); border-radius: var(--radius-full); box-shadow: var(--shadow-md); font-weight: 600; }
.step-title { margin-bottom: var(--space-2); }

.packages-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: var(--space-6); }
.pricing-card { border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-6); background: var(--color-surface); box-shadow: var(--shadow-sm); position: relative; }
.pricing-card--featured { border-color: rgba(200,169,106,0.5); box-shadow: var(--shadow-lg); }
.pricing-card h3 { font-size: var(--font-size-2xl); margin-bottom: var(--space-2); }
.pricing-card .pricing { color: var(--color-primary-700); font-weight: 600; margin-bottom: var(--space-3); }
.pricing-card .features { list-style: none; padding: 0; margin: 0 0 var(--space-5); display: grid; gap: var(--space-2); }
.pricing-card .features li { padding-left: 24px; position: relative; }
.pricing-card .features li::before { content: ""; position: absolute; left: 0; top: 0.55em; width: 10px; height: 10px; border-radius: var(--radius-full); background: var(--color-primary-600); }
.pricing-card .card-actions { display: flex; gap: var(--space-3); flex-wrap: wrap; }

.testimonials-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: var(--space-6); }
.testimonial blockquote { color: var(--color-text); font-size: var(--font-size-lg); line-height: var(--line-height-snug); }
.testimonial figcaption { margin-top: var(--space-3); color: var(--color-muted); font-size: var(--font-size-sm); }

.faq-list { display: grid; gap: var(--space-3); }
.faq-item { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-3) var(--space-4); }
.faq-item[open] { box-shadow: var(--shadow-sm); }
.faq-item summary { cursor: pointer; font-weight: 600; list-style: none; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: "+"; float: right; transition: transform var(--duration-normal) var(--easing-standard); }
.faq-item[open] summary::after { transform: rotate(45deg); }
.faq-content { margin-top: var(--space-2); color: var(--color-muted); }

.team-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: var(--space-6); margin-top: var(--space-4); }
.team-member .team-name { margin-bottom: var(--space-1); }
.team-member .team-role { color: var(--color-primary-700); font-weight: 600; margin-bottom: var(--space-2); }

.contact-wrap { display: grid; grid-template-columns: 1.2fr 0.8fr; gap: var(--space-6); }
.contact-form .form-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-4); }
.contact-form .form-field--full { grid-column: 1 / -1; }
.contact-info h3 { margin-bottom: var(--space-2); }
.contact-info .card-actions { margin-top: var(--space-3); display: flex; gap: var(--space-3); flex-wrap: wrap; }

@media (max-width: 880px) {
  .contact-wrap { grid-template-columns: 1fr; }
  .contact-form .form-grid { grid-template-columns: 1fr; }
}

/* Reveal on scroll */
.reveal { opacity: 0; transform: translateY(10px); transition: opacity var(--duration-slow) var(--easing-standard), transform var(--duration-slow) var(--easing-standard); }
.reveal.is-visible { opacity: 1; transform: translateY(0); }
