    @charset "utf-8";

    /* join */
    #sub.join section.board{
        padding-top: 120px;
    }
    .join .mypage_box > div {
    padding: unset;
    border: none;
    }
    .join .info_w {
    display: flex;
    justify-content: space-between;
    height: 50px;
    padding: 15px 0;
    margin-bottom: 60px;
    border: 1px solid #cbcbcb;
    }
    .join .info_w .info_w_text {
    padding-left: 80px;
    font-size: 16px;
    line-height: 50px;
    background-image: url(/images/member/ico_warning.png);
    background-size: contain;
    background-position: top left 20px;
    background-repeat: no-repeat;
    }
    .join_flow_area {
    width: 100%;
    margin: 0 auto;
    }
    .join_flow_area ul {
    margin-bottom: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    }
    .join_flow_area ul.join_flow li {
    width: calc(100% / 3);
    height: 169px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 10px;
    font-size: 20px;
    position: relative;
    }
    .join_flow_area ul.join_flow li:nth-child(1) {
    background: #cacaca;
    }
    .join_flow_area ul.join_flow li:nth-child(2) {
    background: #dddddd;
    }
    .join_flow_area ul.join_flow li:nth-child(3) {
    background: #f6f6f6;
    }
    .join_flow_area ul.join_flow li.on {
    background: #009a6e;
    color: #fff;
    }
    .join_flow_area ul.join_flow li.on::after {
    content: "";
    background: url(/new/images/ico_join_flow_on.png) no-repeat;
    color: #22cacb;
    position: absolute;
    display: inline-block;
    width: 21px;
    height: 11px;
    bottom: -11px;
    left: calc(50% - 10px);
    }
    .join_flow_area ul.join_flow li p:nth-child(1){
        width: 87px;
        height: 87px;
        border-radius: 50%;
        background-color: #fff;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    .join_flow_area ul.join_flow li:nth-child(2) p:nth-child(1) img{
        margin-left: 15px;
    }
    .join_policy .title .title_name {
        font-family: 'S-Core Dream 6';
    }
    .join_policy .cont{
        border: 1px solid #cfcfcf;
        background-color: #f9f9f9;
        padding: 30px;
        box-sizing: border-box;
        margin: 20px 0 15px;
    }
    .join_policy .cont p{
        font-weight: 400;
    }
    .join_policy .cont p span{
        font-weight: 400;
    }
    .coll_bottom {
        gap: 9px;
    }
    /* join01 */
    .join_policy_all_check {
    position: relative;
    padding-left: 28px;
    cursor: pointer;
    user-select: none;
    display: inline-block;
    }
    .join_policy_all_check input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    cursor: pointer;
    height: 0;
    width: 0;
    }
    .checkmark {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    height: 20px;
    width: 20px;
    border: 1px solid #cfcfcf;
    border-radius: 0px;
    background-color: #fff;
    box-sizing: border-box;
    }
    .join_policy_all_check input:checked + .checkmark::after {
    content: "";
    position: absolute;
    left: 5px;
    top: 1px;
    width: 6px;
    height: 12px;
    border: solid #009a6e;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
    }
    .join .board_btn a{
        width: 218px;
        height: 74px;
    }

        /* join02 */
    .join02 .join_policy .cont{
    background-color: #fff;
    gap: 35px;
    line-height: 30px;
    }
    .join_form_wrap{
    margin-top: 25px;
    }
    .join_form_wrap .sub_txt{
    width: 100%;
    text-align: right;
    padding-bottom: 10px;
    border-bottom: 1px solid #000;
    }
    .join_form_wrap form {
    margin: 0 auto;
    }

    .join_form_wrap .form_group {
    display: flex;
    align-items: center;
    gap: 15px;
    width: 100%;
    height: 103px;
    padding: 15px 0;
    border-bottom: 1px solid #cfcfcf;
    box-sizing: border-box;
    }
    .join_form_wrap .form_group.addressWrap{
    height: auto;
    border-bottom: 1px solid #000;
    }

    .input_with_button {
    display: flex;
    gap: 15px;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-start;
    }

    .join_form_wrap .form_group .phone_group{
    display: flex;
    align-items: center;
    gap: 5px;
    }

    .join_form_wrap .form_group label {
    width: 196px;
    display: block;
    font-weight: bold;
    }
    .join_form_wrap .form_group.genderWrap .radio_group label{
    font-weight: 400;
    width: 65px;
    }
    .join_form_wrap .form_group.addressWrap label{
    margin-bottom: auto;
    }
    .join_form_wrap input[type="text"],
    .join_form_wrap input[type="email"],
    .join_form_wrap input[type="password"],
    .join_form_wrap input[type="tel"],
    .join_form_wrap input[type="date"],
    .join_form_wrap select {
    width: 100%;
    height: 72px;
    padding: 10px;
    font-size: 20px;
    border: 1px solid #cfcfcf;
    box-sizing: border-box;
    }
    .join_form_wrap input[type="text"]{max-width: 333px;}
    .join_form_wrap input[type="email"]{max-width: 431px;}
    .join_form_wrap input[type="password"]{max-width: 333px;}
    .join_form_wrap .phone_group input[type="text"]{max-width: 207px;}
    .join_form_wrap input[type="date"] {max-width: 163px;}
    .join_form_wrap input[id="zipcode"]{max-width: 207px;}
    .join_form_wrap input[id="address1"]{max-width: 100%;}
    .join_form_wrap input[id="address2"]{max-width: 664px;}

    .join_form_wrap .birthdate_selects {
    width: 80%;
    display: flex;
    gap: 15px;
    flex-wrap: wrap;
    margin-top: 0.5rem;
    }

    .join_form_wrap .birthdate_selects select {
    max-width: 163px;
    width: 100%;
    font-size: 20px;
    padding: 0.8rem 3rem 0.8rem 1rem;
    border: 1px solid #ccc;
    border-radius: 0px;
    background-image: url('/new/images/ico_search_arr_down.png');
    background-repeat: no-repeat;
    background-position: right 1.8rem center;
    background-size: 10px 6px;

    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    cursor: pointer;
    }

    .join_form_wrap .form_group button {
    width: auto;
    height: 72px;
    padding: 10px 25px;
    background-color: #f1f8f7;
    border: 1px solid #cfcfcf;
    cursor: pointer;
    font-family: "Noto Sans KR", sans-serif;
    letter-spacing: -1px;
    font-weight: 500;
    font-size: 20px;
    display: flex;
    justify-content: center;
    align-items: center;
    white-space: nowrap;
    }

    .join_form_wrap .form_group button:hover {
    color: #009a6e;
    }

    .join_form_wrap .radio_group {
    display: flex;
    gap: 20px;
    align-items: center;
    }

    .radio_group label {
    position: relative;
    padding-left: 30px;
    cursor: pointer;
    font-size: 18px;
    user-select: none;
    }

    .radio_group input[type="radio"] {
    position: absolute;
    opacity: 0;
    cursor: pointer;
    }

    /* 사용자 정의 원형 */
    .radio_group label::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    height: 20px;
    width: 20px;
    border: 1px solid #d1d1d1;
    border-radius: 50%;
    background-color: #fff;
    }

    /* 선택된 상태의 동그라미 안점 */
    .radio_group input[type="radio"]:checked + label::after {
    content: "";
    position: absolute;
    left: 6px;
    top: 50%;
    transform: translateY(-50%);
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #767676;
    }

    /* 체크된 걸 감지하기 위해 구조 변경 필요 */
    .radio_group input[type="radio"]:checked + label::before {
    border-color: #d1d1d1;
    }
    .input_button_wrap {
    width: calc(100% - 210px);
    display: flex;
    gap: 10px;
    align-items: center;
    
    }

    .join .board_btn button{
    width: 218px;
    height: 74px;
    }
    .join .board_btn.cancel_btn button{
    background-color: #4f4f4f;
    border-color: #4f4f4f;
    }
    .join .board_btn.cancel_btn button:hover{
    background-color: #f2f2f2;
    border-color: #4f4f4f;
    color: #4f4f4f;
    }
    .opt-in .input_with_button label {
        width: 80px;
        margin-right: 10px;
    }

    /* join03 */
    .join03 .join_policy .cont{
        background-color: #fff;
        margin-bottom: 0;
    }
    .join .withdrawal {
    padding: 50px 0;
    text-align: center;
    }
    .join .withdrawal_name {
    margin-bottom: 25px;
    }
    .join .withdrawal_ico {
    width: 107px;
    height: 107px;
    margin: 0 auto;
    margin-bottom: 40px;
    background-image: url(/new/images/ico_join_check.png);
    background-size: 60%;
    background-repeat: no-repeat;
    background-position: center;
    background-color: #009a6e;
    border-radius: 50%;
    }
    .join .withdrawalBox,
    .join .withdrawalBox > div {
    display: flex;
    justify-content: center;
    }
    .join .withdrawalBox p {
    margin-bottom: 0 !important;
    line-height: 16px !important;
    }
    .join .withdrawalBox .wb_text .ft500 {
    margin-right: 25px;
    }
    .join .withdrawalBox .bar {
    height: auto;
    margin-top: 0;
    margin-left: 40px;
    margin-right: 40px;
    }
    .join .withdrawal_btn02 {
    width: 240px;
    margin: 0 auto;
    text-align: center;
    font-weight: 500;
    line-height: 65px;
    border-radius: 40px;
    background-color: #424242;
    color: #fff;
    cursor: pointer;
    }
    .join .withdrawal p {
    line-height: 30px;
    }
    .join .board_btn.join_btn button{
        border-color: #009a6e;
        background-color: #fff;
        color: #000;
    }
    .join .board_btn.join_btn button:hover{
        color: #009a6e;
    }

    .multi-accordion {
    overflow: hidden;
    }
    .multi-accordion details {
    position: relative;
    }
    .multi-accordion summary {
    padding: 0 12px;
    cursor: pointer;
    height: 58px;
    font-size: 16px;
    line-height: 58px;
    border-bottom: 1px solid #cfcfcf;
    }
    .multi-accordion details[open] + details > summary {
    border-top: 1px solid #aaa;
    }
    summary::after {
    content: "";
    background-image: url(/images/mypage/join_policy_off.png);
    background-size: cover;
    display: inline-block;
    width: 34px;
    height: 34px;
    position: absolute;
    right: 15px;
    top: 12px;
    }
    details[open] summary::after {
    background-image: url(/images/mypage/join_policy_on.png);
    }
    .multi-accordion .multi-accordion_box {
    padding: 20px 10px;
    }
    .join .multi-accordion .multi-accordion_box p {
    border: 1px solid #cfcfcf;
    height: 245px;
    overflow-y: auto;
    padding: 10px;
    font-size: 14px;
    line-height: 22px;
    }
    .multi-accordion .multi-accordion_box div {
    border: 1px solid #cfcfcf;
    height: 245px;
    overflow-y: auto;
    padding: 10px;
    font-size: 14px;
    }
    .multi-accordion details summary::marker {
    content: "";
    font-size: 0;
    width: 0;
    height: 0;
    display: none;
    }
    .pop_ver02 {
    width: auto;
    height: unset;
    padding: 60px 50px 50px;
    border: unset;
    }
    .join .popup_view::after {
    display: none;
    }
    .popup_close.ver02 {
    left: unset;
    right: 20px;
    top: 20px;
    width: 20px;
    height: 20px;
    transform: unset;
    padding: unset;
    background-color: unset;
    border-radius: unset;
    }

    .popup_close.ver02 img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    }
    .pop_ver02 .pop_name {
    width: fit-content;
    height: 35px;
    margin: 0 auto;
    margin-bottom: 30px;
    padding-left: 45px;
    font-size: 30px;
    font-weight: 500;
    line-height: 30px;
    background-image: url(/images/mypage/ico_link.png);
    background-size: contain;
    background-repeat: no-repeat;
    }
    .pop_ver02 .pop_text {
    font-size: 16px;
    font-weight: 400;
    margin-bottom: 25px;
    padding: 30px;
    border: 1px solid #e4e4e4;
    background-color: #fafafa;
    }
    .pop_ver02 .pop_input input {
    border: 1px solid #c5c5c5;
    width: 100%;
    height: 50px;
    box-sizing: border-box;
    padding: 0 15px;
    margin-bottom: 10px;
    font-size: 18px;
    letter-spacing: -1px;
    }
    .pop_ver02_btn {
    width: 190px;
    margin: 0 auto;
    margin-top: 20px;
    font-size: 18px;
    font-weight: 500;
    line-height: 60px;
    border-radius: 40px;
    background-color: #22cacb;
    color: #fff;
    cursor: pointer;
    }

    /* login */
    .login{
        width: 100%;
        max-width: 506px;
        margin: 0 auto;
    }
    .login .sub{
        padding-top: 120px;
        box-sizing: border-box;
    }
    .member_box{
        text-align: center;
    }
    .member_title {
        font-family: 'S-Core Dream 6';
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 15px;
    }
    .member_sub{
        position: relative;
        padding: 37px 0 45px;
        margin-top: 45px;
        box-sizing: border-box;
    }
    .member_sub::before{
        content: "";
        width: 103px;
        height: 6px;
        background-color: #009a6e;
        position: absolute;
        top: 0;
        left: 50%;
        transform: translateX(-50%);
    }
    .memberWrap form{
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
    }
    .memberWrap form div{
        width: 100%;
    }
    .member_box .input_area input {
        width: 100%;
        height: 72px;
        box-sizing: border-box;
        border: 1px solid #cfcfcf;
        margin-bottom: 10px;
        padding-left: 60px;
    }
    .memberWrap .input_area{
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
    }
    .member_box .input_area input[id="login_id"] {
        background-image: url(/new/images/ico_id.png);
        background-repeat: no-repeat;
        background-position: left 25px center;
    }
    .member_box .input_area input[id="login_pw"] {
        background-image: url(/new/images/ico_pw.png) ;
        background-repeat: no-repeat;
        background-position: left 25px center;
    }
    .member_box .input_area input[id="login_name"] {
        background-image: url(/new/images/ico_name.png) ;
        background-repeat: no-repeat;
        background-position: left 25px center;
    }
    .member_box .input_area input[id="login_email"] {
        background-image: url(/new/images/ico_email.png) ;
        background-repeat: no-repeat;
        background-position: left 25px center;
    }
    .memberWrap .flexBox{
        display: flex;
        align-items: center;
        justify-content: space-between;
    }
    .member_other{
        display: flex;
        align-items: center;
        gap: 10px;
    }
    .member_other a{
        font-size: 18px;
    }
    .member_other .bar{
        position: initial;
        width: 1px;
        height: 16px;
        background-color: #000;
    }
    .memberWrap .coll_bottom .board_btn button{
        width: 100%;
        margin-top: 0px;
        height: 74px;
        border: 1px solid #cfcfcf;
    }
    .memberWrap .coll_bottom .board_btn.join_complete_btn button{
        margin-top: 35px;
    }
    .memberWrap .coll_bottom .board_btn.join_complete_btn button:hover{
        border-color: #125e4d;
        background-color: #009a6e;
        color: #fff;
    }
    .memberWrap .coll_bottom .board_btn.cancel_btn button{
        border-color: #125e4d;
        background-color: #fff;
        color: #000;
    }
    .memberWrap .coll_bottom .board_btn.cancel_btn button:hover{
        color: #125e4d;
    }
    .loginSearch .member_contents{
        background-color: #f6f6f6;
        padding: 50px 55px;
        box-sizing: border-box;
    }
    .loginSearch .memberWrap .coll_bottom .board_btn.join_complete_btn button{
        margin: 20px 0 0;
    }
    .loginSearch .memberWrap .flexBox{
        margin-top: 15px;
    }
    .loginSearch .memberWrap .flexBox .member_other{
        justify-content: center;
    }

    /* mypage */
    .mypage .mypage_nav {
        margin-top: 120px;
        gap: 24px;
    }
    .mypage .mypage_nav a{
        width: calc(100% / 2 - 12px);
        height: 74px;
        display: flex;
        align-items: center;
        justify-content: center;
        border: 1px solid #cfcfcf;
        background-color: #fff;
        box-sizing: border-box;
        font-size: 20px;
        font-weight: 500;
    }
    .mypage .mypage_nav a.on{
        border-color: #009a6e;
        background-color: #009a6e;
        color: #fff;
    }
    #sub.mypage .board_list_title{
        padding-top: 80px;
    }
    .mypage .join_form_wrap input[id="user_id"]{
        border: 0;
    }

