@charset "UTF-8";
/* -----------------------------------------------
  reset
----------------------------------------------- */
* {
  margin: 0;
  padding: 0;
}

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

body {
  font-size: 14px;
  line-height: 1.4;
  color: #7f7f7f;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  margin: 0;
  padding: 0;
  font-family: "Hiragino Kaku Gothic Pro","メイリオ", "Lucida Grande", Arial, sans-serif;
}

h1, h2, h3 {
  font-size: 100%;
}

h4, h5, h6 {
  font-size: 85%;
}

table, p, ul, ol, dl, marquee {
  font-size: 16px;
}

ul li, ol li {
  list-style-type: none;
}

table tr th, table tr td {
  line-height: 1.4;
  text-align: left;
  vertical-align: top;
}

hr {
  display: none;
}

em, strong {
  font-weight: bold;
}

img {
  border: 0;
}

a {
  color: #000000;
  outline: none;
  text-decoration: none;
}

sup {
  position: relative;
  top: .2em;
  font-size: 75%;
}

sub {
  font-size: 75%;
  vertical-align: text-bottom;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block;
}

nav ul {
  list-style: none;
}

input, select {
  vertical-align: middle;
}

.notapColor {
  -webkit-tap-highlight-color: transparent;
}

div#linkContents p {
  position: absolute;
  text-indent: -10000px;
  left: 0;
  top: 0;
  font-size: 1px;
}

/*lib*/
.bx-wrapper {
  margin-bottom: 150px;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  .bx-wrapper {
    margin-bottom: 50px;
  }
}

.bx-wrapper .bx-viewport {
  box-shadow: none;
  border: none;
  left: 0;
}

.bx-wrapper .bx-pager.bx-default-pager a {
  background: #fff;
  border: 1px solid #359bdb;
  width: 24px;
  height: 24px;
  border-radius: 12px;
}

.bx-wrapper .bx-pager.bx-default-pager a:hover, .bx-wrapper .bx-pager.bx-default-pager a.active {
  background: #8bc9f0;
}

.bx-wrapper .bx-pager, .bx-wrapper .bx-controls-auto {
  bottom: -50px;
}

.bx-wrapper img {
  margin: 0 auto;
}

/*inner (contents width)*/
.inner {
  width: 964px;
  margin: 0 auto 0 auto;
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  .inner {
    width: 100%;
    box-sizing: border-box;
    padding: 0 10px 0 10px;
  }
}

/* -----------------------------------------------
  header
----------------------------------------------- */
.header {
  position: fixed;
  width: 100%;
  z-index: 1;
  background: url(../image/bg_header.jpg) no-repeat top center;
  background-size: auto 100%;
  min-height: 640px;
  box-sizing: border-box;
}
@media screen and (min-width: 980px) and (max-width: 1366px) {
  .header {
    background-size: auto 100%;
  }
}
.header h1 {
  text-indent: -10000px;
  background: url(../image/logo.png) no-repeat;
  max-width: 1067px;
  height: 153px;
  line-height: 0;
  margin: 51px auto 430px auto;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  .header h1 {
    background-size: 80%;
    background-position: top center;
    margin-bottom: 0px;
    height: 100px;
    max-width: 500px;
  }
}
.header .list {
  text-align: center;
  width: 100%;
  position: absolute;
  bottom: 20px;
  left: 0;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  .header .list {
    position: static;
    padding-bottom: 60px;
  }
}
.header .list li {
  display: inline-block;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  .header .list li {
    padding: 10px;
    width: 40%;
  }
  .header .list li img {
    width: 100%;
  }
}
.header .list li:nth-child(2) {
  padding: 0 30px 0 30px;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  .header .list li:nth-child(2) {
    padding: 10px;
  }
}
.header .list li:nth-child(3) {
  padding: 0 30px 0 0;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  .header .list li:nth-child(3) {
    padding: 10px;
  }
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  .header {
    background-size: auto 100%;
    background-position: center;
    min-height: 0;
  }
  .header.wide {
    height: 300px;
  }
  .header.wide h1 {
    height: 100px;
    width: 450px;
    margin-top: 10px;
  }
  .header.wide .list li {
    width: 20%;
  }
}

