@charset "utf-8";

/* ===================================================================
CSS information
 file name : header.css
 style info : ヘッダー部分で使用するCSS
=================================================================== */
header {
    position: relative;
    z-index: 20;
    background: white;
}
header.passive {
    z-index: 5;
}
header #headerlogo {
    position: relative;
    height: 46px;
    border-bottom: solid 1px #e8e8e8;
    z-index: 50;
}
header #headerlogo.passive {
    border-bottom: none;
}
header h1 {
    display: inline-block;
    position: absolute;
    top: 8px;
    left: 0;
    right: 0;
    width: 118px;
    height: 30px;
    margin: auto;
    background: url(/images/n/nbo/2016/sp/common/logo_nbo.png) no-repeat;
    background-size: 118px 30px;
    text-indent:100%;
    overflow:hidden;
    white-space:nowrap;
}
header #menuBtn {
    position: absolute;
    top: 0;
    left: 0;
    width: 44px;
    height: 46px;
    background: url(/images/n/nbo/2016/sp/common/icon_menu_open.png) no-repeat;
    background-size: 44px 46px;
    text-indent:100%;
    overflow:hidden;
    white-space:nowrap;
}
header #menuBtn.active {
    background: url(/images/n/nbo/2016/sp/common/icon_menu_close.png) no-repeat;
    background-size: 44px 46px;
}
header #searchBtn {
    position: absolute;
    top: 0;
    right: 0;
    width: 44px;
    height: 46px;
    background: url(/images/n/nbo/2016/sp/common/icon_seach_open.png) no-repeat;
    background-size: 44px 46px;
    text-indent:100%;
    overflow:hidden;
    white-space:nowrap;
}
header #searchBtn.active {
    background: url(/images/n/nbo/2016/sp/common/icon_seach_close.png) no-repeat;
    background-size: 44px 46px;
}
header #searchBtn.passive {
    display: none;
}
/* 検索窓 */
header #searchBox {
    display: none;
    position: absolute;
    top: 46px;
    right: 0;
    margin-bottom: 20px;
    padding: 16px 16px 25px;
    background: #f3f3f3;
    z-index: 30;
}
header #searchBox form {
    position: relative;
}
header #searchBox input {
    margin:0;
    padding:0;
    background: none;
    font-size: 1.5rem;
    -webkit-appearance: none;
}
header #searchBox .field {
    width: 99%;
    height: 36px;
    background: #fff;
    border: 1px solid #c0c0c0;
    border-right: none;
    border-radius: 3px 0 0 3px;
    color: #aaa;
    text-indent: 15px;
}
header #searchBox .btn {
    position: absolute;
    top: 0;
    right: 0;
    width: 36px;
    height: 36px;
    background: #000 url(/images/n/nbo/2016/sp/common/btn_search.png) no-repeat;
    background-size: 36px 36px;
    border: none;
    border-radius: 0 3px 3px 0;
    text-indent: 100%;
    overflow: hidden;
    white-space: nowrap;
    -webkit-appearance: none;
}
/* キーワード */
header #keyword {
    margin-top: 17px;
    padding: 18px 16px 16px;
    background: #fff;
    border-radius: 4px;
}
header #keyword p {
    font-size: 1.2rem;
    font-weight: bold;
    text-align: center;
}
header #keyword ul {
    display: table;
    margin-left: -16px;
    text-align: left;
}
header #keyword ul li {
    display: inline-block;
    margin: 16px 0 0 16px;
    font-size: 1.4rem;
    background: #f3f3f3;
    border-radius: 4px;
}
header #keyword ul li a {
    padding: 5px 11px;
    color: #444;
}
/* メニュー */
header #headerMenu {
    display: none;
    position: absolute;
    top: 46px;
    left: 0;
    background: #fff;
    z-index: 40;
}
header #headerMenu .btnRegister {
    padding-top: 16px;
    font-size: 1.4rem;
    text-align: center;
}
header #headerMenu .btnRegister a {
    display: inline-block;
    width: 83%;
    background: #e50020;
    border-radius: 3px;
    box-shadow: 1px 2px 1px rgba(0,0,0,0.1);
    line-height: 40px;
    color: #fff;
}
header #headerMenu .detailRegister {
    padding: 30px 0;
    font-size: 1.2rem;
    text-align: center;
}
header #headerMenu .detailRegister b {
    color: #e50020;
    font-weight: normal;
}
header #headerMenu .detailRegister a{
    display: inline-block;
    text-decoration: underline;
}
header #headerMenu .menuRegister li {
    border-bottom: solid 1px #e8e8e8;
    font-size: 1.2rem;
    font-weight: bold;
}
header #headerMenu .menuRegister li:first-child {
    border-top: solid 1px #e8e8e8;
}
header #headerMenu .menuRegister li span {
    font-weight: normal;
}
header #headerMenu .menuRegister li a {
    padding: 16px;
}
header #headerMenu .inner {
    background: #f7f7f7;
    border-top: solid 1px #e8e8e8;
}
header #headerMenu .menuGenre ul {
    display: table;
}
header #headerMenu .menuGenre  ul li {
    display: inline-block;
    width: 50%;
    border-bottom: solid 1px #e8e8e8;
    font-size: 1.2rem;
    font-weight: bold;
}
header #headerMenu .menuGenre  ul li.top {
    width: 100%;
}
header #headerMenu .menuGenre  ul li:nth-child(even) {
    border-right: solid 1px #e8e8e8;
}
header #headerMenu .menuGenre  ul li a {
    padding: 12px;
    color: #444;
}
header #headerMenu .menuGenre  ul li a span {
    display: inline-block;
    width: 100%;
    background: #e50020;
    border-radius: 2px;
    color: #fff;
    text-align: center;
}
header #headerMenu .newPublication {
    padding: 18px 16px;
    overflow: hidden;
}
header #headerMenu .newPublication .cover {
    float: left;
    width: 45%;
    margin-right: 5%;
    text-align: center;
}
header #headerMenu .newPublication .cover img {
    width: 100%;
    max-width: 154px;
    height: auto;
}
header #headerMenu .newPublication .detail {
    float: right;
    width: 50%;
    color: #444;
}
header #headerMenu .newPublication .detail a {
    color: #444;
}
header #headerMenu .newPublication .detail p {
    font-size: 1.2rem;
}
header #headerMenu .newPublication .detail .title {
    margin-bottom: 16px;
    font-size: 1.5rem;
    font-weight: bold;
    line-height: 1.3;
}
header #headerMenu .newPublication .detail .title span {
    display: block;
    font-size: 1.2rem;
}
header #headerMenu .newPublication .detail .appybtn {
    margin-top: 5px;
    padding: 8px 0;
    border: solid 1px #9f9f9f;
    border-radius: 4px;
    font-size: 1.2rem;
    font-weight: bold;
    text-align: center;
}
header #headerMenu .newPublication .detail .appybtn a {
    display: inline-block;
    color: #444;
    text-decoration: underline;
}
header #headerMenu .newPublication .detail .appybtn span {
    display: block;
    margin-bottom: 3px;
    font-size: 1.0rem;
    font-weight: normal;
    line-height: 1.2;
    text-decoration: none;
}
header #headerMenu .newPublicationList ul {
    display: table;
    width: 100%;
}
header #headerMenu .newPublicationList ul li {
    display: inline-block;
    width: 50%;
    border-top: solid 1px #e8e8e8;
    border-bottom: solid 1px #e8e8e8;
    font-size: 1.2rem;
    font-weight: bold;
}
header #headerMenu .newPublicationList ul li:first-child {
    border-right: solid 1px #e8e8e8;
}
header #headerMenu .newPublicationList ul li a {
    padding: 12px 15px 12px 16px;
    background: url(/images/n/nbo/2016/sp/common/bg_arrow_bk.png) no-repeat 90% 50%;
    background-size: 4px 8px;
    color: #444;
}
header #headerMenu .social {
    padding: 30px 0;
    border-bottom: solid 1px #e8e8e8;
    text-align: center;
}
header #headerMenu .social p {
    font-size: 1.2rem;
    margin-bottom: 12px;
    color: #444;
}
header #headerMenu .social ul {
    display: table;
    margin: 0 auto;
}
header #headerMenu .social ul li {
    display: inline-block;
    margin-left: 32px;
}
header #headerMenu .social ul li:first-child {
    margin-left: 0;
}
header #headerMenu .social ul li a {
    width: 32px;
    height: 32px;
    text-indent:100%;
    overflow:hidden;
    white-space:nowrap;
}
header #headerMenu .social ul li.fb a {
    background: url(/images/n/nbo/2016/sp/common/icon_fb_gr.png) no-repeat;
    background-size: 32px 32px;
}
header #headerMenu .social ul li.tw a {
    background: url(/images/n/nbo/2016/sp/common/icon_tw_gr.png) no-repeat;
    background-size: 32px 32px;
}
header #headerMenu .social ul li.insta a {
    background: url(/images/n/nbo/2016/sp/common/icon_insta_gr.png) no-repeat;
    background-size: 32px 32px;
}
header #headerMenu .logout {
    border-bottom: solid 1px #e8e8e8;
    font-size: 1.2rem;
    text-align: center;
}
header #headerMenu .logout a {
    padding: 16px 0;
}