@media screen and (max-width: 1280px) {
    /* 1280px - join */
    #sub.join section.board{
        padding-top: 81px;
    }
    #sub.join .board .board_list_title {
        padding: 4.5rem 0 3rem;
    }
    .mypage .mypage_nav {
        margin-top: 45px;
    }
    #sub.mypage .board_list_title{
        padding-top: 40px;
    }
    .join .info_w {
    height: 40px;
    padding: 10px 0;
    margin-bottom: 50px;
    }
    .join .info_w .info_w_text {
    padding-left: 65px;
    font-size: 14px;
    line-height: 40px;
    background-position: top left 15px;
    }
    .join_flow_area ul.join_flow li {
    font-size: 16px;
    height: auto;
    gap: 0px;
    padding: 10px 0;
    box-sizing: border-box;
    }
    .join_flow_area ul.join_flow li p:nth-child(1){
        transform: scale(0.7);
    }

    .join_policy_all_check {
    font-size: 14px;
    }
    .multi-accordion summary {
    font-size: 13px;
    }
    .multi-accordion .multi-accordion_box p {
    font-size: 11px;
    line-height: 19px;
    }
    .join .withdrawal_name {
    font-size: 28px;
    }
    .join .withdrawal_btn02 {
    width: 200px;
    line-height: 55px;
    }
    .join .withdrawal_ico {
    width: 95px;
    height: 95px;
    margin-bottom: 30px;
    }
    .join .withdrawalBox .wb_text .ft500 {
    margin-right: 20px;
    }
    .join .withdrawalBox .bar {
    margin-left: 30px;
    margin-right: 30px;
    }

    /* join02 */
    .join_form_wrap .form_group{
        min-height: 70px;
        height: auto;
        padding: 10px 0;
    }
    .join_form_wrap input[type="email"],  .join_form_wrap input[type="tel"], .join_form_wrap input[type="date"], .join_form_wrap select {
        height: 50px;
    }
    .join_form_wrap .form_group button{
        height: 50px;
        font-size: 16px;
        padding: 10px 15px;
    }
    .join_form_wrap .form_group label{
        width: 120px;
    }
    .join_form_wrap input[type="password"],
    .join_form_wrap input[type="text"]{
        width: calc(100% - 140px);
        height: 50px;
    }
    .join_form_wrap input::placeholder{
        font-size: 16px;
    }
    .input_button_wrap,
    .input_with_button,
    .join_form_wrap .form_group .phone_group,
    .join_form_wrap .birthdate_selects {
        width: calc(100% - 140px);
    }
    .join_form_wrap input[id="user_id"]{
        width: calc(100% - 150px);
    }
    .join_form_wrap input[id="address2"]{
        width: calc(100% - 150px);
    }
    .join_form_wrap .phone_group input[type="text"]{
        width: calc(100%/3 - 10px);
    }
    .join_form_wrap .birthdate_selects{
        gap: 5px;
    }
    .join_form_wrap .birthdate_selects select{
        width: calc(100%/2 - 5px);
        font-size: 16px;
    }
    .join_form_wrap input[type="text"],
    .join_form_wrap input[type="email"],
    .join_form_wrap input[type="password"],
    .join_form_wrap input[type="tel"],
    .join_form_wrap input[type="date"],
    .join_form_wrap select {
        font-size: 16px;
    }
    .join_form_wrap .form_group.genderWrap .radio_group label{
        font-size: 16px;
    }
    .input_button_wrap {
    flex-wrap: wrap;
    }

    /* form_notice는 한 줄일 땐 옆에 있지만 공간 부족하면 줄바꿈 */
    .input_button_wrap .form_notice {
    font-size: 1.4rem;
    color: #666;
    flex-basis: 100%; /* 줄바꿈 강제 */
    order: 2; /* 줄바꿈 시 input/button 아래로 */
    }
    .input_with_button .form_notice {
    font-size: 1.4rem;
    color: #666;
    }

    /* mypage 1280px */
    .mypage .mypage_nav a{
        height: 50px;
        font-size: 18px;
    }
}
@media screen and (max-width: 768px) {
    /* 768px - join */
    #sub.join .board .board_list_title {
        padding: 4rem 0 2rem;
    }
    .mypage .mypage_nav {
        margin-top: 40px;
    }
    #sub.mypage .board_list_title{
        padding-top: 20px;
    }
    .join .info_w {
    height: 35px;
    }
    .join .info_w .info_w_text {
    font-size: 12px;
    line-height: 35px;
    }
    .join_flow_area ul {
    margin-bottom: 30px;
    }
    .join_flow_area ul.join_flow li {
    text-align: center;
    }
    .join_flow_area ul.join_flow li p{
    font-size: 13px;
    }
    .join_flow_area ul.join_flow li p:nth-child(1) {
        transform: scale(0.9);
        width: 50px;
        height: 50px;
    }
    .join_flow_area ul.join_flow li p:nth-child(1) img{
        transform: scale(0.7);
    }
    .join_policy_text {
    padding-top: 20px;
    }
    .join_policy_all_check {
    margin-top: 8px;
    }
    .multi-accordion summary {
    height: 45px;
    line-height: 45px;
    }
    summary::after {
    width: 25px;
    height: 25px;
    right: 15px;
    top: 10px;
    }
    .join .withdrawal_name {
    font-size: 22px;
    }
    .join .withdrawal {
    padding: 30px 0;
    }
    .join .withdrawal p {
    padding: 0 20px;
    line-height: 20px;
    }
    .join .withdrawal_btn02 {
    width: 170px;
    line-height: 48px;
    }
    #pop_memo {
    height: 382px;
    }
    .pop_ver02 {
    width: auto;
    height: unset;
    padding: 50px 30px 30px;
    border: unset;
    }
    .pop_ver02 .popup_close {
    left: unset;
    right: 20px;
    top: 20px;
    width: 15px;
    height: 15px;
    transform: unset;
    padding: unset;
    background-color: unset;
    border-radius: unset;
    }
    .pop_ver02 .pop_name {
    height: 28px;
    margin-bottom: 20px;
    padding-left: 35px;
    font-size: 22px;
    line-height: 22px;
    }
    .pop_ver02 .pop_text {
    font-size: 14px;
    margin-bottom: 18px;
    padding: 20px;
    }
    .pop_ver02 .pop_input input {
    height: 40px;
    margin-bottom: 8px;
    font-size: 15px;
    }
    .pop_ver02_btn {
    width: 120px;
    margin-top: 10px;
    font-size: 13px;
    line-height: 40px;
    }
    .join .withdrawal_ico {
    width: 80px;
    height: 80px;
    }
    .join .withdrawalBox p {
    line-height: 14px !important;
    }
    .join .withdrawalBox .wb_text .ft500 {
    margin-right: 10px;
    }
    .join .withdrawalBox .bar {
    margin-left: 20px;
    margin-right: 20px;
    }
    .coll_bottom {
        max-width: 768px;
        width: 100%;
    }
    .join .board_btn{
        width: calc(100% / 2 - 5px);
    }
    .join .board_btn a{
        width: 100%;
        height: 39px;
        margin: 30px 0 10px;
    }
    .join .board_btn button{
        width: 100%;
        height: 39px;
        margin: 30px 0 10px;
    }
    /* join02 */
    .join_form_wrap .sub_txt{
        font-size: 14px;
    }
    .input_button_wrap .form_notice {
        flex-basis: 100%;
    }
    .join02 .join_policy .cont{
        flex-direction: column;
        gap: 10px;
        line-height: 18px;
        padding: 15px;
    }
    .join02 .join_policy .cont img{
        width: 50px;
    }
    .join_form_wrap .form_group{
        flex-direction: column;
        align-items: flex-start;
    }
    .join_form_wrap .form_group label {
        width: 100%;
    }
    .opt-in .input_with_button label {
        width: auto;
        margin-right: 10px;
        margin-top: 0;
    }
    .join_form_wrap input[type="password"], .join_form_wrap input[type="text"], .input_button_wrap, .input_with_button, .join_form_wrap .form_group .phone_group, .join_form_wrap .birthdate_selects {
        width: calc(100% - 0px);
        max-width: 100%;
    }
    .join_form_wrap input[type="email"], .join_form_wrap input[type="tel"], .join_form_wrap input[type="date"], .join_form_wrap select {
        height: 39px;
    }
    .join_form_wrap input[type="password"], .join_form_wrap input[type="text"] {
        height: 39px;
    }
    .join_form_wrap .form_group button{
        height: 39px;
        font-size: 14px;
    }
    .input_with_button{
        gap: 5px;
    }
    .join_form_wrap input::placeholder,
    .join_form_wrap .birthdate_selects select{
        font-size: 14px;
    }
    .join_form_wrap input[id="user_id"]{
        width: calc(100% - 130px);
    }
    .join_form_wrap input[id="nickname"]{
        width: calc(100% - 92px);
    }
    .join_form_wrap input[id="zipcode"]{
        width: calc(100% - 111px);
    }

    /* login 768px */
    .login{
        padding: 0 10px;
        box-sizing: border-box;
    }
    .login .sub{
        padding-top: 4.5rem;
    }
    .member_title{
        font-size: 30px;
    }
    .member_sub {
        padding: 15px 0 20px;
        margin-top: 20px;
    }
    .member_other a {
        font-size: 14px;
    }
    .member_option .join_policy_all_check{
        margin-top: 0;
    }
    .member_box .input_area input{
        height: 40px;
        padding-left: 40px;
    }
    .memberWrap .coll_bottom .board_btn button{
        height: 40px;
        margin-left: 0;
        margin-right: 0;
    }
    .memberWrap .coll_bottom .board_btn.join_complete_btn button{
        margin-top: 20px;
    }
    .member_box .input_area input[id="login_id"],
    .member_box .input_area input[id="login_name"],
    .member_box .input_area input[id="login_email"],
    .member_box .input_area input[id="login_pw"]{
        background-size: 13px;
        background-position: left 15px center;
    }
    .loginSearch .member_contents{
        padding: 20px 25px;
    }
    .loginSearch .memberWrap .coll_bottom .board_btn.join_complete_btn button{
        margin: 10px 0 0;
    }

    /* mypage 768px */
    .mypage .mypage_nav{
        gap: 10px;
    }
    .mypage .mypage_nav a{
        width: calc(100% / 2 - 5px);
        height: 40px;
        font-size: 16px;
    }
}

@media screen and (max-width: 601px) {
    /* 601px - join */
    .join .info_w {
    height: auto;
    margin-bottom: 45px;
    }
    .join .info_w .info_w_text {
    padding-left: 60px;
    padding-right: 15px;
    font-size: 12px;
    line-height: 18px;
    }
} /* 601px 마지막 */