/* reset */

html,
body {
    height: 100%;
}

ul {
    margin: 0;
    padding: 0;
}

ul li {
    padding: 0;
    background-image: none;
}

ul li a {
    margin: 0;
}

/* main element */
.txt_fwb {
    font-weight: 600;
}

.txt_red {
    color: #d60050;
}

.txt_15px {
    font-size: 15px;
}

.txt_c {
    text-align: center;
}

.txt_r {
    text-align: right;
}

.txt_l {
    text-align: left;
}


.mg_0 {
    margin: 0;
}

.dp_block {
    display: block;
}

.mg_b_10 {
    margin-bottom: 10px;
}


.login_limited-info {
    background-color: #ffff00;
    display: block;
    padding: 20px 0;
    color: #EB2142;
    font-size: 18px;
    text-decoration: none;
}

.login_limited-info span {
    background-color: #EB2142;
    color: #fff;
    padding: 7px 13px;
    border-radius: 3px;
    font-size: 15px;
}

.login_limited-info-after {
    background-color: #EB2142;
    color: #fff;
    font-size: 16px;
}

.login_limited-info-after span {
    background-color: #ffff00;
    color: #EB2142;
    margin-left: 10px;
    font-size: 16px;
    padding: 10px 13px;
    font-weight: bold;
}


.login_limited-info-after-description-more {
    color: #fff;
    font-size: 18px;
    padding-bottom: 80px;
}

.login_limited-info-after-description-more h2 {
    font-size: 30px;
    text-align: center;
    padding-top: 20px;
    color: #EB2142;
}

.login_limited-info-after-description-more-in {
    max-width: 700px;
    margin: 0 auto;
    background-color: #fff;
    color: #000;
    padding: 40px 40px 0;
    border-radius: 3px;
}

.login_limited-info-after-description-more-in-box {
    margin: 30px 0;
    border-top: solid 1px #ccc;
}

.login_limited-info-after-description-more-in h3 {
    padding-top: 40px;
}

.login_limited-info-after-description-more-in p {
    line-height: 170%;
    font-size: 16px;
    padding: 30px 0 0;
}

.login_limited-info-after-description-more-in p span.red {
    color: #EB2142;
    font-weight: bold;
    background-color: #ffff00;
}

.login_limited-info-after-description-more-in p.top {
    font-size: 20px;
}

.login_limited-info-after-description-more-in p.bottom {
    padding: 30px 0;
}

.login_limited-info-after-description-more-in ul {
    list-style-type: disc;
    font-size: 16px;
    line-height: 150%;
    padding: 30px 0;
    padding-bottom: 0;
    padding-left: 30px;
}

.login_limited-info-after-description-more-in li {
    padding-bottom: 10px;
}

.login_limited-info-after-btn {
    display: block;
    background-color: #EB2142;
    width: 350px;
    margin: 40px auto;
    line-height: 60px;
    text-align: center;
    color: #fff;
    font-weight: bold;
    font-size: 23px;
    text-decoration: none;
    border-radius: 6px;
}

.case-forget-mail {
    border: solid 2px red;
    padding: 20px;
}

.case-forget-mail p {
    padding: 0;
}

.case-forget-mail span {
    display: block;
    padding-bottom: 15px;
    font-size: 20px;
    font-weight: bold;
}

.login_wrap {
    text-align: center;
    position: relative;
    font-size: 14px;
    height: 100%;
}

#logo_paperboy {
    position: absolute;
    top: -58px;
    right: 5px;
}

.login_contents_wrap {
    width: 50%;
    min-height: 100%;
    margin: 0;
    float: left;
    text-align: center;
    padding: 40px 0;
    box-sizing: border-box;
    justify-content: center;
    align-items: center;
}



@media (min-width:600px) {
    .login_form_wrap {
        width: 55%;
        margin: 0 auto;
        text-align: left;
    }



}

@media screen and (max-width: 1024px) and (orientation: portrait) {
    .login_contents_wrap {
        width: 100%;
        min-height: 10%;
    }

    .login_form_wrap {
        width: 95%;
        margin: 0 auto;
        text-align: left;
    }


}


