/* contato.css v5 – layout em uma coluna + ícones discretos ao lado do botão WhatsApp + mapa full width */

/* Seção principal de contato */
.contact-hero{
  min-height: 100vh;
  padding-top: calc(var(--header-height) + 32px);
  padding-bottom: 60px;
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;

  background-image:
    linear-gradient(180deg, rgba(15,17,21,.84), rgba(15,17,21,.96)),
    url("img/-IMG_3531.jpg");
  background-size: cover;
  background-position: center;
  background-attachment: fixed;
}

/* Uma coluna fluida */
.contact-shell{
  width: 100%;
}

.contact-main{
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.06);
  background: rgba(10,12,16,.78);
  backdrop-filter: blur(14px);
  box-shadow: 0 20px 48px rgba(0,0,0,.48);
  padding: 28px 26px 26px;
}

/* Cabeçalho de texto */
.contact-head{
  margin-bottom: 22px;
}

.contact-title{
  margin: 10px 0 12px;
  font-size: clamp(2.1rem, 3.2vw, 2.8rem);
  line-height: 1.1;
  letter-spacing: -0.03em;
  font-weight: 700;
}

.contact-sub{
  color: var(--muted);
  max-width: 60ch;
  font-size: 0.98rem;
}

/* Títulos internos suaves */
.contact-h2{
  font-size: 1.05rem;
  letter-spacing: -0.01em;
  margin: 4px 0 8px;
  font-weight: 600;
  color: rgba(255,255,255,.9);
}

.contact-form-intro{
  margin: 0 0 14px;
  font-size: 0.92rem;
  color: rgba(255,255,255,.72);
  max-width: 60ch;
}

/* Formulário */
.contact-form-wrap{
  margin-top: 12px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,.06);
}

.contact-form{
  display: grid;
  gap: 14px;
}

.f-row{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.f-field{
  display: grid;
  gap: 6px;
}

.f-field span{
  color: rgba(255,255,255,.78);
  font-weight: 600;
  font-size: .9rem;
}

.f-field input,
.f-field select,
.f-field textarea{
  width: 100%;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.02);
  color: rgba(255,255,255,.92);
  padding: 11px 12px;
  outline: none;
  font-size: 0.95rem;
  transition:
    border-color .18s ease,
    box-shadow .18s ease,
    background .18s ease;
}

.f-field textarea{
  resize: none;
}

.f-field input:focus,
.f-field select:focus,
.f-field textarea:focus{
  border-color: rgba(56,214,201,.45);
  box-shadow: 0 0 0 2px rgba(56,214,201,.16);
  background: rgba(255,255,255,.03);
}

/* Ações do formulário */
.f-actions{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 4px;
}

/* Wrapper do botão WhatsApp + ícones */
.contact-quick{
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

/* Ícones pequenos e discretos ao lado do botão */
.contact-icons{
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.social-icon-small{
  width: 26px;
  height: 26px;
  border-radius: 50%;
  object-fit: contain;
  display: block;
  transition: transform .16s ease, box-shadow .16s ease;
}

.contact-icons a:hover .social-icon-small{
  transform: translateY(-1px);
  box-shadow: 0 6px 14px rgba(0,0,0,.35);
}

.f-note{
  margin: 2px 0 0;
  color: rgba(255,255,255,.72);
  font-size: .88rem;
  min-height: 20px;
}

/* Botão WhatsApp fixo no mobile */
.wa-fab{
  display: none;
  position: fixed;
  left: 16px;
  right: 16px;
  bottom: 14px;
  z-index: 2100;

  text-align: center;
  padding: 14px 18px;
  border-radius: 999px;
  font-weight: 900;
  letter-spacing: .01em;

  background: linear-gradient(135deg, rgba(255,255,255,.95), rgba(255,255,255,.65));
  color: rgba(10,10,12,.95);
  border: 1px solid rgba(255,255,255,.20);
  box-shadow: 0 18px 46px rgba(0,0,0,.40);
}

/* SEÇÃO DE LOCALIZAÇÃO FULL WIDTH */
.contact-location{
  padding: 40px 0 0;
  background: transparent;
}

.contact-location-inner{
  padding-bottom: 24px;
}

.location-text{
  max-width: 640px;
  margin: 0 auto 18px;
  text-align: center;
}

.location-title{
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  margin-bottom: 6px;
  color: rgba(255,255,255,.9);
}

.location-address{
  font-size: 0.95rem;
  color: rgba(255,255,255,.78);
  line-height: 1.6;
}

/* Horário bem sutil, sem negrito */
.location-hours{
  margin-top: 8px;
  font-size: 0.86rem;
  color: rgba(255,255,255,.6);
  font-weight: 400;
}

/* Mapa como faixa full width */
.location-map-shell{
  width: 100%;
  border-top: 1px solid rgba(255,255,255,.08);
}

.location-map{
  width: 100%;
  height: 230px;
  position: relative;
  overflow: hidden;
}

.location-map iframe{
  width: 100%;
  height: 100%;
  display: block;
  border: 0;
}

/* leve vinheta em cima do mapa */
.location-map::before{
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 50%, rgba(0,0,0,.06) 0%, rgba(0,0,0,.4) 85%),
    linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.4));
  pointer-events: none;
}

/* Responsivo */
@media (max-width: 1024px){
  .contact-main{
    padding: 24px 20px 22px;
  }
}

@media (max-width: 680px){
  .contact-hero{
    background-attachment: scroll;
    padding-top: calc(var(--header-height) + 20px);
    padding-bottom: 40px;
  }

  .contact-main{
    padding: 20px 16px 18px;
  }

  .f-row{
    grid-template-columns: 1fr;
  }

  .f-actions{
    flex-direction: column;
    align-items: stretch;
  }

  .contact-quick{
    width: 100%;
    justify-content: space-between;
  }

  .f-actions .btn{
    width: 100%;
  }

  .wa-fab{
    display: block;
  }

  .main-footer{
    padding-bottom: 86px;
  }

  .location-map{
    height: 210px;
  }
}