@charset "UTF-8";

@media screen and (min-width:980px) {

.pc {
    display: none !important; }

.sp {
    display: block !important;
}

/* ------------------------------------------------------------------
    Header
-------------------------------------------------------------------*/

.header{
    border-bottom: 1px solid #F79799;
}

.header-menu{
    display: none;
}

.header-login{
    display: block;
    width: 60px;
    height: 60px;
    border-left: 1px solid #D1CDC2;
    text-align: center;
}

.header-login-link{
    background: #FFF;
}

.header-login-link span {
    display: block;
    position: relative;
    height: 28px;
    width: 28px;
    margin: 6px auto 0;
    background: url(../../img/front/icon-login.png) center center no-repeat;
    background-size: 28px 28px;
    transition: all .3s;
}

.header-login-link .login-text {
    margin-top: 0px;
    font-size: 12px;
    color: #A39B85;
    font-style: normal;
    text-decoration: none;
    font-weight: 600;
}

.header-logout{
    display: block;
    width: 60px;
    height: 60px;
    border-left: 1px solid #D1CDC2;
    text-align: center;
}

.header-logout-link{
    background: #FFF;
}

.header-logout-link span {
    display: block;
    position: relative;
    height: 28px;
    width: 28px;
    margin: 6px auto 0;
    background: url(../../img/front/icon-login.png) center center no-repeat;
    background-size: 28px 28px;
    transition: all .3s;
}

.header-logout-link .logout-text {
    margin-top: 0px;
    font-size: 12px;
    color: #A39B85;
    font-style: normal;
    text-decoration: none;
    font-weight: 600;
}


/* ------------------------------------------------------------------
    Main
-------------------------------------------------------------------*/

.main{
    display: flex;
    justify-content: center;
    padding-top: 60px;
}

.container{
    display: flex;
    justify-content: center;
    position: relative;
    max-width: 980px;
    padding: 0 16px;
}


/* ------------------------------------------------------------------
    Contents
-------------------------------------------------------------------*/

.contents{
    position: relative;
    width: 660px;
}

.page-title{
    padding: 8px 0;
    text-align: center;
}

.page-title-l{
    padding: 8px 0;
    text-align: left;
}

.block-item:last-child{
    margin-bottom: 5px;
}

.page-buttons{
    padding: 8px 0px;
}

.page-buttons button{
    margin-left: 0;
    margin-right: 0;
}

.page-buttons.centered button{
    margin-left: auto;
    margin-right: auto;
}

.page-main-button{
    /* border-bottom: 1px solid #E0E0E0; */
    margin-bottom: 20px;
}

.ec-figs{
    width: 60%;
    text-align: center;
    margin: 20px 19%;
}

/* ------------------------------------------------------------------
    Top
-------------------------------------------------------------------*/
.top-section{
    padding-top: 60px;

}

.top-section-title{
    padding: 8px;
    background-size: contain;
}

.top-section-title .container{
    justify-content: center;
    flex-direction: column;
    margin: 0 auto;
    text-align: left;
}

.top-title-mid{
    display: block;
    font-size: 3rem;
    line-height: 5rem;
    color: #242424;
    font-weight: 300;
}

.welcome-message{
    font-size: 1.3rem;
    line-height: 2rem;
    color: #606060;
    font-weight: 600;
}

.top-section-info{
    min-height: auto;
    margin: 0;
    padding: 8px;
    background: #FEF1F2;
}

.top-section-info .container{
    justify-content: flex-start;
    margin: 0 auto;
    text-align: left;
}

.top-info-message a{
    font-size: 1.4rem;
    line-height: 2rem;
    color: #FF0000;
    font-weight: 600;
    background: none;
}

.top-info-message span{
    margin-right: 4px;
    padding: 4px 8px;
    background: #FF0000;
    font-size: 1.5rem;
    font-weight: 700;
    color: #FFF;
    border-radius: 32rem;
}

.top-section + .main{
    padding-top: 10px !important;
}

.welcome-section + .main{
    padding-top: 10px !important;
}

.welcome-section{
    display: block;
    position: relative;
    padding: 60px 8px 0 8px;
    background: #FFFAFA;
}

.welcome-section .container{
    display: flex;
    justify-content: center;
    flex-direction: column;
    margin: 0 auto;
    height: 38px;
    text-align: left;
}

/* ------------------------------------------------------------------
    Top Menu
-------------------------------------------------------------------*/

.top-menu{
    margin-top: 24px;
    margin-bottom: 30px;
}

.top-menu-items{
    display: flex;
    align-content: stretch;
    flex-wrap: wrap;
}

.top-menu-item{
    display: flex;
    align-items: flex-start;
    align-content: stretch;
    margin: 5px;
    padding: 16px;
    width: calc(50% - 10px);
    min-height: 120px;
}

.top-menu-item .a-block{
    position: relative;
    align-items: flex-start;
    align-content: stretch;
    background: none;
    padding-right: 8px;
}

.top-menu-fig{
    position: absolute;
    top: 0px;
    left: 0px;
}

.top-menu-name{
    margin-top: 12px;
    margin-bottom: 12px;
    padding-left: 78px;
    font-size: 1.4rem;
}

.top-menu-name span{
    display: block;
    /*font-size: 2.2rem;*/
    font-size: 1.8rem;
    line-height: 2.6rem;
    font-weight: 600;
}


/* ------------------------------------------------------------------
    Menu
-------------------------------------------------------------------*/

.menu-nav{
    display: none;
}

/* ------------------------------------------------------------------
    Side Menu
-------------------------------------------------------------------*/

.side-nav{
    display: block;
    padding-top: 30px;
    width: 238px;
    margin-left: 82px;
}

.side-nav .nav-head{
    background: #F79799;
    padding: 8px;
    color: #FFF;
    text-align: center;
    font-size: 1.5rem;
    line-height: 2.2rem;
    font-weight: 700;
}

.side-nav .nav-lists{
    display: block;
    margin: 0 auto;
    border: 1px solid #FCD9DA;
}


.side-nav .nav-list a{
    display: block;
    width: 100%;
    border-bottom: 1px solid #FCD9DA;
    padding: 12px;
    background: #FFF url(../../img/front/arrow-r-s-pink.png) right 8px center no-repeat;
    background-size: 20px;
    border-radius: 0;
    color: #2B2B2B;
    font-size: 1.4rem;
    line-height: 2.2rem;
    transition: .3s;
}

.side-nav .nav-list:last-child a{
    border-bottom: none;
}

.side-nav .nav-list a:hover{
    background:  #FEF1F2 url(../../img/front/arrow-r-s-pink.png) right 2px center no-repeat;
    background-size: 20px;
    color: #9B0000;
}

.side-nav .nav-list.active a{
    background: #FFE6E7;
    color: #9B0000;
    font-weight: 600;
    cursor: default;
}

}