@charset "UTF-8";
/* ------------------- 공통 -------------------- */
.sub_tit > span {
  font-size: clamp(16px, 1.04vw, 20px);
  color: var(--color-point);
  font-weight: 500;
}
.sub_tit h2 {
  font-size: clamp(32px, 2.08vw, 40px);
  font-weight: 700;
}
.sub_tit > p {
  font-size: clamp(16px, 1.15vw, 22px);
  color: #444;
}

/* ------------------- 서브 링크 섹션 -------------------- */
#sub_more_area ul li {
  width: calc((100% - clamp(50px, 4.17vw, 80px)) / 3);
  background-color: #f6f7f8;
}
#sub_more_area ul li a {
  padding: clamp(20px, 1.72vw, 33px) clamp(17px, 1.56vw, 30px);
  position: relative;
}
#sub_more_area ul li a .tit {
  font-size: clamp(19px, 1.35vw, 26px);
  font-weight: 700;
  border-bottom: 2px solid #222;
  width: fit-content;
  line-height: 1.5;
}
#sub_more_area ul li a .txt {
  font-size: clamp(14px, 0.94vw, 18px);
  color: #444;
  line-height: 1.5;
}
#sub_more_area ul li a .bubble_wrapper {
  position: absolute;
  top: clamp(15px, 1.56vw, 30px);
  right: clamp(12px, 1.56vw, 30px);
}
#sub_more_area ul li a .bubble_wrapper .speech_bubble {
  font-size: clamp(11px, 0.83vw, 16px);
  font-weight: 700;
  color: #fff;
  background: linear-gradient(to right bottom, #1a49db, #e860e3);
  padding: clamp(6px, 0.52vw, 10px) clamp(10px, 0.94vw, 18px);
  border-radius: 20px;
  position: relative;
}
#sub_more_area ul li a .bubble_wrapper .speech_bubble::after {
  content: "";
  position: absolute;
  bottom: -11px; /* 아래쪽에 배치 */
  right: 20px; /* 원하는 위치 조정 */
  width: 14px;
  height: 14px;
  clip-path: polygon(0% 0%, 100% 0%, 0% 100%);
  background: linear-gradient(to bottom, #b85ae1, #e860e3);
}

/* ------------------- 서브 폼 섹션 -------------------- */
#sub_form_area {
  background-color: #f6f6f6;
}
#sub_form_area .sub_tit {
  width: 32%;
  min-width: 300px;
}
#sub_form_area .sub_tit h2 {
  line-height: 1.4;
}

/* 개선된 링크 버튼 영역 */
#sub_form_area .link {
  display: flex;
  gap: clamp(20px, 1.82vw, 35px);
}

#sub_form_area .link a {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  text-decoration: none;
  transition: transform 0.2s ease;
}

#sub_form_area .link a:hover {
  transform: translateY(-3px);
}

#sub_form_area .link a span {
  width: clamp(60px, 4.48vw, 86px);
  height: clamp(60px, 4.48vw, 86px);
  background-color: var(--color-point);
  border-radius: 20%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
}

#sub_form_area .link a:hover span {
  background-color: var(--color-point-hover, #004080);
  transform: scale(1.05);
}

#sub_form_area .link a span::after {
  content: "";
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  display: block;
}

#sub_form_area .link a p {
  font-size: clamp(15px, 0.89vw, 17px);
  font-weight: 500;
  color: var(--color-point);
  margin-top: 10px;
  white-space: nowrap;
}

#sub_form_area .link a .call::after {
  background-image: url(../images/call_icon_t.svg);
  width: clamp(26px, 1.35vw, 26px);
  height: clamp(26px, 1.35vw, 26px);
}

#sub_form_area .link a .kakao::after {
  background-image: url(../images/kakao_icon_new.png);
  width: clamp(32px, 1.67vw, 32px);
  height: clamp(28px, 1.46vw, 28px);
}

