:root{
  --joinColor: #f5f5f5;
  --joinHeight: 40px;
  --joinBorder: #ddd;
  --joinRadius: 4px;
  --joinPadding: 0 15px;

  --joinFont_s: 15px;
}

/* 회원가입 ============================================== */
.sc_join{
  padding: 80px 0;
  background: var(--brandColor3);
}
.sc_join h2{
  margin-bottom: 40px;
  text-align: center;
  font-size: 48px;
  font-weight: 600;
}
.sc_join h3{
  padding: 20px 10px;
  font-size: 20px;
  font-weight: 600;
  border-bottom: 2px solid #000;
}

.sc_join .group_form {
  padding: 60px;
  background: #fff;
  border-radius: var(--joinRadius);
  box-shadow: rgba(100, 100, 111, 0.1) 0px 4px 20px 0px;
}
.sc_join .group_form2 {
  padding-top: 40px;
}

.sc_join ul {
  width: 100%;
  display: flex;
  flex-direction: column;
}
.sc_join ul li{
  display: flex;
  align-items: flex-start;
  padding: 18px 15px;
}
.sc_join ul li:not(:last-child){
  /* border-bottom: 1px solid #ddd; */
}
.sc_join ul li .flex_wrap{
  display: flex;
  align-items: center;
  gap: 7px;
}
.sc_join ul li .title{
  padding-top: 11px;
  min-width: 165px;
  font-size: 17px;
  font-weight: 600;
}
.sc_join .text {
  min-width: 300px;
  height: var(--joinHeight);
  padding: var(--joinPadding);
  font-size: var(--joinFont_s);
  border: 0;
  outline: none;
  background: var(--joinColor);
  /* border-bottom: 1px solid var(--joinBorder); */
}
.btn_all{
  height: var(--joinHeight);
  padding: 0 20px;
  font-size: 14px;
  border-radius: var(--joinRadius);
  cursor: pointer;
}
.btn_resend{
  border: 1px solid #ddd;
}
.btn_num{
  background: var(--brandColor2);
  color: #fff;
}
.btn_check{
  color: #fff;
  background: var(--brandColor2);
}
.btn_all .check_ok{
  display: none;
}
.btn_all.ok{
  color: var(--brandColor);
  background: #fff5ed;
  border: 1px solid var(--brandColor);
}
.btn_all.ok .check_ok{
  display: block;
}

/* 비밀번호 */
.sc_join .mobile_box2 .wrap{
  position: relative;
}
.sc_join .mobile_box2 .time{
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
  color: #444;
  font-size: 14px;
}
.sc_join ul li .mobile_box2 .mobile_text{
  min-width: 356px;
  padding-right: 40px;
}


/* 회원구분 */
.sc_join .customer_wrap{
  margin-top: 15px;
}

/* 전화번호 */
.sc_join ul li select{
  height: var(--joinHeight);
  padding: var(--joinPadding);
  border-radius: var(--joinRadius);
  border: 1px solid #ddd;
  font-size: var(--joinFont_s);
  background: #fff;
}
.sc_join ul li select option{
  background: #fff;
}
.sc_join ul li .mobile_wrap{
  display: flex;
  align-items: center;
  gap: 5px;
}
.sc_join ul li .mobile_wrap .wrap{
  display: flex;
  align-items: center;
  gap: 3px;
}
.sc_join ul li .mobile_box1{
  width: 100%;
}
.sc_join ul li .mobile_box1 .mobile_text{
  max-width: 85px;
  min-width: auto;
}
.sc_join ul li .codenum_wrap{
  display: flex;
  align-items: center;
  gap: 10px;
  padding-top: 15px;
}

/* 이메일 */
.sc_join ul li .email {
  min-width: auto;
  max-width: 160px;
}


/* input 체크박스 스타일 */
.sc_join ul li .check_area{
  flex: 1;
}
.sc_join ul li .check_area .check_wrap{
  display: flex;
  align-items: center;
  gap: 15px;
  margin-top: 20px;
}

