@charset "utf-8";
@import url("../bdu/common/css/fonts.css");
@font-face {
  font-family: 'Material Symbols Outlined';
  font-style: normal;
  font-weight: 700;
  font-display: block;
  src: url(https://fonts.gstatic.com/s/materialsymbolsoutlined/v121/kJF1BvYX7BgnkSrUwT8OhrdQw4oELdPIeeII9v6oDMzByHX9rA6RzaxHMPdY43zj-jCxv3fzvRNU22ZXGJpEpjC_1n-q_4MrImHCIJIZrDBIG-ej.woff2) format('woff2');
}

label.deco-chk:before,
.division p::before,
.material-symbols-outlined {
  font-family: 'Material Symbols Outlined';
  font-weight: normal;
  font-style: normal;
  font-size: 24px;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  -webkit-font-feature-settings: 'liga';
  -webkit-font-smoothing: antialiased;
}

/* reset */
html{font-size: 62.5%;}
body, pre, textarea, input, select, button {font-family:"Pretendard", Malgun Gothic, sans-serif;font-size:var(--fs-r);}
body, pre, textarea, input {color:#3f3f3f;font-weight:400;word-break:keep-all;}
input[type="search"], input[type="text"], input[type="password"], input[type="number"], input[type="date"], input[type="time"], input[type="month"], select { background-color:#ffffff; border:solid 1px #e5e5e5; padding:3px 6px; color:#333; height:28px }

label {display:inline-flex;align-items:center;cursor:pointer;}
input[type="submit"], button {background-color:#3f3f3f;border:solid 1px #e5e5e5;padding:3px 5px;color:#333;cursor:pointer;}
input:focus, select:focus, option:focus, textarea:focus, button:focus {outline:none;}
p { line-height:150% }
a, a:active, a:hover, a:focus { color:inherit; text-decoration:none }

/* checkbox, radio 꾸밈  */
/* label.deco-chk { display:inline-flex } */
label.deco-chk:before { content:"\e835"; font-size:24px; margin:0 6px; border-radius:3px; font-weight:400; border:0; }

input.deco-chk, label.deco-chk span { /* display:none */ position: absolute; opacity: 0; width: 20px;  /* or 1px */ height: 20px; /* or 1px */ z-index: -1;}
input.deco-chk:focus-visible + label.deco-chk{outline:2px solid var(--point-color2);}
input:focus:not(:focus-visible) {outline: none; }
input[type="radio"].deco-chk + label.deco-chk:before {content:"\e836"; width:20px; height:20px;}

input.deco-chk:checked + label.deco-chk:before { font-weight:900; color:var(--point-color2) !important; }
input[type="radio"].deco-chk:checked + label.deco-chk:before { content:"\e837" }
input[type="checkbox"].deco-chk:checked + label.deco-chk:before { content:"\e834" }

/* 기본 */
:root {
    --layout-color:rgba(43, 49, 57, 1);
    --layout-color02:rgba(57, 66, 79, 1);
    --layout-color03:#848a91; /* rgba(57, 66, 79, 0.6); */
    --layout-color04:rgba(57, 66, 79, 0.5);
    --layout-color-m:#343439;
    --layout-color-s:#e2a62bc4;
    --point-color:#FB5700;
    --point-color-over:#DF4D00;
    --point-color2:#2F6AF9;
    --point-color2-over:#1552e4;
    --point-text-color:#fff;
    --point-color3:#7fb142;
    --font-color-m:#D6462C;
    --font-color-s:#ffffff;
    --require-color:#c20324;
    --box-color:#e6ecf0;
    --point-color01:#B883DB;
    --point-color01-50:#0054FD50;
    --point-color02:#912EDF;
    --point-color02-50:#384C9E50;
    --point-txt-color:#7109B6;
    --txt-color:#1A2128;
    --txt-lt-color:#6D757E;
    --bg-color:#e7ecf2;
    --table-border:#595959;
    --table-tbody-border:#D9D9D9;
    --table-bg: #F4F6F7;
    --border-color:#BFCAD8;
    --border-color-over:#97a5b7;
    --border-lt-color:#E6EBF2;
    --border-dp-color:#505050;
    --fs-xxl: 2.4rem;
    --fs-xl: 2rem;
    --fs-l: 1.8rem;
    --fs-r: 1.5rem;
    --fs-s: 1.4rem;
    --fs-xs:1.3rem;
}

/* login */
body.login{position: absolute;top: 0;left: 0;bottom: 0;right: 0;align-items: flex-start;background: #E7ECF2 radial-gradient(#cdcecf, transparent); overflow: hidden;}
body.login:after{content: '';background-image:url(../asset/image/login/bg_symbol.png);background-position: right 3%;background-repeat: no-repeat;background-blend-mode: color;position: absolute;width: 30rem;height: 120rem;background-size: contain;right: 10rem;top: 10rem;opacity: 0.2;}
body.login #wrap{min-width:auto;}
.login_box{position: absolute;top: 50%;left: 50%;transform: translate(-50%, -50%);z-index: 999;transition: all 1s;background: #fff;width: 1024px;/*height: 568px;*/padding: 4rem;display: flex; flex-wrap: wrap; flex-direction: row;gap: 4rem 5rem;box-shadow:0 4px 20px 0px rgba(0, 0, 0, 0.05);border-radius: 3rem;}
.bg_img {position: absolute; left: -5rem; bottom: -4.3rem;}
.login_box .blockRight *{width:100%;}

.blockTop{position:absolute;top: -8rem;display: flex;align-items: center;left: 0;}
.division {width: 100%;background: #194d93;color:#fff;padding: 2rem;display: flex;align-items: center;justify-content: center;gap: 3rem; border-radius:5px;}
.division input.deco-chk:checked + label.deco-chk:before {color:#fff}
.division p{margin-bottom: 0; margin-left: auto; display: flex; gap:0.8rem; align-items: flex-start;}
.division p::before{content: '\e88e'; font-size: 20px;}
.blockMiddle{width:100%;}
.blockBottom{position:absolute;bottom: -6rem;display: flex;align-items: center;left: 0;justify-content: center;width: 100%; text-align: center;}
section{display: flex; flex-direction: column; gap:1.2rem; width: calc((100% - 10rem) / 3); position: relative; flex-grow: 1;}
section:after{content: '';width: 1px;height: 100%;background-color: var(--border-lt-color);position: absolute;right: -2.5rem;}
section:last-of-type:after{display: none;}
.login_box h1{position:relative;width: 420px;height:64px;margin:0 0 10px;background-size:contain;font-size:2.4rem;font-weight: 700;color:#333333;}
.login_box h1.logo{background: url(../asset/image/login/h1_login.png) left 50% no-repeat;margin:0;display: flex;align-items: center;padding-left: 205px;}
.login_box h1 .system_name {display: flex;color: #194d93;font-size: 20px;}
.login_box h2{color: #033C89;font-weight: 600;font-size: 2.2rem;/* margin-left:5.8rem; */}
.login_box h3{font-size: 20px;padding-top: 1.2rem;position: relative;font-weight: 600;margin-bottom: 0.8rem;}
.login_box h3:before{content: ''; width: 30px; height: 4px; background: var(--point-color2); position: absolute; top:0;}
.login_box h3 + div {margin-bottom:1.5rem}
.login_box h3 + div:before{content: '';width: 80px;height:80px;display: flex;margin: 0 auto;margin-bottom: 2rem;border-radius:8px; background-repeat:  no-repeat;}
.login_box section:nth-of-type(1) h3 + div:before{background-image:url(../asset/image/login/icon_login01.png);}
.login_box section:nth-of-type(2) h3 + div:before{background-image:url(../asset/image/login/icon_login02.png);}
.login_box section:nth-of-type(3) h3 + div:before{background-image:url(../asset/image/login/icon_login03.png);}
.login_box .group {display: flex; padding: 2rem 0; justify-content: center;}
.login_box .group label {width: 100%;}

.login_box input{clear:both;height:40px; color:#001c57}
.login_box .btnBox{display: flex;gap:1rem;margin-top: auto;}
.login_box .btnBox a{display: inline-flex; padding:1rem; border:1px solid var(--border-color); width: 100%; justify-content: center;}
.login_box .btnBox a:hover{border:1px solid var(--border-color-over);}
.login_box .btn_login{display:block;background-color: var(--point-color2);color:#fff;height:5.6rem;padding:12px 50px;font-size: 1.6rem;border-radius:5px;text-align:center;font-weight: 600;width: 100%;}
.login_box .btn_login:hover{background-color:var(--point-color2-over);}
/* label{display: flex; font-size: 15px; color: #767676;}
input[type=text], input[type=password]{border-radius: .4rem;border: 1px solid #EAEAEA;margin-top:0.8rem;width: 100%;height: 5.2rem;} */
.login_box .copyright{/* font-size:10px; */}

.sr_only{position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;}

input:-webkit-autofill{box-shadow: 0 0 0px 1000px white inset !important;
  -webkit-text-fill-color: #000 !important;}
.input_item input.input_id[type="text"], .input_item input.input_pw[type="password"], .input_item input.input_pw[type="text"] {
    position: relative;
    display: block;
    width: 100%;
    height: 34px;
    font-weight: 400;
    line-height: 22px;
    letter-spacing: -.2px;
    color: #1e1e23;
    z-index: 5;
    border:0;
    padding: 11px 0 0 0;
    }
.input_item input:focus{border:0 !important;}
.input_item {
    position: relative;
    padding: 10px 15px 5px;
    border: 1px solid #c5ccd2;
    border-radius: 5px;
    box-sizing: border-box;
    z-index: 1;
    margin-bottom:8px;
    }
.input_item label {
    display: inline-block;
    position: absolute;
    bottom: 13px;
    left: 15px;
    font-size: 16px;
    font-weight: 400;
    line-height: 22px;
    letter-spacing: -.2px;
    transition: all .3s cubic-bezier(.4,0,.2,1);
    color: rgba(0, 0, 0, .38);
    pointer-events: none;
    box-sizing: border-box;
    z-index: 5;
    }  
label.deco-chk{padding:5px}
.btn_login:focus-visible, .input_item.focus, button:focus-visible, a:focus-visible, input.deco-chk:focus-visible{outline:2px solid var(--point-color2);}
.btn_login:focus:not(:focus-visible),a:focus-visible:focus:not(:focus-visible) { outline: none;}

.input_item.focus label, .input_item label.on{font-size:14px; bottom: 25px;}  
.input_item button{border:0; background: transparent;}
.btn_view {position: absolute; top: 5px; right: 40px; width: 40px; height: 40px; z-index: 7; }
.btn_delete{position: absolute; top: 5px; right: 5px; width: 40px; height: 40px; z-index: 7; }
.icon_delete:before{content:'\e5c9'; font-size:20px; color:var(--layout-color04);}
.icon_view:before{content:'\e8f5'; font-size:20px; color:var(--layout-color04);}
.icon_hide:before{content:'\e8f4'; font-size:20px; color:var(--layout-color04);}

@media (max-width:1123px) {
	body.login #wrap{background-size: contain; background-position-y: unset;}
	.login_box{width:95%; padding:3rem; gap:2rem;}
    .division{gap:2rem}
	section:after{right:-1rem;}
	.bg_img{width:48vw;}
}

@media (max-width:820px) {
	body.login {overflow: auto;}
	body.login:after{display: none;}
	.login_box{flex-direction: column; transform: translate(-50%, 0); gap: 4rem; top:80px;}
    .division{flex-wrap: wrap;}
    .blockBottom{bottom:-9rem;}
	section{width:100%;}
	section:after{border-right:0;width: 100%;height: 1px;right: 0;bottom: -2rem;}
	.login_box .copyright{padding-bottom: 1rem;}
	.blockTop{top: -7rem;}
	.blockLeft,.blockRight{width:100%}
	.blockLeft{padding-right: 0}
	.bg_img{display: none}
    .blockMiddle{margin-top: -3rem !important;}
}

/* 팝업 */
.popup {position: fixed; top:0; left:0; right: 0; bottom: 0; background: rgba(0,0,0,0.3); z-index:1000; overflow: hidden; display: flex; align-items: center; justify-content: center;}
.popup .popup_box {width: 530px;/*height: 500px;*/background: #ffffff;border-radius: 1.5rem;padding: 3rem;display: flex;align-items: stretch;flex-direction: column;}
.popup .popup_box h3{font-size: 2.5rem;font-weight: 600;text-align: center;display: flex;justify-content: center;flex-direction: column;}
.popup .popup_box h3 span {display: flex; justify-content: center; flex-direction: column; font-size: 1.6rem; margin-top:1rem;}
.popup .popup_box .content {height: auto;padding: 1rem 0;display: flex;flex-direction: column;gap: 1.5rem;}
.popup .popup_box .content .form_group {display: flex; flex-direction: column; gap:1.5rem;}
.form_birth_box {display: flex; flex-direction: row; gap:1rem;}
.form_group .input_item, .form_group select{ padding: 1rem; display: inline-flex; width: 100%; height: auto;}
.form_certify_box {display: flex; flex-direction: row; gap: 3rem;}
.form_certify_input.phone_certify {display: flex; flex-direction: row; flex-wrap: nowrap; align-items: center; gap: 0.8rem;}
.buttonBox {margin-top:auto;display: flex;gap: 1rem;}
.buttonBox button {padding: 1.5rem 2rem;border-radius: 8px;display: flex;flex-grow: 1;justify-content: center;align-items: center;font-size: 1.8rem;}
.buttonBox .btn {background: #2F6AF9; width: 56%;}
.buttonBox .btn_line {border:1px solid #c5ccd2;background: #fff;color: #333;}

/* 공동인증서등록 */
.registBox {display: flex;flex-direction: column;width: 100%;}
.registBox h1{padding:1.5rem 2rem; margin:0; background: #194d93; color: #fff; font-size: 2rem; font-weight: 500;}
.registBox .list_circle{padding: 2rem 2rem 1rem 5rem; list-style: none;}
.registBox .list_circle li {counter-increment: num; position: relative; list-style-position: outside; line-height: 140%}
.registBox .list_circle > li:before {content: counter(num); display: inline-flex; align-items: center; justify-content: center;  width: 20px; height: 20px; margin-right: 8px; border: 1px solid var(--border-dp);  border-radius: var(--radius-full); font-size: var(--fs-sm); margin-left: -2.8rem;}
.registBox .dot_list {}
.registBox .box {padding: 2rem;background: #E7ECF2;border-radius: 12px;margin: 0 2rem;display: flex;flex-direction: column;gap:4px;}
.registBox .box .group {display: flex;flex-grow: 1;padding-bottom: 1rem;border-bottom: 1px dashed #93a0af;margin-bottom: 1rem;}
.registBox .box .group label {display: flex; flex-grow: 1;}
.registBox .box > div {display: flex; flex-direction: row; }
.registBox .box > div > dt {width: 20%}
.registBox .box > div > dd {width: 80%;display: flex;flex-direction: row;flex-wrap: wrap;align-items: center;}
.registBox .box > div > dd p {font-size: 14px; margin-top:4px; display: flex; width: 100%;}
.registBox .box input{border-radius: 5px;}
.registBox .btnBox {display: flex; padding: 1.5rem 2rem 2rem; gap: 8px;}
.registBox .btnBox .btn_primary{display:flex;background-color: var(--point-color2);color:#fff;padding:12px 50px;font-size: 1.6rem;border-radius:5px;text-align:center;font-weight: 600;width: 100%; justify-content: center;}
.registBox .btnBox .btn{display:flex; background-color:#fff; color:#3f3f3f; padding:12px 50px;font-size: 1.6rem;border-radius:5px;text-align:center;font-weight: 600;width: 100%; justify-content: center;}

@media (max-width:420px) {
	.registBox .box {gap:12px;}
	.registBox .box > div {flex-direction: column; gap: 5px;}
	.registBox .box > div > dt, .registBox .box > div > dd {width: 100%}
	.registBox input[type="text"], .registBox input[type="password"] {width: 100%;}
	.registBox .box > div > dd.row input[type="text"],
	.registBox .box > div > dd.row input[type="password"]{width: 45%}
}