@charset "UTF-8";
@import url(https://fonts.googleapis.com/earlyaccess/notosansjapanese.css);
@import url(https://code.ionicframework.com/ionicons/2.0.1/css/ionicons.min.css);
body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,textarea,p,blockquote,th,td,header,main,nav,footer{ 
    margin:0;
    padding:0;
    font-family: 'Scheherazade','Noto Sans Japanese';
}
table {
    border-collapse:collapse;
    border-spacing:0;
}
img { 
    border:0;
    vertical-align:bottom;
}
ol,ul {
    list-style:none;
}
caption,th {
    text-align:left;
}
h1,h2,h3,h4,h5,h6 {
    font-size:100%;
    font-weight:normal;
}
area{
    outline:none;
}
input{
    border-style:none;
}
/* utility */
.floatL{
    float:left; 
}
.floatR{
    float:right;    
}
.clearBoth{
    clear:both; 
}
.clearfix:after{
  content:"."; 
  display:block; 
  height:0; 
  clear:both; 
  visibility:hidden;
}
.clearfix {display: inline-block;}
/* Hides from IE-mac \*/
* html .clearfix{ height:1%; }
.clearfix{ display:block; }
/* End hide from IE-mac */
.hover:hover{
    opacity:0.5;
    filter:alpha(opacity=50);
    -ms-filter: "alpha(opacity=30)";
    -webkit-transition-duration: 0.5s;
    -moz-transition-duration: 0.5s;
    -o-transition-duration: 0.5s;
    transition-duration: 0.5s;
}
.mb{
    margin-bottom:80px !important;
}
.mbHalf{
    margin-bottom:40px !important;
}
.mbQuot{
    margin-bottom:20px !important;
}
.mbShort{
    margin-bottom:10px !important;
}
.mbNone{
    margin-bottom:0 !important;
}
.anti{
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
.transtion{
    -webkit-transition-duration: 0.5s;
    -moz-transition-duration: 0.5s;
    -o-transition-duration: 0.5s;
    transition-duration: 0.5s;
}
a{
    color:#000;
    text-decoration:none;
}
a.mag:hover{
    opacity:0.5;
}
.btn{
    padding: 10px 0;
    display: block;
    border: 1px solid #000;
    text-align: center;
}
sup{
    font-size:60%;
}
small{
    font-size:72.5%;
}
.pa_5{
    padding: 5%;
}
/* header */
#header.active{
    background:none;
}
#logo{
    margin: 4% auto 0;
    text-align: center;
    overflow: hidden;
}
#logo a{
    display:block;
}
#closeOverlay{
    width:100%;
    height:120%;
    position: fixed;
    top:0;
    background:#ffffff;
    z-index:3332;
    display:none;
}
#nav{
    width:100%;
    position:absolute;
    display:none;
}
#nav.active{
    display:block;
}
#nav ul{
    margin:0 auto;
}

