@charset "UTF-8";

html {
    margin-bottom: 1px !important;
    height: 100%;
}

body{
    color: #333;
    text-align: justify;
    text-justify: inter-ideograph;
    font-size: 12px;
    font-family: "メイリオ","Hiragino Kaku Gothic Pro","ヒラギノ角ゴ Pro W3",Osaka,"MS PGothic","ＭＳ Ｐゴシック",Verdana,Arial,sans-serif;
    line-height: 1.7;

}

.spn {
    display: none;
}
.pc {
    display: block;
}

.cnt_right { float: right;}
.cnt_left { float: left;}

.tar { text-align: right;}
.tal { text-align: left;}


table {
     border-collapse: collapse;
 }
table td {
     padding: 10px;
     border: 1px solid #b6b6b6;
 }
table td:first-child {
    background: #e0e0e0;
}

.audiojs {
    overflow: hidden;
    width: 62px;
    height: 27px;
    background: none;
    background-image: none;
    box-shadow: none;
}
.audiojs>div{
    border: none !important;
}
.audiojs .play-pause {
    width: 62px;
    height: 27px;
}
.audiojs .play {
    width: 62px;
    height: 27px;
    background: url(../images/top/img_music_00_new.png);
}
.audiojs .pause {
    width: 62px;
    height: 27px;
    background: url(../images/top/img_music_01_new.png);
}
.audiojs .loading,
.audiojs .error{
   background: none !important;
}
.audiojs .scrubber,
.audiojs .time {
    display: none;
}
.audiojs.loading .pause,
.audiojs.loading .play {
}
/*  header
----------------------------------------------- */

.header.spn {
    display: none;
}
.header {
    position: relative;
    margin: auto;
    padding-top: 13px;
    width: 960px;
    background: #fff;
}
.header h1 ,
.header ul ,
.header ul li {
    display: inline-block;
    *display: inline;
    *zoom: 1;
}
.header ul li {
    margin-left: 11px;
}
.header ul li:first-child {
}
.header ul li img {
    vertical-align: middle;
}
.header h1 img {
    vertical-align: middle;
}
.header ul.g_nav {
    height: 100px;
    line-height: 100px;
}
.header ul.g_submenu {
    position: absolute;
    top: 15px;
    right: 10px;
    font-size: 12px;
}
.header ul.g_submenu a {
    color: gray;
    text-decoration: none;
}
.header ul.g_submenu img{
    margin-right: 7px;
    vertical-align: middle;
}
.header ul.g_submenu li {
    margin-left: 10px;
}

/*  eyecatch
----------------------------------------------- */

.eyecatch {
    position: relative;
}
.eyecatch .stage {
    position: relative;
    margin: auto;
    width: 960px;
    height: 455px;
}
/* 背景 */
.eyecatch [class^=bg_anim]{
}
.eyecatch .bg_anim_01 {
    background: url(../images/top_eyecatch/bg_top_eyecatch_anim_01.png) repeat-x 0 360px;
}
.eyecatch .bg_anim_01_02 {
    background: url(../images/top_eyecatch/bg_top_eyecatch_anim_01_02.png) 0 306px no-repeat;
}
.eyecatch .bg_anim_02 {
    background: url(../images/top_eyecatch/bg_top_eyecatch_anim_02.png) repeat-x 0 443px;
}
.eyecatch .bg_anim_03 {
    background: url(../images/top_eyecatch/bg_top_eyecatch_anim_03.png) repeat-x 0 60px;
}


.eyecatch .stage .tokushimaru {
    position: absolute;
    bottom: 0px;
    left: 50%;
}
.eyecatch .stage .tokushimaru > img {
    animation: movecar 10s ease-in-out infinite alternate;
    margin-left: -230px;
}
.eyecatch .stage .main_comment {
    position: absolute;
    bottom: 275px;
    left: 50%;
}
.eyecatch .stage .main_comment img {
    margin-left: -170px;
}

/* 音楽 */
.eyecatch .stage .btn_music {
    position: absolute;
    top: 20px;
    right: 23px;
    cursor: pointer;
}

/* 吹き出し */
.eyecatch .stage [class^=hukidashi] p {
    position: absolute;
    z-index: 1;

}

