/* =========================
   CONTACT PAGE ONLY
   ========================= */

/* ===== CONTACT CARDS SECTION ===== */
.contact-cards{
  width:1344px;
  margin:0 auto;
  padding:30px 0 0;
  display:grid;
  grid-template-columns:380px 1fr 1fr;
  gap:32px;
  align-items:start;
}

/* left address card */
.contact-card{
  background:var(--beige);
  border-radius:var(--radius-15);
  padding:24px;
}

.contact-card h3{
  margin:0 0 8px;
  font-size:18px;
  font-weight:800;
  line-height:20px;
  color:#27221B;
}

.contact-card p{
  margin:0 0 18px;
  font-size:14px;
  font-weight:600;
  line-height:1.45;
  color:#27221B;
}

.contact-map{
  width:100%;
  height:270px;
  border-radius:10px;
  object-fit:cover;
  display:block;
}

/* ===== TEAM CARDS ===== */
.team-card{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.team-photo{
  width:100%;
  height:360px;
  border-radius:15px;
  object-fit:cover;
  display:block;
}

.team-name{
  margin:0;
  font-size:16px;
  font-weight:800;
  line-height:20px;
  color:#27221B;
}

.team-meta{
  margin:0;
  font-size:14px;
  font-weight:600;
  line-height:1.45;
  color:#27221B;
}

.team-meta a{
  color:#1a63ff;
  text-decoration:underline;
}

/* ===== CONTACT FORM WRAP ===== */
.contact-form-wrap{
  width:1344px;
  margin:32px auto 0;
  background:var(--beige);
  border-radius:var(--radius-20);
  padding:60px 0 48px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:40px;
}

.contact-form-wrap .form-intro{
  width:855px;
  margin:0;
  text-align:center;
  font-size:24px;
  font-weight:400;
  line-height:1.35;
  color:#000;
}

.contact-form{
  width:512px;
  display:flex;
  flex-direction:column;
  gap:16px;
}

.contact-form .row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}

/* inputs */
.field{
  width:100%;
  height:46px;
  border:0;
  padding:0 14px;
  border-radius:22px;
  background:#fff;
  font-size:15px;
  outline:none;
}

.field:focus{
  outline:2px solid rgba(153,141,130,0.35);
  outline-offset:2px;
}

.field-textarea{
  min-height:120px;
  padding:12px 14px;
  border-radius:10px;
  resize:vertical;
}

/* checkbox */
.form-consent{
  display:flex;
  align-items:center;
  gap:10px;
  margin-top:6px;
}

.form-consent input{
  width:18px;
  height:18px;
}

/* submit button */
.contact-submit{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:16px 32px;
  border-radius:50px;
  background:var(--brown);
  color:#fff;
  border:0;
  cursor:pointer;
  font-size:16px;
  font-weight:500;
}

/* =========================
   HERO FIX (override generic .hero styles)
   ========================= */
.hero.contact-hero{
  width:1344px;
  margin:0 auto;
  background:var(--beige);
  border-radius:var(--radius-15);
  overflow:hidden;
  display:flex;
  align-items:stretch;
  min-height:740px;
}

/* left glass panel */
.hero.contact-hero .hero-text{
  width:493px;
  max-width:493px;
  padding:50px;
  background:rgba(255,255,255,0.10);
  backdrop-filter:blur(15px);
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:20px;
}

.hero.contact-hero .badge{
  background:#fff;
  border-radius:50px;
  padding:10px 15px;
  display:inline-flex;
  width:max-content;
}

.hero.contact-hero .hero-text h1{
  margin:0;
  font-family:Unbounded, system-ui, sans-serif;
  font-size:38px;
  font-weight:300;
  line-height:1.15;
}

.hero.contact-hero .hero-text p{
  margin:0;
  width:411px;
  max-width:100%;
  font-size:16px;
  line-height:1.45;
}

.hero.contact-hero .hero-image{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:46px;
  box-sizing:border-box;
}

.hero.contact-hero .hero-image img{
  width:100%;
  height:648px;
  max-height:648px;
  object-fit:cover;
  border-radius:16px;
  display:block;
}

/* =========================
   RESPONSIVE
   ========================= */
@media (max-width:1100px){
  .contact-cards,
  .contact-form-wrap,
  .hero.contact-hero{
    width:100%;
    padding-left:20px;
    padding-right:20px;
    box-sizing:border-box;
  }

  .contact-form-wrap .form-intro{
    width:100%;
    padding:0 10px;
  }

  .hero.contact-hero .hero-image{
    padding:24px;
  }
}

@media (max-width:768px){
  .contact-cards{
    grid-template-columns:1fr;
  }

  .team-photo{
    height:320px;
  }

  .contact-form{
    width:100%;
    max-width:512px;
  }

  .contact-form .row{
    grid-template-columns:1fr;
  }

  .hero.contact-hero{
    flex-direction:column;
    min-height:auto;
    padding-left:0;
    padding-right:0;
  }

  .hero.contact-hero .hero-text{
    width:100%;
    max-width:100%;
    padding:18px;
  }

  .hero.contact-hero .hero-image{
    padding:18px;
  }

  .hero.contact-hero .hero-image img{
    height:auto;
    max-height:520px;
  }
}