.cms_logo_login_wrap {
    text-align: center;
    padding-bottom: 30px;
    padding-top: 40px;
}

.cms_logo_login_wrap img {
    width: 200px;
}

/* campaign logo wrap */
.cms_logo_login_wrap {
    position: relative;
}


.login_footer-bnr-area {
    text-align: center;
    padding: 30px 0;
}

.login_footer-bnr-area a {
    display: inline-block;
}

.login_campaign_info--title {
    font-weight: bold;
    margin-bottom: 15px;
}

#login_footer {
    width: 100%;
    text-align: center;
    color: #999;
    font-size: 11px;
    padding-top: 30px;
}



/* //main element */


/* contents element */

.block_form_wrap {
    position: relative;
    display: block;
    padding: 10px 15px;
    background-color: #ffffff;
    -o-border-radius: 3px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    -ms-border-radius: 3px;
    border-radius: 3px;
    height: 3px;
}

.block_form_list {
    display: block;
    margin-bottom: 20px;
}

label {
    display: block;
    vertical-align: middle;
}

.login_txt {
    padding: 0 0 8px 0;
    color: #333;
    font-size: 15px;
    display: block;
    font-weight: bold;
    line-height: .5em;
}

.pass_txt {
    color: #333;
    font-size: 15px;
    display: block;
    padding: 10px 0;
    font-weight: bold;
    line-height: 1.1em;
}

.pass_txt {
    width: 180px;
}

.input_login_wrap,
.input_pass_wrap {
    width: 100%;
    height: 50px;
    position: relative;
    border: 2px solid #ddd;
    border-radius: 4px;
}

.input_pass_wrap {
    width: 100%;
}

.login_url_01 {
    display: block;
    position: absolute;
    color: #666666;
    left: 15px;
    top: 18px;
}

.login_url_02 {
    display: block;
    position: absolute;
    color: #666666;
    right: 15px;
    top: 18px;
}

.input_login {
    width: 100%;
    height: 50px;
    padding: 2px 10px;
    border: none;
    font-size: 18px;
    display: block;
    line-height: 1.1em;
    background-color: transparent;
    /*ime-mode:disabled;*/
    z-index: 11;
    zoom: 1;
    box-sizing: border-box;
}

.input_pass {
    height: 45px;
    margin: 2px;
    padding: 10px;
    border: none;
    font-size: 16px;
    display: block;
    width: 291px;
    line-height: 1.1em;
    background-color: transparent;
    ime-mode: disabled;
    z-index: 11;
    zoom: 1;
}

.input_login_url {
    display: block;
    position: absolute;
    left: 70px;
    top: 0;
    width: 200px;
}

#lbl_chk {
    width: 20px;
    height: 20px;
    vertical-align: -4px;
}

.form_login_url {
    left: 80px;
    width: 290px;
    padding: 14px 0;
}

.login_form_sub_tit {
    color: #333;
    font-weight: bold;
    font-size: 22px;
    text-align: center;
    width: 300px;
    margin: 0 auto 30px;
    padding: 5px 0;
    background-color: #ffffff;
    -o-border-radius: 30px;
    -webkit-border-radius: 30px;
    -moz-border-radius: 30px;
    -ms-border-radius: 30px;
    border-radius: 30px;
}

.txt_login_save_wrap {
    padding: 0 15px;
}

.block_remind_list_wrap {
    width: 100%;
}

.block_remind_list {
    display: block;
    text-align: center;
}

.block_remind_link {
    display: block;
    position: relative;
    margin-bottom: 10px;
}

.block_remind_link img {
    width: 15px;
    height: 15px;
    vertical-align: -3px;
    padding: 0 3px;
}

.block_remind_link:after {
    position: absolute;
    right: 15px;
    top: 2px;
    width: 6px;
    height: 10px;

}

a.block_remind_link:link,
a.block_remind_link:visited {
    color: #0088e8;
    text-decoration: none;
    font-size: 14px;
}

a.block_remind_link:active,
a.block_remind_link:hover {
    color: #333;
    transition: 0.2s linear;
}


.block_signup_list_wrap {
    width: 100%;
    margin-top: 20px;
    text-align: center;
    list-style: none;
}