#btnMenu{
    display: block !important;
    width: 20px;
    height: 18px;
    padding:20px 15px;
    color: #fff;
    font-size: 1.5em;
    cursor: pointer;
    position: absolute;
    top:-4px;
    left:0;
    z-index: 6666;
    -moz-transition: all 0.4s cubic-bezier(0.230, 1.000, 0.320, 1.000);
    -o-transition: all 0.4s cubic-bezier(0.230, 1.000, 0.320, 1.000);
    -webkit-transition: all 0.4s cubic-bezier(0.230, 1.000, 0.320, 1.000);
    transition: all 0.4s cubic-bezier(0.230, 1.000, 0.320, 1.000);
    -moz-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
}
.bars.active{
  background: transparent;
}
.bars.active:before, .bars.active:after {
    top: 0;
    width: 100%;
    user-select: none;
}
.bars.active:before {
    -moz-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
}
.bars.active:after {
   -moz-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);

}
.bars {
    width: 100%;
    height: 1px;
    margin-top: .3em;
    background: #000;
    position: relative;
    display: block;
    -moz-transition: all 0.2s ease;
    -o-transition: all 0.2s ease;
    -webkit-transition: all 0.2s ease;
    transition: all 0.2s ease;
}
.bars:before {
    top: -7px;
}
.bars:after {
  top: 7px;
}
.bars:before, .bars:after {
    width: 100%;
    height: 1px;
    background: #000;
    position: absolute;
    left: 0;
    content: '';
    -moz-transform: rotate(0);
    -ms-transform: rotate(0);
    -webkit-transform: rotate(0);
    transform: rotate(0);
    -moz-transition: all 0.2s ease;
    -o-transition: all 0.2s ease;
    -webkit-transition: all 0.2s ease;
    transition: all 0.2s ease;
}
/*
#loading{
    width:100%;
    height:100%;
    position:absolute;
    top:0;
    background:#fff;
    z-index:9999;
}

#loadingLogo{
    width:160px;
    height:160px;
    position:absolute;
    top:50%;
    left:50%;
    margin:-80px 0 0 -80px;
}
*/
.btnClose{
    padding-top:5px;
    font-size:75%;
}
.overlay{
    position:absolute;
    top:0;
    left:0;
    display:none;
    padding:30px;
    color:#fff;
    background: #666;
    opacity:0.9;
}
.overlay li p{
    background: #666;
}
.overlay li .floatL{
    font-size:80%;
    margin-top:5px;
    padding-right:5px;
}
.overlay li .floatR{
    font-size:120%;
    padding-left:5px;
}
/* items */
#items{
    padding-top:40px;
    width: 1100px;
    margin: 120px auto 50px;
    position: relative;
}

#items::before{
    position: absolute;
    left: 50%;
    bottom: 0;
    display: block;
    content: "";
    width: 1px;
    height: 100px;
    background-color: #000000;
    opacity: 0.5;
    top: 0;
}

#items .title{
    text-align: center;
    font-size: 3rem;
    letter-spacing: 3px;
    margin: 10% 0 3% 0;
    padding: 5% 0 0 0;
}



#itemList li img{
    -moz-transition: -moz-transform 1.5s linear;
    -webkit-transition: -webkit-transform 1.5s linear;
    -o-transition: -o-transform 1.5s linear;
    -ms-transition: -ms-transform 1.5s linear;
    transition: transform 1.5s linear;
}

#itemList li img.active{
    -webkit-transform: scale(1.05);
    -moz-transform: scale(1.05);
    -o-transform: scale(1.05);
    -ms-transform: scale(1.05);
    transform: scale(1.1);
}

.itemTitle h2{
    text-align:center;
    color:#fff;
    opacity:0;
    -webkit-transition-duration: 0.3s;
    -moz-transition-duration: 0.3s;
    -o-transition-duration: 0.3s;
    transition-duration: 0.3s;
}

