/* ============================================
   JJES Login Modal - login_modal.css
   jjes.co.kr/xe 기존 디자인 재현
   ============================================ */

/* ----- 오버레이 배경 ----- */
#im_modal_login {
    display: none;
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0, 0, 0, 0.55);
    z-index: 9999;
    align-items: center;
    justify-content: center;
    padding: 20px;
    box-sizing: border-box;
}

#im_modal_login.open {
    display: flex;
    animation: jjesModalFadeIn 0.2s ease;
}

@keyframes jjesModalFadeIn {
    from { opacity: 0; }
    to   { opacity: 1; }
}

/* ----- 로그인 카드 ----- */
#im_modal_login .loginWindow {
    background: #3bb5e8;       /* JJES 기존 하늘색 */
    border-radius: 4px;
    width: 100%;
    max-width: 490px;
    padding: 0;
    position: relative;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.35);
    animation: jjesModalSlideUp 0.25s cubic-bezier(0.25, 0.8, 0.25, 1);
    overflow: hidden;
}

@keyframes jjesModalSlideUp {
    from { transform: translateY(20px); opacity: 0; }
    to   { transform: translateY(0);    opacity: 1; }
}

/* ----- 헤더 영역 (Login 타이틀 + 닫기) ----- */
#im_modal_login .loginWindow_header {
    display: flex;
    align-items: center;
    padding: 16px 20px 14px 28px;
    margin: 0;
    /* 닫기 버튼을 같은 행 오른쪽에 배치 */
}

#im_modal_login .loginWindow_header img {
    display: none; /* 이미지 숨기고 텍스트로 대체 */
}

#im_modal_login .loginWindow_header::before {
    content: 'Login';
    font-size: 28px;
    font-weight: 700;
    color: #ffffff;
    font-family: 'Outfit', 'Noto Sans KR', sans-serif;
    letter-spacing: -0.5px;
}

/* ----- 유효성 메시지 ----- */
#im_modal_login .message {
    margin: 0 28px 12px;
    padding: 10px 14px;
    border-radius: 4px;
    font-size: 13px;
    background: rgba(255, 255, 255, 0.85);
    color: #d63031;
    font-weight: 500;
}

/* ----- fieldset ----- */
#im_modal_login fieldset {
    border: none;
    padding: 0 28px 0;
    margin: 0;
}

#im_modal_login legend.im_hidden {
    position: absolute;
    width: 1px; height: 1px;
    overflow: hidden;
    clip: rect(0,0,0,0);
}

/* ----- 입력 그룹 (dl/dt/dd) ----- */
#im_modal_login dl {
    display: flex;
    flex-direction: column;
    gap: 14px;
    margin: 0; padding: 0;
    list-style: none;
}

#im_modal_login dt {
    margin: 0 0 6px;
    padding: 0;
}

#im_modal_login dt label {
    font-size: 14px;
    font-weight: 500;
    color: #ffffff;
    display: block;
}

#im_modal_login dd {
    margin: 0; padding: 0;
}

/* 입력 필드 */
#im_modal_login .inputuid,
#im_modal_login .inputupw {
    width: 100%;
    padding: 14px 16px;
    border: none;
    border-radius: 3px;
    font-size: 15px;
    font-family: 'Noto Sans KR', sans-serif;
    color: #333;
    background: #ffffff;
    outline: none;
    box-sizing: border-box;
    transition: box-shadow 0.15s;
}

#im_modal_login .inputuid:focus,
#im_modal_login .inputupw:focus {
    box-shadow: inset 0 0 0 2px rgba(255,255,255,0.8);
}

/* ----- 로그인 유지 체크박스 ----- */
#im_modal_login .keepWrap {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 14px;
}

#im_modal_login .keep {
    display: flex;
    align-items: center;
}

#im_modal_login .inputCheck {
    width: 18px;
    height: 18px;
    accent-color: #2980b9;
    cursor: pointer;
    margin: 0;
}

#im_modal_login .keep_text span {
    font-size: 14px;
    color: #ffffff;
}

/* ----- 로그인 버튼 ----- */
#im_modal_login .submit_btn {
    margin-top: 18px;
}

#im_modal_login .submit_btn {
    display: flex;
    justify-content: center;
    margin-top: 18px;
}

#im_modal_login .login_submit {
    display: inline-block;
    width: auto;
    min-width: 160px;
    padding: 13px 40px;
    background: #333333;
    color: #ffffff;
    text-align: center;
    border-radius: 3px;
    font-size: 15px;
    font-weight: 600;
    font-family: 'Noto Sans KR', sans-serif;
    letter-spacing: 0.5px;
    transition: background 0.2s;
    cursor: pointer;
    text-decoration: none;
    border: none;
    outline: none;
}

#im_modal_login .login_submit:hover {
    background: #222222;
}

#im_modal_login .login_submit:active {
    background: #111111;
}

/* ----- 하단 링크 메뉴 (회원가입 | ID/PW 찾기) ----- */
#im_modal_login .login_menu {
    padding: 18px 28px 24px;
}

#im_modal_login .login_menu ul {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0;
    padding: 0;
    margin: 0;
    list-style: none;
}

#im_modal_login .login_menu li {
    text-align: center;
}

/* | 구분자 */
#im_modal_login .login_menu li + li::before {
    content: '|';
    color: rgba(255, 255, 255, 0.5);
    margin: 0 12px;
}

#im_modal_login .login_menu a {
    font-size: 14px;
    color: #ffffff;
    text-decoration: none;
    transition: opacity 0.15s;
}

#im_modal_login .login_menu a:hover {
    opacity: 0.75;
    text-decoration: underline;
}

/* 닫기 버튼 - 모달 우측 상단 절대위치 */
#im_modal_login .close_loginWindow {
    position: absolute;
    top: 14px;
    right: 18px;
    margin: 0;
    line-height: 1;
}

#im_modal_login .modal_close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    font-size: 22px;
    color: #ffffff;
    text-decoration: none;
    transition: opacity 0.15s;
    background: none;
}

#im_modal_login .modal_close:hover {
    opacity: 0.7;
}

/* ----- 헤더 로그인 트리거 버튼 (layout.html 상단) ----- */
#jjes-layout .login-trigger-btn {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 13px;
    font-weight: 500;
    color: var(--primary-color, #1a365d);
    cursor: pointer;
    padding: 5px 10px;
    border-radius: 20px;
    border: 1px solid #e2e8f0;
    text-decoration: none;
    transition: all 0.2s;
}

#jjes-layout .login-trigger-btn:hover {
    background: var(--primary-color, #1a365d);
    color: #fff;
    border-color: var(--primary-color, #1a365d);
}

/* ----- 반응형: 소형 화면 ----- */
@media (max-width: 540px) {
    #im_modal_login .loginWindow {
        max-width: 100%;
        border-radius: 8px;
    }
    #im_modal_login fieldset,
    #im_modal_login .loginWindow_header,
    #im_modal_login .login_menu {
        padding-left: 20px;
        padding-right: 20px;
    }
    #im_modal_login .loginWindow_header::before {
        font-size: 22px;
    }
}