.block_signup_link {
    display: block;
    position: relative;
    margin-bottom: 10px;
}

.block_signup_link:after {
    position: absolute;
    right: 15px;
    top: 2px;
    width: 6px;
    height: 10px;
}

a.block_signup_link:link,
a.block_signup_link:visited {
    color: #0088e8;
    text-decoration: none;
    font-size: 14px;
}

a.block_signup_link:active,
a.block_signup_link:hover {
    color: #333;
    transition: 0.2s linear;
}

/* //contents element */

/* banner */
.login_bnr {
    margin: 40px 0 0;
}

.login_bnr_img {
    width: 100%;
}

/* //banner */

/* parts */
.tit_form_lavel {
    margin-bottom: 10px;
}


.txt_login_save {
    color: #333;
    font-size: 16px;
    text-align: center;
    display: block;
}

.link_reminder {
    display: block;
    position: absolute;
    right: 15px;
    top: 15px;
}

.link_reminder a {
    position: relative;
    display: block;
}

.link_reminder a:link,
.link_reminder a:visited,
.link_reminder a:hover,
.link_reminder a:active {
    text-decoration: none;
}

.link_reminder a .help_tooltip {
    background-color: #00e1f8;
    display: none;
    font-size: 13px;
    position: absolute;
    right: 35px;
    top: -3px;
    padding: 8px;
    white-space: nowrap;
    z-index: 200;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    -ms-border-radius: 5px;
    -o-border-radius: 5px;
    border-radius: 5px;
    text-decoration: none;
    font-weight: bold;
    color: #333;
}

.form_login_url_txt01,
.form_login_url_txt02 {
    position: absolute;
    top: 15px;
    font-family: Verdana;
    font-size: 18px;
}

.form_login_url_txt01 {
    left: 15px;
}

.form_login_url_txt02 {
    right: 15px;
}

a.txt_captcha_change {
    font-size: 12px;
    display: block;
    margin-top: 10px;
}

a.txt_captcha_change:link,
a.txt_captcha_change:visited {
    color: #333;
    text-decoration: none;
}

a.txt_captcha_change:active,
a.txt_captcha_change:hover {
    color: #333;
    text-decoration: underline;
}

.login_form_wrap input {
    outline: none;
}

/* //parts */

.txt_focus {
    color: #333333;
}

.btn_submit_s {
    width: 185px;
    float: left;
}

.login_btn {
    clear: both;
}

.login_btn a {
    color: #333;
    text-decoration: none;
}

.btn_type_action,
.btn_type_passive {
    text-align: center;
    margin: 15px 0;
    zoom: 1;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    -ms-border-radius: 3px;
    -o-border-radius: 3px;
    border-radius: 3px;
}


.login_btn_inner_size_l {
    width: 100%;
}

.login_btn_inner_size_l {
    width: 430px;
}

.login_btn_inner_size_s {
    width: 200px;
}

.btn_submit_s {
    text-align: center;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    -ms-border-radius: 3px;
    -o-border-radius: 3px;
    border-radius: 3px;
}

.btn_back_s {
    float: right;
    text-align: center;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    -ms-border-radius: 3px;
    -o-border-radius: 3px;
    border-radius: 3px;
}

.login_btn_inner,
.returntop_btn_inner {
    width: 100%;
    display: block;
    margin: 0 auto;
    padding: 16px 0;
    line-height: 1.1em;
    cursor: pointer;
    outline: none;
    background: #6CB7C1;
    border: none;
    border-radius: 4px;
    text-align: center;
    color: #fff;
    text-decoration: none;
    font-weight: 500;
    font-size: 16px;
}

.login_btn_inner:hover,
.returntop_btn_inner:hover {
    opacity: .7;
    transition: 0.2s linear;
}

.img_rem_flow {
    width: 290px;
    margin: 0 auto 30px;
    color: #333;
}

/* password reminder */
.txt_rem_desc_wrap {
    width: 100%;
    position: relative;
}

.link_rem_txt {
    color: #333;
    font-size: 11px;
    line-height: 1.8;
    margin-bottom: 20px;
    background-color: #f2f2f2;
    padding: 15px;
}

.link_rem_txt p {
    margin-bottom: 1em;
}