.itemTitle h2.active{
    opacity:1;
    -webkit-transition-duration: 0.3s;
    -moz-transition-duration: 0.3s;
    -o-transition-duration: 0.3s;
    transition-duration: 0.3s;
}
#footer{
  text-align: center;
}
#footerLogo{
  width: 80px;
}
@media only print, only screen and (min-width: 18.75em){   
.tab,
.pc,
.pc_tab{
    display:none;
}
.sp,
.tab_sp{
    display:block;
}
#nav li{
    text-align: center;
    letter-spacing: 0.05em;
    margin: 5% 0;
}
.title{
    text-align: left;
    font-size: 2.8rem;
    letter-spacing: 2px;
    margin: 8% 0 5%;
    line-height: 0.9;
}
#header{
    width:100%;
    height:130px;
    padding-top:60px;
    position:absolute;
    top:0;
    z-index:3333;
    border-top: 10px solid #00263b;
}
#main{
    margin-top:140px;
    padding:0 20px;
}
#logo{
    line-height: 4.5;
}
#nav{
    top:50px;
}
#navL{
    margin: 2% 0;
}
#navL p{
    font-size: 1.8rem;
    line-height: 1;
}
#navL span{
    display: block;
    font-size: 0.7rem;
    margin: 0 0 3% 0;
    font-family: 'Roboto','Noto Sans Japanese';
    letter-spacing: 0.5px;
} 
#main{
    margin-top:20px;
}
#btnMenu{
    display: block !important;
    width: 30px;
    height: 18px;
    top: 10px;
    left: 0;
}
.subTitle{
    text-align: left;
    font-size: 0.8rem;
    line-height: 1.8;
    margin-bottom: 50px;
}
#itemLogo{
    position:absolute;
    top:40px;
    left:40px;
}
#mainVisual{
    width:100%;
    text-align: center;
    margin: 0 auto 40px;
}
.overlay .line{
    margin-bottom:15px !important;
    background:#fff !important;
}
.overlay{
    width:250px;
    height:350px;
    padding:40px 34px;
}
.overlay .detail{
    font-size:81.25%;
    line-height:2;
}
/* items */
#items{
    padding: 40px 0 10px;
    width: 100%;
    margin: 50px auto 50px;
    position: relative;
}
#items::before{
    position: absolute;
    left: 50%;
    bottom: 0;
    display: block;
    content: "";
    width: 1px;
    height: 50px;
    background-color: #000000;
    opacity: 0.5;
    top: 0;
}
#items .title{
    text-align: center;
    font-size: 2.5rem;
    letter-spacing: 2px;
    margin: 3% 0;
    padding: 5% 0 0 0;
}
#itemList li{
    text-align: center;
    float:left;
    margin:0;
    position:relative;
    overflow:hidden;
    -moz-transition: -moz-transform 1s linear;
    -webkit-transition: -webkit-transform 1s linear;
    -o-transition: -o-transform 1s linear;
    -ms-transition: -ms-transform 1s linear;
    transition: transform 1s linear;
}
.itemTitle h2{
    text-align:center;
    color:#fff;
    opacity:0;
    -webkit-transition-duration: 0.3s;
    -moz-transition-duration: 0.3s;
    -o-transition-duration: 0.3s;
    transition-duration: 0.3s;
}
.itemTitle h2.active{
    opacity:1;
    -webkit-transition-duration: 0.3s;
    -moz-transition-duration: 0.3s;
    -o-transition-duration: 0.3s;
    transition-duration: 0.3s;
}
/* items */
#itemList{
    margin:0 auto;
    padding: 5% 10% 10%;
}
#itemList ul li{
    text-align: center;
}
.itemTitle h2{
    padding-top:115px;
    font-size:150%;
}
#itemList h3.model_ttl {
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: normal;
    font-size: 2rem;
    font-style: normal;
    text-align: left;
    line-height: 1.5;
    margin: 2% 0 0 0;
}
#itemList p.model_cap {
    font-weight: normal;
    font-size: 0.8rem;
    text-align: left;
    line-height: 1.8;
    margin: 0 0 15% 0;
}
figure.model_ h3 span{
    font-size: 3.0rem;
}
/* btns */
#btns{
    width: 80%;
    margin: 10% auto;
}
#btns a.btn{
    margin: 0;
    font-size: 1.8rem;
    transition: all .3s;
    max-width: 100%;
    color: #fff;
    line-height: 1;
    background-color: #000000;
    padding: 4% 0;
    font-style: italic;
}
li#btn{
    float: none;
    margin: 9% 3% 0 0;
    width: 100%;
}
#btn span{
    display: block;
    font-size: 50%;
    line-height: 1;
    letter-spacing: 0.1em;
    font-size: 0.5rem;
}
/* SHIPS Mag */
#shipsmag{
    padding: 40px 0 10px;
    width: 100%;
    margin: 50px auto 50px;
    position: relative;
}
#shipsmag::before{
    position: absolute;
    left: 50%;
    bottom: 0;
    display: block;
    content: "";
    width: 1px;
    height: 50px;
    background-color: #000000;
    opacity: 0.5;
    top: 0;
}
#shipsmag .title{
    text-align: center;
    font-size: 2.5rem;
    letter-spacing: 2px;
    margin: 3% 0;
    padding: 5% 0 0 0;
}
#mag{
    width: 47%;
    margin: 0 1% 5% 2%;
    display: inline-block;
    letter-spacing: 0.1em;
    font-family: 'Roboto','Noto Sans Japanese';
}
#mag:nth-child(2n){
    margin: 0;
}
#mag img{
    width: 100%;
}
.mag span.cap_mag{
    font-size: 0.7rem;
    line-height: 1.5;
    display: block;
    margin: 5% 0 0 0;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}