.sc_join ul li input[type=radio]:checked + label::before,
.sc_join ul li input[type=checkbox]:checked + label::before{
  border: 0;
  background: url(../img/check.svg) var(--brandColor) no-repeat center/contain;
}

/* 약관 */
.sc_join .privacy_list{
  flex-direction: row;
  gap: 50px;
}
.sc_join .privacy_list .privacy_item{
  flex: 1;
  flex-direction: column;
  padding: 0;
  border: 0;
}
.sc_join .privacy_list .privacy_item .flex_wrap{
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 15px;
}
.sc_join .privacy_list .privacy_item .flex_wrap label{
  font-size: 17px;
  font-weight: 500;
}
.sc_join .privacy_list .privacy_item .agree_box{
  height: 200px;
  padding: 15px;
  border: 1px solid #ddd;
  background: #fff;
  overflow-y: scroll;
}
.sc_join .privacy_list .privacy_item .agree_box p{
  font-size: var(--joinFont_s);
  font-weight: 300;
  line-height: 1.4;
}

/* 가입하기 버튼 */
.sc_join .link_join {
  display: block;
  margin: 0 auto;
  margin-top: 80px;
  width: 220px;
  padding: 16px 0;
  text-align: center;
  font-size: 20px;
  font-weight: 600;
  color: #fff;
  background: var(--brandColor);
  border-radius: var(--joinRadius);
}



