/* /assets/css/contact.css
   Contact page CSS ONLY (aligned with your system)
*/

html, body{ overflow-x:hidden; }

.alt-surface{
  background: var(--bg2);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

/* Hero */
.contact-hero{
  position: relative;
  padding: 64px 0 38px;
  background: #0b2a3a;
}

.contact-hero-visual{
  position:absolute;
  inset:0;
  z-index:0;
}
.contact-hero-media{ position:absolute; inset:0; }

.contact-hero-bg{
  position:absolute;
  inset:0;
  opacity:0;
  transition: opacity 1s ease;
  background-size: cover;
  background-position: center;
  background-repeat:no-repeat;
  transform: scale(1.02);
  will-change: opacity, transform;
}

/* Replace with real images */
.contact-hero-bg[data-contact-hero="0"]{ background-image: url("../images/contact-hero-1.jpg"); }
.contact-hero-bg[data-contact-hero="1"]{ background-image: url("../images/contact-hero-2.jpg"); }
.contact-hero-bg[data-contact-hero="2"]{ background-image: url("../images/contact-hero-3.jpg"); }

.contact-hero-bg.is-active{
  opacity:1;
  transform: scale(1.05);
  transition: opacity 1s ease, transform 10s ease;
}

.contact-hero-overlay{
  position:absolute;
  inset:0;
  background: linear-gradient(90deg, rgba(0,0,0,.72), rgba(0,0,0,.16));
}

.contact-hero-card{
  position: relative;
  z-index: 2;
}

.contact-hero-copy{
  padding: 84px 0 56px;
  max-width: 820px;
}

.contact-hero-copy h1{
  margin: 14px 0 10px;
  font-size: 54px;
  line-height: 1.05;
  letter-spacing: -1px;
  color:#fff;
}

.contact-hero-copy .lead{
  margin: 0;
  margin-top: 12px;
  color: rgba(255,255,255,.88);
  max-width: 62ch;
}

.contact-hero-actions{
  margin-top: 22px;
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
}

.contact-hero-copy .btn{
  border-color: rgba(255,255,255,.22);
  background: rgba(255,255,255,.10);
  color:#fff;
}
.contact-hero-copy .btn.primary{
  background:#0b0b0b;
  border-color: transparent;
  color:#fff;
}

.contact-trust{
  margin: 18px 0 0;
  font-size: 13px;
  color: rgba(255,255,255,.78);
}

/* Options */
.contact-grid{
  margin-top: 22px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.contact-card{
  padding: 22px;
  border-radius: 22px;
  border: 1px solid var(--line);
  background: #fff;
  box-shadow: 0 10px 26px rgba(16,24,40,.06);
}

.contact-card h3{
  margin: 0 0 10px;
}

.contact-meta{
  margin-top: 14px;
  display:grid;
  gap: 10px;
}

.contact-line{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}

.contact-label{
  font-weight: 800;
  font-size: 13px;
}

.contact-value{
  font-size: 13px;
  color: var(--muted);
}

/* Form shell */
.form-shell{
  margin-top: 22px;
  border-radius: 26px;
  border: 1px solid var(--line);
  background: #fff;
  box-shadow: 0 16px 40px rgba(16,24,40,.10);
  padding: 28px;
}

.contact-form .field{
  display:grid;
  gap: 6px;
  margin-bottom: 14px;
}

.contact-form label{
  font-size: 13px;
  color: var(--muted);
}

.contact-form input,
.contact-form select,
.contact-form textarea{
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background:#fff;
  font-family: inherit;
  font-size: 14px;
  outline: none;
}

.contact-form textarea{
  min-height: 130px;
  resize: vertical;
}

.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus{
  border-color: rgba(22,61,82,.55);
  box-shadow: 0 0 0 4px rgba(22,61,82,.10);
}

/* Grid fields */
.form-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}

.form-actions{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 10px;
}

.form-note{
  margin: 12px 0 0;
  font-size: 12px;
  color: var(--muted);
}

/* Responsive */
@media (max-width: 1100px){
  .contact-hero-copy{ padding: 74px 0 46px; }
  .contact-hero-copy h1{ font-size: 42px; line-height: 1.08; }
  .contact-grid{ grid-template-columns: 1fr; }
  .form-grid{ grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 680px){
  .contact-hero-copy h1{ font-size: 34px; }
  .contact-hero-actions .btn{ width:100%; justify-content:center; }
  .form-grid{ grid-template-columns: 1fr; }
  .form-actions .btn{ width:100%; justify-content:center; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .contact-hero-bg{ transition:none; transform:none; }
  .contact-hero-bg.is-active{ transform:none; }
}