/* -----------------------------------------------
  contents
----------------------------------------------- */
#contents.none {
  position: static;
  top: auto;
}

#contents {
  z-index: 2;
  position: relative;
  top: 640px;
  background: #fff;
}
#contents h3 {
  background: url(../image/bg_line.gif) bottom repeat-x;
  font-size: 342%;
  font-weight: normal;
  color: #2b96d9;
  padding: 45px 0 45px 0;
  text-align: center;
  margin-bottom: 65px;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents h3 {
    font-size: 22px;
    padding: 40px 0 20px;
    margin-bottom: 30px;
  }
}
#contents p {
  color: #7f7f7f;
  text-align: center;
  line-height: 2;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents p {
    text-align: left;
  }
  #contents p br {
    display: none;
  }
}
#contents a {
  color: #2b96d9;
  font-size: 129%;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents a {
    font-size: 16px;
  }
}
#contents .link {
  text-align: left;
  padding-top: 20px;
  text-align: center;
}
#contents #about {
  background: url(../image/bg_about.jpg) no-repeat center bottom #8bc9f0;
  padding: 30px 0 60px 0;
}
#contents #about .logo {
  width: 180px;
  margin: 0 auto 20px;
}
#contents #about h2 {
  font-size: 326%;
  font-weight: normal;
  color: #1c618c;
  text-align: center;
  margin-bottom: 40px;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents #about h2 {
    font-size: 20px;
  }
}
#contents #about p {
  color: #1c618c;
  text-align: center;
  line-height: 2;
  margin-bottom: 1em;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents #about p {
    text-align: left;
  }
  #contents #about p br {
    display: none;
  }
}
#contents .past-action-contents {
  position: relative;
  width: 100%;
  overflow: hidden;
  margin-bottom: 45px;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents .past-action-contents .article {
    margin-top: 50px;
  }
}
#contents .past-action-contents h4 {
  color: #2b96d9;
  text-align: center;
  font-size: 326%;
  font-weight: normal;
  margin-bottom: 35px;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents .past-action-contents h4 {
    font-size: 20px;
  }
}
#contents .past-action-contents h4 .year {
  display: block;
  font-size: 61%;
}
#contents .past-action-contents #num1 {
  background: url(../image/hd_num_1.png) left top no-repeat;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents .past-action-contents #num1 {
    background-size: 12%;
    margin-top: 0;
  }
}
#contents .past-action-contents #num2 {
  background: url(../image/hd_num_2.png) left top no-repeat;
  min-height: 490px;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents .past-action-contents #num2 {
    background-size: 30%;
    min-height: 300px;
  }
}
#contents .past-action-contents #num3 {
  background: url(../image/hd_num_3.png) left top no-repeat;
}
#contents .past-action-contents #num3 .expo-box {
  width: 100%;
}
#contents .past-action-contents #num3 .expo-box:after {
  display: block;
  visibility: hidden;
  clear: both;
  height: 0;
  font-size: 0;
  content: " ";
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents .past-action-contents #num3 .expo-box {
    margin-bottom: 30px;
  }
  #contents .past-action-contents #num3 .expo-box:first-of-type {
    margin-top: 30px;
  }
}
#contents .past-action-contents #num3 .expo-box figure {
  box-sizing: border-box;
  float: left;
  width: 42%;
  padding: 50px;
  background-repeat: no-repeat;
}
#contents .past-action-contents #num3 .expo-box figure#poster1 {
  background-image: url(../image/bg_num3_1.png);
}
#contents .past-action-contents #num3 .expo-box figure#poster2 {
  background-image: url(../image/bg_num3_2.png);
  background-position: right top;
  float: right;
}
#contents .past-action-contents #num3 .expo-box figure#poster3 {
  background-image: url(../image/bg_num3_3.png);
  background-position: left bottom;
}
#contents .past-action-contents #num3 .expo-box figure#poster4 {
  background-image: url(../image/bg_num3_4.png);
  background-position: right top;
  float: right;
}
#contents .past-action-contents #num3 .expo-box figure img {
  width: 100%;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents .past-action-contents #num3 .expo-box figure {
    width: 100%;
    display: block;
    background-size: 100%;
    padding: 10%;
  }
  #contents .past-action-contents #num3 .expo-box figure img {
    width: 100%;
  }
}
#contents .past-action-contents #num3 .expo-box .text-area {
  float: left;
  padding-top: 100px;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents .past-action-contents #num3 .expo-box .text-area {
    padding-top: 0;
  }
}
#contents .past-action-contents #num3 .expo-box .text-area h5 {
  text-align: center;
  font-size: 171%;
  color: #2b96d9;
  margin-bottom: .5em;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents .past-action-contents #num3 .expo-box .text-area h5 {
    font-size: 16px;
  }
}
#contents .past-action-contents #num3 .expo-box .text-area .term {
  font-size: 129%;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents .past-action-contents #num3 .expo-box .text-area .term {
    font-size: 16px;
  }
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents .past-action-contents #num3 {
    background-size: 31%;
  }
}
#contents .past-action-contents #num4 {
  background: url(../image/hd_num_4.png) left top no-repeat;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents .past-action-contents #num4 {
    background-size: 33%;
  }
}
#contents .past-action-contents #bicycle1 {
  position: absolute;
  bottom: 30px;
  right: -100px;
  width: 331px;
  height: auto;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents .past-action-contents #bicycle1 {
    display: none;
  }
}
#contents .past-action-contents #bicycle1.on {
  animation-name: anime1;
  animation-duration: 6s;
  animation-timing-function: ease;
  animation-iteration-count: 1;
}
#contents .past-action-contents #bicycle1.on img {
  animation-duration: 6.5s !important;
}
@keyframes anime1 {
  0% {
    right: -100px;
  }
  20% {
    right: -100px;
  }
  50% {
    right: 120%;
    transform: rotateY(0);
  }
  51% {
    width: 331px;
    bottom: 30px;
    boright: 120%;
    transform: rotateY(180deg);
  }
  90% {
    width: 100px;
    bottom: 500px;
    right: -500px;
    transform: rotateY(180deg);
  }
  95% {
    width: 100px;
    right: -500px;
    transform: rotateY(0);
  }
  96% {
    width: 331px;
    right: -500px;
    transform: rotateY(0);
  }
  100% {
    width: 331px;
    bottom: 30px;
    right: -100px;
    transform: rotateY(0);
  }
}
#contents .past-action-contents #bicycle2 {
  position: relative;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents .past-action-contents #bicycle2 {
    display: none;
  }
}
#contents .past-action-contents img.pedal_2 {
  position: absolute;
  width: 93px;
  height: auto;
  top: -268px;
  right: 113px;
  transform: translateY(-210px) translateX(-68px);
}
#contents .past-action-contents .on img.pedal_2 {
  animation-name: orbit1;
  animation-duration: 14s;
  animation-timing-function: linear;
  animation-iteration-count: 1;
}
#contents .past-action-contents img.pedal_3 {
  position: absolute;
  width: 93px;
  height: auto;
  top: -268px;
  right: 113px;
  transform: translateY(210px) translateX(68px);
}
#contents .past-action-contents .on img.pedal_3 {
  animation-name: orbit2;
  animation-duration: 14s;
  animation-timing-function: linear;
  animation-iteration-count: 1;
}
@keyframes orbit2 {
  from {
    transform: rotate(0deg) translateY(210px) translateX(73px) rotate(0deg);
  }
  to {
    transform: rotate(-1440deg) translateY(210px) translateX(73px) rotate(1440deg);
  }
}
@keyframes orbit1 {
  from {
    transform: rotate(0deg) translateY(-210px) translateX(-73px) rotate(0deg);
  }
  to {
    transform: rotate(-1440deg) translateY(-210px) translateX(-73px) rotate(1440deg);
  }
}
#contents .past-action-contents img.pedal_1 {
  position: absolute;
  bottom: 30px;
  right: 20px;
  width: 280px;
  height: auto;
}
#contents .past-action-contents .on img.pedal_1 {
  animation-name: anime2;
  animation-duration: 14s;
  animation-timing-function: linear;
  animation-iteration-count: 1;
}
@keyframes anime2 {
  from {
    transform: rotateZ(0);
  }
  to {
    transform: rotateZ(-1440deg);
  }
}
#contents .past-action-contents #bicycle3 {
  position: absolute;
  top: 0;
  right: 0;
  width: 331px;
  height: 194px;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents .past-action-contents #bicycle3 {
    display: none;
  }
}
#contents .past-action-contents #bicycle3 img.bicycle {
  position: absolute;
  top: 0;
  right: 0;
  width: 331px;
  height: auto;
}
#contents .past-action-contents #bicycle3 img.bicycle {
  position: absolute;
  top: 0;
  right: 0;
  width: 331px;
  height: auto;
}
#contents .past-action-contents #bicycle3.on {
  animation: bicycle3 linear 15s;
  animation-iteration-count: 1;
  transform-origin: 50% 50%;
}
@keyframes bicycle3 {
  0% {
    opacity: 1;
    transform: translate(273px, -18px) scaleX(1) scaleY(1);
  }
  53% {
    opacity: 1;
    transform: translate(-1400px, 150px) scaleX(0.7) scaleY(0.7);
  }
  61% {
    opacity: 1;
    transform: translate(-1600px, 180px) scaleX(0.7) scaleY(0.7);
  }
  65% {
    opacity: 1;
    transform: translate(-1850px, 202px) scaleX(0.7) scaleY(0.7);
  }
  67% {
    opacity: 0;
    transform: translate(-1850px, 202px) scaleX(0.7) scaleY(0.7);
  }
  75% {
    opacity: 0;
    transform: translate(333px, 2px) scaleX(1) scaleY(1);
  }
  76% {
    opacity: 1;
    transform: translate(333px, 2px) scaleX(1) scaleY(1);
  }
  100% {
    opacity: 1;
    transform: scaleX(1) scaleY(1);
  }
}
#contents .past-action-contents div.wheel {
  position: absolute;
  height: 134px;
  display: inline-block;
  top: 61px;
  left: 0;
}
#contents .past-action-contents .wheel_inner {
  position: relative;
}
#contents .past-action-contents img.wheel {
  position: absolute;
  top: 0;
  width: 134px;
  height: auto;
}
#contents .past-action-contents .on img.wheel {
  animation: wheel 15s linear;
}
@keyframes wheel {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(-1440deg);
  }
}
#contents .past-action-contents img#wheel_2 {
  left: 197px;
}
#contents .past-action-contents #bicycle3.on img {
  /*animation: anime3 linear 8s;*/
  animation-iteration-count: 1;
  transform-origin: 50% 50%;
}
@keyframes anime3 {
  0% {
    right: -100px;
  }
  20% {
    right: -100px;
  }
  50% {
    right: 120%;
    transform: rotateY(0);
  }
  100% {
    right: 120%;
    transform: rotateY(0);
  }
}
#contents .past-action-contents #bicycle4 {
  position: absolute;
  bottom: 0;
  left: -150px;
  width: 331px;
  height: auto;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents .past-action-contents #bicycle4 {
    display: none;
  }
}
#contents .past-action-contents #bicycle4.on {
  animation: anime4 linear 10s;
  animation-iteration-count: 1;
}
#contents .past-action-contents #bicycle4.on img {
  animation-duration: 11.5s !important;
}
@keyframes anime4 {
  0% {
    right: 500px;
  }
  19% {
    opacity: 1;
  }
  20% {
    transform: scaleX(1) scaleY(1);
    left: -400px;
    bottom: 0;
    opacity: 0;
  }
  25% {
    opacity: 0;
    left: 1850px;
  }
  26% {
    opacity: 1;
    left: 1650px;
    bottom: 300px;
    transform: scaleX(0.5) scaleY(0.5);
  }
  70% {
    opacity: 1;
    left: 300px;
  }
}
#contents #bxslider-num4 li {
  text-align: center;
}
#contents #bxslider-num4 li div {
  position: relative;
}
#contents #bxslider-num4 li .caption {
  display: block;
  width: 100%;
  background-color: rgba(0, 0, 0, 0.4);
  color: #fff;
  text-align: center;
  position: absolute;
  left: 0;
  bottom: 0;
  padding: 10px 0;
}
#contents #incoming-action .row-box {
  display: table;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents #incoming-action .row-box {
    display: block;
  }
}
#contents #incoming-action dl {
  width: 450px;
  display: table-cell;
}
#contents #incoming-action dl:first-of-type {
  padding-right: 64px;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents #incoming-action dl {
    display: block;
    width: 100%;
    box-sizing: border-box;
  }
}
#contents #incoming-action dl dt {
  color: #2b96d9;
  font-weight: bold;
  margin-bottom: .5em;
}
#contents #incoming-action dl dd {
  margin-bottom: 2em;
}
#contents #incoming-action dl dd p {
  text-align: left;
}
#contents #inquiry {
  text-align: center;
}
#contents #inquiry p {
  margin-bottom: 4em;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents #inquiry p {
    margin-bottom: 2em;
  }
}
#contents #inquiry .btn {
  text-align: center;
  font-size: 270%;
  line-height: 1;
}
#contents #inquiry .btn a {
  color: #808080;
  border: 1px solid #2b96d9;
  display: inline-block;
  padding: 10px 50px;
}
#contents #inquiry .btn a span {
  color: #2b96d9;
}
#contents #inquiry .btn a:hover {
  background-color: #e5f5ff;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents #inquiry .btn a:hover {
    background-color: #fff;
  }
}
#contents #contents-footer {
  position: relative;
  background: url(../image/bg_contentsfooter.png) right bottom no-repeat #e5f5ff;
}
#contents #contents-footer .inner {
  padding: 70px 150px 50px 150px;
  box-sizing: border-box;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents #contents-footer .inner {
    padding: 30px 10px 120px;
  }
}
#contents #contents-footer .inner h4 {
  font-size: 118%;
  margin-bottom: .3em;
}
#contents #contents-footer .inner p {
  text-align: left;
  font-size: 118%;
  line-height: 1.6;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents #contents-footer .inner p {
    font-size: 14px;
  }
}
#contents .pagetop {
  position: fixed;
  right: 15px;
  bottom: 10px;
  z-index: -1;
}
#contents .pagetop a {
  display: block;
  width: 68px;
  height: 68px;
  background: url(../image/bt_pagetop.png) no-repeat;
  text-indent: -10000px;
}
#contents .pagetop.block {
  z-index: 10000;
}
#contents .pagetop.hide {
  z-index: -1;
}
#contents #footer {
  padding: 10px;
  text-align: center;
  background: #8bc9f0;
}
#contents #footer p {
  font-weight: bold;
  color: #fff;
  font-size: 118%;
}
@media screen and (min-width: 320px) and (max-width: 980px) {
  #contents #footer p {
    font-size: 12px;
    text-align: center;
  }
}

.pedal {
  position: relative;
}

#contents .past-action-contents .pedal {
  position: absolute;
  transform: scale(0.14);
  bottom: 25px;
  right: 128px;
}

.bicycle_an {
  width: 331px;
  height: 194px;
  display: block;
  position: relative;
}

.bicycle_an .wheel--2 {
  left: 197px !important;
}