/* 회원가입을 축하합니다 ============================================== */
.sc_religion{
  padding: 100px 0;
}
.sc_religion .col_top{
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.sc_religion h2{
  font-size: 45px;
  font-weight: 700;
}
.sc_religion p{
  text-align: center;
  font-size: 22px;
  font-weight: 400;
  color: #444;
  line-height: 1.4;
}
.sc_religion p b{
  color: #000;
  font-weight: 600;
}

.sc_religion img{
  padding: 50px 0 30px;
}



/* 로그인 버튼 */
.sc_religion .link_wrap{
  display: flex;
  justify-content: center;
  gap: 15px;
  margin-top: 40px;
}
.sc_religion .link_wrap .box{
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  margin-top: 40px;
  width: 220px;
  padding: 16px 0;
  text-align: center;
  font-size: 20px;
  font-weight: 600;
  color: var(--brandColor);
  background: #fff;
  border: 1px solid var(--brandColor);
  border-radius: var(--joinRadius);
  box-shadow: rgb(142 68 0 / 20%) 0px 4px 15px 0px;
}
.sc_religion .link_wrap #link_login{
  color: #fff;
  background: var(--brandColor);
}
.sc_religion .link_wrap .box span{
  font-size: 17px;
  font-weight: 400;

}



  /* 959 ~ 768 */
  @media (max-width: 959px) {
    .sc_join h2 {
      margin-bottom: 30px;
      font-size: 38px;
    }
    .sc_join h3 {
      padding: 15px 10px;
      font-size: 18px;
    }
    .sc_join .group_form {
      padding: 32px;
    }

    .sc_join ul li .title {
      min-width: 150px;
    }
    .sc_join ul li select{
      font-size: 14px;
    }
    .sc_join ul li .mobile_box1{
      align-items: start;
      flex-direction: column;
    }
    .sc_join ul li .mobile_box1 .mobile_text{
      max-width: 105px;
    }
    .sc_join ul li .mobile_box1 .btn_num {
      width: 435px;
    }
    .sc_join ul li .mobile_box2 .mobile_text{
      min-width: 273px;
    }
    /* .sc_join ul li .flex_wrap, .sc_join .text {
      width: 100%;
    } */
     
  }
  /* 767 ~ 587 */
  @media (max-width: 767px) {
    :root {
      --joinPadding: 0 10px;
      --joinFont_s: 14px;
    }
    .sc_join h2 {
      font-size: 33px;
    }
    .sc_join .group_form {
      padding: 20px;
    }
    .sc_join ul li{
      flex-direction: column;
    }
    .sc_join ul li .title {
      padding-top: 0;
      padding-bottom: 10px;
      min-width: 120px;
      font-size: 15px;
    }
    .sc_join ul li .flex_wrap{
      width: 100%;
    }
    .sc_join .text{
      flex: 1;
    }

    .sc_join ul li .mobile_box1 .mobile_text {
      max-width: 103px;
    }
    .sc_join ul li .mobile_box1 .btn_num{
      width: 410px;
    }
    .sc_join ul li .mobile_box2 .mobile_text{
      min-width: 245px;
    }
    .sc_join ul li{
      padding: 25px 15px;
    }
    .sc_join ul li .check_area .check_wrap {
      margin-top: 16px;
    }
    .check_wrap label{
      font-size: 15px;
      padding-left: 25px;
    }
    .check_wrap label::before {
      width: 16px;
      height: 16px;
    }

    .sc_join .privacy_list{
      flex-direction: column;
      gap: 30px;
    }
    .sc_join .privacy_list .privacy_item .flex_wrap label {
      font-size: 16px;
    }
    .sc_join .link_join {
      margin-top: 55px;
      width: 160px;
      padding: 13px 0;
    }
  }
  /* 586 ~ 431 */
  @media (max-width: 586px) {
    .sc_join {
      padding: 55px 0;
    }
    .sc_join h2 {
      font-size: 32px;
    }
    .sc_join h3 {
      padding: 25px 5px 10px;
      font-size: 17px;
    }

    .sc_join .group_form {
      padding: 15px;
    }
    .sc_join ul li {
      padding: 15px 5px;
    }
    .sc_join ul li select {
      font-size: 13px;
    }
    .sc_join ul li .mobile_box1 .mobile_text {
      max-width: 67px;
    }
    .sc_join ul li .mobile_box1 .btn_num {
      width: 330px;
    }
    .sc_join ul li .mobile_box2 .mobile_text{
      min-width: auto;
      max-width: 201px;
    }
    .sc_join ul li .codenum_wrap {
      gap: 5px;
    }
    .btn_all {
      padding: 0px 15px;
      font-size: 13px;
    }
    .sc_join ul li .time {
      font-size: 13px;
    }
    .check_wrap label {
      font-size: 14px;
    }

    .sc_join .privacy_list .privacy_item .agree_box {
      height: 140px;
    }
  }
  /* 430 ~ 360 */
  @media (max-width: 430px) {
    :root {
      --joinHeight: 45px;
    }
    .sc_join{
      background: #fff;
    }
    .sc_join .group_form{
      padding: 0;
      background: 0;
      box-shadow: none;
    }
    .sc_join ul li:not(:last-child){
      border: 0;
    }
    .sc_join ul li {
      padding: 18px 0;
    }
    .sc_join h2 {
      margin-bottom: 20px;
      font-size: 28px;
    }
    .sc_join h3 {
      font-size: 16px;
    }
    .sc_join .customer_area {
      gap: 8px;
    }
    .sc_join ul li .title{
      font-size: 14px;
      color: #444;
    }
    .sc_join ul li .mobile_wrap{
      /* flex-direction: column;
      align-items: flex-start; */
    }
    .sc_join ul li .mobile_box1 .mobile_text {
      max-width: 61px;
    }
    .sc_join ul li .mobile_box1 .btn_num {
      width: 320px;
    }
    .sc_join #join_codenum.text {
      max-width: 191px;
    }
    .sc_join ul li .mobile_box1 .btn_num{
      background: var(--brandColor2);
      color: #fff;
    }

    .sc_join ul li .email {
      max-width: 140px;
    }

    .btn_all {
      padding: 0px 15px;
    }
  }
