/* =========================================================
CONTACT PAGE — contact.css
Depends on main.css variables + base styles
========================================================= */

/* HERO */
.contact-hero{
  position: relative;
  min-height: 56vh;
  display: flex;
  align-items: center;
  background-size: cover;
  background-position: center;
  overflow: hidden;
}

.contact-hero-overlay{
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(0,0,0,.58), rgba(0,0,0,.18) 58%, rgba(0,0,0,.48)),
    linear-gradient(180deg, rgba(0,0,0,.55), rgba(0,0,0,.18) 45%, rgba(0,0,0,.55));
}

.contact-hero-content{
  position: relative;
  z-index: 2;
  padding: 130px 0 80px;
  color: #fff;
  max-width: 850px;
}

.contact-hero-content h1{
  font-family: var(--fontH);
  font-size: clamp(2.1rem, 4vw, 3.4rem);
  line-height: 1.05;
  margin: 10px 0 14px;
}

.contact-hero-content .hero-sub{
  max-width: 65ch;
  font-size: 1.06rem;
  opacity: .95;
  margin: 0;
}

.contact-hero-pills{
  display:flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.contact-hero-pills .pill{
  display:inline-flex;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.10);
  font-size: .88rem;
}

/* MAIN */
.contact-main{
  padding: 80px 0;
  background: rgba(0,0,0,.02);
}

.contact-grid{
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 22px;
  align-items: start;
}

/* LEFT */
.contact-info{
  border: 1px solid var(--line);
  background: rgba(255,255,255,.92);
  border-radius: var(--radius2);
  box-shadow: 0 18px 45px rgba(0,0,0,.08);
  padding: 22px;
}

.contact-info h2{
  font-family: var(--fontH);
  margin: 6px 0 10px;
}

.info-cards{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-top: 18px;
}

.info-card{
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 14px;
  background: rgba(255,255,255,.94);
}

.info-card h3{
  font-family: var(--fontH);
  margin: 0 0 6px;
  font-size: 1.05rem;
}

.info-card p{
  margin: 0;
}

/* RIGHT: FORM */
.contact-form{
  border: 1px solid var(--line);
  background:#fff;
  border-radius: var(--radius2);
  box-shadow: 0 18px 45px rgba(0,0,0,.10);
  padding: 22px;
}

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

.contact-form label{
  display:block;
  margin-bottom: 12px;
}

.contact-form label span{
  display:block;
  font-weight: 600;
  margin-bottom: 6px;
}

.contact-form input,
.contact-form select,
.contact-form textarea{
  width:100%;
  border-radius: 12px;
  border: 1px solid rgba(20,20,20,.12);
  background: #fff;
  color: var(--ink);
  padding: 12px;
  outline:none;
  font-family: var(--fontB);
}

.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus{
  border-color: rgba(201,164,91,.70);
  box-shadow: 0 0 0 3px rgba(201,164,91,.18);
}

.form-note{
  margin-top: 10px;
}

/* STRIP */
.contact-strip{
  padding: 60px 0 90px;
  background: #fff;
}

.strip-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.strip-card{
  position: relative;
  min-height: 210px;
  border-radius: var(--radius);
  overflow: hidden;
  background-size: cover;
  background-position: center;
  border: 1px solid var(--line);
  box-shadow: 0 18px 45px rgba(0,0,0,.10);
  transition: transform .16s ease, box-shadow .16s ease;
}

.strip-card:hover{
  transform: translateY(-3px);
  box-shadow: 0 26px 60px rgba(0,0,0,.14);
}

.strip-overlay{
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.55), rgba(0,0,0,.12) 50%, rgba(0,0,0,.55));
}

.strip-content{
  position: relative;
  z-index: 2;
  color:#fff;
  padding: 18px;
}

.strip-content h3{
  font-family: var(--fontH);
  margin: 0 0 6px;
}

.strip-content p{
  margin: 0;
  opacity: .92;
}

/* RESPONSIVE */
@media (max-width: 980px){
  .contact-grid{
    grid-template-columns: 1fr;
  }
  .info-cards{
    grid-template-columns: 1fr;
  }
  .strip-grid{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 700px){
  .form-row{
    grid-template-columns: 1fr;
  }
  .contact-hero-content{
    padding: 120px 0 70px;
  }
}

.form-message {
  margin: 16px 0 10px;
  padding: 14px 16px;
  border-radius: 14px;
  font-size: 0.95rem;
  display: none;
}

.form-message.success,
.form-message.error {
  display: block;
}

.form-message.success {
  background: rgba(201, 164, 91, 0.10);
  border: 1px solid rgba(201, 164, 91, 0.35);
  color: #3a3123;
}

.form-message.error {
  background: rgba(180, 60, 60, 0.08);
  border: 1px solid rgba(180, 60, 60, 0.28);
  color: #7a2d2d;
}

.contact-mini a {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid rgba(201, 164, 91, 0.4);
  transition: all 0.2s ease;
}

.contact-mini a:hover {
  border-bottom-color: rgba(201, 164, 91, 1);
  color: #c9a45b;
}
