﻿/*웹폰트*/

/*본문 텍스트*/
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@100;300;400;500;700&display=swap');
/*본문 숫자 font-family: 'Open Sans', sans-serif;   */
@import url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@300;400;600;700;800&display=swap');

@font-face {
    font-family: 'GmarketSansMedium';
    src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2001@1.1/GmarketSansMedium.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

/*:root*/

/*1899D9*/

:root{
    --main_c :#2474F0;
    --pink :#ef2f9f;    /*메인 핫핑크*/
    --purpleTxt :#9232C2;   /*텍스트*/
    --purpleBtn :#7C41ED;  /*서브 보라 버튼*/
    --p_tb_c :#F6F2FF; /*보라색 테이블컬러*/
    /*#1EB5C1*/



}

select{
    border: 1px solid #c1c1c1;
    padding: 6px 10px;
    width: 100%;
    height: 36px;
    font-size:15px;
    background:url(/common/image/icon/select_arrow.png) no-repeat;
    background-position:96% 48%;
    background-size:18px;
}

body{
min-width:320px;
color:#333;
font-family: 'Noto Sans KR', sans-serif;
height:100%;
overflow-x:hidden;
}


form{
    height:100%;
}


/*본문 숫자 font-family: 'Open Sans', sans-serif;   */

    
@font-face {
font-family: 'Open Sans';
font-style: normal;
font-weight: 500;
src: url(https://fonts.gstatic.com/s/opensans/v18/mem5YaGs126MiZpBA-UN_r8OX-hpOqc.woff2) format('woff2');
unicode-range: U+0030-0039;
}



.tit_ft{
font-family: 'GmarketSansMedium';
}


/*---------layout-------------*/
.Xcenter{
left:50%;
transform:translateX(-50%);
-webkit-transform:translateX(-50%);
-ms-transform:translateX(-50%);
-moz-transform:translateX(-50%);
-o-transform:translateX(-50%);
}
.Ycenter{
top:50%;
transform:translateY(-50%);
-webkit-transform:translateY(-50%);
-moz-transform:translateY(-50%);
-o-transform:translateY(-50%);
}
.Acenter{
top:50%;
left:50%;
transform:translate(-50%,-50%);
-webkit-transform:translate(-50%,-50%);
-moz-transform:translate(-50%,-50%);
-o-transform:translate(-50%,-50%);
}

.c_area{
    padding-left:4%;
    padding-right:4%;
}

.mt1{margin-top:10px}
.mr1{margin-right:10px}


.clearfix:after{
    content:'';
    display:block;
    clear:both;

}

#header{
 position:fixed;
 z-index:999;
 width:100%;
 box-shadow:0px 2px 4px rgba(206, 206, 206,0.3);
}
.headWrap{
width:100%;
height:54px;
box-sizing:border-box;
border-bottom:1px solid rgba(255,255,255,0.2);
background:#3C3C43;

}

.logo{
display:inline-block;
float:left;
margin-left:3%;
top:2px;
position:relative;

}

.logo img{
width:98px;
margin-top:13px;
}

.openNav{
display:inline-block;
float:right;
margin-right:3%;
width:32px;
height:32px;
position:relative;
top:50%;
transform:translateY(-50%);
-webkit-transform:translateY(-50%);
-moz-transform:translateY(-50%);
-o-transform:translateY(-50%);
z-index:99999;     
box-sizing:border-box;


}

.openNav span{
display:inline-block;
width:25px;
height:2px;
border-radius:5px;
background:#FFF;
position:absolute;
left:2px; 
box-sizing:border-box;
transform-origin:center;
transition:0.3s;
}

.openNav span:nth-of-type(1){top:6px}
.openNav span:nth-of-type(2){top:50%; transform:translateY(-50%);
-webkit-transform:translateY(-50%);
-moz-transform:translateY(-50%);
-o-transform:translateY(-50%);}
.openNav span:nth-of-type(3){bottom:6px}
.openNav.active{
 position:fixed;
 top:25px;
 right:0;
margin-right:3%;
}
.openNav.active span:nth-of-type(1){
transform:rotate(45deg);
top:16px;
background:#FFFFFF;
}

.openNav.active span:nth-of-type(2){
display:none;
}

.openNav.active span:nth-of-type(3){
transform:rotate(-45deg);
bottom:14px;                                                                                                                             
background:#FFFFFF;
}


/*사이드 메뉴 스타일*/

.sideLogo{
    width:100%;
    height:190px;
    text-align:center;
    border-bottom:1px solid #aaa;
    background:url(/common/image/masterpage/bg.png) no-repeat;
    background-size:cover;
    position:relative;
}

.sideLogo img{
    width:140px;
    margin-top:60px;
}


.p_numb{
 margin-top:20px;
 color:#FFF;
 font-size:18px;
 font-family:'NanumSquare', sans-serif ;
 letter-spacing:0px;
}


/*상단 전화번호*/

.callinfo{
width:100%;
height:34px;
/*background:#4b82d6;*/
background:#3C3C43;
padding-left:3%;
padding-right:3%;
/*background: url(/common/image/masterpage/bg.png) no-repeat;*/
/*background:linear-gradient(to right, #338CD2 30%,#4E7FCB 100% );*/
text-shadow:1px 1px 2px rgba(0,0,0,0.2);
} 

.callinfo p{
font-size:17px;
padding-left:25px;
position:relative;
margin-left:7px;
font-family: 'NanumSquare', sans-serif !important;
position:relative;
top:8px;
letter-spacing:-0.9px;
color:#FFF;
font-weight:600;

}


.callinfo p:before{
content:'';
display:inline-block;
width:19px;
height:26px;
background:url(/common/image/masterpage/mobile.png) no-repeat;
background-size:contain;
position:absolute;
left:-5px;
top:-3px

}

.gnb-overlay-bg-m{
width:100%;
height:100vh;
position:fixed;
top:0;
right:0;
background:rgba(0,0,0,0.2);
display:none;
z-index:22;
}
#menu{
width:90%;
height:100%;
background:#f9f9f9;
position:fixed;
top:0;
z-index:999;
right:-90%; 
transition:0.5s;
overflow-y:scroll;
}

