/* 
=============================================================
|  Tred-Mark Communications | Developed by Javorsky Studio  |
|  Viewing File: ~/public-site/assets/css/pages/contact.css |
| --- Styling/CSS for `~/public-site/contact/index.html --- |
============================================================= 
*/

.page-contact{
  min-height:100vh;
  color:var(--text);
  background:#070a12;
}

.page-contact::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-2;

  background:
    url("/assets/media/contact/page-bg.webp")
    center center / cover
    no-repeat;
}

.page-contact::after{
  content:"";
  position:fixed;
  inset:0;
  z-index:-1;
  pointer-events:none;

  background:
    linear-gradient(
      90deg,
      rgba(7,10,18,.34) 0%,
      rgba(7,10,18,.82) 30%,
      rgba(7,10,18,.88) 70%,
      rgba(7,10,18,.38) 100%
    ),
    linear-gradient(
      180deg,
      rgba(7,10,18,.62) 0%,
      rgba(7,10,18,.78) 45%,
      rgba(7,10,18,.92) 100%
    );
}

.contact-page{
  padding:clamp(5rem, 9vw, 8rem) var(--space-5) var(--space-6);
}

.contact-hero{
  width:min(1180px, 100%);
  margin:0 auto var(--space-5);
  padding:clamp(2.5rem, 6vw, 5rem);
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:
    linear-gradient(135deg, rgba(7,10,18,.82), rgba(12,24,42,.68)),
    radial-gradient(circle at top right, rgba(76,183,255,.24), transparent 38%);
  box-shadow:0 24px 80px rgba(0,0,0,.34);
  overflow:hidden;
}

.contact-hero .eyebrow{
  margin:0 0 .75rem;
  color:var(--accent);
  font-size:.82rem;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.contact-hero h1{
  margin:0;
  max-width:780px;
  font-size:clamp(2.35rem, 6vw, 5.25rem);
  line-height:.95;
  letter-spacing:-.07em;
  background:linear-gradient(90deg, #fff, #7de3ff 50%, #8a5cff);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  padding-bottom:.22em;
}

.contact-hero p:not(.eyebrow){
  max-width:760px;
  margin:1.25rem 0 0;
  color:var(--muted);
  font-size:clamp(1rem, 1.5vw, 1.2rem);
  line-height:1.7;
}

.contact-layout{
  width:min(1180px, 100%);
  margin:0 auto;
  display:grid;
  grid-template-columns:.85fr 1.25fr;
  gap:var(--space-4);
  align-items:stretch;
}

.contact-info-card,
.contact-form-card,
.contact-map-card{
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:rgba(7,10,18,.72);
  box-shadow:0 20px 70px rgba(0,0,0,.28);
  backdrop-filter:blur(14px);
}

.contact-left-column{
  position:sticky;
  top:calc(var(--nav-height, 80px) + 1.25rem);

  display:grid;
  grid-template-rows:auto 1fr;
  gap:var(--space-4);
  align-self:stretch;
}

.contact-info-card,
.contact-form-card{
  padding:clamp(1.5rem, 3vw, 2.25rem);
}

.contact-info-card{
  position:relative;
  top:auto;
}

.contact-info-card h2,
.office-hours-card h2,
.contact-form-card h2,
.contact-map-card h2{
  margin:0 0 1rem;
  font-size:clamp(1.55rem, 3vw, 2.25rem);
  letter-spacing:-.04em;
}

.office-hours-card{
  position:relative;
  display:flex;
  flex-direction:column;
  margin-top:0;
  min-height:0;
  padding:clamp(1.5rem, 3vw, 2.25rem);
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:rgba(7,10,18,.72);
  box-shadow:0 20px 70px rgba(0,0,0,.28);
  backdrop-filter:blur(14px);
}

.hours-list{
  display:grid;
  gap:1rem;
}

.hours-row{
  display:flex;
  justify-content:space-between;
  gap:1rem;
  color:var(--muted);
}

.hours-row strong{
  color:var(--text);
  font-weight:700;
  transition:color .2s ease;
}

.hours-row strong.hours-open{
  color:#67e08a;
}

.hours-row strong.hours-closed{
  color:#ff7a7a;
}

.contact-form-card{
  height:100%;
}

.contact-form-card > p{
  margin:0 0 1.5rem;
  color:var(--muted);
  line-height:1.65;
}

.contact-info-list{
  display:grid;
  gap:1.25rem;
  margin:1.5rem 0 2rem;
}

.contact-info-list h3{
  margin:0 0 .35rem;
  color:var(--accent);
  font-size:.8rem;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
}

.contact-info-list p{
  margin:0;
  color:var(--muted);
  line-height:1.6;
}

.contact-info-list a{
  color:var(--text);
  text-decoration:none;
}

.contact-info-list a:hover{
  color:var(--accent);
}

.contact-form{
  display:grid;
  gap:1rem;
}

.form-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:1rem;
}

.contact-form label{
  display:grid;
  gap:.45rem;
  color:var(--text);
  font-size:.9rem;
  font-weight:750;
}

.contact-form input,
.contact-form select,
.contact-form textarea{
  width:100%;
  border:1px solid rgba(255,255,255,.14);
  border-radius:14px;
  background:rgba(255,255,255,.055);
  color:var(--text);
  padding:.9rem 1rem;
  font:inherit;
  outline:none;
  transition:border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.contact-form select{
  cursor:pointer;
}

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

.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus{
  border-color:rgba(125,227,255,.72);
  box-shadow:0 0 0 4px rgba(125,227,255,.11);
  background:rgba(255,255,255,.075);
}

.contact-form input::placeholder,
.contact-form textarea::placeholder{
  color:rgba(255,255,255,.38);
}

.contact-form select option{
  color:#07101d;
}

.form-honeypot{
  position:absolute !important;
  left:-9999px !important;
  width:1px !important;
  height:1px !important;
  opacity:0 !important;
  pointer-events:none !important;
}

.form-status{
  min-height:1.4rem;
  margin:.25rem 0 0;
  color:var(--muted);
  font-size:.95rem;
}

.contact-map-section{
  width:min(1180px, 100%);
  margin:var(--space-4) auto 0;
}

.contact-map-card{
  padding:clamp(1.25rem, 3vw, 2rem);
}

.map-frame{
  position:relative;
  overflow:hidden;
  border-radius:calc(var(--radius) - 6px);
  border:1px solid rgba(255,255,255,.12);
  min-height:420px;
}

.map-frame img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.map-overlay-link{
  position:absolute;
  bottom:1rem;
  right:1rem;

  padding:.75rem 1rem;
  border-radius:999px;

  background:rgba(7,10,18,.85);
  border:1px solid rgba(255,255,255,.15);

  color:white;
  text-decoration:none;
  font-weight:700;

  backdrop-filter:blur(12px);
}

@media (max-width:900px){
  .contact-left-column{
    position:relative;
    top:auto;
    grid-template-rows:auto;
  }

  .contact-page{
    padding:6rem 1rem 3rem;
  }

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

  .contact-info-card{
    position:relative;
    top:auto;
  }
}

@media (max-width:640px){
  .contact-hero{
    padding:2rem 1.25rem;
  }

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

  .contact-info-card,
  .contact-form-card,
  .contact-map-card{
    padding:1.25rem;
  }

  .map-frame{
    min-height:320px;
  }
}