/* ���̾ƿ� Ʋ */
html {
  height: 100%;
}

body {
  margin: 0;
  height: 100%;
  background: #f5f6f7;
  font-family: Dotum, "����", Helvetica, sans-serif;
  font-size: 16px;
  line-height: 1.5rem;
}
h1,
h2,
h3 {
  line-height: 2rem;
}
#logo {
  width: 240px;
  height: 44px;
  cursor: pointer;
}

#header {
  padding-top: 20px;
  padding-bottom: 20px;
  text-align: center;
}
#wrapper {
  position: relative;
  height: 100%;
}

#content {
  padding: 1% 20%;
}

/* �Է��� */

h3 {
  margin: 19px 0 8px;
  font-size: 14px;
  font-weight: 700;
}

.box {
  display: block;
  width: 100%;
  height: 51px;
  border: solid 1px #dadada;
  padding: 10px 14px 10px 14px;
  box-sizing: border-box;
  background: #fff;
  position: relative;
}

.int {
  display: block;
  position: relative;
  width: 100%;
  height: 29px;
  border: none;
  background: #fff;
  font-size: 15px;
}

a {
  word-break: break-all;
}

input {
  font-family: Dotum, "����", Helvetica, sans-serif;
}

.box.int_id {
  padding-right: 110px;
}

.box.int_pass {
  padding-right: 40px;
}

.box.int_pass_check {
  padding-right: 40px;
}

.step_url {
  /*@naver.com*/
  position: absolute;
  top: 16px;
  right: 13px;
  font-size: 15px;
  color: #8e8e8e;
}

.pswdImg {
  width: 18px;
  height: 20px;
  display: inline-block;
  position: absolute;
  top: 50%;
  right: 16px;
  margin-top: -10px;
  cursor: pointer;
}

#bir_wrap {
  display: table;
  width: 100%;
}

#bir_yy {
  display: table-cell;
  width: 147px;
}

#bir_mm {
  display: table-cell;
  width: 147px;
  vertical-align: middle;
}

#bir_dd {
  display: table-cell;
  width: 147px;
}

#bir_mm,
#bir_dd {
  padding-left: 10px;
}

select {
  width: 100%;
  height: 29px;
  font-size: 15px;
  background: #fff
  url(https://static.nid.naver.com/images/join/pc/sel_arr_2x.gif) 100% 50%
  no-repeat;
  background-size: 20px 8px;
  -webkit-appearance: none;
  display: inline-block;
  text-align: start;
  border: none;
  cursor: default;
  font-family: Dotum, "����", Helvetica, sans-serif;
}

#zip {
  display: table-cell;
  width: 330px;
}

#zip_search {
  display: table-cell;
  width: 130px;
}

/* �����޼��� */

.error_next_box {
  margin-top: 9px;
  font-size: 12px;
  color: red;
  display: none;
}

#alertTxt {
  position: absolute;
  top: 19px;
  right: 38px;
  font-size: 12px;
  color: red;
  display: none;
}

/* ��ư */

.btn_area {
  margin: 30px 0 91px;
}

#btnJoin {
  width: 100%;
  padding: 21px 0 17px;
  border: 0;
  cursor: pointer;
  color: #fff;
  background-color: #289aff;
  font-size: 20px;
  font-weight: 400;
  font-family: Dotum, "����", Helvetica, sans-serif;
}

#btnSearch {
  width: 100%;
  padding: 12px 0 15px;
  border: 0;
  cursor: pointer;
  color: #fff;
  background-color: #8c8c8c;
  font-size: 20px;
  font-weight: 400;
  font-family: Dotum, "����", Helvetica, sans-serif;
}
/* yrchae 230202 */
.policy-wrap {
  line-height: 1.25;
  word-break: keep-all;
}
.policy-wrap table {
  margin: 1rem 0;
}
.policy-wrap table td {
  padding: 6px 6px;
}
.policy-wrap .txt-box {
  border: 1px solid #222;
  padding: 1rem;
  box-sizing: border-box;
}
.policy-wrap ol,
.policy-wrap ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
.policy-wrap ol li,
.policy-wrap ul li {
  padding-bottom: 1rem;
}
.policy-wrap .sub-list {
  margin-top: 1rem;
  margin-left: 1rem;
}
.policy-wrap .txt-box.ty2 {
  border: 0;
  text-align: left;
  padding: 0;
}

