:root{
  --main-background: rgb(0, 0, 0);
  --ad-background: rgb(50, 50, 50);
  --font-overall: Arial, sans-serif;
  --text-color: #d3d3d3;


  --accent:#a1a1aa;
  --muted:#a1a1aa;
  --card:#1f1f1f;
  --card:rgb(0, 0, 0);

  --radius:12px;
  --font-overall: Arial, sans-serif;

  font-family: Arial, sans-serif;
}

*{box-sizing:border-box}

body{
  margin:0;
  background:var(--main-background);
  color:#e4e4e7;
}

.contact-wrapper h2 {
  text-align: center;
  font-size: 4rem;
  color: var(--text-color);


  text-decoration: underline;
  text-underline-offset: 9px;
  text-decoration-thickness: 4px;
}

.contact-wrapper h3 {
  text-align: left;
  font-size: 2.5rem;
  color: var(--text-color);


  text-decoration: underline;
  text-underline-offset: 9px;
  text-decoration-thickness: 4px;
}

.contact-wrapper {
  margin-top: 80px;
}

.contact-container-wrapper{
  text-align: center;
  padding: auto;
}

.contact-container{
  height: 500px;
  background-color: var(--card);
  margin: auto;
  display: flex;           /* Flexbox voor kolommen */
  gap: 20px;               /* Ruimte tussen kolommen */

  height: auto;
}

.contact-wrapper h4 {
  margin: 0;
  font-size: 2rem;
  font-weight: 600;
}

.contact-wrapper p {
  font-size: 1.25rem;
  margin: 0;
}

.map{
  grid-column:1 / -1;
  padding:0;
  height: auto;
  border-radius:var(--radius);
  overflow: hidden;
  border-radius: 0;
}

.map iframe{
  border:0;
  display:block;
  width: 100%; 
  height: 500px;
  border-radius: 0;
}

















.contact-wrapper{
  padding: 20px;
}

.container{
  max-width:1100px;
  margin:0 auto;
  padding:28px;
  background-color: #1f1f1f;
  border-radius:22px;
  margin-top: 50px;
  margin-bottom: 75px;

}

.brand{
  display:flex;
  align-items:center;
  gap:14px;
}

.logo{
  width:56px;
  height:56px;
  background:#0b74ff;
  border-radius:10px;
  display:grid;
  place-items:center;
  color:white;
  font-weight:700;
}

p.lead, .small{
  color:var(--muted);
  text-align: center;
  font-size: 1.25rem;
}

.grid{
  display:grid;
  grid-template-columns:1fr;
  gap:20px;
}

@media(min-width:900px){
  .grid{grid-template-columns:1fr 420px}
}

@media(max-width: 900px){
  .contact-info{
    order: -1;
  }
  .container{
    padding:0px;
  }
}

.card{
  background:var(--card);
  padding:22px;
  border-radius:var(--radius);
  box-shadow:0 6px 18px rgba(0,0,0,0.5);
}

form label{
  display:block;
  font-size:13px;
  color:var(--muted);
  margin-bottom:6px;

  font-size: 1.15rem;
}

input[type=text], input[type=email], input[type=tel], select, textarea, input[type=date]{
  width:100%;
  padding:10px 12px;
  border-radius: 2px;
  background:#111111;
  color:#e4e4e7;
  font-size:15px;
  border: 0;
}

textarea{
  min-height:140px;
  resize:vertical;
}

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

@media(min-width:600px){
  .row.cols2{
    grid-template-columns:1fr 1fr;
  }
}

.contact-info{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.info-item{
  display:flex;
  gap:12px;
  align-items:flex-start;

  text-align: center;
  font-size: 1.25rem;
}

.btn {
  display: inline-flex;
  align-items: center;     /* verticale uitlijning */
  gap: 10px;
  padding: 5px 15px 5px 5px;
  background:#111111;
  border: 0;
  border-radius: 6px;
  max-height: 70px;
  margin-top: 20px;
}

.btn svg {
  width: 50px;
  height: 50px;
}
.btn-text {
  display: flex;           /* 🔑 */
  align-items: center;     /* 🔑 */
  line-height: 1;          /* 🔑 voorkomt optische offset */
  font-size: 1.5rem;
  padding: 12px;
  color: var(--text-color);
}

.btn-arrow {
  border-radius: 6px;
  display: block;          /* voorkomt inline-SVG baseline issues */
  background-color: var(--text-color);
}


.btn:hover .btn-arrow {
    transform: translateX(8px); /* subtiele hover-animatie */
}

.success{
  background:#064d2d20;
  padding:12px;
  border-radius:8px;
  color:#e6ffef;
  margin-bottom:12px;
}

.error{
  background:#7a122220;
  padding:12px;
  border-radius:8px;
  color:#ffccd5;
  margin-bottom:12px;
}

#contact-heading{
  text-align: left;
  font-size: 2.75rem;

  text-decoration: underline;
  text-underline-offset: 9px;
  text-decoration-thickness: 4px;
}

.info-item a {
    text-decoration: none;
    color: var(--muted);
}









.right1 {
    flex: 2; /* takes equal space as .right */
    background-color: var(--card);
    margin-top: 50px;
}

.left1 {
    flex: 1;
    height: 500px;
}

.contact-button{
  width: auto;
  height: 40px;

  border: none;
  border-radius: 5px;

  padding-left: 20px;
  padding-right: 20px;

  margin-top: auto;
  margin-left: auto;
  margin-right: auto;

  margin-bottom: 100px;
  
  font-size: 1.5rem;
  font-weight: 600;
}

.contact-button:hover{
  background-color: red;
}

.column{
  display: flex;
  flex-direction: column;
  height: 350px; /* 🔥 essentieel */
  width: 250px;
  padding: 0 50px 0 50px;
  flex: 1;                 /* Alle kolommen gelijk breed */
}

#whatsapp {
  background-color: rgb(89, 197, 57);
  color: whitesmoke;
}

#whatsapp:hover {
  color: black;
}

#route::before {
    content: "\f4d7";
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    margin-right: 8px;
}

#whatsapp::before {
    content: "\f232";
    font-family: "Font Awesome 6 Brands";
    font-weight: 900;
    margin-right: 8px;
}

#call::before {
    content: "\f095";
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    margin-right: 8px;
}

@media (max-width: 991px) {
    .form-wrapper {
        flex-direction: column; /* 🔥 onder elkaar */
    }

    .right {
        height: auto; /* belangrijk: voorkomt mega blok */
        padding: 24px; /* vaak fijner op mobiel */
    }

  .map {
        border-radius: 20px;

  }

  .map iframe{
    padding: 20px 100px 20px 100px;
  }    
}

/* Media query voor mobiele schermen */
@media (max-width: 1200px) {
  .contact-container {
    flex-direction: column; /* Kolommen onder elkaar */
  }

  .map iframe{
    padding: 25px;  
  }

  .column{
    margin: auto;
    width: 350px;
  }

  #btn-submit {
    display: flex;
    justify-content: center;
  }

  #contact-heading {
    text-align: center;
  }

.right1 {
    flex: 1; /* takes equal space as .right */
}

.left {
    flex: 1;
} 
}