@charset "utf-8";
@import url('./base.css');

/****************************
**********  input  **********
*****************************/
label {cursor: pointer;}


/****************************
**********  button  **********
*****************************/

img   {max-width:100%;}

a[class^=btn]   {display:inline-block; padding:0 16px;}
a[class^=btn]:hover   {text-decoration: none; }
button    {cursor: pointer; width:100%; }
.btn        { line-height:38px; font-size:14px; font-weight:500; padding:0px 16px; background: #45D0D6;  white-space: nowrap; border-radius:8px;   }
button.btnOk      { height:48px; font-size:16px; border:1px solid  #45D0D6; background: #45D0D6; color:#fff;  border-radius:8px; }



[type=button]     { font-size: 14px;  font-weight: 700; color:#fff;  border-radius: 8px;}
button.btnOk      { height:48px; border:1px solid  #45D0D6; background: #45D0D6; color:#fff; min-width: 100px;  }
button.btnWebCall      { height:48px; border:1px solid #45505D; background:#45505D; color:#fff; min-width: 120px;  }
button.icoTel1          {width:100%; height:42px; padding:0; text-align:center }
button.icoTel2          {width:100%; height:42px; padding:0; text-align:center }
button.icoTel1::before     {content: ""; display:inline-block; vertical-align: top; padding-right:4px; width:20px; height:20px; background: url(../images/btn_ico_1.svg) no-repeat 50% 50%;  }
button.icoTel2::before     {content: ""; display:inline-block; vertical-align: top; padding-right:4px; width:20px; height:20px; background: url(../images/btn_ico_2.svg) no-repeat 50% 50%;  }
button.btnArr     { width:100%; height:42px; border:1px solid  #45D0D6; background:#fff; color: #45D0D6;  }
button.btnArr::after     { content:""; display:inline-block; width:20px; height:20px; background:url(../images/arr_r_blue.svg) no-repeat 50% 50%; vertical-align: top; margin-top:1px; }
button.down     { font-size: 14px;  }
button.down::after     { content:""; display:inline-block; margin-left:4px; width:20px; height:20px; background:url(../images/ico_down.svg) no-repeat 50% 50%; vertical-align: top; margin-top:1px; }

button.lineBtn      { height:48px; font-size: 16px; border:1px solid #E0E0E0; background:#fff; color:#333; min-width: 100px;  }

.btBtns      {padding:24px 0 32px; display:flex; gap:8px; }
.btBtns a    {width:100%; text-align: center; height:48px; line-height:46px; font-weight: 700; border-radius: 8px; background: #45D0D6; color:#fff; font-size:16px; }

select    {border:1px solid #E0E0E0; width:100%; height:48px; border-radius: 8px; font-weight: 500; text-align: center; background: url(../images/select_bul.svg) no-repeat right 16px top 50%; }
select:disabled    {background-image: url(../images/select_bul_disabled.svg); background-color: #F5F5F5; }

.grayBtnS     {height:28px; padding:0 8px; width:auto; color:#333; font-weight: 500; overflow: hidden;  }
.btnChoice    {height:34px; padding:0 16px; width:auto; white-space: nowrap; color:#fff; background: #45D0D6; font-weight: 500;  }



/****************************
**********  main  **********
*****************************/
html  {overflow: hidden; height:100%; overflow-y: scroll; background-color: #ddd;}
body  {height:100%; }
.wrap       { position:relative; min-height:100%; /*width:360px;*/ margin:0 auto; box-sizing: border-box; overflow: hidden; background-color: #fff;  }
.wrap header    { position:relative; height:48px; padding:0 16px; text-align: center; }
.wrap header h1   { font-size: 16px; padding:14px 0 0; line-height:1.2  }
.wrap header h1.myPageTit { text-align: left; }
.wrap header h1.myPageTit a   { display:inline-block; font-size: 22px; width:auto; padding-right:22px; background:url(../images/icon/g_right.png) no-repeat 100% 50% / 20px  }
.wrap header button    { position:absolute; width:28px; height:28px; top:10px; border:0; padding:0;    }
.wrap header button.back    { display:block; left:16px; background: url(../images/common/gnb_back.png) no-repeat 0 0 / 28px;}
.wrap header button.close   {  right:16px; background: url(../images/common/gnb_close.png) no-repeat 0 0 / 28px;}
.wrap.pageBt header button.back     { display:block }
.wrap.pagePop header button.close   { display:block }

.container      { }
.container.callEnd    {padding: 0;}
.container > section + section       {border-top:8px solid #F0F3FB; margin:0 -16px; padding:24px 16px ; }
.container > section + section:last-of-type      {padding-bottom:0; }
.container > section    {padding-bottom:24px; }

.overBox      {margin:0 -16px; }

.flexBox      {display:flex; gap:8px;}

ul.list1    {}
ul.list1 li      {border-bottom:1px solid #ddd; padding:21px 0; }


input[type=text],
textarea                    {width:100%; border:1px solid #E0E0E0; padding:12px; border-radius: 8px;   }
input[type=text]            {height:48px;  }
input[type=text].bg         {background:#F0F3FB; border:0;   }
input[type=text]::placeholder     {color:#BDBDBD; }
textarea   {height:120px; }

ul.form     {}
ul.form + .btnR     {margin-top:16px; }
ul.form + .btnR button     {width:80px; }
.memList + ul.form     {margin-top:24px; }
ul.form li     {}
ul.form li + li       {margin-top:16px;}
ul.form.line > li + li       {margin-top:24px; border-top:1px solid #E0E0E0; padding-top:24px; }
ul.form li label     {display:flex; width:100%;justify-content: space-between; align-items: center; margin-bottom:10px; font-weight: 500;  }
ul.form li label button     {}
ul.form li div   {display:flex; gap:8px;  }
ul.form li div + div   {margin-top:8px; }
ul.form li span.unit   {position:absolute; padding:15px 0 0 12px; color:#828282;  }
ul.form li span.unit + input[type=text]  {padding-left:50px; }
ul.form li ul.view      {padding:6px 0 0; }
ul.form li ul.view li   {display:flex;  }
ul.form li ul.view li + li   {margin-top:16px; }
ul.form li ul.view li span   {width:114px; color:#828282; font-weight: 400;}
ul.form li ul.view li strong {font-weight: 500;}
ul.form li table.view      {  }
ul.form li table.view th    {text-align: left; font-weight: 400; color:#828282;  }
ul.form li table.view td    {font-weight: 500; text-align: left; padding:2px 0; padding-left:10px;  }
ul.member   {margin-top:18px; }
ul.member li + li{margin-top:20px; } 
ul.member li a   {display:flex; width:100%; height:24px; align-items: center; padding-left:32px; background: url(../images/ico_user.svg) no-repeat 0 0;; }

.tabBox       {display:flex; gap:8px; }
.tabBox button{ width:100%; height:48px; font-size:14px; font-weight: 400; padding:0; text-align: center; border:1px solid #E0E0E0; background:#fff; color:#828282; border-radius: 8px ;}
.tabBox button.on{  font-weight:700 ; color:#fff; background: #45D0D6; border-color:  #45D0D6;}

/* 레이어 팝업 */

.layerWrap.show         {top:0; }
.layerWrap.show::before   {opacity: 1; transition: .3s;}
.layerWrap.show .layerBody   {transition:.3s .1s; transform: translateY(0);  opacity: 1;}
.layerWrap.show.bottom .layerBody   {transition:.3s .1s; transform: translateY(0);  opacity: 1;}

.layerWrap      {position:fixed; display:flex; z-index:1000; left:50%; top:100%; width:100%; height:100%;  transform: translateX(-50%); justify-content: center; }
.layerWrap::before      {content: ''; position:absolute; width:100%; height:100%; opacity:0; background:rgba(0,0,0,0.5); }
.layerWrap .layerBody   { position:relative;  z-index:10;  display:flex; flex-direction: column; margin:auto; width:336px; min-height:190px; overflow: hidden; opacity: 0; background:#fff; border-radius: 8px; transform: translateY(25%);   }
.layerWrap .layerBody .layerClose   {display:none; position: absolute; right:16px; top:20px; width:24px; height:24px; background: url(../images/layer_close.png) no-repeat;}
.layerWrap.bottom      {}
.layerWrap.bottom .layerBody   {width:360px; margin:auto auto 0; border-radius: 8px 8px 0 0; overflow: hidden; transform: translateY(100%);  }
.layerWrap.bottom .layerBody .layerClose   {display:none; }
.layerWrap.bottom .layerBtn   {padding:0 16px 24px; gap:10px  }
.layerWrap.bottom .layerBtn button   {border-radius: 8px;}

.layerWrap .layerBtn   { width:100%; display:flex; margin-top:auto;  }
.layerWrap .layerBtn button   { width:100%; height:48px; text-align: center; border-radius: 0; }
.layerWrap .layerBtn button.btn   { border:0; background:#F5F5F5;  }
.layerWrap .layerBtn .btnOK   { min-width:60%}
.layerWrap .layerBody .ment   { display:flex; height:150px;  }
.layerWrap .layerBody .ment p   {margin: auto;}
.layerWrap .layerCont   { padding:18px 20px 24px; max-height: calc(100vh - 65px); overflow: auto; }
.layerWrap .managerContact .titBox   { display:flex; padding:0  0 15px 0; justify-content: space-between;}
.layerWrap .managerContact .titBox strong    {font-size:16px; font-weight: 400; }
.layerWrap .managerContact .titBox button    {flex:0; white-space: nowrap; font-size:14px; }
.error    {font-size: 12px; color:#FF5757; margin-top:6px; }

.layerWrap .payType .tit     {font-size: 20px; ;}
.layerWrap .payType .payInfo     {padding:12px 0 0; line-height: 110%; font-size: 16px;;}
.layerWrap .payType .payInfo strong    {color:#F49B3E;}
.layerWrap .payType ~ .layerBtn     {}
.layerWrap .payType ~ .layerBtn button     {display:flex; padding:16px; height:130px; flex-direction: column;  }
.layerWrap .payType ~ .layerBtn button strong     { font-size:20px;  }
.layerWrap .payType ~ .layerBtn button span       { font-size:16px; line-height: 17px; font-weight: 400;   }
.layerWrap .payType ~ .layerBtn button.btn        { border:1px solid #E0E0E0; color:#828282; }
.layerWrap .payType ~ .layerBtn button.type01     {background:url(../images/pay_company.png) no-repeat right 18px bottom 18px #FFDB1F;}
.layerWrap .payType ~ .layerBtn button.type02     {background:url(../images/pay_personal.png) no-repeat right 18px bottom 18px #fff;}

.layerWrap .paymentConfirm     {padding:8px 0 0;  }
.layerWrap .paymentConfirm .titBox     { }
.layerWrap .paymentConfirm .titBox > em       {display:block; font-size:16px; font-weight: 700;   }
.layerWrap .paymentConfirm .titBox > strong   {display:block; font-size:26px; font-weight: 700;   }
.layerWrap .paymentConfirm .titBox P.tip    {padding-left:20px; font-size: 14px; color:#FF5757;  background:url(../images/warning.png) no-repeat 0 50%; }
.layerWrap .paymentConfirm ul.payInfo       {padding:20px 0;}
.layerWrap .paymentConfirm ul.payInfo li    { display:flex; justify-content: space-between; margin-top:6px; font-size: 16px; line-height:24px;}
.layerWrap .paymentConfirm ul.payInfo li em    { color:#77889C;}
.layerWrap .paymentConfirm ul.payInfo li span  {}
.layerWrap .paymentConfirm .paytime     {display:flex; height:48px; padding:8px 12px; justify-content: space-between; background:#FFF5A5; border-radius: 8px;}
.layerWrap .paymentConfirm .paytime span      {margin:auto 0; font-size: 16px; }
.layerWrap .paymentConfirm .paytime button    {height:32px; border-radius: 8px; padding:0 14px; flex:none}

.layerWrap .paymentConfirm .payPoint    {border-top:1px solid #D7E2E4; padding:17px 20px 0; width:100%; margin-left:-20px; box-sizing: content-box; }
.layerWrap .paymentConfirm .payPoint em   {display:inline-block; padding:0 10px; line-height:20px; background: #45D0D6; color:#fff;    }
.layerWrap .paymentConfirm .payPoint p    {margin-top:9px; color: #45D0D6; }


.layerWrap .datepicker .tit    {text-align: center; font-size: 16px; font-weight: 700;}
.layerWrap .datepicker ~ .layerBtn    {padding:0 24px 32px; gap:10px;}
.layerWrap .datepicker ~ .layerBtn button   {border-radius: 8px;}
.layerWrap .datepicker ~ .layerBtn .btn     {background:#fff; border:1px solid #E0E0E0}
.layerWrap .datepicker ~ .layerBtn .btnOK   {min-width: 10%;}
.layerWrap .ui-widget-content    {width:100%; box-shadow: none; padding:0; margin:30px 0 0; }
.layerWrap .ui-datepicker .ui-datepicker-header   {padding:0; }
.layerWrap .ui-datepicker .ui-datepicker-title    {font-size: 20px; line-height: 30px;  }
.layerWrap .ui-datepicker .ui-datepicker-prev     { background: url(../images/arrow_l_b.png) no-repeat 50% 50%; left:50px;}
.layerWrap .ui-datepicker .ui-datepicker-next     { background: url(../images/arrow_r_b.png) no-repeat 50% 50%; right:50px;}
.layerWrap .ui-state-default,
.layerWrap .ui-widget-content .ui-state-default,
.layerWrap .ui-widget-header .ui-state-default    {border:0; margin:0 auto; border-radius: 8px;}
.ui-datepicker td span, .ui-datepicker td a   {padding:0; }

.ui-datepicker th   {color:#333;}
.ui-state-highlight,
.ui-widget-content .ui-state-highlight,
.ui-widget-header .ui-state-highlight   {background:#ddd; color:#333}

.ui-state-active,
.ui-widget-content .ui-state-active,
.ui-widget-header .ui-state-active     {background: #45D0D6; color:#fff !important; }

.ui-datepicker-week-end .ui-state-default  {color:#FF5757}
.ui-datepicker-week-end ~ .ui-datepicker-week-end .ui-state-default  {color:#3E82F4}



.timepicker       {}
.timepicker .layerClose{display:none !important; }
.timepicker .tit       {position:relative; text-align: center; font-size: 16px; font-weight: 700; padding-bottom:15px; }
.timepicker .tit span.chk  {display: none; position:absolute; right:0; top:2px;  }
.timepicker .tit span.chk label  {font-size: 12px; vertical-align: top; line-height:20px; }
.timepicker .timePick  {position:relative; display:flex; height:200px; overflow: hidden; justify-content: center; font-size:24px; }
.timepicker .timePick .day   { position:relative; margin-right:30px; z-index:5; overflow: scroll; overflow-x: hidden; }
.timepicker .timePick .hour   { position:relative; z-index:5; width:36px; overflow: scroll; overflow-x: hidden; }
.timepicker .timePick .txt    { position:relative; z-index:5; margin:auto 0; padding:0 8px; }
.timepicker .timePick .minute { position:relative; z-index:5; width:36px; overflow: scroll; overflow-x: hidden; }
.timepicker .timePick div::-webkit-scrollbar {  display: none;}
.timepicker .timePick div button {width:100%; padding:0; font-size:24px;height:36px; background: transparent; text-align: center; color:#BDBDBD; border: none;}
.timepicker .timePick div.day  button {width:120px; font-size: 20px; font-weight: 400; }
.timepicker .timePick div button.on {color:#333 ; font-weight: 700;}
.timepicker .timePick ul {}
.timepicker .timePick ul li { height:40px;  }
.timepicker .timePick span.focus { position:absolute; z-index: 1; top:82px; width:100%; height:36px; background:#D8ECFE; opacity: 1; border-radius: 8px; }
/* .timepicker .timePick span.focus1 { position:absolute; z-index: 10; top:42px; width:100%; height:36px; background:#fff;  opacity: .5; border-radius: 8px; }
.timepicker .timePick span.focus2 { position:absolute; z-index: 10; top:122px; width:100%; height:36px; background:#fff; opacity: .5; border-radius: 8px; } */
.timepicker .timePick span.focus3 { position:absolute; z-index: 10; top:0px; width:100%; height:40px; background:#fff;   opacity: .8; border-radius: 8px; }
.timepicker .timePick span.focus4 { position:absolute; z-index: 10; top:162px; width:100%; height:40px; background:#fff; opacity: .8; border-radius: 8px; }

.layerWrap.bottom .timepicker .layerBtn    {padding:0 24px 32px; gap:10px;}
.layerWrap.bottom .timepicker .layerBtn button   {font-size: 16px; border-radius: 100px;}
.layerWrap.bottom .timepicker .layerBtn .btn     {background:#fff; border:1px solid #E0E0E0;}
.layerWrap.bottom .timepicker .layerBtn .btnOK   {min-width: 10%; color: #fff; background:  #45D0D6; border: none;}



/* 팝업 신규 */
.layerWrap.dateSetting .layerCont{padding: 24px 16px 16px;}
.layerWrap.dateSetting .layerCont.searchFilter    { padding-top: 0;}
.layerWrap.dateSetting .tit   {padding-bottom: 10px; text-align: left; font-weight: 500;}
.layerWrap.dateSetting .datepicker span{line-height: 42px;}
.layerWrap.dateSetting .datepicker select   {font-size: 16px;}
.layerWrap.dateSetting .datepicker input   {width: calc(50% - 13px); height: 42px; }
.layerWrap.dateSetting .searchFilter label   { font-size: 16px;}
.layerWrap.dateSetting .tabBox{padding-bottom: 16px; width: 100%;}
.layerWrap.dateSetting .tabBox ul.tab{margin-top: 10px; display: flex; width: 100%; gap: 4px; justify-content: space-between; text-align: center;}
.layerWrap.dateSetting .tabBox ul.tab li{width: 25%; height: 42px; box-sizing: border-box; border-radius: 8px; }
.layerWrap.dateSetting .tabBox ul.tab li input[type=radio]    {opacity: 0; position: absolute;}
.layerWrap.dateSetting .tabBox ul.tab li input[type=radio] + label    {display: block; border-radius: 8px; height: 42px; line-height: 42px; border: 1px solid #E0E0E0; }
/* radio checked */
.layerWrap.dateSetting .tabBox ul.tab li input[type=radio] + label    {color: #282828; background: #fff; } 
.layerWrap.dateSetting .tabBox ul.tab li input[type=radio]:checked + label   { color: #fff; background:  #45D0D6; border:1px solid  #45D0D6; }
.layerWrap.dateSetting .layerBtn   {padding: 0 16px 32px;}
.layerWrap.dateSetting .btnSearch    {color: #fff; border: none; background:  #45D0D6; border: none;}


#layer_12.layerWrap.dateSetting .layerCont.searchFilter{ padding-top: 24px;}


/* CONTENTS */