#menu.open{
right:0; 
min-width:215px; 
}



.navWrap{
width:80%;
height:100%;
background:#FFF;
position:absolute;
right:0;
}

.navheader{
    padding-top:30px;
    padding-bottom:30px;
    border-bottom:1px solid #eaeaea;
    background:#FFF;
    border-top:1px solid #eaeaea;
}

.navheader li{
    font-size:17px;
    padding-bottom:16px;
    color:#333;
    position:relative;


}
/*.navheader li:after{
    content:'';
    display:inline-block;
    width:10px;
    height:18px;
    background:url(/common/image/icon/arrow.png) no-repeat;
    background-size:contain;
    position:absolute;
    right:20px;
    opacity:0.7;
    top:6px
}*/

.navheader li a{
    position:relative;
}

.navheader li a:before{
 content:'';
 display:inline-block;
 width:28px;
 height:28px;
 position:absolute;
 background:#eaeaea;
 left:20px;
}

/*.navheader li a:after{*/
.navheader li.depth1 a:after{
 content:'';
 display:inline-block;
 width:16px;
 height:25px;
 position:absolute;
 background:url(/common/image/icon/arrow.png) no-repeat;
 background-size:contain;
 right:20px;
 background-position-y:5px
}
.navheader li .depth2 a:after{
     display:none !important;
}

#menu1>a:before{
    background:url(/common/image/masterpage/sideIcon2.png) no-repeat;
    background-size:105%;
}

#menu2>a:before{
    background:url(/common/image/masterpage/sideIcon3.png) no-repeat;
   background-size:105%;
}


#menu3>a:before{
    background:url(/common/image/masterpage/sideIcon4.png) no-repeat;
   background-size:105%;
}


#menu4>a:before{
    background:url(/common/image/masterpage/sideIcon1.png) no-repeat;
    background-size:contain
}

#menu5>a:before{
    background:url(/common/image/masterpage/sideIcon5.png) no-repeat;
   background-size:105%;
}