#sub_form_area .link a .location::after {
  background-image: url(../images/location_icon_t.svg);
  width: clamp(22px, 1.15vw, 22px);
  height: clamp(28px, 1.46vw, 28px);
}

#sub_form_area .right {
  width: 50%;
}
#sub_form_area .right #sub_form label span {
  font-weight: 500;
  margin-right: clamp(20px, 2.08vw, 40px);
  font-size: clamp(14px, 0.94vw, 18px);
}
#sub_form_area .right #sub_form label input {
  font-size: clamp(14px, 0.94vw, 18px);
  width: clamp(200px, 12.5vw, 240px);
  padding: clamp(15px, 1.04vw, 20px);
  border: 1px solid #dddddd;
}
#sub_form_area .right #sub_form label select {
  background: #fff url(../img/form_arrow.svg) right 20px center no-repeat;
  padding: clamp(15px, 1.04vw, 20px);
  border: 1px solid #dddddd;
  appearance: none;
  position: relative;
  color: #666;
  width: clamp(200px, 12.5vw, 240px);
  font-size: clamp(14px, 0.94vw, 18px);
  cursor: pointer;
}
#sub_form_area .right #sub_form label select option {
  color: #222;
}
#sub_form_area .right #sub_form .txt_wrapper {
  width: 100%;
}
#sub_form_area .right #sub_form .txt_wrapper label {
  width: 100%;
}
#sub_form_area .right #sub_form .txt_wrapper label span {
  margin-right: 13px;
}
#sub_form_area .right #sub_form .txt_wrapper label textarea {
  border: 1px solid #dddddd;
  font-size: clamp(14px, 0.94vw, 18px);
  padding: 10px clamp(15px, 1.04vw, 20px);
  width: 100%;
}
#sub_form_area .right #sub_form .txt_wrapper label textarea::placeholder {
  color: #666;
}
#sub_form_area .right #sub_form .agree_wrapper {
  margin-top: 30px;
  margin-bottom: 50px;
}
#sub_form_area .right #sub_form .agree_wrapper input[type=checkbox] + span {
  width: 20px;
  height: 20px;
  background: none;
  margin-right: 10px;
  background-color: #fff;
  border: 1px solid #ddd;
}
#sub_form_area .right #sub_form .agree_wrapper input[type=checkbox]:checked + span {
  background-image: url(../images/check_icon_b.svg);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 18px 15px;
}
#sub_form_area .right #sub_form .agree_wrapper label {
  color: #222;
  font-weight: 300;
  margin-right: 10px;
  font-size: clamp(16px, 0.83vw, 16px);
}
#sub_form_area .right #sub_form .agree_wrapper button {
  font-weight: 600;
  color: #999;
  font-size: clamp(14px, 0.73vw, 14px);
}
#sub_form_area .right #sub_form .subCounsel_btn {
  width: 100%;
  background-color: var(--color-point);
  color: #fff;
  font-size: clamp(20px, 1.04vw, 20px);
  font-weight: 700;
  padding: 23px 0;
}

@media (max-width: 1120px) {
  #sub_form_area .right #sub_form label {
    display: flex;
    flex-wrap: wrap;
  }
  #sub_form_area .right #sub_form label span {
    margin-bottom: 10px;
    width: 100%;
  }
  #sub_form_area .right #sub_form label input {
    width: clamp(170px, 22.73vw, 250px);
  }
  #sub_form_area .right #sub_form label select {
    width: clamp(170px, 22.73vw, 250px);
  }
  #sub_form_area .right #sub_form .txt_wrapper label {
    align-items: flex-start;
  }
}