/* hukidashi01 */
.eyecatch .stage .hukidashi01 {
    animation: movehukidashi 10s ease-in-out infinite alternate;
    position: absolute;
    top: 95px;
    right: -30px;
    opacity :0;
}
.eyecatch .stage .hukidashi01 img.bg {
    position: absolute;
    top: 0;
    left: 0;
}
.eyecatch .stage .hukidashi01 p {
    top: 0;
    left: 0;
    width: 126px;
    height: 120px;
    color: #fff;
    text-align: center;
    font-weight: bold;
    font-size: 16px;
    line-height: 120px;
}

/* hukidashi02 */
.eyecatch .stage .hukidashi02 {
    animation: movehukidashi 12s ease-in-out infinite alternate;
    position: absolute;
    top: 5px;
    right: -185px;
    opacity :0;
}
/* hukidashi03 */

.eyecatch .stage .hukidashi03 {
    animation: movehukidashi 15s ease-in-out infinite alternate;
    position: absolute;
    top: -105px;
    right: -245px;
    opacity :0;
}
.eyecatch .stage .hukidashi03 .download{
    position: absolute;
    bottom: 30px;
    color: white;
    line-height: 1.2;
    font-size: 10px;
    text-align: center;
    right: 17px;
    border: 1px solid white;
    border-radius: 2px;
}
.eyecatch .stage .hukidashi03 .download a{
    display: block;
    text-decoration: none;
    padding: 2px;
    color: white;
    transition: 0.1s;
}
.eyecatch .stage .hukidashi03 .download a:hover {
    background: #ffc200;
    transition: 0.1s;
}

.pr-box {
    font-size: .6rem;
    color: #fff;
    line-height: 1.2;
    border-radius: 4px;
    overflow: hidden;
}

.pr-box.spn {
    margin-top: 50px;
    text-align: center;
    font-size: .7rem;
    padding-bottom: 1em;
}

.pr-box.pc {
    width: 280px;
    position: absolute;
    left: 10px;
    top: 20px;
    z-index: 500;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.46);
}

.pr-box.pc.close {
    display: none;
}

.pr-box img {
    max-width: 100%;
    height: auto;
}

#pr-box-close {
    display: block;
    width: 24px;
    height: 24px;
    position: absolute;
    z-index: 999;
    top: 0;
    right: 0;
}

/* ----  btnCloud ---- */
.btnCloud {
  position: absolute;
  top: -80px;
  left: -460px;
  font-size: 15px;
  opacity: 0.2;
}

.btnCloud2 {
    position: absolute;
    top: 40px;
    left: -560px;
    font-size: 14px;
    opacity: 0.2;
}

.btnCloud.show,
.btnCloud2.show {
  left: -360px;
  opacity: 1;
  transition: left 50s , opacity 3s;
}

.btnCloud2.show {
    left: -420px;
}



.btnCloud a,
.btnCloud2 a {
  color: #e34600;
  font-weight: bold;
}
.btnCloud a p,
.btnCloud2 a p {
  position: absolute;
  width: 180px;
  text-align: center;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%,-50%);
  transform: translate(-50%,-50%);
}
.btnCloud a p .btn,
.btnCloud2 a p .btn {
  display: inline-block;
  font-size: 10px;
  padding: 0 4px;
  border: 1px solid #e34600;
  transition: 0.1s;
  border-radius: 2px;
}
.btnCloud a p .btn:hover,
.btnCloud2 a p .btn:hover {
  background: #e34600;
  color: white;
  transition: 0.1s;
}

/*  sub eyecatch
----------------------------------------------- */
.eyecatch.sub .bg_anim_01 {
    background-position: 0 120px;
}
.eyecatch.sub .bg_anim_02 {
    background-position: 0 68px;
}
.eyecatch.sub .bg_anim_03 {
    background-position: 0 120px;
}
.eyecatch.sub .stage {
    height: 80px;
}
.eyecatch.sub .stage .tokushimaru {
    left: 100%;
}
.eyecatch.sub .stage .tokushimaru img{
    width: 100px;
}


/*  content
----------------------------------------------- */