#menu6>a:before{
    background:url(/common/image/masterpage/sideIcon7.png) no-repeat;
    background-size:contain
}

.menu7>a:before{
    background:url(/common/image/masterpage/sideIcon5.png) no-repeat !important;
       background-size:cover !important;
}

.menu8>a:before{
    background:url(/common/image/masterpage/sideIcon11.png) no-repeat !important;
       background-size:cover !important;
}
.menu9>a:before{
    background:url(/common/image/masterpage/sideIcon10.png) no-repeat !important;
       background-size:cover !important;
}

#menu10>a:before{
    background:url(/common/image/masterpage/sideIcon12.png) no-repeat !important;
       background-size:cover !important;
}

.menu13>a:before{
    background:url(/common/image/masterpage/sideIcon13.png) no-repeat !important;
    background-size:contain !important;
}

.menu14>a:before{
    background:url(/common/image/masterpage/sideIcon14.png) no-repeat !important;
    background-size:contain !important;
}

.menu15>a:before{
    background:url(/common/image/masterpage/sideIcon15.png) no-repeat !important;
    background-size:contain !important;
}
.menu16>a:before{
    background:url(/common/image/masterpage/sideIcon16.png) no-repeat !important;
    background-size:contain !important;
}
.menu17>a:before{
    background:url(/common/image/masterpage/sideIcon17.png) no-repeat !important;
    background-size:contain !important;
}
.menu18>a:before{
    background:url(/common/image/masterpage/sideIcon18.png) no-repeat !important;
    background-size:contain !important;
}