.mag span.season{
    font-size: 0.2rem;
    display: block;
    margin: 5% 0 0 0;
    color: #666666;
    font-weight: bold;
}
/* Footer */
.l-footer{
    position: relative;
    z-index: 100;
    margin: 5% 0 0 0;
}
.l-footer__header{
    padding:30px;
    border-bottom: 1px solid #ebebeb;
    margin: 0 0 30px 0;
}
.l-footer-banner{
    text-align:center;
    padding:0;
}
.l-footer-banner__item{
    display:inline-block;
    letter-spacing:normal;
    max-width:320px;
    padding:0 10px;
}
.l-footer-banner__item i.fab{
    font-size: 22px;
    color: #000000;
}
.l-footer-sns{
    text-align:center;
}
.l-footer-sns__item{
    display:inline-block;
    margin:0 10px;
}
.l-footer-sns__item a{
    display:block;
    color:#003659;
    font-size:17px;
    -webkit-transition:.3s;
    -o-transition:.3s;
    transition:.3s;
}
.l-footer-sns__item a:hover{
    opacity:0.5;
}
.l-footer-sns__item span{
    vertical-align:bottom;
}
.l-footer__body{
    padding:20px 30px;
    position:relative;
    background-color:#FFF;
    text-align:center;
}
.l-footer__logo{
    width:80px;
    height:24px;
    margin:0 auto 25px;
}
.l-footer__logo img{
    width:100%;
    height:auto;
}
.l-footer-copyright{
    font-size:11px;
    font-family: 'Roboto','Noto Sans Japanese';
    font-weight:normal;
    letter-spacing:0.1em;
    color:#000;
}
.l-content__footer{padding:0 0 40px;position:relative;background-color:#FFF}

/* Navi Footer */
.navi-sns{
    position: relative;
    z-index: 100;
}
.navi-sns_header{
    margin: 50px 0;
}
.navi-sns{
    text-align:center;
    padding:0;
}
.navi-sns__item{
    display:inline-block;
    letter-spacing:normal;
    max-width:320px;
    padding:0 10px;
}
.navi-sns__item i.fab{
    font-size: 1.5rem;
    color: #000000;
    font-weight: normal;
}
.navi-sns__item{
    text-align:center;
}
.navi-sns__item{
    display:inline-block;
    margin:0 10px;
}
.navi-sns__item a:hover{
    opacity:0.5;
}
.navi-sns__item span{
    vertical-align:bottom;
}

}

