@charset "utf-8";

.mem-buttons .btn-pack {min-width:clamp(160px, calc( 300 / var(--inner) * 100vw ), 300px) !important;  height: clamp(42px, calc( 60 / var(--inner) * 100vw ), 60px) !important; line-height: clamp(40px, calc( 58 / var(--inner) * 100vw ), 58px) !important;  font-size: clamp(15px, calc( 18 / var(--inner) * 100vw ), 18px) !important; border-radius: 60px;}
.widtype2 .real-cont {padding:clamp(50px, calc( 130 / var(--inner) * 100vw ), 130px) clamp(60px, calc( 150 / var(--inner) * 100vw ), 150px);}

/* 로그인 */
.login-area {max-width:470px; margin:0 auto;}
.login-tab {text-align:center; border-bottom:4px solid var(--color-primary); margin-bottom:50px;}
.login-tab ul {display:flex; padding:0 2px;}
.login-tab ul li {flex:1; border:4px solid #dfdfdf; border-bottom:0; margin:0 -2px; border-radius:10px 10px 0 0;}
.login-tab ul li a {display:block; color:#333; font-size:18px; font-weight:500; line-height:60px;}
.login-tab ul li.active {position:relative; z-index:2; border-color:var(--color-primary);}
.login-tab ul li.active:after {content:""; position:absolute; left:0; right:0; bottom:-4px; height:4px; background:#fff;}
.login-tab ul li.active a {color:var(--color-primary); font-weight:700;}
.login-content .group {margin-bottom:8px;}
.login-content .group .input {display:block; width:100%; height:54px; font-size:16px;}
.login-content .links {display:flex; justify-content:space-between; margin-top:20px; font-size:14px; color:#505050; font-weight:500; line-height:1.5em;}
.login-content .links a:hover {text-decoration:underline;}
.login-content .links .bar {display:inline-block; vertical-align:middle; margin:-.2em 12px 0; width:1px; height:16px; background:#ddd;}
.login-content .btn-pack {display:block; width:100%; margin-top:10px;border-radius: 60px;}
.login-content .btn-pack.focus {margin-top:28px;}
.login-content .btn-pack.xlarge {font-weight:500;}

.sns-login {text-align:center; margin-top:50px;}
.sns-login .tit {position:relative; color:#333; font-size:15px; font-weight:400; line-height:1.3em; margin-bottom:35px;}
.sns-login .tit:before {content:""; position:absolute; top:50%; left:0; margin-top:-1px; width:100%; height:1px; background:#ddd;}
.sns-login .tit span {display:inline-block; position:relative; padding:0 30px; background:#fff;}
.sns-login a {margin:0 12px;}

/* 약관동의 */
.agree-wrap {max-width:680px; margin:0 auto 60px;}
.agree-wrap .group {margin-top:40px;}
.agree-wrap .group:first-child {margin-top:0;}
.agree-wrap .agree-tit {color:#333; font-size:20px; font-weight:600; line-height:1.3em;}
.agree-wrap .agree-tit .checkbox label:before {margin-top:-.02em; width:24px; height:24px; background:#fff url("../images/member/checkbox.png") 50% 50% no-repeat; border:2px solid #ccc; border-radius:100%;}
.agree-wrap .agree-tit .checkbox input:checked + label:before {background-color:var(--color-primary); border-color:var(--color-primary); background-image:url("/images/member/checkbox_on.png");}
.agree-wrap .agree-box {position:relative; max-height:175px; margin-top:17px; padding:16px 20px; border:1px solid #ddd; overflow:auto;}
.agree-wrap .agree-box .terms-wrap {color:#767676; font-size:14px;}
.agree-wrap .agree-box .terms-wrap .sec {margin-bottom:20px;}
.agree-wrap .agree-box .terms-wrap .sec h3 {color:#767676; font-size:14px; font-weight:400; margin-bottom:0;}
.agree-wrap .agree-box .terms-wrap .sec strong {font-weight:400;}

.terms-wrap {font-weight:400; color:#666; line-height:1.75em;}
.terms-wrap .sec {margin-bottom:40px;}
.terms-wrap .sec h3 {color:#222; font-size:1.1em; font-weight:700; margin-bottom:7px;}
.terms-wrap .sec p {margin-bottom:1em;}
.terms-wrap .sec strong {font-weight:700;}
.terms-wrap .sec ol li {padding-left:1em; text-indent:-1em;}
.terms-wrap .sec ol li ol li {padding-left:1.35em; text-indent:-1.35em;}
.terms-wrap .policy-contact {display:flex; padding:20px 0; background:#fafafa; border:1px solid #e5e5e5; margin-bottom:1em;}
.terms-wrap .policy-contact dl {flex:1; padding:0 20px; border-left:1px solid #e5e5e5;}
.terms-wrap .policy-contact dl:first-child {border-left:0;}
.terms-wrap .policy-contact dt {font-weight:500; color:#333; margin-bottom:12px;}

/* 회원가입 */
.join-form {max-width:900px; margin:0 auto;}
.join-form .required {color:#fd8239}
.join-form .join-form-txt {color:#505050; font-weight:400; line-height:1.4em; margin-bottom:12px;font-size: clamp(12px, calc( 14 / var(--inner) * 100vw ), 14px);}
.join-form table {width:100%; border-collapse:collapse; border-spacing:0px; border-top:2px solid #868686; font-size:16px; line-height:1.5;}
.join-form table th {padding:15px 20px; border:1px solid #ddd; background:#fff; font-weight:700; color:#333; }
.join-form table td {padding:12px 20px; border:1px solid #ddd; color:#505050;}
.join-form tr th:first-child,
.join-form tr td:first-child {border-left:0;}
.join-form tr th:last-child,
.join-form tr td:last-child {border-right:0;}
.join-form input[readonly] {background-color:#fff; color:#505050;}
.join-form .help-text {display:inline-block; margin-left:10px; color:#767676;}
.join-form + .buttons {margin-top:60px;}

.leavebox {margin-top: clamp(10px, calc( 20 / var(--inner) * 100vw ), 20px);}
.leavebox .link-leave {color: #454545; font-size: clamp(15px, calc( 18 / var(--inner) * 100vw ), 18px); font-weight: 500; text-decoration: underline;}

.join-head {display: flex;align-items: center;justify-content: space-between; margin-bottom:  clamp(15px, calc( 30 / var(--inner) * 100vw ), 30px);}
.formflx {display: flex; flex-wrap: wrap;align-items: center;}
.join-form .birthbx {margin-right: clamp(15px, calc( 45 / var(--inner) * 100vw ), 45px);}
.mem-buttons .btn-pack {font-size: clamp(15px, calc( 18 / var(--inner) * 100vw ), 18px) !important; min-width: clamp(160px, calc( 300 / var(--inner) * 100vw ), 300px) !important; height: clamp(42px, calc( 60 / var(--inner) * 100vw ), 60px) !important; line-height: clamp(40px, calc( 58 / var(--inner) * 100vw ), 58px) !important; border-radius:60px;}

/* 가입완료 */
.join-complete {text-align:center;}
.join-complete .tit {color:var(--color-primary); font-size:28px; font-weight:700; line-height:1.4em; margin-bottom:30px;}
.join-complete .txt {color:#333; font-size:18px; line-height:1.8em;}
.join-complete .icon {width:180px; height:180px; background:var(--color-primary) url("../images/member/complete.png") 50% 50% no-repeat; border-radius:100%; margin:36px auto 45px;}
.join-complete .buttons {margin:0;}
.join-complete .lordicon {margin: 20px 0;}
.join-complete .lordicon lord-icon {width: clamp(80px, calc( 250 / var(--inner) * 100vw ), 250px); height: clamp(80px, calc( 250 / var(--inner) * 100vw ), 250px);}
.complete-buttons {max-width: 470px; width: 100%; margin: 0 auto;}
.complete-buttons .compflx {display: flex;flex-direction: column; gap:10px;}
.complete-buttons .btn-pack {font-size: clamp(15px, calc( 18 / var(--inner) * 100vw ), 18px) !important; border-radius: 60px;}

/* 게정찾기 */
.find-area {max-width:470px; margin:0 auto;}
.find-tab {text-align:center; border-bottom:4px solid var(--color-primary); margin-bottom:50px;}
.find-tab ul {display:flex; padding:0 2px;}
.find-tab ul li {flex:1; border:4px solid #dfdfdf; border-bottom:0; margin:0 -2px; border-radius:10px 10px 0 0;}
.find-tab ul li a {display:block; color:#333; font-size:18px; font-weight:500; line-height:60px;}
.find-tab ul li.active {position:relative; z-index:2; border-color:var(--color-primary);}
.find-tab ul li.active:after {content:""; position:absolute; left:0; right:0; bottom:-4px; height:4px; background:#fff;}
.find-tab ul li.active a {color:var(--color-primary); font-weight:700;}
.find-content .group {margin-bottom:8px;}
.find-content .group .input {display:block; width:100%; height:54px; font-size:16px;}
.find-content .btn-pack {display:block; width:100%; margin-top:10px;}
.find-content .btn-pack.focus {margin-top:30px;}
.find-content .btn-pack.xlarge {font-weight:500;}
.find-result {text-align:center; padding:34px 42px; color:#505050; font-size:18px; font-weight:400; line-height:1.75em; background:#fafafa; border-top:2px solid var(--color-primary); border-bottom:1px solid #ddd;}
.find-result h4 {font-size:22px; font-weight:700; line-height:1.4em; margin-bottom:20px;}
.find-result p:first-child {margin-bottom:10px;}
.find-result .name {color:var(--color-primary); font-size:30px; font-weight:700; line-height:1.5em;}

/* 회원탈퇴 */
.member-leave .txt {text-align:center; color:#505050; line-height:1.7em; margin-bottom:40px;}
.member-leave .txt .tit {color:#333; font-size:20px; line-height:1.5em; margin-bottom:15px;}
.member-leave .form {max-width:470px; margin:0 auto 40px; padding:50px; color:#666; font-size:16px; line-height:1.5em; background:#f9f9f9; border:1px solid #e5e5e5; border-radius:10px;}
.member-leave .form .group {display:flex; align-items:center; margin-bottom:20px;}
.member-leave .form .group:last-child {margin-bottom:0;}
.member-leave .form .group .label-tt {width:90px; color:#222; font-weight:700;}
.member-leave .form .group .text-id,
.member-leave .form .group .input {flex:1 1 auto; min-width:0; width:1%;}

/* 마이페이지 */
.fancybox-opened .fancybox-skin {background: transparent !important; box-shadow: none !important;}
.fancybox-close-custom {width: 30px !important; height: 30px !important; right: -15px !important; top: -15px !important; border-radius: 50% !important; background-size: 12px auto !important; background-color: var(--color-primary) !important;}

.print-item {text-align: center; max-width: 795px; width: 100%; margin: 0 auto;}
.print-item .thumb {position:relative; padding-bottom:138.36%; overflow:hidden; }
.print-item .thumb:after {content:""; position:absolute; top:0; left:0; right:0; bottom:0; border:1px solid #ddd; }
.print-item .thumb iframe {position:absolute; top:50%; left:0; transform:translateY(-50%); width:100%; height:auto; max-width:100%; min-height:100%;object-fit : cover;}

.print-item .btns {padding-top: clamp(40px, calc( 60 / var(--inner) * 100vw ), 60px); text-align: center;}
.print-item .btns a {display: inline-flex;align-items: center;justify-content: center; min-width: clamp(160px, calc( 300 / var(--inner) * 100vw ), 300px); height: clamp(44px, calc( 60 / var(--inner) * 100vw ), 60px); font-size: clamp(14px, calc( 18 / var(--inner) * 100vw ), 18px); font-weight: 600; background: var(--color-primary); color: #fff; border-radius: 60px; text-align: center;}

.btn-comp {display: inline-flex;align-items: center;justify-content: center; margin:0 auto; width:clamp(30px, calc( 38 / var(--inner) * 100vw ), 38px); height: clamp(30px, calc( 38 / var(--inner) * 100vw ), 38px); border-radius: 50%; border: 1px solid #ddd;}
.btn-comp  svg {width: clamp(10px, calc( 15 / var(--inner) * 100vw ), 15px); height: clamp(13px, calc( 18 / var(--inner) * 100vw ), 18px);}
.btn-comp:hover {background: var(--color-secondary);border-color: var(--color-secondary);}
.btn-comp:hover path {fill: #fff;}
.btn-comp.bg2:hover {background: var(--color-primary); border-color: var(--color-primary);}

.join-form {max-width: 900px; width: 100%; margin: 0 auto;}
.join-form .radiobox .item {flex: initial;}
.join-form .join-form-txt {font-size: clamp(12px, calc( 14 / var(--inner) * 100vw ), 14px); font-weight: 400;}
.join-form .inputtext {display: flex;align-items: center;height: clamp(38px, calc( 44 / var(--inner) * 100vw ), 44px) ;}