.navheader li.depth1>a:after {
    transform: rotate(90deg)
}
.navheader li.depth1>a.on:after {
    transform: rotate(-90deg)
}
.depth1>ul {display: none;}
.depth1>ul li {
    padding-bottom: 0px;
    padding-top: 10px;
}
.depth2 li{padding-top:5px !important;}
.depth2 li a{color:#525252 !important;font-size: 0.97em !important; font-weight: 400 !important;}
.depth2 li a:before {
    background: #fff !important;
}

.navheader li a{
    display:block;
    width:100%;
    padding-left:60px;
    padding-top:6px;
    padding-bottom:6px;
    /*font-weight: 500;*/
}

.settings{
    position:absolute;
    background:url(/common/image/masterpage/sideIcon9.png) no-repeat;
    margin-top:10px;
    background-size:cover;
    display:block;
    left:20px;
    opacity:0.8;
    background-size:22px 22px;
    font-size:14px;
    padding-left:24px;
    padding-bottom:3px;
    color:#FFF;


    
}

/*컨텐츠영역*/

.wrapper{
width:100%;
height:100%;
overflow-y:scroll;
}


.content{
width:100%;
padding-left:4%;
padding-right:4%;  
padding-top:calc( 8% + 88px);
padding-bottom:20%;
}
 

.content:after{
    content:'';
    display:block;
    clear:both;
}


/*------------------------버튼스타일-----------------------*/

/*색상*/
.btnst1{
 border:none;
 background:var(--main_c);
 color:#FFF;
 font-size:15px;
}


.btnst2{
    border: none;
    font-size:15px;
    background:#eaeaea;
    color:#555;
}

.btnst3{
        border: 1px solid var(--main_c);
    font-size: 15px;
    background: #fff;
    color: var(--main_c);
    padding: 2px 5px;
  
}



/*크기*/
.l_btn{
    width:100%;
    height:40px;
    /*margin-top:20px;*/
}

.btnWrap{
    bottom:0;
    width:100%;
    position:fixed;
    /*padding-bottom:calc(env(safe-area-inset-bottom));
    padding-bottom:calc(constant(safe-area-inset-bottom));*/
	background: var(--main_c);
}

.btnWrap input{
    cursor:pointer;
}

/*input스타일*/

.info input[type=text],.info input[type=tel]{
    border: 1px solid #c1c1c1;
    padding: 2px 10px;
    width: 100%;
    height: 36px;
    color: #676767;
}


.info input[type=text]:focus,.info input[type=tel]:focus{
 border:1px #2693D6 solid;
 box-shadow:1px 0px 6px  rgba(149,134,213,0.3)
}


/*input스타일2*/

.info2 input[type=text],.info2 input[type=tel]{
    border: none;
    text-align:right;
    padding: 2px 10px;
    width: 100%;
    height: 36px;
    color: #676767;
}

.s_title{
    font-size:1.13em;
    margin-bottom:10px;
    color:#222;                            
        font-family: 'GmarketSansMedium';
        position:relative;
        padding-left:16px;

}

.s_title:before{
    content:'';
    display:inline-block;
    width:7px;
    height:7px;
    background:#ef2f9f;
    margin-top:4px;
    position:absolute;
    left:1px;
    top:6px
}

.btnWrap2{
    /*margin-top:30px;*/
    position:fixed;
    bottom:0;
    width:100%;
    padding-bottom:calc(env(safe-area-inset-bottom));
    padding-bottom:calc(constant(safe-area-inset-bottom));
}

.btnWrap2 input[type=button]{
    width:50%;
   
}

.btnWrap2:after{
    content:'';
    display:block;
    clear:both
}

.btnWrap2 input[type=button]:nth-of-type(1){
    float:left;
}

.btnWrap2 input[type=button]:nth-of-type(2){
    float:right;
}



.info p{
    margin-bottom:8px;
    margin-top:16px;
    font-size:15px;
    color:#222;
}

.info_tit {
margin-bottom:8px !important;
margin-top:16px!important;
font-size:16px!important;
color:#222;
}


.noti_wrap{
    border: 1px dotted #aaa;
    padding:10px;
    margin-top:14px;
}

.noti_wrap p{
    font-size:15px;
    color:#666;
    margin-bottom:4px;
 
}

.noti_wrap p:before{
    content:'-';
    margin-right:6px;
}



/*테이블 스타일*/

.box{
    margin-bottom:10px;
}

.tb_wrap {
    margin-top:16px;
}

.tb_wrap table{
    width:100%;
}

.tb_st-1 td{
   padding:6px 8px;
    
   border:1px solid #ccc;
   color:#444
}

.min-ht td >div{
    min-height:19px;
}

.tb_st-1 td:nth-of-type(1){
   background:#F6F2FF;
   width:32%;

}




/*input스타일*/
.ipwrap:after{
    content:'';
    display:block;
    clear:both;
}

.ipwrap >input[type=text] {
    width:65%;
    float:left;
}choice_type2
.ipwrap >input[type=button]{
 height:36px;
 border: none;
 width:32%;
 float:right;
}

.priceip input[type=text],.priceip input[type=tel]{
 width: calc(100% - 30px) !important;
}

.priceip span{
    margin-left:8px;
}

.ip_num2 input[type=text],.ip_num2 input[type=tel]{
 width:calc(50% - 10px);  
}

.ip_num2 input[type=text]:nth-of-type(1),.ip_num2 input[type=tel]:nth-of-type(1){
    float:left;
}

.ip_num2 input[type=text]:nth-of-type(2),.ip_num2 input[type=tel]:nth-of-type(2){
    float:right;
}

.ip_num2 span{
    display:inline-block;
    width:20px;
    font-size:1em;
    text-align:center;
    position:relative;
    top:5px;
    left:-1px;
    color:#999;
}


/*라디오*/
.choice_type {position:relative;}
.choice_type input[type=radio]{
  visibility:hidden;
  position:absolute;

}
.choice_type label{
    width:50%;
    display:inline-block;
    float:left;
}
.choice_type label:nth-of-type(2){
    float:right;
}


.choice_type span{
    display:inline-block;
    width:100%;
    background:#eaeaea;
    color:#aaa;
    font-size:16px;
    text-align:center;
    line-height:36px;
    font-weight:500;
    box-sizing:border-box;
    height:40px;
    transition:all 0.3s;
    border:0;
}        


.choice_type input[type=radio]:checked ~ span{
   border:1px solid #2069D6;
   color:#2069D6;
   box-sizing:border-box;
   background:#FFF;
}              

/*라디오2*/
.choice_type2 {position:relative;}
.choice_type2 input[type=radio]{
  visibility:hidden;
  position:absolute;

}
.choice_type2 label{
    width:33%;
    display:inline-block;
    float:left;
}

.choice_type2 span{
    display:inline-block;
    width:100%;
    background:#eaeaea;
    color:#aaa;
    font-size:16px;
    text-align:center;
    line-height:36px;
    font-weight:500;
    box-sizing:border-box;
    height:40px;
    transition:all 0.3s;
    border:0;
}        


.choice_type2 input[type=radio]:checked ~ span{
   border:1px solid #2069D6;
   color:#2069D6;
   box-sizing:border-box;
   background:#FFF;
}   

/*전체화면 로딩*/
.mloader2 {
    position: fixed;
    background-color: rgba(113, 113, 113, 0.6) !important;
    display: none;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 1000;
   
}

    .mloader2 .masterkey_blink {
        color:#fff;
        text-align: center;
        /*-webkit-animation: masterkey_blink 5s linear infinite;*/
            font-size: 1.5em;
    }

.spinner {
  margin:  auto;
  margin-top:-100px;
  width: 110px;
  height: 10%;
  text-align: center;
  font-size: 60px;
}
.mloader2 > p{
    /*font-size:450px;*/
    color:transparent;
    height:50%;
  }

audio{
  visibility:hidden;
}
 
.spinner > div {
  background-color: #333;
  height: 100%;
  width: 8px;
  display: inline-block;  
  -webkit-animation: sk-stretchdelay 1.2s infinite ease-in-out;
  animation: sk-stretchdelay 1.2s infinite ease-in-out;
}

.spinner .rect1 {
   background:#a0e1ff;
  -webkit-animation-delay: -1.2s;
  animation-delay: -1.2s;
}
.spinner .rect2 {
     background:#8fdcff;
  -webkit-animation-delay: -1.1s;
  animation-delay: -1.1s;
}

.spinner .rect3 {
     background:#76d4ff;
  -webkit-animation-delay: -1.0s;
  animation-delay: -1.0s;
}

.spinner .rect4 {
     background:#65cfff;
  -webkit-animation-delay: -0.9s;
  animation-delay: -0.9s;
}

.spinner .rect5 {
  -webkit-animation-delay: -0.8s;
  animation-delay: -0.8s;
     background:#5acbff;
}

@-webkit-keyframes sk-stretchdelay {
  0%, 40%, 100% { -webkit-transform: scaleY(0.4) }  
  20% { -webkit-transform: scaleY(1.0) }
}

@keyframes sk-stretchdelay {
  0%, 40%, 100% { 
    transform: scaleY(0.4);
    -webkit-transform: scaleY(0.4);
  }  20% { 
    transform: scaleY(1.0);
    -webkit-transform: scaleY(1.0);
  }
}
/* 로딩 끝 */

.content-modal{
    display:none;
}

.modal-background {
    display: inherit;
    width: 100%;
    height: 100%;
    z-index: 99;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
}
.modal-frame {
    display: table;
    margin-left: auto;
    margin-right: auto;
    margin-top: 50%;
    width: 70%;
    padding: 5% 10%;
    background-color: white;
    border: 1px solid #cccccc;
    border-radius: 5px;
    box-shadow: 2px 2px 8px 2px rgba(0, 0, 0, 0.2);
}


/*뒷배경*/
.bgWrap {
    width:100%;
    height:100vh;
    background:rgba(0,0,0,0.2);
    position:fixed;
    z-index:2;
    display:none;
    top:0;
    left:0;
}

.rctAcct table td:nth-of-type(1){
    background:none;
}

.rctAcct table tr:nth-of-type(1) td{
  background: #F6F2FF;
}

.divNavBotton{
    font-size:13px;
    padding:10px;
}

.submg{
    padding-top:0 !important;
    margin-top:40px;
}

/*text box*/
.input-style-1{
    border: 1px solid #c1c1c1;
    padding: 2px 10px;
    width: 100%;
    height: 36px;
    color: #676767;
}