@media only print, only screen and (min-width: 768px){
.sp,
.tab,
.tab_sp{
    display:none;
}
.pc,
.pc_tab{
    display:block;
}
.title{
    text-align: left;
    font-size: 4.5rem;
    letter-spacing: 5px;
    margin: 8% 0 2% 0;
}
#nav li{
    text-align: center;
    letter-spacing: 0.05em;
    margin: 2% 0;
}
#header{
    width:100%;
    height:130px;
    padding-top:60px;
    position:absolute;
    top:0;
    z-index:3333;
    border-top: 20px solid #00263b;
}
#main{
    margin-top:140px;
    padding:0 20px;
}
#logo{
    line-height: 3.5;
}
#nav{
    top:120px;
}
#navL{
    margin: 2% 0;
}
#navL p{
    font-size: 2.7rem;
    line-height: 1;
}
#navL span{
    display: block;
    font-size: 0.7rem;
    margin: 0 0 0.5% 0;
    font-family: 'Roboto','Noto Sans Japanese';
    letter-spacing: 0.5px;
} 
#main{
    margin-top:50px;
}
#btnMenu{
    display: block !important;
    width: 30px;
    height: 18px;
    top:30px;
    left:20px;
}
.subTitle{
    text-align: left;
    font-size: 0.8rem;
    line-height: 1.8;
    margin-bottom: 50px;
}
#itemLogo{
    position:absolute;
    top:40px;
    left:40px;
}
#mainVisual{
    width:80%;
    text-align: center;
    margin: 0 auto 40px;
}
.overlay .line{
    margin-bottom:15px !important;
    background:#fff !important;
}
.overlay{
    width:250px;
    height:350px;
    padding:40px 34px;
}
.overlay .detail{
    font-size:81.25%;
    line-height:2;
}
/* items */
#items{
    padding: 40px 0 10px;
    width: 80%;
    margin: 120px auto 50px;
    position: relative;
}

#items::before{
    position: absolute;
    left: 50%;
    bottom: 0;
    display: block;
    content: "";
    width: 1px;
    height: 100px;
    background-color: #000000;
    opacity: 0.5;
    top: 0;
}

#items .title{
    text-align: center;
    font-size: 4.5rem;
    letter-spacing: 3px;
    margin: 10% 0 3% 0;
    padding: 5% 0 0 0;
}

#itemList li{
    text-align: center;
    float:left;
    margin:0 3% 8% 0;
    position:relative;
    overflow:hidden;
    -moz-transition: -moz-transform 1s linear;
    -webkit-transition: -webkit-transform 1s linear;
    -o-transition: -o-transform 1s linear;
    -ms-transition: -ms-transform 1s linear;
    transition: transform 1s linear;
}
#itemList li:last-child{
    margin:0 0 8% 0;
    overflow:hidden;
    -moz-transition: -moz-transform 1s linear;
    -webkit-transition: -webkit-transform 1s linear;
    -o-transition: -o-transform 1s linear;
    -ms-transition: -ms-transform 1s linear;
    transition: transform 1s linear;
}

#itemList li img{
    -moz-transition: -moz-transform 1.5s linear;
    -webkit-transition: -webkit-transform 1.5s linear;
    -o-transition: -o-transform 1.5s linear;
    -ms-transition: -ms-transform 1.5s linear;
    transition: transform 1.5s linear;
}

#itemList li img.active{
    -webkit-transform: scale(1.05);
    -moz-transform: scale(1.05);
    -o-transform: scale(1.05);
    -ms-transform: scale(1.05);
    transform: scale(1.1);
}

.itemTitle h2{
    text-align:center;
    color:#fff;
    opacity:0;
    -webkit-transition-duration: 0.3s;
    -moz-transition-duration: 0.3s;
    -o-transition-duration: 0.3s;
    transition-duration: 0.3s;
}

.itemTitle h2.active{
    opacity:1;
    -webkit-transition-duration: 0.3s;
    -moz-transition-duration: 0.3s;
    -o-transition-duration: 0.3s;
    transition-duration: 0.3s;
}
/* items */
#itemList{
    margin:0 auto;
    padding: 0;
}
#itemList ul li{
    width:31%;
}
.itemTitle{
    width:256px;
    height:256px;
    margin:-128px 0 0 -128px;
    position:absolute;
    top:50%;
    left:50%;
}
.itemTitle h2{
    padding-top:115px;
    font-size:150%;
}

