/* =========================
   CONTACT PAGE
========================= */

.contact-page-section{
  position:relative;

  padding:100px 0;

  background:#050505;

  overflow:hidden;
}

/* BACKGROUND GLOW */

.contact-page-section::before{
  content:'';

  position:absolute;

  top:-120px;
  left:-120px;

  width:320px;
  height:320px;

  border-radius:50%;

  background:#1f2937;

  filter:blur(140px);

  opacity:.20;
}

.contact-page-section::after{
  content:'';

  position:absolute;

  bottom:-150px;
  right:-150px;

  width:380px;
  height:380px;

  border-radius:50%;

  background:#374151;

  filter:blur(160px);

  opacity:.18;
}

/* =========================
   HEADING
========================= */

.contact-heading{
  position:relative;

  z-index:2;

  text-align:center;

  max-width:760px;

  margin:auto auto 70px;
}

/* BADGE */

.contact-badge{
  display:inline-flex;
  align-items:center;

  gap:10px;

  padding:10px 18px;

  border-radius:999px;

  background:rgba(255,255,255,0.05);

  border:1px solid rgba(255,255,255,0.08);

  color:#d1d5db;

  font-size:13px;
  font-weight:500;

  margin-bottom:22px;
}

.contact-badge span{
  width:8px;
  height:8px;

  border-radius:50%;

  background:#ffffff;
}

/* TITLE */

.contact-heading h1{
  color:#ffffff;

  font-size:52px;
  font-weight:800;

  line-height:1.2;

  margin-bottom:20px;
}

/* TEXT */

.contact-heading p{
  color:#9ca3af;

  font-size:15px;

  line-height:1.9;
}

/* =========================
   WRAPPER
========================= */

.contact-wrapper{
  display:grid;

  grid-template-columns:420px 1fr;

  gap:35px;

  align-items:start;
}

/* =========================
   LEFT SIDE
========================= */

.contact-info-box{
  padding:35px;

  border-radius:30px;

  background:rgba(255,255,255,0.03);

  border:1px solid rgba(255,255,255,0.06);

  backdrop-filter:blur(14px);
}

/* INFO CARD */

.contact-info-card{
  display:flex;
  align-items:flex-start;

  gap:18px;

  padding-bottom:28px;

  margin-bottom:28px;

  border-bottom:1px solid rgba(255,255,255,0.06);
}

/* ICON */

.contact-icon{
  width:62px;
  height:62px;

  border-radius:18px;

  background:#111111;

  border:1px solid rgba(255,255,255,0.08);

  display:flex;
  align-items:center;
  justify-content:center;

  color:#ffffff;

  font-size:22px;
}

/* INFO TEXT */

.contact-info-card h3{
  color:#ffffff;

  font-size:20px;
  font-weight:700;

  margin-bottom:8px;
}

.contact-info-card p{
  color:#9ca3af;

  font-size:14px;

  line-height:1.8;
}

/* SOCIAL */

.contact-social{
  display:flex;
  align-items:center;

  gap:14px;
}

.contact-social a{
  width:44px;
  height:44px;

  border-radius:14px;

  background:rgba(255,255,255,0.04);

  border:1px solid rgba(255,255,255,0.06);

  display:flex;
  align-items:center;
  justify-content:center;

  color:#ffffff;

  font-size:16px;

  transition:.35s;

  text-decoration:none;
}

.contact-social a:hover{
  transform:translateY(-5px);

  background:#ffffff;

  color:#000000;
}

/* =========================
   FORM
========================= */

.contact-form-box{
  padding:40px;

  border-radius:30px;

  background:rgba(255,255,255,0.03);

  border:1px solid rgba(255,255,255,0.06);

  backdrop-filter:blur(14px);
}

/* GRID */

.form-grid{
  display:grid;

  grid-template-columns:repeat(2,1fr);

  gap:20px;
}

/* GROUP */

.form-group{
  margin-bottom:24px;
}

/* LABEL */

.form-group label{
  display:block;

  color:#ffffff;

  font-size:14px;
  font-weight:600;

  margin-bottom:12px;
}

/* INPUT */

.form-group input,
.form-group select,
.form-group textarea{
  width:100%;

  padding:16px 18px;

  border-radius:16px;

  background:#111111;

  border:1px solid rgba(255,255,255,0.08);

  outline:none;

  color:#ffffff;

  font-size:14px;

  transition:.35s;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  border-color:rgba(255,255,255,0.20);
}

/* BUTTON */

.contact-btn{
  width:100%;

  padding:16px 24px;

  border:none;

  border-radius:16px;

  background:#ffffff;

  color:#000000;

  font-size:15px;
  font-weight:700;

  cursor:pointer;

  transition:.35s;
}

.contact-btn:hover{
  transform:translateY(-4px);
}

/* =========================
   RESPONSIVE
========================= */

@media(max-width:992px){

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

  .contact-heading h1{
    font-size:44px;
  }

}

@media(max-width:768px){

  .contact-page-section{
    padding:80px 0;
  }

  .contact-heading{
    margin-bottom:50px;
  }

  .contact-heading h1{
    font-size:36px;
  }

  .contact-heading p{
    font-size:14px;
  }

  .contact-form-box,
  .contact-info-box{
    padding:28px;
  }

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

}

@media(max-width:480px){

  .contact-page-section{
    padding:70px 0;
  }

  .contact-heading h1{
    font-size:30px;
  }

  .contact-heading p{
    font-size:13px;
  }

  .contact-form-box,
  .contact-info-box{
    padding:22px;
    border-radius:24px;
  }

  .contact-info-card{
    gap:14px;
  }

  .contact-icon{
    width:54px;
    height:54px;

    font-size:20px;
  }

  .contact-info-card h3{
    font-size:18px;
  }

  .contact-info-card p{
    font-size:13px;
  }

  .contact-social a{
    width:40px;
    height:40px;

    font-size:14px;
  }

}