/**
 * Estilos reutilizáveis para páginas de produto (hero, destaques, vantagens, blocos técnicos, carrossel).
 * Incluir após templatemo-snapx-photography.css nas páginas que usarem estas classes.
 */

/* ── Hero do produto ── */
.pp-hero-banner {
  padding-top: 140px;
  padding-bottom: 60px;
}

.pp-hero-text {
  text-align: left;
}

.pp-hero-heading {
  align-items: flex-start;
  text-align: left;
  margin-bottom: 0;
}

.pp-hero-lead {
  margin-top: 20px;
  max-width: 520px;
}

/* ── Seção de conteúdo (padding alternativo ao padrão) ── */
.pp-content-tight {
  padding: 60px 0;
}

/* ── Títulos de bloco ── */
.pp-block-heading {
  margin-bottom: 36px;
}

.pp-block-heading--left {
  align-items: flex-start;
  text-align: left;
}

/* ── Linha de cards de destaque (3 colunas) ── */
.pp-highlight-row {
  margin-top: 40px;
  margin-bottom: 40px;
}

.pp-highlight-col {
  min-width: 0;
}

.pp-highlight-card {
  background: #f0faf5;
  border-radius: 14px;
  padding: 28px 24px;
  text-align: center;
  height: 100%;
  border-left: 4px solid #00934f;
}

.pp-highlight-icon {
  font-size: 2rem;
  color: #00934f;
  margin-bottom: 12px;
}

.pp-highlight-title {
  font-weight: 700;
  color: #222;
  margin-bottom: 8px;
}

.pp-highlight-body {
  margin: 0;
  font-size: 0.95rem;
}

/* ── Vantagens + imagem lateral ── */
.pp-advantages-row {
  margin-top: 50px;
}

.pp-check-list {
  list-style: none;
  padding: 0;
  margin-top: 20px;
}

.pp-check-list__item {
  padding: 10px 0;
  border-bottom: 1px solid #eee;
  display: flex;
  align-items: center;
  gap: 12px;
}

.pp-check-list__item:last-child {
  border-bottom: none;
}

.pp-check-list__icon {
  color: #00934f;
  font-size: 1.1rem;
  flex-shrink: 0;
}

.pp-side-image {
  max-width: 100%;
  border-radius: 14px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.14);
}

/* ── Blocos técnicos (observações) ── */
.pp-tech-row {
  margin-top: 60px;
}

.pp-tech-block {
  background: #fff;
  border-radius: 14px;
  padding: 28px 30px;
  margin-bottom: 20px;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
  border-left: 4px solid #00934f;
}

.pp-tech-block__title {
  font-weight: 700;
  color: #00934f;
  margin-bottom: 12px;
  font-size: 1.1rem;
}

.pp-tech-block__title i {
  margin-right: 8px;
}

.pp-tech-block__lead {
  margin-bottom: 12px;
}

.pp-tech-block__body {
  margin: 0;
}

.pp-tech-steps {
  list-style: none;
  padding: 0;
  margin: 0;
}

.pp-tech-steps__item {
  padding: 6px 0;
  display: flex;
  gap: 10px;
}

.pp-tech-steps__icon {
  color: #00934f;
  margin-top: 4px;
  flex-shrink: 0;
}

/* ── Carrossel de fotos do produto ── */
.pp-carousel-section {
  margin-top: 60px;
  padding: 60px 0;
  background: #f7f7f7;
}

.pp-carousel-section .section-heading h4 {
  color: #222;
}

.pp-carousel-footer {
  margin-top: 40px;
}

/* ── Grid de subprodutos (cards com imagem + título) ── */
.pp-subgrid-row {
  margin-top: 40px;
  margin-bottom: 32px;
}

.pp-subgrid-card {
  display: block;
  text-decoration: none;
  color: inherit;
  background: #fff;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 2px 14px rgba(0, 0, 0, 0.08);
  height: 100%;
  border-left: 4px solid #00934f;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.pp-subgrid-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 32px rgba(0, 0, 0, 0.12);
  color: inherit;
  text-decoration: none;
}

.pp-subgrid-card__media {
  background: #f5f7f6;
  padding: 18px;
  text-align: center;
}

.pp-subgrid-card__media img {
  max-width: 100%;
  height: auto;
  max-height: 160px;
  object-fit: contain;
}

.pp-subgrid-card__label {
  padding: 16px;
  text-align: center;
  font-weight: 700;
  font-size: 1.05rem;
  color: #222;
}

.pp-breadcrumb {
  margin-bottom: 20px;
}

.pp-breadcrumb a {
  color: #00934f;
  font-weight: 600;
  text-decoration: none;
}

.pp-breadcrumb a:hover {
  text-decoration: underline;
}

/* Diagrama / esquema técnico (evita altura fixa de .product-image que corta a arte) */
.pp-diagram-card {
  background: #fff;
  border-radius: 12px;
  overflow: visible;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.1);
  border-bottom: 4px solid #00934f;
  padding: 16px;
}

.pp-diagram-card img {
  width: 100%;
  max-width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
}
