.contact-hero{
  min-height:68vh;
  display:flex;
  align-items:center;
  color:#fff;
  background:
    linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.62),rgba(0,0,0,.20)),
    url('/assets/img/contactos-hero.png');
  background-size:cover;
  background-position:center;
}

.contact-hero-inner{padding:86px 0 76px}

.contact-breadcrumb{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:34px;
  color:rgba(255,255,255,.78);
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:13px;
}

.contact-breadcrumb strong{color:#ffdf00}

.contact-hero-copy{max-width:860px}

.contact-hero h1{
  font-size:clamp(58px,9vw,116px);
  line-height:.84;
  letter-spacing:-4px;
  text-transform:uppercase;
  margin:0 0 22px;
}

.contact-hero p{
  max-width:760px;
  color:rgba(255,255,255,.82);
  font-size:20px;
  line-height:1.55;
  margin:0;
}

.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:30px;
}

.btn-light{background:#fff;color:#050505}

.contact-section{
  background:#f4f4f4;
  padding:84px 0;
}

.contact-layout{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:22px;
  align-items:stretch;
}

.contact-info-card,
.contact-form-card{
  border-radius:32px;
  padding:38px;
  box-shadow:0 18px 50px rgba(0,0,0,.08);
}

.contact-info-card{
  background:#ffdf00;
  color:#050505;
  display:flex;
  flex-direction:column;
}

.contact-form-card{background:#fff}

.kicker.dark{color:#050505}

.contact-info-card h2,
.form-heading h2,
.map-heading h2{
  margin:10px 0 14px;
  font-size:clamp(34px,4vw,58px);
  line-height:.9;
  letter-spacing:-1.8px;
  text-transform:uppercase;
}

.contact-info-card p,
.form-heading p{
  color:rgba(0,0,0,.68);
  font-weight:800;
  line-height:1.6;
  margin:0;
}

.contact-details{
  display:grid;
  gap:12px;
  margin:34px 0;
}

.contact-detail{
  background:rgba(255,255,255,.45);
  border:1px solid rgba(0,0,0,.08);
  border-radius:22px;
  padding:18px;
}

.contact-detail span{
  display:block;
  color:rgba(0,0,0,.55);
  font-size:12px;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.12em;
  margin-bottom:6px;
}

.contact-detail strong{
  display:block;
  font-size:18px;
  line-height:1.35;
}

.social-links{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:auto;
}

.social-links a{
  display:inline-flex;
  align-items:center;
  min-height:42px;
  padding:0 15px;
  border-radius:999px;
  background:#050505;
  color:#fff;
  font-size:13px;
  font-weight:950;
}

.form-heading{margin-bottom:26px}

.contact-form{display:grid;gap:14px}

.form-grid.two{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}

.contact-form input,
.contact-form textarea{
  width:100%;
  border:1px solid #e6e6e6;
  background:#f7f7f7;
  color:#050505;
  border-radius:22px;
  padding:0 18px;
  font:inherit;
  font-weight:800;
  outline:none;
}

.contact-form input{min-height:56px}

.contact-form textarea{
  min-height:170px;
  padding-top:18px;
  resize:vertical;
}

.contact-form input:focus,
.contact-form textarea:focus{
  border-color:#050505;
  background:#fff;
}

.captcha-wrap{
  overflow:auto;
  padding:4px 0;
}

.contact-form .btn{
  justify-self:start;
  min-height:54px;
}

.map-section{
  background:#fff;
  padding:76px 0 92px;
}

.map-heading{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:20px;
  margin-bottom:24px;
}

.map-heading h2{max-width:760px;margin-bottom:0}

.map-frame{
  position:relative;
  overflow:hidden;
  border-radius:34px;
  min-height:460px;
  background:#e9e9e9;
  box-shadow:0 18px 50px rgba(0,0,0,.10);
}

.map-frame iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
}

@media(max-width:980px){
  .contact-layout{grid-template-columns:1fr}
  .map-heading{align-items:flex-start;flex-direction:column}
  .form-grid.two{grid-template-columns:1fr}
}

@media(max-width:560px){
  .contact-hero{min-height:auto}
  .contact-hero-inner{padding:64px 0 58px}
  .contact-hero h1{letter-spacing:-2px}
  .contact-info-card,
  .contact-form-card{padding:26px;border-radius:26px}
  .contact-section{padding:50px 0}
  .map-frame{min-height:360px;border-radius:26px}
}

.hp-field{
  position:absolute!important;
  left:-9999px!important;
  width:1px!important;
  height:1px!important;
  overflow:hidden!important;
}

.form-alert{
  margin:18px 0;
  padding:14px 16px;
  border-radius:18px;
  font-weight:900;
  line-height:1.4;
}

.form-alert.success{
  background:#e5ffe9;
  color:#063b12;
}

.form-alert.error{
  background:#ffe1e1;
  color:#5b0000;
}

