/* 로그인 */
.login { display: flex; align-items: center; height: 100%; }

.login .icon-togethers_ci { display: flex; justify-content: center; align-items: center; margin: 0 auto; font-size: 10rem; color: #ffffff; }

.login__box { width: 47rem; margin: auto; padding: 6rem; border-radius: .3rem; background: #353d52; box-shadow: box-shadow; }

.login__tit { display: flex; flex-direction: column; justify-content: center; align-items: center; margin-bottom: 4rem; font-size: 2rem; font-weight: 100; text-align: center; color: #f8f9fa; letter-spacing: -.1rem; }

.login__txt { margin-top: 1.5rem; color: #ced4da; }

.login__label { display: block; margin: 2rem 0 0; color: #343a40; }

.login__checkbox { color: #ced4da; }

.login__tfbox { display: inline-flex; align-items: stretch; width: 100%; height: 5rem; margin-top: 1.5rem; padding: 1rem; border: 0.1rem solid #dee2e6; border-radius: .3rem; background: #e7f5ff; line-height: 1.5; }

.login__tfbox > input { display: block; width: 100%; height: 100%; background: transparent; border: transparent; }

.login__tfbox > input::placeholder { color: #868e96; }

.login__tfbox > span { display: block; padding: .3rem 0; white-space: nowrap; }

.login__btn { display: block; width: 100%; margin: 3rem 0 1rem; padding: 1.6rem; border-radius: .3rem; font-size: 1.6rem; background: #228be6; color: #ffffff; text-align: center; }

.login__btn:hover { background: #339af0; text-decoration: none; }

.login__btn:disabled, .login__btn.disabled { background: rgba(255, 255, 255, 0.1); color: #868e96; }

.login__infobox { padding: 2rem; border-radius: .3rem; background: #f03e3e; color: #ffffff; }

.login__link { margin: auto 0; color: #ced4da; }

.login__option { display: flex; margin-top: 1.5rem; }

/* 레이어팝업 */
.layerpopup__wrap { display: none; position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 400px; height: 450px; padding: 7px 15px 15px; border-radius: 3px; background: #fff; box-shadow: 0 0 10px rgba(0, 0, 0, 0.5); z-index: 12; }

.layerpopup__tit { position: relative; margin: 8px 0; font-weight: bolder; }

.layerpopup__tit:before { content: ''; display: inline-block; width: 3px; height: 10px; margin-right: 5px; background: #888; }

.layerpopup__btn { display: inline-block; margin-top: 20px; padding: 4px 8px; border: 1px solid #228be6; border-radius: 2px; font-size: 13px; background: #339af0; color: #fff; vertical-align: top; box-shadow: inset 0 1px 0 #80B0FB; cursor: pointer; }

.layerpopup__btn:hover { border-color: #1c7ed6; background: #228be6; text-decoration: none; box-shadow: 1px 1px 1px #EAEAEA, inset 0 1px 0 #5A94F1; }

.layerpopup__btn:active { background: #1c7ed6; box-shadow: inset 1px 1px 1px rgba(0, 0, 0, 0.1); }

.layerpopup__btn--line { border-color: #4dabf7; background-color: #fff; color: #228be6; box-shadow: none; }

.layerpopup__btn--line:hover { border-color: #339af0; background: #e7f5ff; box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.1); }

.layerpopup__btn--line:active { background: #d0ebff; box-shadow: inset 1px 1px 1px rgba(0, 0, 0, 0.1); }

.bg_blackmask { display:none;position:fixed;top:0;left:0;bottom:0;right:0;z-index:11;  background: #000; opacity: 0.8; -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=60)"; }


input:invalid { background: #ffe5e5; border-color: #ff0000; }

.require { color:#ff0000; font-weight:bold; }