/* =========================================================
   contact.css — Contact overlay (clean + premium)
   (Overrides any messy main.css rules)
========================================================= */

#contactOverlay .catalog-content{
  /* garante que o card não fica “achatado” */
  width: min(760px, 92vw);
  max-width: 760px;
  border-radius: 14px;
}

#contactOverlay #contactContent{
  /* se algum CSS antigo colocou height/opacity/display errado, isso salva */
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
  height: auto !important;
  max-height: none !important;

  padding: 18px;
  box-sizing: border-box;
  color: rgba(255,255,255,.92);

  /* fonte padrão do site */
  font-family: "Inter", "Space Grotesk", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

#contactOverlay .contact-email{
  margin: 0 0 14px;
  font-weight: 600;
  letter-spacing: -0.01em;
}

#contactOverlay .contact-email a{
  color: rgba(255,255,255,.92);
  text-decoration: underline;
  text-decoration-color: rgba(255,255,255,.35);
  text-underline-offset: 3px;
}
#contactOverlay .contact-email a:hover{
  text-decoration-color: rgba(255,255,255,.75);
}

/* form wrapper */
#contactOverlay .contact-form{
  margin-top: 10px;
}

/* anti-bot hidden field */
#contactOverlay .contact-hidden{
  display: none !important;
}

/* grid */
#contactOverlay .contact-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

@media (max-width: 720px){
  #contactOverlay .contact-grid{
    grid-template-columns: 1fr;
  }
}

/* field */
#contactOverlay .contact-field{
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 12px;
}

#contactOverlay .contact-field label{
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
  font-family: inherit;
}

/* inputs */
#contactOverlay .contact-input,
#contactOverlay .contact-textarea{
  width: 100%;
  box-sizing: border-box;

  background: rgba(0,0,0,.28);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 12px;

  padding: 12px 12px;
  color: rgba(255,255,255,.92);

  font-size: 14px;
  line-height: 1.2;
  font-family: inherit;

  outline: none;
}

#contactOverlay .contact-textarea{
  resize: vertical;
  min-height: 120px;
}

#contactOverlay .contact-input:focus,
#contactOverlay .contact-textarea:focus{
  border-color: rgba(255,255,255,.28);
  box-shadow: 0 0 0 3px rgba(255,255,255,.08);
}

/* SEND button */
#contactOverlay .contact-send{
  width: 100%;
  height: 44px;
  border-radius: 12px;

  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.10);
  color: rgba(255,255,255,.95);

  font-weight: 600;
  letter-spacing: .10em;
  text-transform: uppercase;
  cursor: pointer;

  transition: transform .15s ease, background .15s ease, border-color .15s ease;
}

#contactOverlay .contact-send:hover{
  background: rgba(255,255,255,.14);
  border-color: rgba(255,255,255,.24);
  transform: translateY(-1px);
}

#contactOverlay .contact-send:disabled{
  opacity: .6;
  cursor: not-allowed;
  transform: none;
}

/* Toast: curto, “descolado”, com efeito */
#contactOverlay .contact-toast{
  margin-top: 12px;
  height: 0;
  overflow: visible;
  pointer-events: none;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  padding: 0;
  opacity: 0;
  transform: translateY(6px) scale(.98);
  transition: opacity .18s ease, transform .18s ease;
}

#contactOverlay .contact-toast.show{
  opacity: 1;
  transform: translateY(0) scale(1);
}

#contactOverlay .contact-toast.show::before{
  content: attr(data-text);
  display: inline-flex;
  align-items: center;
  justify-content: center;

  padding: 8px 12px;
  border-radius: 999px;

  background: rgba(0,0,0,.55);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 18px 40px rgba(0,0,0,.45);

  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.92);
}

/* FIX contact collapsing height */

#contactOverlay .catalog-content{
  display: block !important;
  height: auto !important;
  min-height: auto !important;
  overflow: visible !important;
}

#contactOverlay #contactContent{
  display: block !important;
}

#contactOverlay .contact-form{
  display: block !important;
}

/* HARD OVERRIDES — kill “black card behind” */
#contactOverlay #contactContent,
#contactOverlay .contact-wrap,
#contactOverlay form.contact-form{
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
}

#contactOverlay .contact-wrap{
  padding: 0 !important;
  margin: 0 !important;
}

/* se algum CSS antigo estiver aplicando um “panel” */
#contactOverlay .contact-panel,
#contactOverlay .contact-card{
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
}

/* =========================================
   CONTACT — Only black form, no outer card
========================================= */

/* remove visual do card externo */
#contactOverlay .catalog-content{
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
}

/* mantém o header alinhado */
#contactOverlay .catalog-header{
  padding: 0 0 18px 0;
}

/* deixa só o form como bloco principal */
#contactOverlay .contact-form{
  background: #000 !important;
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 16px;
  padding: 20px;
  box-shadow: 0 25px 60px rgba(0,0,0,.6);
}

/* =========================================
   CONTACT — Compact container aligned to form
========================================= */

/* Overlay centraliza tudo */
#contactOverlay{
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Container externo agora abraça o conteúdo */
#contactOverlay .catalog-content{
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;

  width: auto !important;
  max-width: 640px;
  padding: 0 !important;

  display: flex;
  flex-direction: column;
}

/* Header alinhado ao form */
#contactOverlay .catalog-header{
  padding: 0 0 12px 0;
  width: 100%;
}

/* Close não fica isolado */
#contactOverlay .catalog-close{
  margin: 0;
}

/* Bloco preto principal */
#contactOverlay .contact-form{
  background: #000;
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 16px;
  padding: 20px;
  box-shadow: 0 30px 70px rgba(0,0,0,.6);
}

/* Remove espaçamentos extras */
#contactOverlay #contactContent{
  padding: 0 !important;
}

.catalog-overlay{
  pointer-events: none !important;
}

.catalog-overlay.active{
  pointer-events: auto !important;
}

.catalog-overlay .catalog-content{
  pointer-events: auto !important;
}

.artist-overlay{
  pointer-events: none !important;
}

.artist-overlay.active{
  pointer-events: auto !important;
}

.artist-overlay .artist-content{
  pointer-events: auto !important;
}