.link_rem_txt a {
    color: #0088e8;
    text-decoration: none;
    font-weight: 500;
}

.link_rem_txt a:hover {
    color: #333;
    transition: 0.2s linear;
}

.link_rem_btn {
    background: #ffffff;
    color: #0088e8;
    border: 1px solid #0088e8;
    width: 100%;
    display: block;
    margin: 0 auto;
    padding: 8px 0;
    line-height: 1.1em;
    cursor: pointer;
    outline: none;
    border-radius: 4px;
    text-align: center;
    text-decoration: none;
    font-weight: 500;
    font-size: 12px;
}

.link_rem_cont {
    display: none;
    position: absolute;
    right: -345px;
    top: 0;
    width: 300px;
    padding: 15px;
    color: #333;
    line-height: 1.6em;
    background-color: rgba(0, 0, 0, 0.6);
    background-color: #355053;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    -ms-border-radius: 3px;
    -o-border-radius: 3px;
    border-radius: 3px;
}

.tit_login_id_url {
    color: #333;
    font-size: 16px;
    line-height: 1.8em;
    margin-bottom: 15px;
}

.tit_login_id_url strong {
    font-weight: bold;
}

.rem_desc_list_wrap {
    font-size: 15px;
    color: #333;
    margin-bottom: 15px;
}

.rem_desc_list {
    margin: 0;
    padding: 0 0 5px;
}


.BOX_nl {
    background-color: #F9FFCF;
    padding: 15px;
    color: #333333;
    margin-bottom: 10px;
}

.BOX2_nl {
    background-color: #333;
    padding: 15px;
    color: #333333;
    margin-bottom: 10px;
}

.txt_rem {
    line-height: 1.1em;
    text-align: center;
    margin: 0;
    padding: 0 20px 0 0;
    font-size: 12px;
    color: #999;
}

.txt_rem_current {
    color: #333;
}

.txt_rem_last {
    padding-right: 0;
}

.img_rem {
    float: left;
    color: #333;
    margin-right: 20px;
}

.img_rem:last-child {
    margin-right: 0;
}


#nl_information_wrap {
    margin: 0 auto;
    padding: 5px;
    font-size: 13px;
    background-color: rgba(255, 255, 255, 0.9);
    background-color: #f7f7f7;
}

#nl_information {
    margin: 0;
    line-height: 1.5em;
    font-weight: bold;
}


.block_login_error {
    margin: 15px 0;
    font-size: 13px;
    line-height: 1.5em;
    padding: 15px;
    color: #333;
    background-color: #fee4e4;
    background-color: #fee4e4;
}

.block_login_error_link {
    color: #333;
    text-decoration: underline;
    display: inline-block;
    padding: 0 5px;
}

.block_login_error_link:hover {
    text-decoration: none;
}

.block_login_txt {
    margin: 15px 0 0;
    font-size: 13px;
    line-height: 1.5em;
    padding: 15px;
    background-color: rgba(252, 255, 255, 0.8);
    background-color: #fcff00;
}

.input_error_txt {
    color: #ff4545;
    margin-top: 1em;
}

.pass_strength_state_wrap {
    background-color: #f2f2f2;
    padding: 10px;
    margin-bottom: 10px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    -ms-border-radius: 3px;
    -o-border-radius: 3px;
    border-radius: 3px;
}

.pass_strength_tit_wrap {
    padding: 0 0 10px;
}

.pass_strength_tit {
    font-size: 14px;
    font-weight: bold;
    color: #333;
    float: left;
    display: block;
}

.pass_strength_txt {
    color: #333;
    float: right;
    display: block;
}

.pass_strength_bar_wrap {
    width: 370px;
    padding: 1px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    -ms-border-radius: 5px;
    -o-border-radius: 5px;
    border-radius: 5px;
}

.pass_strength_bar {
    display: block;
    height: 10px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    -ms-border-radius: 5px;
    -o-border-radius: 5px;
    border-radius: 5px;
}


/* --- clearfix Start ----- */
.clearfix:after {
    content: "";
    display: block;
    clear: both;
    height: 0;
}

.clearfix {
    display: inline-block;
}

/* Hides from IE-mac \*/
* html .clearfix {
    height: 1%;
}

