/* =====================================================
   theContt — Home page styles
   ===================================================== */

/* ─── Seção: Problemas ─── */
.problems-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-6);
}

.problem-item {
  display: flex;
  gap: var(--sp-4);
  align-items: flex-start;
  padding: var(--sp-6);
  background: var(--color-surface);
  border-radius: var(--radius-xl);
  border: 1px solid var(--color-border);
}

.problem-icon {
  font-size: 1.5rem;
  flex-shrink: 0;
  margin-top: 2px;
}

.problem-item h3 {
  font-size: var(--text-base);
  font-weight: var(--fw-semibold);
  margin-bottom: var(--sp-1);
}

.problem-item p {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.6;
}

/* ─── Seção: Por que a theContt ─── */
.why-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-16);
  align-items: center;
}

.why-content {}

.why-content h2 { margin-bottom: var(--sp-4); }

.why-content > p {
  font-size: var(--text-lg);
  color: var(--color-text-muted);
  margin-bottom: var(--sp-8);
}

.why-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  margin-bottom: var(--sp-8);
}

.why-item {
  display: flex;
  gap: var(--sp-4);
  align-items: flex-start;
}

.why-check {
  width: 24px;
  height: 24px;
  border-radius: var(--radius-full);
  background: var(--color-cta);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: var(--fw-bold);
  flex-shrink: 0;
  margin-top: 1px;
}

.why-item-text h4 {
  font-size: var(--text-base);
  font-weight: var(--fw-semibold);
  margin-bottom: var(--sp-1);
}

.why-item-text p {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.6;
}

.why-visual {
  position: relative;
}

.why-stats-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-2xl);
  padding: var(--sp-8);
  box-shadow: var(--shadow-lg);
}

.why-stats-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-4);
}

.why-stat {
  text-align: center;
  padding: var(--sp-5);
  border-radius: var(--radius-lg);
  background: var(--color-bg);
}

.why-stat-num {
  font-size: var(--text-3xl);
  font-weight: var(--fw-bold);
  color: var(--color-primary);
  line-height: 1;
  margin-bottom: var(--sp-1);
}

.why-stat-label {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  font-weight: var(--fw-medium);
}

.why-stat--cta .why-stat-num { color: var(--color-cta); }

/* ─── Seção: Serviços (home preview) ─── */
.services-preview {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-6);
}

/* ─── Seção: Para quem (público-alvo) ─── */
.audience-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-6);
}

.audience-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--sp-7);
  text-align: center;
}

.audience-emoji {
  font-size: 2.5rem;
  margin-bottom: var(--sp-4);
  display: block;
}

.audience-card h3 {
  font-size: var(--text-lg);
  margin-bottom: var(--sp-2);
}

.audience-card p {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.6;
}

/* ─── Seção: Processo ─── */
.processo-steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-6);
  position: relative;
}

.processo-steps::before {
  content: '';
  position: absolute;
  top: 28px;
  left: calc(12.5% + 28px);
  right: calc(12.5% + 28px);
  height: 2px;
  background: repeating-linear-gradient(
    to right,
    var(--color-border) 0,
    var(--color-border) 6px,
    transparent 6px,
    transparent 12px
  );
}

.processo-step {
  text-align: center;
  position: relative;
}

.processo-num {
  width: 56px;
  height: 56px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: #fff;
  font-weight: var(--fw-bold);
  font-size: var(--text-xl);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--sp-4);
  position: relative;
  z-index: 1;
  border: 3px solid var(--color-bg);
}

.processo-step h3 {
  font-size: var(--text-base);
  font-weight: var(--fw-semibold);
  margin-bottom: var(--sp-2);
}

.processo-step p {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.6;
}

/* ─── Seção: Depoimentos ─── */
.testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-6);
}

/* ─── Seção: Calculadoras (home preview) ─── */
.calcs-preview-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-6);
}

.calc-preview-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--sp-7);
  text-align: center;
  transition: box-shadow var(--transition-normal), transform var(--transition-normal);
}

.calc-preview-card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-3px);
}

.calc-preview-icon {
  width: 64px;
  height: 64px;
  border-radius: var(--radius-xl);
  background: var(--color-cta-light);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--sp-4);
  font-size: 1.75rem;
}

.calc-preview-card h3 {
  font-size: var(--text-lg);
  margin-bottom: var(--sp-2);
}

.calc-preview-card p {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.6;
  margin-bottom: var(--sp-5);
}

@media (max-width: 1024px) {
  .processo-steps { grid-template-columns: repeat(2, 1fr); }
  .processo-steps::before { display: none; }
}

@media (max-width: 900px) {
  .problems-grid { grid-template-columns: 1fr; }
  .why-grid { grid-template-columns: 1fr; gap: var(--sp-10); }
  .why-visual { display: none; }
  .services-preview { grid-template-columns: 1fr; }
  .audience-grid { grid-template-columns: 1fr 1fr; }
  .testimonials-grid { grid-template-columns: 1fr; }
  .calcs-preview-grid { grid-template-columns: 1fr; }
}

@media (max-width: 600px) {
  .audience-grid { grid-template-columns: 1fr; }
  .processo-steps { grid-template-columns: 1fr; }
}