/* btns */
#btns{
    width: 100%;
    margin: 0 auto;
}
#btns a.btn{
    margin: 0;
    font-size: 2rem;
    transition: all .3s;
    max-width: 100%;
    color: #000000;
    background-color: #ffffff;
    padding: 5% 0;
    font-style: italic;
    transform: rotate(.03deg);
}
#btns a.btn:hover{
    color: #ffffff;
    background-color: #00263b;
}
li#btn{
    display: inline-block;
    margin: 3% 3% 0 0;
    width: 46.5%;
}
#btn span{
    display: block;
    font-size: 50%;
    line-height: 1;
    letter-spacing: 0.1em;
    font-size: 0.5rem;
}
/* SHIPS Mag */
#shipsmag{
    padding-top:40px;
    width:80%;
    margin: 120px auto 50px;
    position: relative;
}

#shipsmag::before{
    position: absolute;
    left: 50%;
    bottom: 0;
    display: block;
    content: "";
    width: 1px;
    height: 100px;
    background-color: #000000;
    opacity: 0.5;
    top: 0;
}
#shipsmag .title{
    text-align: center;
    font-size: 3.5rem;
    letter-spacing: 3px;
    margin: 10% 0 3% 0;
    padding: 5% 0 0 0;
}
#mag{
    width: 47%;
    margin: 0 2% 5% 0;
    display: inline-block;
    letter-spacing: 0.1em;
    font-family: 'Roboto','Noto Sans Japanese';
}
#mag:last-child{
    margin: 0;
}
#mag img{
    width: 100%;
}
.mag span.cap_mag{
    font-size: 0.7rem;
    line-height: 1.5;
    display: block;
    margin: 5% 0 0 0;
}
.mag span.season{
    font-size: 0.2rem;
    display: block;
    margin: 5% 0 0 0;
    color: #666666;
    font-weight: bold;
}
/* Footer */
.l-footer{
    position: relative;
    z-index: 100;
    margin: 5% 0 0 0;
}
.l-footer__header{
    padding:30px;
    border-bottom: 1px solid #ebebeb;
    margin: 0 0 30px 0;
}
.l-footer-banner{
    text-align:center;
    padding:0;
}
.l-footer-banner__item{
    display:inline-block;
    letter-spacing:normal;
    max-width:320px;
    padding:0 10px;
}
.l-footer-banner__item i.fab{
    font-size: 22px;
    color: #000000;
}
.l-footer-sns{
    text-align:center;
}
.l-footer-sns__item{
    display:inline-block;
    margin:0 10px;
}
.l-footer-sns__item a{
    display:block;
    color:#003659;
    font-size:17px;
    -webkit-transition:.3s;
    -o-transition:.3s;
    transition:.3s;
}
.l-footer-sns__item a:hover{
    opacity:0.5;
}
.l-footer-sns__item span{
    vertical-align:bottom;
}
.l-footer__body{
    padding:20px 30px;
    position:relative;
    background-color:#FFF;
    text-align:center;
}
.l-footer__logo{
    width:80px;
    height:24px;
    margin:0 auto 25px;
}
.l-footer__logo img{
    width:100%;
    height:auto;
}
.l-footer-copyright{
    font-size:11px;
    font-family: 'Roboto','Noto Sans Japanese';
    font-weight:normal;
    letter-spacing:0.1em;
    color:#000;
}
.l-content__footer{padding:0 0 40px;position:relative;background-color:#FFF}

/* Navi Footer */
.navi-sns{
    position: relative;
    z-index: 100;
}
.navi-sns_header{
    margin: 0 0 30px 0;
}
.navi-sns{
    text-align:center;
    padding:0;
}
.navi-sns__item{
    display:inline-block;
    letter-spacing:normal;
    max-width:320px;
    padding:0 10px;
}
.navi-sns__item i.fab{
    font-size: 1.5rem;
    color: #000000;
    font-weight: normal;
}
.navi-sns__item{
    text-align:center;
}
.navi-sns__item{
    display:inline-block;
    margin:0 10px;
}
.navi-sns__item a:hover{
    opacity:0.5;
}
.navi-sns__item span{
    vertical-align:bottom;
}
}