.overflow-x {
  overflow-x: auto;
}
.allOpenDiv {
  width:100%;
  text-align: left;
}
/* jhj 추가 수정 24.07.19 */
#allOpen {
  height:40px;
  margin-bottom:20px;
  background:#fafafa;
  color:#555;
  border-radius:3px;
  border:1px solid #ccc;
  font-weight: 700;
  width:100%;
}
.d-flex {
  display: flex;
}
.d-flex > div {
  width:50%;
  display: flex;
  align-items: center;
}
/* start jhj 추가 수정 24.07.19 */
fieldset {
  border:0;
}

.agree-list {
  border-radius: 5px;
  border:1px solid #ccc;
  margin-bottom:20px;
  background:#fafafa;
}

.agree-list .terms-title {
  display: flex;
  align-items: center;
  margin:0;
  font-size: 16px;
  justify-content: space-between;
}

.agree-list.active .terms-title i {
  transform: rotate(180deg);
}

.agree-list.active .terms-item {
  display: block;
}

.btn-next {
  height:50px;
  border-radius: 5px;
  font-weight: 700 !important;
  padding:10px !important;
}
.btn-next.active {
  background:#34a2ef !important;
}

.agree-checkbox {
  display:flex;
}

.agree-checkbox [type="checkbox"]:not(:checked),
.agree-checkbox [type="checkbox"]:checked {
  position: absolute;
  left: 0;
  opacity: 0.01;
}
.agree-checkbox [type="checkbox"]:not(:checked) + label,
.agree-checkbox [type="checkbox"]:checked + label {
  position: relative;
  padding-left: 25px;
  cursor: pointer;
  line-height: 1.3;
}

.agree-checkbox [type="checkbox"]:not(:checked) + label:before,
.agree-checkbox [type="checkbox"]:checked + label:before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  width: 16px;
  height: 16px;
  border: 1px solid #aaa;
  background: #FFF;
  border-radius: 5px;
}

.agree-checkbox [type="checkbox"]:not(:checked) + label:after,
.agree-checkbox [type="checkbox"]:checked + label:after {
  content: '';
  position: absolute;
  width: 16px;
  height: 16px;
  border: 1px solid #34a2ef;
  top: 0;
  left: 0;
  line-height: 0;

  border-radius: 5px;
  background:#34a2ef url('../images/membership/ico_check_white.svg') no-repeat center center;
  background-size:10px;
}

.agree-checkbox [type="checkbox"]:not(:checked) + label:after {
  opacity: 0;
}
.agree-checkbox [type="checkbox"]:checked + label:after {
  opacity: 1;
}
/* end jhj 추가 수정 24.07.19 */

@media screen and (max-width: 1024px) {
  #content {
    padding: 1% 5rem;
  }

} /*tablet*/

@media screen and (max-width: 768px) {

  #content {
    padding: 1% 2rem;
  }

}

@media screen and (max-width: 480px) {
  h1, h2, h3 {
    font-size: 20px;
    letter-spacing: -0.1em;
  }
  .terms-title {
    font-size: 18px;
    letter-spacing: -0.15em;
  }
  .d-flex > div label {
    font-size: 14px;
  }
}/*mobile*/

@media screen and (min-width: 600px) {
  #allOpen {
    width:100px;
    height:40px;
    font-size:20px;
  }
}

@media screen and (min-width: 1024px) {
  #allOpen {
    width:120px;
    height:40px;

  }

}