@media (max-width: 750px) {
  .sub_tit span {
    font-size: clamp(16px, 3.73vw, 28px);
  }
  .sub_tit h2 {
    font-size: clamp(28px, 6.4vw, 48px);
  }
  .sub_tit p {
    font-size: clamp(16px, 3.73vw, 28px);
  }
  
  #sub_form_area .container {
    flex-direction: column;
  }
  
  #sub_form_area .sub_tit {
    width: 100%;
    text-align: center;
    min-width: unset;
  }
  
  /* 개선된 모바일 링크 버튼 */
  #sub_form_area .link {
    display: flex;
    justify-content: center;
    gap: clamp(30px, 8vw, 60px);
    max-width: 400px;
    margin: 0 auto;
  }
  
  #sub_form_area .link a {
    flex: 0 1 auto;
  }
  
  #sub_form_area .link a span {
    width: clamp(70px, 18.67vw, 140px);
    height: clamp(70px, 18.67vw, 140px);
    border-radius: 18%;
  }
  
  #sub_form_area .link a .call::after {
    width: clamp(28px, 6.4vw, 48px);
    height: clamp(28px, 6.4vw, 48px);
  }
  
  #sub_form_area .link a .kakao::after {
    width: clamp(32px, 7.47vw, 56px);
    height: clamp(28px, 6.67vw, 50px);
  }
  
  #sub_form_area .link a .location::after {
    width: clamp(24px, 5.33vw, 40px);
    height: clamp(30px, 6.67vw, 50px);
  }
  
  #sub_form_area .link a p {
    font-size: clamp(15px, 3.73vw, 28px);
    margin-top: clamp(12px, 3.2vw, 24px);
    font-weight: 600;
  }
  
  #sub_form_area .right {
    width: 100%;
    margin-left: 0 !important;
  }
  #sub_form_area .right #sub_form .input_wrapper {
    flex-direction: column;
    padding-bottom: 0;
  }
  #sub_form_area .right #sub_form .select_wrapper {
    flex-direction: column;
  }
  #sub_form_area .right #sub_form label {
    margin-bottom: clamp(30px, 8vw, 60px);
  }
  #sub_form_area .right #sub_form label span {
    margin-right: 0;
    margin-bottom: clamp(15px, 4vw, 30px);
    font-size: clamp(18px, 4vw, 30px);
  }
  #sub_form_area .right #sub_form label input {
    width: 100%;
    font-size: clamp(18px, 4vw, 30px);
    padding: clamp(18px, 5.47vw, 41px);
  }
  #sub_form_area .right #sub_form label select {
    width: 100%;
    font-size: clamp(18px, 4vw, 30px);
    padding: clamp(18px, 5.47vw, 41px);
    background: #fff url(../img/form_arrow.svg) right clamp(18px, 5.47vw, 41px) center no-repeat;
    background-size: clamp(15px, 3.2vw, 24px) clamp(10px, 1.87vw, 14px);
  }
  #sub_form_area .right #sub_form .txt_wrapper label textarea {
    height: clamp(140px, 32vw, 240px);
    padding: clamp(18px, 5.47vw, 41px);
    font-size: clamp(18px, 4vw, 30px);
  }
  #sub_form_area .right #sub_form .agree_wrapper {
    margin: clamp(30px, 8vw, 60px) 0;
  }
  #sub_form_area .right #sub_form .agree_wrapper input[type=checkbox] + span {
    width: clamp(22px, 4vw, 30px);
    height: clamp(22px, 4vw, 30px);
    margin-right: clamp(10px, 2.67vw, 20px);
  }
  #sub_form_area .right #sub_form .agree_wrapper input[type=checkbox]:checked + span {
    background-size: clamp(18px, 3.2vw, 24px) clamp(15px, 2.8vw, 21px);
  }
  #sub_form_area .right #sub_form .agree_wrapper label {
    margin-bottom: 0;
    font-size: clamp(16px, 3.73vw, 28px);
    font-weight: 400;
    margin-right: clamp(10px, 2.67vw, 20px);
  }
  #sub_form_area .right #sub_form .agree_wrapper button {
    font-size: clamp(14px, 3.33vw, 25px);
  }
  #sub_form_area .right #sub_form .subCounsel_btn {
    font-size: clamp(22px, 4.53vw, 34px);
    padding: clamp(20px, 5.33vw, 40px);
  }
}