@media only print, only screen and (min-width: 1000px){
.sp,
.tab,
.tab_sp{
    display:none;
}
.pc,
.pc_tab{
    display:block;
}
.title{
    text-align: left;
    font-size: 6.0rem;
    letter-spacing: 3px;
    margin: 8% 0 0 0;
}
#nav ul{
    margin: 5% auto;
    width: 800px;
}
#nav li{
    text-align: left;
    letter-spacing: 0.05em;
    margin: 4% 0;
}
#header{
    width:100%;
    height:130px;
    padding-top:60px;
    position:absolute;
    top:0;
    z-index:3333;
    border-top: 20px solid #00263b;
}
#logo{
    line-height:1.5;
}
#nav{
    top:50px;
}
#navL{
    margin: 2% 0;
}
#navL p{
    font-size: 4.0rem;
    line-height: 0.8;
}
#navL span{
    display: block;
    font-size: 0.7rem;
    margin: 0 0 1.5% 0;
    font-family: 'Roboto','Noto Sans Japanese';
    letter-spacing: 0.5px;
} 
#main{
    margin-top:50px;
}
#btnMenu{
    display: block !important;
    width: 30px;
    height: 18px;
    top:30px;
    left:20px;
}
.subTitle{
    text-align: left;
    font-size: 0.8rem;
    line-height: 1.8;
    margin-bottom: 50px;
}
#itemLogo{
    position:absolute;
    top:40px;
    left:40px;
}
#mainVisual{
    width:900px;
    margin: 0 auto 40px;
    text-align: center;
}
.overlay .line{
    margin-bottom:15px !important;
    background:#fff !important;
}
.overlay{
    width:250px;
    height:350px;
    padding:40px 34px;
}
.overlay .detail{
    font-size:81.25%;
    line-height:2;
}
/* items */
#items{
    padding: 40px 0 0 0;
    width: 1000px;
    margin: 120px auto 50px;
    position: relative;
}
#items::before{
    position: absolute;
    left: 50%;
    bottom: 0;
    display: block;
    content: "";
    width: 1px;
    height: 100px;
    background-color: #000000;
    opacity: 0.5;
    top: 0;
}
#itemList{
    margin:0 auto;
    padding: 0;
}
#itemList ul li{
    width: 312px;
}
#itemList li{
    width: 32%;
    text-align: center;
    float:left;
    margin:0 3% 8% 0;
    position:relative;
    overflow:hidden;
    -moz-transition: -moz-transform 1s linear;
    -webkit-transition: -webkit-transform 1s linear;
    -o-transition: -o-transform 1s linear;
    -ms-transition: -ms-transform 1s linear;
    transition: transform 1s linear;
}
#itemList li:last-child{
    margin:0 0 8% 0;
    overflow:hidden;
    -moz-transition: -moz-transform 1s linear;
    -webkit-transition: -webkit-transform 1s linear;
    -o-transition: -o-transform 1s linear;
    -ms-transition: -ms-transform 1s linear;
    transition: transform 1s linear;
}
.itemTitle{
    width:256px;
    height:256px;
    margin:-128px 0 0 -128px;
    position:absolute;
    top:50%;
    left:50%;
}
.itemTitle h2{
    padding-top:115px;
    font-size:150%;
}
/* btns */
#btns{
    width:1000px;
    margin: 0;
}
#btns a.btn{
    width: 312px;
    margin: 0;
    font-size: 2.0rem;
    transition: all .3s;
    color: #000000;
    background-color: #ffffff;
    padding: 7% 0;
    line-height: 1.2;
    transform: rotate(.03deg);
    font-style: italic;
}
#btns a.btn:hover{
    color: #ffffff;
    background-color: #00263b;
}
#btns .btn{
    width:310px;
}
li#btn:nth-child(3n){
    margin: 3% 0 0 0;
}
li#btn{
    margin: 3% 3% 0 0;
    width: 31%;
    display: inline-block;
    text-align: center;
}
#btn span{
    display: block;
    font-size: 50%;
    line-height: 1;
    letter-spacing: 0.1em;
    font-size: 0.5rem;
    font-style: normal;
}
/* SHIPS Mag */
#shipsmag{
    padding-top:40px;
    width: 1000px;
    margin: 120px auto 50px;
    position: relative;
}

