/* Home Page Styles */
.page-container {
  background-color: var(--color-bg-white);
  padding: 1rem;
  box-shadow: 0 4px 6px -1px rgba(0,0,0,0.1);
  border: 1px solid var(--color-border);
  width: 100%;
}
@media (min-width: 768px) {
  .page-container { padding: 2rem; }
}

.section-block {
  margin-bottom: 3rem;
}

.section-title {
  font-size: 1.875rem;
  font-weight: 600;
  border-bottom: 2px solid var(--color-secondary);
  padding-bottom: 0.5rem;
  margin-bottom: 1.5rem;
  text-transform: uppercase;
  letter-spacing: -0.025em;
  color: var(--color-secondary);
  margin-top: 0;
}

.section-title-alt {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--color-secondary);
  margin-bottom: 1.5rem;
  border-left: 4px solid var(--color-primary);
  padding-left: 1rem;
}

.prose-text {
  color: #374151; /* gray-700 */
  line-height: 1.625;
}
.prose-text p {
  margin-top: 0;
  margin-bottom: 1rem;
}

.grid-2 { display: grid; gap: 1.5rem; }
@media (min-width: 768px) { .grid-2 { grid-template-columns: repeat(2, 1fr); } }

.grid-4 { display: grid; gap: 1.5rem; }
@media (min-width: 640px) { .grid-4 { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .grid-4 { grid-template-columns: repeat(4, 1fr); } }

/* Cards & Features */
.feature-card {
  padding: 1.25rem;
  background-color: #f9fafb; /* gray-50 */
  border-left: 4px solid var(--color-primary);
}
.feature-title {
  font-weight: 600;
  color: var(--color-secondary);
  margin: 0 0 0.5rem 0;
}
.feature-desc {
  font-size: 0.875rem;
  margin: 0;
  color: #4b5563; /* gray-600 */
}

/* Intro Cards */
.intro-grid {
  display: grid; gap: 1.5rem; margin-top: 2.5rem;
}
@media (min-width: 768px) { .intro-grid { grid-template-columns: repeat(2, 1fr); } }

.intro-card {
  display: flex; gap: 1rem; padding: 1.25rem;
  border: 1px solid #f3f4f6; /* gray-100 */
  background-color: #f9fafb; /* gray-50 */
  transition: all 0.3s;
}
.intro-card:hover {
  background-color: var(--color-bg-white);
  box-shadow: 0 4px 6px -1px rgba(0,0,0,0.1);
}
.intro-card-icon {
  color: var(--color-primary); flex-shrink: 0; width: 32px; height: 32px;
}

/* Services */
.services-list {
  display: flex; flex-direction: column; gap: 2rem;
  color: #374151; line-height: 1.625;
}
.service-item-title {
  font-size: 1.25rem; font-weight: 600; color: var(--color-text-main); margin: 0 0 0.75rem 0;
}
.service-item p { margin: 0; }

/* Pricing Table */
.pricing-subtitle {
  margin: 0 0 1.5rem 0; font-style: italic; color: #4b5563;
}
.pricing-table-wrapper {
  overflow-x: auto;
}
.pricing-table {
  width: 100%; border-collapse: collapse;
  border: 1px solid #d1d5db; /* gray-300 */
  text-align: left; box-shadow: 0 1px 2px 0 rgba(0,0,0,0.05);
}
.pricing-table th {
  padding: 1rem; border: 1px solid #d1d5db;
  background-color: var(--color-secondary); color: white;
  text-transform: uppercase; font-size: 0.875rem; font-weight: 600;
}
.pricing-table td {
  padding: 1rem; border: 1px solid #d1d5db;
}
.pricing-table tr { background-color: var(--color-bg-white); transition: background-color 0.3s; }
.pricing-table tr:hover { background-color: #f9fafb; }
.pricing-table tr.alt-row { background-color: #f9fafb; }
.pricing-table tr.alt-row:hover { background-color: #f3f4f6; }
.pricing-col-header { font-weight: 600; color: var(--color-text-main); }
.pricing-val { color: var(--color-primary-dark); font-weight: 700; font-size: 1.125rem; }
.text-center { text-align: center; }

/* Process */
.process-card {
  padding: 1.5rem; border: 1px solid var(--color-border);
  border-radius: 2px; background-color: var(--color-bg-white);
  transition: all 0.3s;
}
.process-card:hover { border-color: var(--color-primary); }
.process-number {
  display: block; font-size: 2.25rem; font-weight: 900; color: #64748b; /* slate-500 for WCAG AAA passing */
  transition: color 0.3s; margin-bottom: 1rem;
}
.process-card:hover .process-number { color: var(--color-primary); }
.process-title { font-weight: 600; font-size: 1.125rem; margin: 0 0 0.5rem 0; }
.process-desc { font-size: 0.875rem; color: #4b5563; margin: 0; line-height: 1.625; }

/* SEO Promo CTA */
.promo-box {
  background-color: #f9fafb; padding: 1.5rem;
  border-left: 4px solid var(--color-primary);
  margin: 1.5rem 0;
}
.promo-box-title { font-weight: 600; color: var(--color-secondary); margin: 0 0 0.5rem 0; }
.promo-box-desc { font-size: 0.875rem; margin-bottom: 1rem; }
.btn-link {
  color: var(--color-primary); font-weight: 600; font-size: 0.875rem; background: none; border: none; padding: 0; cursor: pointer; text-decoration: none;
}
.btn-link:hover { text-decoration: underline; }

/* Maintenance Box */
.maintenance-box {
  margin-top: 1rem; padding: 1rem; background-color: var(--color-secondary);
  color: white; border-radius: 2px;
}
.maintenance-text { font-size: 0.875rem; font-style: italic; margin: 0; }

/* FAQ */
.faq-list { display: flex; flex-direction: column; gap: 1.5rem; }
.faq-item { border-left: 4px solid var(--color-primary); padding-left: 1rem; }
.faq-q { font-weight: 600; color: var(--color-text-main); margin: 0 0 0.5rem 0; }
.faq-a { font-size: 0.875rem; color: #4b5563; margin: 0; }

/* Portfolio */
.portfolio-card {
  position: relative; overflow: hidden; background-color: #f3f4f6;
  border: 1px solid var(--color-border); box-shadow: 0 1px 2px 0 rgba(0,0,0,0.05);
  transition: transform 0.3s;
}
.portfolio-img {
  width: 100%; height: 12rem; object-fit: cover;
  transition: transform 0.5s;
}
.portfolio-card:hover .portfolio-img { transform: scale(1.05); }
.portfolio-content { padding: 1rem; position: relative; z-index: 2; background-color: var(--color-bg-white); }
.portfolio-title { font-weight: 600; color: var(--color-secondary); margin: 0; }
.portfolio-subtitle { font-size: 0.75rem; color: #6b7280; margin: 0; }

/* Testimonials */
.testimonials-section {
  background-color: #f9fafb; padding: 2rem; border: 1px solid var(--color-border);
}
.testimonials-title {
  font-size: 1.5rem; font-weight: 600; color: var(--color-secondary);
  margin-bottom: 2rem; text-align: center; text-transform: uppercase; letter-spacing: -0.025em;
}
.testimonial-card {
  background-color: var(--color-bg-white); padding: 1.5rem;
  box-shadow: 0 1px 2px 0 rgba(0,0,0,0.05); border: 1px solid #f3f4f6;
  position: relative;
}
.testimonial-quote-mark {
  color: var(--color-primary); font-size: 2.25rem; font-family: serif;
  position: absolute; top: 0.5rem; left: 1rem; opacity: 0.2; line-height: 1;
}
.testimonial-text {
  font-size: 0.875rem; color: #4b5563; font-style: italic; margin: 0 0 1rem 0;
  position: relative; z-index: 10; line-height: 1.5;
}
.testimonial-author-wrapper { display: flex; align-items: center; gap: 0.75rem; }
.testimonial-avatar { width: 2.5rem; height: 2.5rem; background-color: #e5e7eb; border-radius: 50%; overflow: hidden; }
.testimonial-avatar img { width: 100%; height: 100%; object-fit: cover; }
.testimonial-name { font-weight: 600; font-size: 0.875rem; margin: 0; }
.testimonial-role { font-size: 0.75rem; color: #6b7280; margin: 0; }

/* CTA Section */
.cta-block {
  background-color: var(--color-secondary); color: white; padding: 2.5rem;
  text-align: center; border-radius: 2px; box-shadow: 0 20px 25px -5px rgba(0,0,0,0.1);
}
.cta-title { font-size: 1.5rem; font-weight: 600; margin: 0 0 1rem 0; }
.cta-text { margin: 0 0 2rem 0; opacity: 0.8; }
.cta-actions { display: flex; flex-direction: column; justify-content: center; gap: 1rem; }
@media (min-width: 640px) { .cta-actions { flex-direction: row; } }
.btn-primary {
  background-color: var(--color-primary); color: white; padding: 0.75rem 2rem;
  font-weight: 600; text-transform: uppercase; border: none; cursor: pointer; transition: background-color 0.3s;
}
.btn-primary:hover { background-color: var(--color-primary-dark); }
