.topo-fornecedor {
  padding: 34px 0 20px;
}

.bloco-apresentacao-fornecedor {
  overflow: hidden;
}

/* Hero com foto de capa em tela cheia + logo em quadrado à direita */
.bloco-apresentacao-fornecedor--hero-capa {
  position: relative;
  min-height: 280px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.hero-fornecedor-midia {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

.hero-fornecedor-midia .hero-fornecedor-capa-img {
  pointer-events: auto;
  cursor: zoom-in;
}

.hero-fornecedor-capa-img {
  width: 100%;
  height: 100%;
  min-height: 280px;
  object-fit: cover;
  display: block;
}

.hero-fornecedor-midia-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    to top,
    rgba(35, 28, 32, 0.78) 0%,
    rgba(35, 28, 32, 0.35) 45%,
    rgba(35, 28, 32, 0.2) 100%
  );
}

.logo-hero-fornecedor {
  position: absolute;
  top: 16px;
  right: 16px;
  z-index: 3;
  width: 144px;
  height: 144px;
  padding: 0;
  overflow: hidden;
  border-radius: 14px;
  background: #fff;
  border: 1px solid rgba(45, 45, 45, 0.1);
  box-shadow: 0 8px 24px rgba(35, 28, 32, 0.22);
  display: block;
  flex-shrink: 0;
  pointer-events: auto;
}

.logo-hero-fornecedor img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  border-radius: 0;
}

.capa-fornecedor {
  min-height: 260px;
  background: linear-gradient(135deg, rgba(212, 163, 115, 0.3), rgba(232, 180, 184, 0.55));
  display: grid;
  place-items: center;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.82rem;
}

.capa-fornecedor--img {
  padding: 0;
  display: block;
  min-height: 0;
}

.dados-principais-fornecedor {
  padding: 24px;
  display: grid;
  gap: 12px;
}

.dados-principais-fornecedor--sobre-capa {
  position: relative;
  z-index: 2;
  padding-top: 28px;
  padding-bottom: 28px;
  color: #fff;
}

.dados-principais-fornecedor--sobre-capa.dados-principais-fornecedor--com-logo-hero {
  padding-top: 184px;
}

.dados-principais-fornecedor--sobre-capa .tag {
  color: rgba(255, 255, 255, 0.92);
}

.dados-principais-fornecedor--sobre-capa h1 {
  text-shadow: 0 2px 18px rgba(0, 0, 0, 0.35);
}

.dados-principais-fornecedor--sobre-capa .descricao-fornecedor {
  color: rgba(255, 255, 255, 0.94);
  text-shadow: 0 1px 10px rgba(0, 0, 0, 0.3);
}

.dados-principais-fornecedor--sobre-capa .grade-informacoes-rapidas span {
  background: rgba(255, 255, 255, 0.16);
  border-color: rgba(255, 255, 255, 0.28);
  color: #fff;
  backdrop-filter: blur(6px);
}

.descricao-fornecedor {
  max-width: 760px;
}

.grade-informacoes-rapidas {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.grade-informacoes-rapidas span {
  background: rgba(212, 163, 115, 0.12);
  border: 1px solid rgba(45, 45, 45, 0.08);
  border-radius: 999px;
  padding: 8px 12px;
  font-size: 0.85rem;
}

.acoes-fornecedor {
  margin-top: 2px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.botao-primario-fornecedor {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 11px 18px;
  border-radius: 14px;
  border: none;
  background: linear-gradient(135deg, var(--cor-romantica), var(--cor-acento));
  color: #fff;
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
}

.botao-primario-fornecedor--placeholder {
  opacity: 0.75;
  cursor: default;
}

.botao-secundario {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 11px 16px;
  border-radius: 14px;
  border: 1px solid rgba(45, 45, 45, 0.2);
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
}

.form-pedir-orcamento-fornecedor {
  display: grid;
  gap: 8px;
}

.form-pedir-orcamento-fornecedor label {
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
  color: rgba(45, 45, 45, 0.74);
}

.form-pedir-orcamento-fornecedor textarea {
  width: 100%;
  border: 1px solid rgba(45, 45, 45, 0.14);
  border-radius: 12px;
  background: #fff;
  padding: 12px;
  font-family: "Inter", Arial, sans-serif;
  font-size: 0.94rem;
  resize: vertical;
}

.form-pedir-orcamento-fornecedor .botao-primario-fornecedor {
  width: 100%;
}

.texto-ajuda-contato-fornecedor {
  margin: 0;
  font-size: 0.84rem;
  color: rgba(45, 45, 45, 0.65);
}

.layout-detalhes-fornecedor {
  display: grid;
  grid-template-columns: minmax(0, 1.8fr) minmax(280px, 1fr);
  gap: 18px;
}

.coluna-principal-fornecedor,
.coluna-lateral-fornecedor {
  display: grid;
  gap: 14px;
}

.bloco-detalhes,
.bloco-lateral {
  padding: 22px;
  display: grid;
  gap: 10px;
}

.bloco-detalhes h2,
.bloco-lateral h2 {
  font-size: clamp(1.25rem, 2.5vw, 1.65rem);
}

.grade-galeria-fornecedor {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.imagem-galeria {
  min-height: 128px;
  border-radius: 14px;
  border: 1px solid rgba(45, 45, 45, 0.08);
  background: linear-gradient(135deg, rgba(212, 163, 115, 0.28), rgba(232, 180, 184, 0.45));
  display: grid;
  place-items: center;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.09em;
}

.imagem-galeria-fornecedor-com-foto {
  padding: 0;
  overflow: hidden;
  min-height: 0;
}

.imagem-galeria-fornecedor-com-foto img {
  width: 100%;
  height: 100%;
  min-height: 128px;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  display: block;
  cursor: zoom-in;
}

.lista-servicos-fornecedor {
  display: grid;
  gap: 10px;
}

.lista-servicos-fornecedor > div {
  border: 1px solid rgba(45, 45, 45, 0.08);
  border-radius: 14px;
  padding: 12px;
  background: rgba(252, 249, 247, 0.75);
}

.lista-servicos-fornecedor h3 {
  font-family: "Inter", Arial, sans-serif;
  font-size: 1rem;
  margin-bottom: 4px;
}

.bloco-lateral ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 8px;
  font-size: 0.92rem;
}

@media (max-width: 960px) {
  .layout-detalhes-fornecedor {
    grid-template-columns: 1fr;
  }

  .grade-galeria-fornecedor {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .grade-galeria-fornecedor {
    grid-template-columns: 1fr;
  }

  .bloco-apresentacao-fornecedor--hero-capa {
    min-height: 260px;
  }

  .hero-fornecedor-capa-img {
    min-height: 260px;
  }

  .logo-hero-fornecedor {
    width: 128px;
    height: 128px;
    top: 12px;
    right: 12px;
  }

  .dados-principais-fornecedor--sobre-capa.dados-principais-fornecedor--com-logo-hero {
    padding-top: 156px;
  }

  .capa-fornecedor {
    min-height: 210px;
  }
}