.content {
    background: #e34600;
}
.content.top .l_nav {
    margin : auto;
    padding-top: 40px;
    width: 720px;
}
.content.top .l_nav ul {
}
.content.top .l_nav ul li {
    position: relative;
    float: left;
    margin-bottom: 10px;
    margin-left: 10px;
    padding: 30px 30px 35px;
    width: 170px;
    height: 170px;
    background: url(../images/top/bg_top_menu.png) no-repeat;
}
.content.top .l_nav ul li h2 {
    margin-left: -10px;
    width: 200px;
    color: #e34600;
    font-size: 14px;
    line-height: 36px;
}
.content.top .l_nav ul li p {
    margin-top: 20px;
}
.content.top .l_nav ul li a {
    position: absolute;
    right: 30px;
    bottom : 35px;
}
.content.top .l_nav ul li h2 span {
    display: inline-block;
    width: 30px;
    *display:inline;
    *zoom: 1;
}
.content.top .l_nav ul li h2 span img {
    vertical-align: middle;
}
.content.top .l_nav ul li h2 img.icon01 { }
.content.top .l_nav ul li h2 img.icon02 { margin: 0 0 3px 0px; width: 23px;}
.content.top .l_nav ul li h2 img.icon03 { margin-left: 3px; }
.content.top .l_nav ul li h2 img.icon04 { }
.content.top .l_nav ul li h2 img.icon05 { margin-top: -2px; }
.content.top .l_nav ul li h2 img.icon06 { margin-top: -5px; }
.content.top .l_nav ul li h2 img.icon07 { margin-left: -3px; width: 28px; height: auto;}
.content.top .l_nav ul li h2 img.icon08 { margin-left: 2px; width: 16px;}
.content.top .l_nav ul li h2 img.icon09 { margin-top: -7px; margin-left: -9px; width: 32px; }

.content .wrap {
    margin: auto;
    padding-top: 40px;
    width: 960px;
}

.content.sub h1 {
    margin-left: 195px;
    height: 225px;
    font-size: 16px;
    line-height: 225px;
}
.content.sub .subcnt {
    padding-left: 50px;
    min-height: 1px;
    width: 145px;
    text-align: left;
}
.content.sub .subcnt li {
    text-decoration: underline;
}
.content.sub .subcnt li:hover {
    color: #F9BE00;
}
.content.sub .main {
    width: 670px;
}
.content.sub .main .text_box {
    float: left;
    margin: 30px 0;
    width: 370px;
    font-weight: bold;
    font-size: 12px;
    line-height: 2;
}
.content.sub .main .img_box {
    position: absolute;
    position: relative;
    float: left;
    margin: 40px 0;
    margin-left: 70px;
    width: 230px;
}
.content.sub .main .img_box .img_box_wrap {
    position: absolute;
}
.content.sub .main .img_box img {
    position: static;
    margin-top: 40px;
}
.content.sub .main .img_box img {
    position: absolute;
    position: static;
    top: 0;
    left: 0;
    margin-top: 40px;
    max-width: 230px;
    height: auto;
}
.content.sub .main .img_box img:first-child {
    margin-top: -3px;
}
.content.sub .main h2 {
    color: #c7470d;
    font-size: 16px;
    line-height: 1.5;
}
.content.sub h2.sub_ttl {
    color: #333;
    font-size: 14px;
}

.content.sub h1 img {
    vertical-align: middle;
}

.bg_note {
    background: #fff;
}
.bg_note_wrap {
}
.bg_note_wrap img.note_top {
    vertical-align: top;
}
.bg_note_wrap img.note_foot {
    margin-top: 110px;
}


/*  footer
----------------------------------------------- */
.footer {
    background: #e34600;
    font-size: 10px;
}
.footer .wrap {
    margin: auto;
    padding: 10px 0 20px;
    width: 950px;
    color: #fff;
}
.footer.top .wrap {
    width: 710px;
}
.footer .js-totop {
    cursor: pointer;
}

/*  copy
----------------------------------------------- */

.copy {
    display: flex;
    position: relative;
    padding: 4px 0;
    background: #e34600;
    color: #fff;
    text-align: center;
    font-weight: bold;
}
.copy .totop {
    position: absolute;
    top: -25px;
    left: 50%;
}
.copy .totop:hover {
    top: -28px;
}
.copy .totop a {
    position: absolute;
    left: 320px;
}
/*  privacy
----------------------------------------------- */
.privacy a {
    color: white;
    margin-right: 15px;
    font-size: 12px;
}

/*  animation
----------------------------------------------- */
@keyframes movecar {
    0% {
        transform:translate(10px,0px);
    }
    50%{
        transform:translate(-10px,0px);
    }
  100% {
      transform:translate(10px,0px);
  }
}
@keyframes movehukidashi {
    0% {
        transform:translate(0px,2px);
    }
    50%{
        transform:translate(0px,-2px);
    }
  100% {
      transform:translate(0px,2px);
  }
}
