/* ===== CONTACTO ===== */
.contact-grid{
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 14px;
  align-items: start;
}

.contact-card{
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.03);
  box-shadow: 0 10px 26px rgba(0,0,0,.35);
  padding: 16px;
  position: relative;
  overflow: hidden;
}

.contact-card::before{
  content:"";
  position:absolute;
  inset:0;
  background: radial-gradient(700px 240px at 10% 0%, rgba(254,1,38,.12), transparent 60%);
  pointer-events:none;
}

.contact-title{
  position: relative;
  margin: 0 0 6px;
  letter-spacing: -0.01em;
}

.contact-sub{
  position: relative;
  margin: 0 0 14px;
  color: rgba(255,255,255,.78);
  line-height: 1.6;
}

.contact-form{ position: relative; }

.form-row{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 12px;
}

.field{
  display: grid;
  gap: 6px;
}

.field span{
  font-size: 12px;
  color: rgba(255,255,255,.78);
}

.field input,
.field select,
.field textarea{
  width: 100%;
  padding: 12px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(3,2,3,.65); /* brand black */
  color: rgba(255,255,255,.92);
  outline: none;
}

.field input:focus,
.field select:focus,
.field textarea:focus{
  border-color: rgba(254,1,38,.45);
  box-shadow: 0 0 0 4px rgba(254,1,38,.12);
}

.form-actions{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 10px;
}

.form-note{
  margin: 10px 0 0;
  font-size: 12px;
  color: rgba(255,255,255,.65);
  line-height: 1.5;
}

/* Info */
.info-list{
  position: relative;
  display: grid;
  gap: 10px;
  margin-top: 10px;
}

.info-item{
  display: grid;
  gap: 4px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.02);
}

.info-label{
  font-size: 12px;
  color: rgba(255,255,255,.72);
}

.info-link{
  color: rgba(255,255,255,.92);
  text-decoration: none;
}

.info-link:hover{
  color: #fff;
  text-decoration: underline;
}

.info-text{
  color: rgba(255,255,255,.9);
}

.contact-cta{
  position: relative;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 14px;
}

/* Mapa */
.map-card{
  position: relative;
  margin-top: 14px;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.02);
}

.map-embed{
  aspect-ratio: 16 / 10;
  background: #000;
}

.map-embed iframe{
  width: 100%;
  height: 100%;
  border: 0;
}

.map-note{
  margin: 0;
  padding: 10px 12px;
  font-size: 12px;
  color: rgba(255,255,255,.72);
}

/* Responsive */
@media (max-width: 980px){
  .contact-grid{ grid-template-columns: 1fr; }
  .form-row{ grid-template-columns: 1fr; }
}