#shipsmag::before{
    position: absolute;
    left: 50%;
    bottom: 0;
    display: block;
    content: "";
    width: 1px;
    height: 100px;
    background-color: #000000;
    opacity: 0.5;
    top: 0;
}
#shipsmag .title{
    text-align: center;
    font-size: 4.5rem;
    letter-spacing: 3px;
    margin: 10% 0 3% 0;
    padding: 5% 0 0 0;
}
#mag,#mag:nth-child(2n){
    width: 23%;
    margin: 0 2% 0 0;
    display: inline-block;
    letter-spacing: 0.1em;
    font-family: 'Roboto','Noto Sans Japanese';
}
#mag:last-child{
    margin: 0;
}
#mag img{
    width: 100%;
}
.mag span.cap_mag{
    font-size: 0.7rem;
    line-height: 1.5;
    display: block;
    margin: 5% 0 0 0;
}
.mag span.season{
    font-size: 0.2rem;
    display: block;
    margin: 5% 0 0 0;
    color: #666666;
    font-weight: bold;
}
/* Footer */
.l-footer{
    position: relative;
    z-index: 100;
    margin: 5% 0 0 0;
}
.l-footer__header{
    padding:30px;
    border-bottom: 1px solid #ebebeb;
    margin: 0 0 30px 0;
}
.l-footer-banner{
    text-align:center;
    padding:0;
}
.l-footer-banner__item{
    display:inline-block;
    letter-spacing:normal;
    max-width:320px;
    padding:0 10px;
}
.l-footer-banner__item i.fab{
    font-size: 22px;
    color: #000000;
}
.l-footer-sns{
    text-align:center;
}
.l-footer-sns__item{
    display:inline-block;
    margin:0 10px;
}
.l-footer-sns__item a{
    display:block;
    color:#003659;
    font-size:17px;
    -webkit-transition:.3s;
    -o-transition:.3s;
    transition:.3s;
}
.l-footer-sns__item a:hover{
    opacity:0.5;
}
.l-footer-sns__item span{
    vertical-align:bottom;
}
.l-footer__body{
    padding:20px 30px;
    position:relative;
    background-color:#FFF;
    text-align:center;
}
.l-footer__logo{
    width:80px;
    height:24px;
    margin:0 auto 25px;
}
.l-footer__logo img{
    width:100%;
    height:auto;
}
.l-footer-copyright{
    font-size:11px;
    font-family: 'Roboto','Noto Sans Japanese';
    font-weight:normal;
    letter-spacing:0.1em;
    color:#000;
}
.l-content__footer{padding:0 0 40px;position:relative;background-color:#FFF}

/* Navi Footer */
.navi-sns{
    position: relative;
    z-index: 100;
}
.navi-sns_header{
    margin: 0 0 30px 0;
}
.navi-sns{
    text-align: left;
    padding: 1% 0;
    width: 800px;
    margin: 0 auto;
    border-top: 1px solid #c9cdcf;
}
.navi-sns__item{
    display:inline-block;
    letter-spacing:normal;
    max-width:320px;
    padding:0 10px;
}
.navi-sns__item i.fab{
    font-size: 1.5rem;
    color: #000000;
    font-weight: normal;
}
.navi-sns__item{
    text-align:center;
}
.navi-sns__item{
    display:inline-block;
    margin:0 10px;
}
.navi-sns__item a:hover{
    opacity:0.5;
}
.navi-sns__item span{
    vertical-align:bottom;
}
}