/*
                       ***************************************************
                                   Technische realisatie door:
                    
                    ▄▄ ▄▄ ▄█▀▀▀▀█ ▄▄  ▄▄ ▄▄  ▄▄ ▄▄  ▄▄▄▄ ▄▄ ▄▄   ▄▄  ▄▄ ▄▄
                    ▀███▀ █  █▀▄  ███▄██ ███▄██ ██ ██▀▀▀ ██▄█▀   ███▄██ ██
                      █   █▄ ▀▀ █ ██ ▀██ ██ ▀██ ██ ▀████ ██ ██ ▄ ██ ▀██ ██▄▄▄
                           ▀▀▀▀▀
                    
                         Wil jij ook een mooie website? Email y@nnick.nl.
                       ***************************************************
*/

:root {
  --accent: #b08a57;
  --line: rgba(92,74,61,.18);
  --container-width: 1240px;
  --nav-logo-width: 250px;
  --nav-logo-max-height: 58px;
}

.contact-hero {
  margin-top: 88px;
  min-height: 56vh;
  padding: 126px 0 64px;
  background:
    linear-gradient(180deg, rgba(24,18,14,.18) 0%, rgba(24,18,14,.28) 52%, rgba(24,18,14,.58) 100%),
    url("../images/contact-hero-maaike.jpg") center center/cover no-repeat;
  background-color: #f2f1ef;
  color: #fff;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
}

.contact-hero::before {
  content: none;
  pointer-events: none;
}

.contact-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(36,28,24,0) 0%, rgba(36,28,24,.18) 62%, rgba(36,28,24,.44) 100%);
  pointer-events: none;
}

.contact-hero-inner {
  position: relative;
  z-index: 1;
  max-width: 620px;
  padding-top: 0;
  margin: 0 auto;
  text-align: center;
}

.contact-kicker {
  width: 44px;
  height: 2px;
  background: var(--accent);
  margin: 0 auto 28px;
}

.contact-hero h1 {
  font-family: var(--font-display);
  font-size: clamp(3.4rem, 7vw, 5.8rem);
  font-weight: 400;
  line-height: .94;
  margin-bottom: 28px;
}

.contact-hero .contact-kicker {
  display: none;
}

.contact-hero h1 em {
  font-style: italic;
}

.contact-hero p {
  max-width: 470px;
  font-size: 1.15rem;
  line-height: 1.9;
  color: rgba(255,255,255,.82);
  margin-bottom: 26px;
}

.hero-note {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.8rem;
  color: rgba(255,255,255,.92);
  display: inline-flex;
  align-items: center;
  gap: 16px;
}

.hero-note svg {
  width: 28px;
  height: 28px;
  stroke: rgba(176,138,87,.9);
  fill: none;
}