.clearfix {
    display: block;
}

/* End hide from IE-mac */
/* --- clearfix End ----- */

.section-signup {
    margin: 50px 0;
}

.section-signup__title {
    text-align: center;
    position: relative;
    color: #333;
    margin-bottom: 30px;
}

.section-signup__title:after {
    content: "";
    display: block;
    position: absolute;
    width: 100%;
    height: 1px;
    background: #333;
    bottom: 50%;
}

.section-signup__title span {
    padding: 0 1em;
    background: #83c9ce;
    position: relative;
    z-index: 1;
}

.signup_btn {
    /*border: 1px solid #333;*/
}

.signup_btn a {
    transition: background 0.2s;
    border-radius: 3px;
    color: #398186;
    background: rgba(255, 255, 255, 0.8);
}

.signup_btn a:hover {
    background: rgba(255, 255, 255, 0.7);
}

.link-block {
    text-align: center;
    margin: 10px 0 30px;
}

.link-block__link {
    display: inline-block;
    font-size: 12px;
}

.link-block__link--login {
    margin-right: 50px;
}

.back-to-login {
    margin: 50px 0 0;
    text-align: center;
}

.login-link {
    color: #333;
    text-decoration: none;
    font-weight: normal;
    position: relative;
    font-size: 12px;
}

.back-to-login__link {
    padding-left: 15px;
}

a.login-link:link,
a.login-link:visited {
    color: #666;
    text-decoration: none;
}

a.login-link:hover,
a.login-link:active {
    color: #333;
    text-decoration: none;
}



/* キャンペーン関連の告知スペースにて指定したCSSはここから */
.login_contents_recommend {
    position: relative;
    background-color: #E8F2EC;
}



@media screen and (max-width: 1024px) and (orientation: portrait) {
    .login_contents_recommend {
        display: block;
    }
}

.login-recommend {
    border-radius: 3px;
    line-height: 1.6;
    height: auto;
    width: 90%;
    margin: 0 auto;
    padding: 45px 30px;
    box-sizing: border-box;
    background-color: #ffffff;
    color: #333;
}


.login-recommend-label {
    padding: 6px 10px;
    margin: 0 auto;
    display: inline-block;
    background-color: #F3F2EF;
    border-radius: 2px;
    font-size: 12px;
    color: #545454;
    font-weight: bold;
    margin-bottom: 20px;
    min-width: 100px;
    box-sizing: border-box;
}

.login-recommend-title {
    font-size: 20px;
    font-weight: 700;
    line-height: 1.4;
    letter-spacing: 1;
    margin-bottom: 20px;
}

.login-recommend-cp-label {
    padding: 10px 15px;
    margin: 0 auto 20px;
    text-align: center;
    font-weight: bold;
    display: inline-block;
    border-radius: 2px;
    background-color: #F57171;
    color: #fff;
    font-size: 13px;
}

.login-recommend-summary {
    font-size: 14px;
    margin-bottom: 25px;
}

.login-recommend-summary a {
    color: #0088e8;
    text-decoration: none;
}

.login-recommend-summary a:hover {
    text-decoration: underline;
}

.login-recommend__sub-cont {
    margin-top: 30px;
}

.login-recommend__sub-cont .login-recommend-summary {
    margin-bottom: 10px;
}

.login-button--general {
    display: block;
    width: 50%;
    height: 45px;
    line-height: 45px;
    text-align: center;
    font-weight: 700;
    font-size: 1rem;
    color: #0087e8;
    background-color: #fff;
    border: 2px solid #0087e8;
    border-radius: 4px;
    text-decoration: none;
    margin: 0 auto;
}

.login-button--general:hover {
    opacity: .7;
    transition: 0.2s linear;
}

.login-recommend-btn-secondary {
    display: block;
    width: 50%;
    height: 45px;
    line-height: 45px;
    text-align: center;
    font-weight: 700;
    font-size: 1rem;
    color: #ffffff;
    background-color: #0087e8;
    border-radius: 4px;
    text-decoration: none;
    margin: 0 auto;
}

.login-recommend-btn-secondary:hover {
    opacity: .7;
    transition: 0.2s linear;
}
