@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,
.icon: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: transparent;}
body.login:after{content: '';background-image:url(../asset/image/ssoLogin/bg_symbol.png);background-position: right 3%;background-repeat: no-repeat;background-blend-mode: color;position: absolute;width: 36rem;height: 42rem;background-size: contain;left: 5%;bottom: 5%;}
body.login #wrap{min-width:auto;display: flex;flex-direction: column;}
header {height: 200px; background: #0d1e4c; display: flex; justify-content: center; padding-bottom: 70px; z-index: 10; box-shadow: none;}

header h1{position:relative;width: 420px;height:64px;margin:0 0 10px;background-size:contain;font-size:2.4rem;font-weight: 700;color:#333333;}
header h1.logo{background: url(../asset/image/ssoLogin/h1_login.png) left 50% no-repeat;margin:0;background-size: contain;display: flex;align-items: center;color: #fff;padding-left: 260px;}
header h1.logo span {display: flex; position: relative;}
header h1.logo span:before { content: ''; width: 1px; height: 20px; background: #fff; position: absolute; top: 4px; left: -2rem;}

.login_box{position: absolute;top: 220px;left: 50%;transform: translate(-50%, 0);z-index: 999;transition: all 1s;background: #fff;width: 1135px; display: flex;flex-wrap: wrap;flex-direction: row;gap: 2rem;}
.box_group {background: #eceef3;border-radius: 1.5rem;padding:3.5rem 2rem 2rem;flex-grow: 1;display: flex;flex-direction: column;gap: 3rem;align-items: stretch;}
.box_group .row{display: flex; flex-direction: row; gap:2rem; flex-grow: 1;}
.login_title {font-size: 2.4rem; font-weight: 600; text-align: center;}
.login_title em {color:#2F6AF9; font-weight: 600;}
.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%;max-width:1135px;margin: -70px auto 0;left: 50%;transform: translateX(-50%);background: #0d1e4c;color:#fff;display: flex;align-items: center;justify-content: center;gap: 0;z-index: 100;position: absolute;}
.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: -10rem;display: flex;align-items: center;left: 0;justify-content: center;width: 100%;text-align: center;background: #eceef3;padding: 2rem;border-radius: 1.5rem; justify-content: space-between;}
.blockBottom ul {display: flex; flex-direction: row; gap:4rem;}
.blockBottom > div, .blockBottom ul li a { display: inline-flex; align-items: center;}
.blockBottom .icon:before {content:''; width:32px; height: 32px; border-radius: 900px; background: #121212; display: inline-flex; margin-right: 1rem; }
.icon:before {color:#fff; font-size: 20px;}
.icon_phone:before {content: '\e61d' !important;}
.icon_info:before {content: '\f59b' !important;}
.icon_keyboard:before {content: '\f028' !important;}
.icon_meno:before {content: '\ef42' !important;}
.icon_connect:before {content: '\e998' !important;}

.box_group section{display: flex;flex-direction: column;gap:1.2rem;position: relative;flex-grow: 1; min-width:310px; background: #fff;padding:2rem;border-radius: 1.5rem;margin: 0 auto; box-shadow: 0 0px 10px rgba(0, 0, 0, 0.1);}

.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: 700;margin-bottom: 0.8rem; text-align: center;}
.login_box h3 + div {margin-bottom:1.5rem}
.login_box h3 + div:before{content: '';width: 115px;height:115px;display: flex;margin: 0 auto;margin-bottom: 2rem;border-radius:8px; background-repeat:  no-repeat; background-size: contain;}
.login_box section:nth-of-type(1) h3 + div:before{background-image:url(../asset/image/ssoLogin/icon_login01.png);}
.login_box section:nth-of-type(2) h3 + div:before{background-image:url(../asset/image/ssoLogin/icon_login02.png);}
.login_box section:nth-of-type(3) h3 + div:before{background-image:url(../asset/image/ssoLogin/icon_login03.png);}

.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; width: 100%; justify-content: center; position: relative;}
.login_box .btnBox a:first-child:after {content: '';width: 1px;height: 16px;background: #909090;position: absolute;top: 11px;right: -1rem;}
.login_box .btnBox a:hover{text-decoration: underline;}
.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;
    }  
.division label.deco-chk{width:100%;padding:20px;justify-content: center;background: #ffffff20; font-size: 2.5rem;}
.division label.deco-chk:before{display: none;}
.division input.deco-chk:checked + label.deco-chk {background: #fff; color: #0d1e4c; font-weight: 600;}
.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);}

.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;}

.Glms{ 
	header {background: #611b29;}
	.division {background: #812638;}
	.login_title em {color:#bb0025;}
	.login_box .btn_login {background-color: #df2a4e;}
	.btn_login:focus-visible, .input_item.focus, button:focus-visible, a:focus-visible, input.deco-chk:focus-visible{outline:2px solid #df2a4e;}
}
@media (max-width:1123px) {
    body.login #wrap{background-size: contain; background-position-y: unset;}
    .login_box{width:95%; gap:2rem;}
    .box_group section {min-width: }100%;
    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);}
    .box_group .row{ flex-direction: column;}
    .blockBottom{bottom:-21rem; flex-direction: column; display: flex; align-items: flex-start; gap: 1rem;}
    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;}
}

@media (max-width:560px) {
	header h1.logo {background-position: 10px 50%;background-size: auto 50px;padding-left: 205px;}
	header h1.logo span:before {left: -1rem;}
	.blockBottom ul {flex-direction:column; flex-wrap: wrap; gap: 1rem; align-items: flex-start;}
}