.contact-main {
  background: linear-gradient(180deg, #f8f3ee 0%, #f5f0ea 100%);
  padding: 88px 0 92px;
}

.contact-grid {
  display: grid;
  grid-template-columns: 1.08fr .92fr;
  gap: 54px;
  align-items: start;
}

.panel-title {
  font-family: var(--font-display);
  font-size: clamp(2.1rem, 3.5vw, 3rem);
  font-weight: 400;
  line-height: 1.08;
  margin-bottom: 16px;
  color: var(--dark-brown);
}

.panel-kicker {
  width: 40px;
  height: 2px;
  background: var(--accent);
  margin-bottom: 26px;
}

.panel-intro {
  font-size: 1rem;
  line-height: 1.9;
  color: var(--olive);
  margin-bottom: 28px;
  max-width: 460px;
}

.form-panel {
  padding-right: 16px;
}

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

.form-status {
  border: 1px solid rgba(92,74,61,.2);
  background: rgba(255,255,255,.58);
  color: var(--dark-brown);
  line-height: 1.7;
  padding: 14px 16px;
}

.form-status[data-type="success"] {
  border-color: rgba(86,112,74,.3);
  background: rgba(86,112,74,.1);
}

.form-status[data-type="error"] {
  border-color: rgba(155,73,53,.32);
  background: rgba(155,73,53,.1);
}

.form-hp {
  position: absolute;
  left: -9999px;
  height: 1px;
  overflow: hidden;
}

.field-group {
  display: grid;
  gap: 8px;
}

.field-group label {
  font-size: .84rem;
  letter-spacing: .02em;
  color: var(--dark-brown);
}

.field-group input,
.field-group select,
.field-group textarea {
  width: 100%;
  border: 1px solid rgba(92,74,61,.24);
  background: rgba(255,255,255,.55);
  color: var(--dark-brown);
  font-family: var(--font-body);
  font-size: 1rem;
  padding: 14px 16px;
  outline: none;
  transition: border-color .2s ease, background .2s ease;
}

.field-group textarea {
  min-height: 160px;
  resize: vertical;
}

.field-group input:focus,
.field-group select:focus,
.field-group textarea:focus {
  border-color: rgba(176,138,87,.8);
  background: #fff;
}

.submit-btn {
  margin-top: 10px;
  width: fit-content;
  background: #171412;
  color: #fff;
  border: none;
  padding: 16px 28px;
  font-family: var(--font-body);
  font-size: .82rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .2s ease;
}

.submit-btn:hover {
  background: #2a221d;
}

.info-panel {
  border-left: 1px solid var(--line);
  padding-left: 40px;
}

.contact-methods {
  display: grid;
  gap: 24px;
  margin-bottom: 36px;
}

.contact-method {
  display: grid;
  grid-template-columns: 42px 1fr;
  gap: 18px;
  align-items: start;
}

.contact-method svg {
  width: 30px;
  height: 30px;
  stroke: var(--accent);
  fill: none;
  stroke-width: 1.6;
  margin-top: 2px;
}

.contact-method strong {
  display: block;
  font-size: 1.18rem;
  font-weight: 500;
  color: var(--dark-brown);
  margin-bottom: 6px;
}

.contact-method p,
.contact-method a {
  font-size: 1rem;
  line-height: 1.75;
  color: var(--olive);
  text-decoration: none;
}

.contact-map {
  width: 100%;
  height: 300px;
  overflow: hidden;
  border: 1px solid rgba(92,74,61,.14);
  background: rgba(255,255,255,.38);
}

.contact-map iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
  filter: sepia(.28) saturate(.62) hue-rotate(342deg) brightness(.96) contrast(.9);
}

.faq-section {
  background: var(--warm-white);
  padding: 88px 0 96px;
}

.faq-header {
  text-align: center;
  margin-bottom: 42px;
}

.faq-header h2 {
  font-family: var(--font-display);
  font-size: clamp(2.2rem, 4vw, 3.4rem);
  font-weight: 400;
  margin-bottom: 16px;
}

.faq-divider {
  width: 40px;
  height: 2px;
  background: var(--accent);
  margin: 0 auto;
}

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

.faq-item {
  border-top: 1px solid rgba(92,74,61,.18);
  padding-top: 22px;
}

.faq-item details {
  height: 100%;
}

.faq-item summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  font-size: 1.08rem;
  color: var(--dark-brown);
  padding-bottom: 14px;
}

.faq-item summary::-webkit-details-marker {
  display: none;
}

.faq-item summary::after {
  content: '+';
  font-size: 1.2rem;
  color: var(--accent);
  flex: none;
}

.faq-item details[open] summary::after {
  content: '-';
}

.faq-item p {
  color: var(--olive);
  line-height: 1.9;
  font-size: .98rem;
  padding-right: 18px;
}

.faq-cta {
  text-align: center;
  margin-top: 40px;
}

.faq-cta a {
  display: inline-block;
  border: 1px solid rgba(44,36,32,.3);
  padding: 15px 28px;
  color: var(--dark-brown);
  text-decoration: none;
  font-size: .78rem;
  letter-spacing: .12em;
  text-transform: uppercase;
}

@media (max-width: 1080px) {
  .contact-hero {
    background-size: cover;
    background-position: center center, center center;
  }

  .contact-hero::before {
    background-position: center center;
  }

  .contact-grid {
    grid-template-columns: 1fr;
    gap: 52px;
  }

  .info-panel {
    border-left: none;
    padding-left: 0;
  }

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

}

@media (max-width: 650px) {
  .contact-hero {
    margin-top: 76px;
    min-height: auto;
    padding: 112px 0 58px;
    background-size: cover;
    background-position: center center, center center;
  }

  .contact-hero h1 {
    font-size: clamp(3rem, 14vw, 4.6rem);
  }

  .hero-note {
    font-size: 1.45rem;
  }

}
