@import 'normalize.css';
/* Layout */
/* Layer */
body {
  font-family: 'Lucida Grande', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Meiryo, 'メイリオ', sans-serif;
  color: #333;
}
@media screen and (max-width: 740px) {
  body {
    font-size: 14px;
  }
}
.hidemail, .hidemail.pc0sp1 {
  /* mail メール の表示設定 4月1日コメントアウト済み*/
  /* display: none!important; */
}
.ie9 .exceptForIE9 {
  display: none !important;
}
.forIE9 {
  display: none !important;
}
.ie9 .forIE9 {
  display: block !important;
}
@media screen and (max-width: 740px) {
  .forIE9 {
    display: none !important;
  }
}
.container {
  border-top: 5px solid #ca0029;
  position: relative;
}
.pc1sp0 {
  display: block;
}
@media screen and (max-width: 740px) {
  .pc1sp0 {
    display: none !important;
  }
}
.pc0sp1 {
  display: none !important;
}
@media screen and (max-width: 740px) {
  .pc0sp1 {
    display: block !important;
  }
}
.blank:after {
  content: ' ';
  /*background: no-repeat right top url(../img/generic/icn-blank.png);*/
  display: block;
  float: right;
  height: 11px;
  margin-left: 2px;
  margin-top: 2px;
  width: 15px;
}
.blank--inline:after {
  float: none;
  display: inline-block;
}
h1 {
  font-size: 2em;
  margin: 0;
}
h2 {
  font-size: 1.5em;
  margin: 0;
}
h3 {
  font-size: 1.17em;
  margin: 0;
}
h4 {
  font-size: 1em;
  margin: 0;
}
h5 {
  font-size: 0.83em;
  margin: 0;
}
h6 {
  font-size: 0.75em;
  margin: 0;
}
p, pre {
  margin: 1em 0;
}
ol, ul {
  margin: 0;
  padding: 0;
}
li {
  list-style-type: none;
}
a {
  color: #666666;
  text-decoration: none;
}
.hsShareImage {
  display: none !important;
}
body.generic {
  background: no-repeat right top url(../img/news/bg-list.png);
}
@media screen and (max-width: 740px) {
  body.generic {
    background: no-repeat right top url(../img-sp/generic/bg-list.png);
    background-size: 185px 203px;
  }
}
body.generic a {
  color: #666666;
  text-decoration: none;
}
.canvas {
  width: 820px;
  margin: 40px auto 50px;
  display: block;
  position: relative;
  background-color: #fff;
  padding-bottom: 35px;
  -webkit-box-shadow: 0 1px 7px rgba(0, 0, 0, 0.3);
  -moz-box-shadow: 0 1px 7px rgba(0, 0, 0, 0.3);
  box-shadow: 0 1px 7px rgba(0, 0, 0, 0.3);
}
@media screen and (max-width: 740px) {
  .canvas {
    width: auto;
    margin: 20px;
  }
}
.canvas .title {
  padding: 82px 0 20px 0;
  margin: 0 25px 20px;
  border-bottom: 1px solid #bfbfbf;
}
@media screen and (max-width: 740px) {
  .canvas .title {
    margin: 0 25px 20px;
    padding: 82px 0 20px 0;
  }
}
.footer {
  z-index: 10;
  position: relative;
  width: 100%;
  overflow: hidden;
}
.footer .contact {
  background-color: #dfe9d5;
  position: relative;
  -webkit-box-shadow: 0 -8px 16px rgba(0, 0, 0, 0.2);
  -moz-box-shadow: 0 -8px 16px rgba(0, 0, 0, 0.2);
  box-shadow: 0 -8px 16px rgba(0, 0, 0, 0.2);
}
.footer .contact--inner {
  width: 1082px;
  margin: 0 auto;
  padding-top: 37px;
  padding-bottom: 37px;
}
.footer .contact--inner:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
.footer .contact--inner:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
@media screen and (max-width: 740px) {
  .footer .contact--inner {
    width: 100%;
  }
  .footer .contact--inner img {
    margin: 0 auto;
  }
}
.footer .contact--title {
  float: left;
  margin-right: 66px;
}
.footer .contact--title h2 {
  font-size: 16px;
}
.footer .contact--title img {
  margin-bottom: 10px;
}
@media screen and (max-width: 740px) {
  .footer .contact--title {
    float: none;
    text-align: center;
    margin-right: 0;
    margin-bottom: 15px;
  }
  .footer .contact--title img {
    width: 150px;
    height: auto;
  }
}
.footer .contact--dscp {
  float: left;
  display: inline-block;
  width: 310px;
  line-height: 1.6em;
}
@media screen and (max-width: 740px) {
  .footer .contact--dscp {
    margin-bottom: 20px;
    float: none;
    width: 244px;
    margin: 0 auto 20px;
    box-sizing: border-box;
    padding: 0;
    font-size: 12px;
    display: block;
    text-align: center;
  }
}
.footer .contact--phone {
  float: right;
  font-size: 12px;
  margin-right: 15px;
  line-height: 1.6em;
  text-align: center;
}
@media screen and (max-width: 740px) {
  .footer .contact--phone {
    float: none;
    width: 237px;
    margin-top: 5px;
    margin-bottom: 5px;
    margin-left: 50px;
    margin-right: 10px;
  }
  .footer .contact--phone img {
    margin: 0 auto;
  }
}
.footer .contact--phone img {
  font-size: 0;
  margin-bottom: 10px;
  line-height: normal;
  display: block;
}
@media screen and (max-width: 740px) {
  .footer .contact--phone img {
    margin-bottom: 5px;
  }
}
.footer .contact--mail {
  float: right;
}
@media screen and (max-width: 740px) {
  .footer .contact--mail {
    float: none;
  }
}
.footer .contact--mail--sp {
  margin-left: 30px;
  margin-right: 30px;
}
.footer .contact--mail a {
  display: block;
}
.footer .contact--mail a:hover {
  -moz-opacity: 0.6;
  -khtml-opacity: 0.6;
  -webkit-opacity: 0.6;
  opacity: 0.6;
}
@media screen and (max-width: 740px) {
  .footer .contact--mail a {
    background-color: #ca0029;
    color: #fff;
    -webkit-border-top-right-radius: 5px;
    -webkit-border-bottom-right-radius: 5px;
    -webkit-border-bottom-left-radius: 5px;
    -webkit-border-top-left-radius: 5px;
    -moz-border-radius-topright: 5px;
    -moz-border-radius-bottomright: 5px;
    -moz-border-radius-bottomleft: 5px;
    -moz-border-radius-topleft: 5px;
    border-top-right-radius: 5px;
    border-bottom-right-radius: 5px;
    border-bottom-left-radius: 5px;
    border-top-left-radius: 5px;
    -moz-background-clip: padding-box;
    -webkit-background-clip: padding-box;
    background-clip: padding-box;
    padding: 10px;
    text-align: center;
    display: block;
  }
  .footer .contact--mail a:after {
    clear: both;
    height: 0;
    visibility: hidden;
    font-size: 0;
    display: block;
    content: "";
  }
  .footer .contact--mail a:after {
    clear: both;
    height: 0;
    visibility: hidden;
    font-size: 0;
    display: block;
    content: "";
  }
  .footer .contact--mail a .fa {
    float: right;
    margin-right: 5px;
    margin-top: 2px;
  }
}
.footer .contact--mail a img {
  font-size: 0;
  display: block;
}
@media screen and (max-width: 740px) {
  .footer .contact--mail a img {
    display: none;
  }
}
.footer .links {
  position: absolute;
  top: 20px;
}
.footer .links:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
.footer .links:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
@media screen and (max-width: 740px) {
  .footer .links {
    padding: 0 20px;
    margin-bottom: 10px;
    top: 10px;
  }
}
.footer .links a {
  color: #65a927;
  font-size: 12px;
  margin: 0 10px 0 0;
  display: inline-block;
  float: left;
}
.footer .corp {
  position: relative;
  -webkit-box-shadow: 0 -1px 19px rgba(0, 0, 0, 0.2);
  -moz-box-shadow: 0 -1px 19px rgba(0, 0, 0, 0.2);
  box-shadow: 0 -1px 19px rgba(0, 0, 0, 0.2);
}
.footer .corp--inner {
  width: 1082px;
  position: relative;
  padding-top: 80px;
  padding-bottom: 55px;
  margin: 0 auto;
}
@media screen and (max-width: 740px) {
  .footer .corp--inner {
    width: 100%;
    padding-top: 60px;
  }
}
.footer .corp--copy {
  text-align: center;
  font-size: 11px;
}
.footer .corp--copy img {
  margin-top: 100px;
  margin-bottom: 15px;
  margin: 0 auto 15px;
}
@media screen and (max-width: 740px) {
  .footer .corp--copy img {
    width: 110px;
    margin-top: 100px;
    height: auto;
  }
}
.footer .corp--policy {
  position: absolute;
  top: 45px;
  left: 0;
}
@media screen and (max-width: 740px) {
  .footer .corp--policy {
    left: 10px;
    top: 15px;
  }
}
.footer .corp--policy a {
  font-size: 12px;
  color: #65a927;
}
.footer .corp--policy img {
  vertical-align: middle;
  margin-left: 3px;
}
.footer .pagetop {
  position: absolute;
  top: -22px;
  right: -2px;
}
@media screen and (max-width: 740px) {
  .footer .pagetop {
    right: 20px;
    width: 50px;
    height: auto;
  }
}
.footer .pagetop a {
  outline: none;
}
.footer .pagetop a:hover {
  -moz-opacity: 0.6;
  -khtml-opacity: 0.6;
  -webkit-opacity: 0.6;
  opacity: 0.6;
}
.side--menu {
  position: fixed;
  left: -253px;
  top: 140px;
  z-index: 100;
  width: 300px;
}
@media screen and (min-width: 741px) {
  .side--menu {
    top: 140px !important;
  }
}
@media screen and (max-width: 740px) {
  .side--menu {
    width: 100%;
    top: -370px;
    top: -500px;
    left: 0 !important;
  }
}
.side--menu .opener {
  width: 46px;
  z-index: 1;
  right: 0;
  height: 405px;
  display: block;
  position: absolute;
  cursor: e-resize;
}
@media screen and (max-width: 740px) {
  .side--menu .opener {
    z-index: -1;
    top: -100%;
    height: 100%;
    width: 100%;
    position: fixed;
    cursor: default;
    background-color: rgba(0, 0, 0, 0.5);
  }
}
.side--menu.open .opener {
  cursor: w-resize;
}
@media screen and (max-width: 740px) {
  .side--menu.open .opener {
    top: 0;
    left: 0;
  }
}
.side--menu ul {
  margin: 0;
  padding: 0;
}
.side--menu li {
  background: 0 bottom repeat-x url(../img/menu/menu-middle-2.png);
  min-height: 45px;
}
@media screen and (min-width: 741px) {
  .side--menu li.current {
    background: 0 bottom repeat-x url(../img/menu/menu-top-2.png);
  }
}
.side--menu li:hover {
  -moz-opacity: 0.9;
  -khtml-opacity: 0.9;
  -webkit-opacity: 0.9;
  opacity: 0.9;
}
.side--menu li.top {
  -webkit-border-top-right-radius: 5px;
  -webkit-border-bottom-right-radius: 0;
  -webkit-border-bottom-left-radius: 0;
  -webkit-border-top-left-radius: 0;
  -moz-border-radius-topright: 5px;
  -moz-border-radius-bottomright: 0;
  -moz-border-radius-bottomleft: 0;
  -moz-border-radius-topleft: 0;
  border-top-right-radius: 5px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  -moz-background-clip: padding-box;
  -webkit-background-clip: padding-box;
  background-clip: padding-box;
}
.side--menu li.top a {
  -webkit-border-top-right-radius: 5px;
  -webkit-border-bottom-right-radius: 0;
  -webkit-border-bottom-left-radius: 0;
  -webkit-border-top-left-radius: 0;
  -moz-border-radius-topright: 5px;
  -moz-border-radius-bottomright: 0;
  -moz-border-radius-bottomleft: 0;
  -moz-border-radius-topleft: 0;
  border-top-right-radius: 5px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  -moz-background-clip: padding-box;
  -webkit-background-clip: padding-box;
  background-clip: padding-box;
}
@media screen and (max-width: 740px) {
  .side--menu li.top {
    -webkit-border-top-right-radius: 0;
    -webkit-border-bottom-right-radius: 0;
    -webkit-border-bottom-left-radius: 0;
    -webkit-border-top-left-radius: 0;
    -moz-border-radius-topright: 0;
    -moz-border-radius-bottomright: 0;
    -moz-border-radius-bottomleft: 0;
    -moz-border-radius-topleft: 0;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 0;
    border-top-left-radius: 0;
    -moz-background-clip: padding-box;
    -webkit-background-clip: padding-box;
    background-clip: padding-box;
  }
  .side--menu li.top a {
    background-image: none;
    -webkit-border-top-right-radius: 0;
    -webkit-border-bottom-right-radius: 0;
    -webkit-border-bottom-left-radius: 0;
    -webkit-border-top-left-radius: 0;
    -moz-border-radius-topright: 0;
    -moz-border-radius-bottomright: 0;
    -moz-border-radius-bottomleft: 0;
    -moz-border-radius-topleft: 0;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 0;
    border-top-left-radius: 0;
    -moz-background-clip: padding-box;
    -webkit-background-clip: padding-box;
    background-clip: padding-box;
  }
}
@media screen and (min-width: 741px) {
  .side--menu li.current .top {
    background: 0 bottom repeat-x url(../img/menu/menu-top-1.png);
  }
}
.side--menu li.last {
  background-position: 0 0;
  -webkit-border-top-right-radius: 0;
  -webkit-border-bottom-right-radius: 5px;
  -webkit-border-bottom-left-radius: 0;
  -webkit-border-top-left-radius: 0;
  -moz-border-radius-topright: 0;
  -moz-border-radius-bottomright: 5px;
  -moz-border-radius-bottomleft: 0;
  -moz-border-radius-topleft: 0;
  border-top-right-radius: 0;
  border-bottom-right-radius: 5px;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  -moz-background-clip: padding-box;
  -webkit-background-clip: padding-box;
  background-clip: padding-box;
}
.side--menu li.last a {
  line-height: 43px;
  background-position: right 0;
  -webkit-border-top-right-radius: 0;
  -webkit-border-bottom-right-radius: 5px;
  -webkit-border-bottom-left-radius: 0;
  -webkit-border-top-left-radius: 0;
  -moz-border-radius-topright: 0;
  -moz-border-radius-bottomright: 5px;
  -moz-border-radius-bottomleft: 0;
  -moz-border-radius-topleft: 0;
  border-top-right-radius: 0;
  border-bottom-right-radius: 5px;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  -moz-background-clip: padding-box;
  -webkit-background-clip: padding-box;
  background-clip: padding-box;
}
.side--menu li.last.current {
  background-position: 0 -2px;
}
.side--menu li a {
  color: #fff;
  display: block;
  line-height: 45px;
  text-align: right;
  padding-right: 52px;
  font-size: 16px;
  background: right bottom no-repeat url(../img/menu/menu-middle-1.png);
  outline: none;
  padding-bottom: 3px;
  line-height: 42px;
}
@media screen and (max-width: 740px) {
  .side--menu li a {
    padding-right: 20px;
    padding-left: 20px;
    text-align: center;
    -webkit-border-top-right-radius: 0;
    -webkit-border-bottom-right-radius: 0;
    -webkit-border-bottom-left-radius: 0;
    -webkit-border-top-left-radius: 0;
    -moz-border-radius-topright: 0;
    -moz-border-radius-bottomright: 0;
    -moz-border-radius-bottomleft: 0;
    -moz-border-radius-topleft: 0;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 0;
    border-top-left-radius: 0;
    -moz-background-clip: padding-box;
    -webkit-background-clip: padding-box;
    background-clip: padding-box;
    background-image: none;
  }
}
@media screen and (min-width: 741px) {
  .side--menu li.current a {
    background: right bottom no-repeat url(../img/menu/menu-top-1.png);
  }
}
@media screen and (max-width: 740px) {
  .side--menu li.current a {
    background-image: url(../img/menu/menu-middle-2.png);
  }
}
body.home .s1--inner, body.home .s2--inner, body.home .s3--inner, body.home .s4--inner, body.home .s5--inner, body.home .s6--inner, body.home .s8--inner {
  width: 1082px;
  margin: 0 auto;
}
@media screen and (max-width: 740px) {
  body.home .s1--inner, body.home .s2--inner, body.home .s3--inner, body.home .s4--inner, body.home .s5--inner, body.home .s6--inner, body.home .s8--inner {
    width: 100%;
    box-sizing: border-box;
  }
}
body.home .s1 {
  -webkit-box-shadow: 0 1px 18px rgba(0, 0, 0, 0.4);
  -moz-box-shadow: 0 1px 18px rgba(0, 0, 0, 0.4);
  box-shadow: 0 1px 18px rgba(0, 0, 0, 0.4);
  min-width: 1082px;
}
@media screen and (max-width: 740px) {
  body.home .s1 {
    background-color: #fff;
    min-width: 100%;
    -webkit-box-shadow: 0 1px 7px rgba(0, 0, 0, 0.4);
    -moz-box-shadow: 0 1px 7px rgba(0, 0, 0, 0.4);
    box-shadow: 0 1px 7px rgba(0, 0, 0, 0.4);
  }
}
body.home .s1--inner {
  width: 1092px;
  margin: 0 auto;
  position: relative;
  min-height: calc(100vh - 50px);
}
@media screen and (max-width: 740px) {
  body.home .s1--inner {
    width: 100%;
    padding: 0 19px 20px;
    box-sizing: border-box;
    min-height: 340px;
  }
}
body.home .s1 .logo {
  margin: 40px 0 0 0;
  color: #ca0029;
  display: inline-block;
  position: relative;
  width: 190px;
}
body.home .s1 .logo:before {
  content: "";
  width: 100%;
  height: 100%;
  background: #fff;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  left: 0;
  background: rgb(255 255 255 / 70%);
  filter: blur(6px);
  -o-filter: blur(6px);
  -ms-filter: blur(6px);
  -moz-filter: blur(6px);
  -webkit-filter: blur(6px);
}
body.home .s1 .logo img {
  display: block;
  z-index: 1;
  position: relative;
  width: 100%;
}
body.home .s1 .logo h1 {
  font-size: 16px;
}
@media screen and (max-width: 740px) {
  body.home .s1 .logo {
    position: absolute;
    bottom: 65px;
    right: 0;
    width: 165px;
  }
}
body.home .s1 .title img {
  display: block;
  margin-bottom: 10px;
  width: 420px
}
body.home .s1 .title h1 {
  color: #ca0029;
  font-size: 15px;
  display: none;
}
@media screen and (max-width: 740px) {
  body.home .s1 .title {
    margin: 20px 0;
  }
  body.home .s1 .title img {
    width: 285px;
    height: auto;
  }
  body.home .s1 .title h1 {
    font-size: 14px
  }
}
body.home .s1 h1, body.home .s1 h2 {
  margin: 0;
  padding: 0;
}
body.home .s1 h2 {
  font-size: 16px;
}
body.home .s1 h2 img {
  margin-bottom: 10px;
}
body.home .s1 h3 {
  font-size: 24px;
}
body.home .s1 section {
  background-image: url("../img/home/banner.jpg?v=1.1");
  background-size: cover;
  background-position: bottom center;
}
@media screen and (max-width: 740px) {
  body.home .s1 section {
    background: none
  }
  body.home .s1 section .s1--inner {
    background-image: url("../img-sp/home/banner.jpg?v=1.1");
    /*background-size: auto 340px;
		background-position: center top; */
    background-size: cover;
    background-position: center -65px;
    background-repeat: no-repeat;
    padding-top: 62px;
  }
}
@media screen and (max-width: 568px) {
  body.home .s1 section .s1--inner {
    background-size: auto 340px;
    background-position: center top;
  }
}
body.home .s1 .link {
  text-align: right;
  margin-top: 40px;
  padding-bottom: 15px;
}
body.home .s1 .link a {
  display: inline-block;
  font-size: 20px;
  position: relative;
  padding: 5px 15px 3px;
  z-index: 11;
  color: #333;
}
body.home .s1 .link a span {
  z-index: 1;
  display: block;
  position: relative;
}
body.home .s1 .link a:before {
  content: "";
  width: 100%;
  height: 100%;
  background: #fff;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  left: 0;
  background: rgb(255 255 255 / 70%);
  filter: blur(6px);
  -o-filter: blur(6px);
  -ms-filter: blur(6px);
  -moz-filter: blur(6px);
  -webkit-filter: blur(6px);
}
@media screen and (max-width: 740px) {
  body.home .s1 .link {
    margin-top: 0;
    padding-bottom: 5px
  }
  body.home .s1 .link a {
    font-size: 16px;
    padding: 0;
    color: #559c1e;
  }
}
@media screen and (max-width: 740px) {
  body.home .s1 h3 {
    font-size: 19px;
  }
}
body.home .s1 .description--wrapper {
  height: calc(100vh - 285px);
  min-height: 500px;
}
@media screen and (max-width: 740px) {
  body.home .s1 .description--wrapper {
    height: auto;
    min-height: 275px;
  }
}
body.home .s1 .description {
  width: 480px;
  line-height: 1.8em;
  margin: 0 auto;
  text-align: center;
  font-size: 22px;
  font-weight: bold;
  position: relative;
  padding: 10px 0;
}
body.home .s1 .description span {
  z-index: 1;
  display: block;
  position: relative;
}
body.home .s1 .description:before {
  content: "";
  width: 100%;
  height: 100%;
  background: #fff;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  left: 0;
  background: rgb(255 255 255 / 70%);
  filter: blur(6px);
  -o-filter: blur(6px);
  -ms-filter: blur(6px);
  -moz-filter: blur(6px);
  -webkit-filter: blur(6px);
}
@media screen and (max-width: 740px) {
  body.home .s1 .description {
    font-size: 14px;
    width: 100%;
    max-width: 320px;
    margin: auto;
  }
}
body.home .s1 .btn--down {
  position: absolute;
  width: 100%;
  bottom: -54px;
  left: 0;
  text-align: center;
  z-index: 10;
}
@media screen and (max-width: 740px) {
  body.home .s1 .btn--down {
    bottom: -27px;
  }
  body.home .s1 .btn--down img {
    width: 53px;
    height: auto;
  }
}
@media screen and (max-width: 740px) {
  .android4-1 body.home .s1 .btn--down {
    bottom: -28px;
  }
}
@media screen and (max-width: 740px) {
  .gecko body.home .s1 .btn--down {
    bottom: -28px;
  }
}
.gecko.win body.home .s1 .btn--down {
  bottom: -57px;
}
@media screen and (max-width: 740px) {
  .gecko.win body.home .s1 .btn--down {
    bottom: -31px;
  }
}
.safari body.home .s1 .btn--down {
  bottom: -53px;
}
@media screen and (max-width: 740px) {
  .safari body.home .s1 .btn--down {
    bottom: -31px;
  }
}
.safari8.mac body.home .s1 .btn--down {
  bottom: -53px;
}
@media screen and (max-width: 740px) {
  .safari8.mac body.home .s1 .btn--down {
    bottom: -28px;
  }
}
@media screen and (max-width: 740px) {
  .safari7.mac body.home .s1 .btn--down {
    bottom: -28px;
  }
}
@media screen and (max-width: 740px) {
  .safari.iphone body.home .s1 .btn--down {
    bottom: -31px;
  }
}
.chrome body.home .s1 .btn--down {
  bottom: -53px;
}
.chrome.mac body.home .s1 .btn--down {
  bottom: -53px;
}
@media screen and (max-width: 740px) {
  .chrome.mac body.home .s1 .btn--down {
    bottom: -28px;
  }
}
.chrome.win body.home .s1 .btn--down {
  bottom: -57px;
}
@media screen and (max-width: 740px) {
  .chrome.win body.home .s1 .btn--down {
    bottom: -31px;
  }
}
.ie.win body.home .s1 .btn--down {
  bottom: -57px;
}
@media screen and (max-width: 740px) {
  .ie.win body.home .s1 .btn--down {
    bottom: -31px;
  }
}
.ie11.win body.home .s1 .btn--down {
  bottom: -57px;
}
@media screen and (max-width: 740px) {
  .ie11.win body.home .s1 .btn--down {
    bottom: -31px;
  }
}
.ie9.win body.home .s1 .btn--down {
  bottom: -57px;
}
@media screen and (max-width: 740px) {
  .ie9.win body.home .s1 .btn--down {
    bottom: -31px;
  }
}
body.home .s1 .btn--down a {
  display: inline-block;
  outline: none;
}
body.home .s1 .btn--menu {
  display: none;
}
@media screen and (max-width: 740px) {
  body.home .s1 .btn--menu {
    background: 0 0 no-repeat url(../img-sp/menu/icn-menu.png);
    position: absolute;
    top: 20px;
    left: 20px;
    background-size: 40px auto;
    display: block;
    width: 40px;
    height: 40px;
  }
}
.top--visual {
  position: absolute;
  overflow: hidden;
  right: 0;
  top: -5px;
}
@media screen and (max-width: 1200px) {
  .top--visual {
    left: 577px;
  }
}
@media screen and (max-width: 740px) {
  .top--visual {
    left: inherit;
  }
  .top--visual img {
    width: 278px;
    height: auto;
  }
}
@media screen and (max-width: 360px) {
  .top--visual {
    left: 83px;
  }
}
.top--visual img {
  max-width: initial;
}
.top--visual .photo {
  display: none;
  -webkit-border-top-right-radius: 100%;
  -webkit-border-bottom-right-radius: 100%;
  -webkit-border-bottom-left-radius: 100%;
  -webkit-border-top-left-radius: 100%;
  -moz-border-radius-topright: 100%;
  -moz-border-radius-bottomright: 100%;
  -moz-border-radius-bottomleft: 100%;
  -moz-border-radius-topleft: 100%;
  border-top-right-radius: 100%;
  border-bottom-right-radius: 100%;
  border-bottom-left-radius: 100%;
  border-top-left-radius: 100%;
  -moz-background-clip: padding-box;
  -webkit-background-clip: padding-box;
  background-clip: padding-box;
  border: 3px solid #fff;
  left: 110px;
  position: absolute;
  top: -190px;
  width: 700px;
  height: 700px;
  z-index: 100;
  background-repeat: no-repeat;
  background-color: transparent;
  background-attachment: scroll;
}
@media screen and (max-width: 740px) {
  .top--visual .photo {
    -webkit-transform: scale(0.4) translate(-680px, -200px);
    -moz-transform: scale(0.4) translate(-680px, -200px);
    -o-transform: scale(0.4) translate(-680px, -200px);
    -ms-transform: scale(0.4) translate(-680px, -200px);
    transform: scale(0.4) translate(-680px, -200px);
  }
}
.top--visual .photo.default {
  display: block;
}
.js .top--visual .photo.default {
  display: none;
}
body.home .s2--inner {
  padding-top: 65px;
  padding-bottom: 56px;
}
@media screen and (max-width: 740px) {
  body.home .s2--inner {
    padding-bottom: 35px;
    min-height: 490px;
  }
}
body.home .s2 .title {
  text-align: center;
}
body.home .s2 .title h2 {
  font-size: 16px;
}
body.home .s2 .title img {
  margin: 0 auto 30px;
}
@media screen and (max-width: 740px) {
  body.home .s2 .title img {
    width: 200px;
    height: auto;
  }
}
body.home .s2 .desciption {
  text-align: center;
}
@media screen and (max-width: 740px) {
  body.home .s2 .desciption {
    display: none;
  }
}
body.home .s2 .external_link {
  text-align: right;
  padding: 10px 20px 0;
}
body.home .s2 .external_link a {
  color: #559c1e;
  font-size: 22px;
}
body.home .s2 .external_link a:after {
  display: none;
}
@media screen and (max-width: 740px) {
  body.home .s2 .external_link a {
    font-size: 16px;
  }
}
body.home .s2 .bike {
  margin-top: auto;
  text-align: center;
  position: relative;
  display: block;
  margin-right: auto;
  margin-bottom: 0;
  margin-left: auto;
}
@media screen and (max-width: 740px) {
  body.home .s2 .bike--inner {
    width: 320px;
    position: relative;
    margin: 0 auto;
    display: inline-block;
  }
}
body.home .s2 .bike img {
  margin: 0 auto;
}
@media screen and (max-width: 740px) {
  body.home .s2 .bike img {
    margin-top: 18px;
    width: 272px;
  }
}
body.home .s2 .bike .img--panel {
  position: absolute;
  top: 29px;
  right: 245px;
  display: block;
  z-index: -1;
}
@media screen and (max-width: 740px) {
  body.home .s2 .bike .img--panel {
    width: 60px;
    right: 34px;
    top: 9px;
  }
}
@media screen and (max-width: 740px) {
  body.home .s2 .bike {
    padding: 0 20px;
    margin-top: 0;
  }
  body.home .s2 .bike img {
    width: 272px;
    height: auto;
  }
}
@media screen and (max-width: 320px) {
  body.home .s2 .bike {
    padding: 0 0;
  }
}
body.home .s2 .link {
  width: 46px;
  height: 46px;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  cursor: pointer;
  outline: none;
  background: 0 0 repeat url(../img/generic/transparent1x1.png);
  -webkit-border-top-right-radius: 100%;
  -webkit-border-bottom-right-radius: 100%;
  -webkit-border-bottom-left-radius: 100%;
  -webkit-border-top-left-radius: 100%;
  -moz-border-radius-topright: 100%;
  -moz-border-radius-bottomright: 100%;
  -moz-border-radius-bottomleft: 100%;
  -moz-border-radius-topleft: 100%;
  border-top-right-radius: 100%;
  border-bottom-right-radius: 100%;
  border-bottom-left-radius: 100%;
  border-top-left-radius: 100%;
  -moz-background-clip: padding-box;
  -webkit-background-clip: padding-box;
  background-clip: padding-box;
}
@media screen and (max-width: 740px) {
  body.home .s2 .link {
    width: 21px;
    height: 21px;
  }
}
body.home .s2 .link:hover {
  -moz-opacity: 1;
  -khtml-opacity: 1;
  -webkit-opacity: 1;
  opacity: 1;
  background-color: #65a927;
}
body.home .s2 .link--1 {
  left: 355px;
  top: 207px;
}
@media screen and (max-width: 740px) {
  body.home .s2 .link--1 {
    left: 82px;
    top: 100px;
  }
}
body.home .s2 .link--2 {
  top: 232px;
  left: 419px;
}
@media screen and (max-width: 740px) {
  body.home .s2 .link--2 {
    left: 108px;
    top: 110px;
  }
}
body.home .s2 .link--3 {
  left: 581px;
  top: 76px;
}
@media screen and (max-width: 740px) {
  body.home .s2 .link--3 {
    left: 178px;
    top: 43px;
  }
}
body.home .s2 .link--4 {
  left: 414px;
  top: 127px;
}
@media screen and (max-width: 740px) {
  body.home .s2 .link--4 {
    left: 108px;
    top: 64px;
  }
}
body.home .s2 .link--5 {
  left: 714px;
  top: 328px;
}
@media screen and (max-width: 740px) {
  body.home .s2 .link--5 {
    left: 236px;
    top: 158px;
  }
}
body.home .s2 .link--6 {
  left: 818px;
  top: -1px;
}
@media screen and (max-width: 740px) {
  body.home .s2 .link--6 {
    left: 262px;
    top: 40px;
  }
}
body.home .s2 .point {
  display: none;
  background-color: #fff;
  border: 1px solid #bfbfbf;
  position: absolute;
  text-align: left;
  top: 120px;
  left: 20px;
  width: 266px;
  -webkit-border-top-right-radius: 10px;
  -webkit-border-bottom-right-radius: 10px;
  -webkit-border-bottom-left-radius: 10px;
  -webkit-border-top-left-radius: 10px;
  -moz-border-radius-topright: 10px;
  -moz-border-radius-bottomright: 10px;
  -moz-border-radius-bottomleft: 10px;
  -moz-border-radius-topleft: 10px;
  border-top-right-radius: 10px;
  border-bottom-right-radius: 10px;
  border-bottom-left-radius: 10px;
  border-top-left-radius: 10px;
  -moz-background-clip: padding-box;
  -webkit-background-clip: padding-box;
  background-clip: padding-box;
  -webkit-box-shadow: 2px 2px 7px rgba(0, 0, 0, 0.3);
  -moz-box-shadow: 2px 2px 7px rgba(0, 0, 0, 0.3);
  box-shadow: 2px 2px 7px rgba(0, 0, 0, 0.3);
  padding: 30px 20px 10px;
}
body.home .s2 .point:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
body.home .s2 .point:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
@media screen and (max-width: 740px) {
  body.home .s2 .point {
    position: absolute;
    padding: 20px 20px 10px 110px;
    box-sizing: border-box;
    top: 198px;
    top: 0;
    left: 27px;
    left: 0;
    min-height: 160px;
    -webkit-box-shadow: 2px 2px 7px rgba(0, 0, 0, 0.3);
    -moz-box-shadow: 2px 2px 7px rgba(0, 0, 0, 0.3);
    box-shadow: 2px 2px 7px rgba(0, 0, 0, 0.3);
  }
}
@media screen and (max-width: 740px) {
  body.home .s2 .point:first-child {
    display: block;
  }
}
body.home .s2 .point h3 {
  font-size: 21px;
}
@media screen and (max-width: 740px) {
  body.home .s2 .point h3 {
    font-size: 14px;
  }
  body.home .s2 .point h3 .small {
    font-size: 12px;
  }
}
body.home .s2 .point h3 .small {
  font-size: 14px;
}
body.home .s2 .point .img {
  position: absolute;
  top: -120px;
  left: 85px;
}
@media screen and (max-width: 740px) {
  body.home .s2 .point .img {
    left: 10px;
    top: 30px;
    width: 90px;
    height: 90px;
  }
}
@media screen and (max-width: 740px) {
  body.home .s2 .points.points__pc {
    display: none !important;
  }
}
body.home .s2 .points.points__sp {
  position: relative;
  overflow: hidden;
  height: 220px;
  width: 100%;
  font-size: 14px;
}
@media screen and (min-width: 741px) {
  body.home .s2 .points.points__sp {
    display: none !important;
  }
}
@media screen and (max-width: 740px) {
  body.home .s2 .points.points__sp {
    display: block !important;
  }
}
body.home .s2 .points.points__sp img {
  top: 0;
}
body.home .s2 .points.points__sp h3 {
  margin-bottom: 10px;
  font-weight: bold;
}
body.home .s2 .points.points__sp h3 .small {
  font-weight: bold;
}
body.home .s2 .points .btn--arrow {
  position: absolute;
  top: 35px;
}
body.home .s2 .points .btn--arrow a {
  display: block;
}
body.home .s2 .points .btn--arrow img {
  width: 56px;
  height: auto;
}
body.home .s2 .points .btn--arrow--right {
  right: 0;
}
body.home .s2 .points .btn--area {
  position: absolute;
  width: 60px;
  height: 160px;
  display: block;
  z-index: 100;
  background: 0 0 repeat url(../img/generic/transparent1x1.png);
  cursor: pointer;
  /*
				background-color:rgba(0,255,0,0.5); //debug
				&:hover{
					.opacity(0.6);
				}
*/
}
body.home .s2 .points .btn--area--left {
  left: 0;
}
body.home .s2 .points .btn--area--left:hover + .btn--arrow--left {
  background-color: #aeadae;
}
body.home .s2 .points .btn--area--right {
  right: 0;
}
body.sixpoint--init .s2 .desciption {
  position: relative;
}
body.sixpoint--init .s2 .points {
  display: inline-block;
  position: relative;
  margin: 0 auto;
  width: 858px;
  margin-left: -56px;
}
body.sixpoint--init .s2 .points:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
body.sixpoint--init .s2 .points:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
@media screen and (max-width: 740px) {
  body.sixpoint--init .s2 .points {
    width: 280px;
    margin-left: 0;
    margin-top: 30px;
  }
}
body.sixpoint--init .s2 .btn--arrow {
  display: none !important;
}
body.sixpoint--init .s2 .point {
  display: block;
  float: left;
  position: relative;
  margin: 0 0 160px 20px;
  min-height: 180px;
}
@media screen and (max-width: 740px) {
  body.sixpoint--init .s2 .point {
    margin: 0 0 20px 0px;
    top: inherit;
    left: inherit;
  }
}
body.sixpoint--init .s2 .point--1 {
  float: left;
  position: relative;
}
body.sixpoint--init .s2 .point--2 {
  float: left;
  position: relative;
}
body.sixpoint--init .s2 .point--3 {
  float: left;
  position: relative;
}
body.sixpoint--init .s2 .point--4 {
  float: left;
  position: relative;
}
body.sixpoint--init .s2 .point--5 {
  float: left;
  position: relative;
}
body.sixpoint--init .s2 .point--6 {
  float: left;
  position: relative;
}
body.home .s3 {
  background-color: #dfe9d5;
}
body.home .s3--inner {
  padding-top: 65px;
  padding-bottom: 56px;
}
@media screen and (max-width: 740px) {
  body.home .s3--inner {
    padding-top: 15px;
  }
}
body.home .s3 .title {
  text-align: center;
}
body.home .s3 .title h2 {
  font-size: 16px;
}
@media screen and (max-width: 740px) {
  body.home .s3 .title {
    margin-bottom: 20px;
  }
}
body.home .s3 .title img {
  margin: 0 auto 10px;
}
@media screen and (max-width: 740px) {
  body.home .s3 .title img {
    width: 200px;
    height: auto;
  }
}
body.home .s3 ul {
  margin: 0;
  padding: 0;
  text-align: center;
}
body.home .s3 ul:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
body.home .s3 ul:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
@media screen and (max-width: 740px) {
  body.home .s3 ul {
    padding-left: 20px;
    padding-right: 20px;
  }
}
body.home .s3 li {
  float: left;
  display: inline-block;
  width: 240px;
  margin-left: 28px;
}
@media screen and (max-width: 740px) {
  body.home .s3 li {
    width: 50%;
    margin-left: 0;
    box-sizing: border-box;
  }
  body.home .s3 li:nth-child(odd) {
    padding-right: 5px;
    clear: both;
  }
  body.home .s3 li:nth-child(even) {
    padding-left: 5px;
  }
}
body.home .s3 li.pcClear {
  clear: both;
}
@media screen and (max-width: 740px) {
  body.home .s3 li.pcClear {
    clear: none;
  }
}
@media screen and (min-width: 741px) {
  body.home .s3 li.koutouku {
    margin-left: 160px;
  }
}
@media screen and (min-width: 741px) {
  body.home .s3 li.yokohama p {
    margin-top: 0px;
  }
}
body.home .s3 li p {
  text-align: left;
}
@media screen and (max-width: 740px) {
  body.home .s3 li p {
    font-size: 12px;
    width: 100%;
    min-height: 96px;
  }
}
body.home .s3 li p img {
  margin-bottom: 10px;
}
@media screen and (max-width: 740px) {
  body.home .s3 li p img {
    width: 100%;
  }
}
body.home .s4--inner {
  padding-top: 65px;
  position: relative;
}
@media screen and (max-width: 740px) {
  body.home .s4--inner {
    padding-top: 15px;
  }
}
body.home .s4 .title {
  text-align: center;
  margin-bottom: 20px;
}
body.home .s4 .title h2 {
  font-size: 16px;
}
body.home .s4 .title img {
  margin: 30px auto 10px;
}
@media screen and (max-width: 740px) {
  body.home .s4 .title img {
    width: 200px;
    height: auto;
  }
}
@media screen and (max-width: 740px) {
  body.home .s4 .title--future img {
    height: auto;
  }
}
body.home .s4 .description {
  margin-bottom: 20px;
  width: 660px;
  margin: 0 auto 20px;
  line-height: 1.6em;
}
@media screen and (max-width: 740px) {
  body.home .s4 .description {
    box-sizing: border-box;
    padding-left: 35px;
    padding-right: 35px;
    width: auto;
  }
}
body.home .s4 .incidental .description {
  margin-bottom: 40px;
}
@media screen and (max-width: 740px) {
  body.home .s4 .incidental .description {
    margin-bottom: 20px;
  }
}
body.home .s4 .circle {
  margin-bottom: 72px;
  text-align: center;
}
@media screen and (max-width: 740px) {
  body.home .s4 .circle {
    margin: 0 40px 12px;
  }
}
body.home .s4 .circle img {
  margin-left: 30px;
}
@media screen and (max-width: 740px) {
  body.home .s4 .circle img {
    width: 43%;
    height: auto;
    margin-bottom: 10px;
  }
}
body.home .s4 .circle img:first-child {
  margin-left: 0;
}
@media screen and (max-width: 740px) {
  body.home .s4 .circle img:nth-child(even) {
    margin: 0 0 20px 10px;
  }
}
@media screen and (max-width: 740px) {
  body.home .s4 .circle img:nth-child(odd) {
    margin: 0 10px 20px 0;
  }
}
body.home .s4 .illust {
  display: block;
  margin: 10px auto 26px;
}
@media screen and (max-width: 740px) {
  body.home .s4 .illust {
    box-sizing: border-box;
    width: 100%;
    height: auto;
    padding-left: 20px;
    padding-right: 20px;
  }
}
body.home .s4 .illisimg {
  font-size: 12px;
  display: block;
  position: absolute;
  bottom: 0;
  right: 100px;
}
@media screen and (max-width: 740px) {
  body.home .s4 .illisimg {
    bottom: -30px;
    right: 10px;
    font-size: 11px;
  }
}
body.home .s5 {
  -webkit-box-shadow: 0 1px 10px rgba(0, 0, 0, 0.3);
  -moz-box-shadow: 0 1px 10px rgba(0, 0, 0, 0.3);
  box-shadow: 0 1px 10px rgba(0, 0, 0, 0.3);
}
body.home .s5--inner {
  padding: 65px 0;
  position: relative;
}
body.home .s5--inner:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
body.home .s5--inner:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
@media screen and (max-width: 740px) {
  body.home .s5--inner {
    padding: 65px 0 25px;
  }
}
body.home .s5 .title {
  float: left;
  margin: 3px 35px 0 26px;
  display: block;
  position: relative;
}
@media screen and (max-width: 740px) {
  body.home .s5 .title {
    float: none;
    margin: 3px 25px 0 25px;
  }
}
body.home .s5 .title img {
  margin-bottom: 15px;
}
body.home .s5 .btn--news {
  display: block;
}
@media screen and (max-width: 740px) {
  body.home .s5 .btn--news--wrapper {
    position: absolute;
    top: -6px;
    right: 0;
  }
}
body.home .s5 .btn--news--wrapper:hover {
  -moz-opacity: 0.6;
  -khtml-opacity: 0.6;
  -webkit-opacity: 0.6;
  opacity: 0.6;
}
@media screen and (max-width: 740px) {
  body.home .s5 .entry {
    padding: 0 20px;
  }
}
body.home .s5 #entry-template {
  display: none;
}
body.home .s5 .item {
  border: 1px solid #bfbfbf;
  width: 280px;
  float: left;
  padding: 10px;
  margin-left: 10px;
  min-height: 154px;
  box-sizing: border-box;
  -webkit-border-top-right-radius: 5px;
  -webkit-border-bottom-right-radius: 5px;
  -webkit-border-bottom-left-radius: 5px;
  -webkit-border-top-left-radius: 5px;
  -moz-border-radius-topright: 5px;
  -moz-border-radius-bottomright: 5px;
  -moz-border-radius-bottomleft: 5px;
  -moz-border-radius-topleft: 5px;
  border-top-right-radius: 5px;
  border-bottom-right-radius: 5px;
  border-bottom-left-radius: 5px;
  border-top-left-radius: 5px;
  -moz-background-clip: padding-box;
  -webkit-background-clip: padding-box;
  background-clip: padding-box;
}
body.home .s5 .item section {
  overflow: hidden;
}
@media screen and (max-width: 740px) {
  body.home .s5 .item {
    float: none;
    margin-left: 0;
    margin-bottom: 10px;
    width: 100%;
    min-height: inherit !important;
  }
}
body.home .s5 .item:first-child {
  margin-left: 0;
}
body.home .s5 .item--inner:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
body.home .s5 .item--inner:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
@media screen and (max-width: 740px) {
  body.home .s5 .item--inner {
    min-height: inherit !important;
  }
}
body.home .s5 .item--date {
  margin-bottom: 18px;
}
@media screen and (max-width: 740px) {
  body.home .s5 .item--date {
    margin-bottom: 8px;
  }
}
body.home .s5 .item--photo {
  float: left;
  margin-right: 10px;
}
body.home .s5 .item--photo:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
body.home .s5 .item--photo:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
body.home .s5 .item--photo img {
  display: block;
}
body.home .s5 .item--title {
  display: block;
}
body.home .s5 .item--title a {
  font-size: 16px;
  color: #65a927;
  line-height: 1.6em;
  word-break: break-all;
  word-wrap: break-word;
  overflow-wrap: break-word;
}
@media screen and (min-width: 741px) {
  /*body.home .s5 .item--title a {
    display: inline-block;
    width: 150px;
  }
  body.home .s5 .item--title a::after {
    content: " ";
    width: 10px;
    height: 12px;
    display: block;
  }
  .ie9 body.home .s5 .item--title a:hover::after {
    content: " ";
    width: 10px;
    height: 11px;
    display: block;
  }*/
}
@media screen and (max-width: 740px) {
  body.home .s5 .item--title a {
    font-size: 14px;
  }
}
body.home .s6 {
  position: relative;
  margin-bottom: -2px;
}
body.home .s6 .bg-1, body.home .s6 .bg-2 {
  width: 100%;
  height: 100%;
  position: absolute;
  bottom: 0;
  z-index: -1;
}
body.home .s6 .bg-3, body.home .s6 .bg-4 {
  width: 100%;
  height: 100%;
  position: absolute;
  bottom: 0;
  z-index: -1;
  background-color: rgba(255, 0, 0, 0.2);
}
body.home .s6 .bg-1 {
  background: left bottom no-repeat url(../img/home/img-s6-1.png);
  bottom: -60px;
}
@media screen and (max-width: 1300px) {
  body.home .s6 .bg-1 {
    display: none;
  }
}
body.home .s6 .bg-2 {
  background: right bottom no-repeat url(../img/home/img-s6-2.png);
  bottom: -190px;
}
@media screen and (max-width: 1300px) {
  body.home .s6 .bg-2 {
    display: none;
  }
}
body.home .s6 .bg-3 {
  display: none;
}
@media screen and (max-width: 1300px) {
  body.home .s6 .bg-3 {
    display: block;
    background: left bottom no-repeat url(../img/home/img-s6-1.png);
    bottom: -60px;
    left: -110px;
  }
}
@media screen and (max-width: 740px) {
  body.home .s6 .bg-3 {
    display: none;
  }
}
body.home .s6 .bg-4 {
  display: none;
}
@media screen and (max-width: 1300px) {
  body.home .s6 .bg-4 {
    display: block;
    background: right bottom no-repeat url(../img/home/img-s6-2.png);
    bottom: -190px;
    right: -109px;
  }
}
@media screen and (max-width: 740px) {
  body.home .s6 .bg-4 {
    display: none;
  }
}
body.home .s6--inner {
  padding-bottom: 88px;
  position: relative;
  overflow: hidden;
}
@media screen and (min-width: 1082px) {
  body.home .s6--inner {
    width: 100%;
  }
}
@media screen and (max-width: 740px) {
  body.home .s6--inner {
    padding-bottom: 30px;
  }
}
body.home .s6 .title {
  position: relative;
  width: 660px;
  margin: 0 auto 20px;
}
@media screen and (max-width: 740px) {
  body.home .s6 .title {
    width: 100%;
  }
}
body.home .s6 .title h2 {
  font-size: 16px;
  text-align: center;
}
body.home .s6 .title h2 > img {
  margin: 0 auto 10px;
  display: block;
  padding-top: 50px;
}
@media screen and (max-width: 740px) {
  body.home .s6 .title h2 > img {
    padding-top: 30px;
  }
}
body.home .s6 .title .btn--about--wrapper {
  position: absolute;
  bottom: 0;
  right: -100px;
}
body.home .s6 .title .btn--about--wrapper a img {
  display: block;
  width: 130px
}
@media screen and (max-width: 740px) {
  body.home .s6 .title .btn--about--wrapper {
    right: 5px;
  }
  body.home .s6 .title .btn--about--wrapper a img {
    width: 120px
  }
}
body.home .s6--about table {
  width: 660px;
  margin: 0 auto;
  border-top: 1px solid #000;
  border-bottom: 1px solid #000;
}
@media screen and (max-width: 740px) {
  body.home .s6--about table {
    width: auto;
    margin: 0 20px;
  }
}
body.home .s6--about table th, body.home .s6--about table td {
  border-bottom: 1px solid #bfbfbf;
  padding: 18px 0;
}
@media screen and (max-width: 740px) {
  body.home .s6--about table th, body.home .s6--about table td {
    padding: 18px 0;
  }
}
body.home .s6--about table tr:last-child th, body.home .s6--about table tr:last-child td {
  border-bottom: none;
}
body.home .s6--about table th {
  width: 105px;
  font-weight: normal;
}
body.home .s6--about table .btn--map {
  margin: 10px 0 0;
}
body.home .s6--about table .btn--map a {
  background-color: #559c1e;
  color: #fff;
  -webkit-border-top-right-radius: 5px;
  -webkit-border-bottom-right-radius: 5px;
  -webkit-border-bottom-left-radius: 5px;
  -webkit-border-top-left-radius: 5px;
  -moz-border-radius-topright: 5px;
  -moz-border-radius-bottomright: 5px;
  -moz-border-radius-bottomleft: 5px;
  -moz-border-radius-topleft: 5px;
  border-top-right-radius: 5px;
  border-bottom-right-radius: 5px;
  border-bottom-left-radius: 5px;
  border-top-left-radius: 5px;
  -moz-background-clip: padding-box;
  -webkit-background-clip: padding-box;
  background-clip: padding-box;
  padding: 10px;
  text-align: center;
  display: block;
}
body.home .s6--about table .btn--map a:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
body.home .s6--about table .btn--map a:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
body.home .s6--about table .btn--map a .fa {
  float: right;
  margin-right: 5px;
  margin-top: 2px;
}
body.home .s6--about table .btn--map img {
  width: 100%;
  max-width: 260px;
}
body.home .s6--greetings .description {
  width: 660px;
  margin: 0 auto;
  line-height: 1.8em;
}
@media screen and (max-width: 740px) {
  body.home .s6--greetings .description {
    width: auto;
    margin: 0 20px;
  }
}
body.home .s6--greetings .description .sign {
  text-align: right;
  display: block;
  margin: 0 0 0 auto;
}
@media screen and (max-width: 740px) {
  body.home .s6--greetings .description .sign {
    margin: 0 auto;
  }
  body.home .s6--greetings .description .sign img {
    width: 119px;
    height: auto;
  }
}
body.home .s7 {
  margin-bottom: -2px;
}
body.home .s7 #googlemap {
  width: 100%;
  height: 348px;
}
@media screen and (max-width: 740px) {
  body.home .s7 {
    display: none;
  }
}
body.news {
  background: no-repeat right top url(../img/news/bg-list.png);
}
@media screen and (max-width: 740px) {
  body.news {
    background: no-repeat right top url(../img-sp/generic/bg-list.png);
    background-size: 185px 203px;
  }
}
body.news a {
  color: #3A7B00;
  text-decoration: none;
}
body.news .canvas {
  width: 820px;
  margin: 40px auto 50px;
  display: block;
  position: relative;
  background-color: #fff;
  -webkit-box-shadow: 0 1px 7px rgba(0, 0, 0, 0.3);
  -moz-box-shadow: 0 1px 7px rgba(0, 0, 0, 0.3);
  box-shadow: 0 1px 7px rgba(0, 0, 0, 0.3);
}
@media screen and (max-width: 740px) {
  body.news .canvas {
    width: auto;
    margin: 20px;
  }
}
body.news .title {
  padding: 82px 0 20px 0;
  margin: 0 25px 20px;
  border-bottom: 1px solid #bfbfbf;
}
@media screen and (max-width: 740px) {
  body.news .title {
    margin: 0 25px 20px;
    padding: 82px 0 20px 0;
  }
}
body.news .title h1 span {
  text-indent: -9999px;
  position: fixed;
  top: -100%;
  left: -100%;
}
body.news .logo {
  position: absolute;
  top: 18px;
  right: 16px;
}
@media screen and (max-width: 740px) {
  body.news .logo img {
    width: 55px;
    height: auto;
  }
}
body.news .btn--index {
  position: absolute;
  left: 0;
  top: 0;
}
@media screen and (max-width: 740px) {
  body.news .btn--index img {
    width: 99px;
    height: auto;
  }
}
body.news .btn--index a:hover {
  -moz-opacity: 0.6;
  -khtml-opacity: 0.6;
  -webkit-opacity: 0.6;
  opacity: 0.6;
}
body.news .btn--index--backhome {
  display: none;
}
body.news--index .list {
  margin: 0 25px;
}
body.news--index .item {
  background: 0 bottom repeat-x url(../img/news/line-news-1.png);
  margin-bottom: 15px;
  box-sizing: border-box;
}
body.news--index .item:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
body.news--index .item:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
body.news--index .item--inner {
  position: relative;
}
body.news--index .item--inner:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
body.news--index .item--inner:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
@media screen and (min-width: 741px) {
  body.news--index .item--inner {
    padding-bottom: 20px;
  }
}
@media screen and (max-width: 740px) {
  body.news--index .item--inner {
    position: relative;
  }
}
body.news--index .item--title {
  padding-bottom: 20px;
  display: table-cell;
}
body.news--index .item--title a {
  display: block;
}
@media screen and (max-width: 740px) {
  body.news--index .item--title {
    width: initial;
    box-sizing: border-box;
    padding-top: 0;
  }
}
body.news--index .item--title h2 {
  font-size: 16px;
  font-weight: normal;
  display: inline-block;
}
@media screen and (max-width: 740px) {
  body.news--index .item--title h2 {
    font-size: 12px;
  }
}
body.news--index .item--date {
  display: block;
  padding-right: 20px;
  padding-top: 10px;
  margin-bottom: 18px;
}
@media screen and (min-width: 741px) {
  body.news--index .item--date {
    top: 0;
    padding-top: 0;
  }
}
@media screen and (max-width: 740px) {
  body.news--index .item--date {
    width: initial;
    box-sizing: border-box;
    padding-right: 50px;
    padding-top: 0;
    font-size: 12px;
  }
}
body.news--index .item--photo {
  float: left;
  margin-right: 10px;
  margin-bottom: 18px;
}
@media screen and (max-width: 740px) {
  body.news--index .item--photo {
    padding-left: 0;
  }
}
body.news--index .item--photo img {
  display: block;
}
body.news--index .pagenavi {
  padding-top: 20px;
  text-align: center;
  padding-bottom: 30px;
}
@media screen and (max-width: 740px) {
  body.news--index .pagenavi {
    font-size: 12px;
  }
}
body.news--detail .article {
  margin-right: 40px;
  padding-bottom: 65px;
  margin-left: 40px;
}
@media screen and (max-width: 740px) {
  body.news--detail .article {
    margin-left: 25px;
    margin-right: 25px;
    padding-bottom: 20px;
    font-size: 12px;
  }
}
body.news--detail .article .item--title {
  margin-bottom: 27px;
}
@media screen and (max-width: 740px) {
  body.news--detail .article .item--title {
    margin-bottom: 10px;
  }
  body.news--detail .article .item--title h2 {
    font-size: 19px;
  }
}
body.news--detail .article .item--date {
  margin-bottom: 30px;
  text-align: right;
}
body.news--detail .article .item--photo {
  margin-bottom: 40px;
  padding: 0 66px;
}
@media screen and (max-width: 740px) {
  body.news--detail .article .item--photo {
    padding: 0;
    margin-bottom: 20px;
  }
}
body.news--detail .article .item--photo--thumb {
  margin-bottom: 15px;
}
@media screen and (max-width: 740px) {
  body.news--detail .article .item--photo--thumb {
    margin-bottom: 8px;
  }
}
body.news--detail .article .item--photo--thumb img {
  display: block;
  max-width: 608px;
  width: auto;
}
@media screen and (max-width: 740px) {
  body.news--detail .article .item--photo--thumb img {
    width: 100%;
  }
}
body.news--detail .article .item--photo--caption {
  font-size: 12px;
}
@media screen and (max-width: 740px) {
  body.news--detail .article .item--photo--caption {
    font-size: 10px;
  }
}
body.news--detail .article .item--description {
  margin-bottom: 40px;
  line-height: 1.6em;
}
@media screen and (max-width: 740px) {
  body.news--detail .article .item--description {
    margin-bottom: 20px;
  }
}
body.news--detail .article .item--description a.blank {
  margin-right: 4px;
}
body.news--detail .article .item--description a.blank::after {
  float: none;
  padding-right: 20px;
  right: 0;
  margin: 0;
  margin-right: 4px;
  padding: 0 0 0 2px;
  display: inline-block;
}
body.news--detail .article .item h3 {
  border-left: 7px solid #ca0029;
  padding: 6px 10px;
  box-sizing: border-box;
  display: block;
  font-size: 18px;
  margin-bottom: 10px;
}
@media screen and (max-width: 740px) {
  body.news--detail .article .item h3 {
    margin-bottom: 20px;
    font-size: 12px;
  }
}
body.policy {
  line-height: 1.6em;
}
body.policy .spolicy--inner h2 {
  font-size: 16px;
  text-align: center;
}
body.policy .spolicy--inner h2 img {
  margin: 30px auto 10px;
}
body.policy .spolicy--inner .illust {
  width: 100%;
}
body.policy h1 {
  font-size: 16px;
}
body.policy h1:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
body.policy h1:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
body.policy h1 img {
  float: left;
  margin: 0 24px 0 0;
}
@media screen and (max-width: 740px) {
  body.policy h1 img {
    width: 292px;
    height: auto;
    max-width: 100%;
  }
}
body.policy h1 span {
  float: left;
  display: inline-block;
  margin-top: 7px;
}
body.policy h2, body.policy h3, body.policy h4 {
  margin-bottom: 10px;
  font-weight: bold;
}
body.policy h2 {
  margin-bottom: 30px;
  font-size: 1.5em;
}
body.policy h3 {
  font-size: 1.17em;
}
body.policy p {
  margin: 1em 0;
}
body.policy p.disc {
  display: list-item;
  list-style-type: disc;
  margin-left: 20px;
}
body.policy table {
  border: 1px solid #bfbfbf;
  border-style: solid none none solid;
  width: 100%;
  margin-bottom: 30px;
}
body.policy table th, body.policy table td {
  border: 1px solid #bfbfbf;
  border-style: none solid solid none;
  padding: 8px 10px;
  vertical-align: middle;
}
body.policy .logo {
  position: absolute;
  top: 18px;
  right: 16px;
}
@media screen and (max-width: 740px) {
  body.policy .logo img {
    width: 56px;
    height: auto;
  }
}
body.policy .btn--index {
  position: absolute;
  left: 0;
  top: 0;
}
@media screen and (max-width: 740px) {
  body.policy .btn--index img {
    width: 99px;
    height: auto;
  }
}
body.policy .btn--index a:hover {
  -moz-opacity: 0.6;
  -khtml-opacity: 0.6;
  -webkit-opacity: 0.6;
  opacity: 0.6;
}
body.policy .fa {
  font-size: 11px;
  position: relative;
  top: -2px;
}
body.policy .ppolicy {
  background: 0 bottom repeat-x url(../img/news/line-news-1.png);
  margin-bottom: 15px;
  box-sizing: border-box;
  padding: 0 35px 35px;
  margin-bottom: 70px;
}
body.policy .spolicy {
  padding: 0 35px;
}
body.notfound {
  background: no-repeat right top url(../img/news/bg-list.png);
}
@media screen and (max-width: 740px) {
  body.notfound {
    background: no-repeat right top url(../img-sp/generic/bg-list.png);
    background-size: 185px 203px;
  }
}
body.notfound a {
  color: #65a927;
  text-decoration: none;
}
body.notfound .canvas {
  width: 820px;
  margin: 40px auto 50px;
  display: block;
  position: relative;
  background-color: #fff;
  -webkit-box-shadow: 0 1px 7px rgba(0, 0, 0, 0.3);
  -moz-box-shadow: 0 1px 7px rgba(0, 0, 0, 0.3);
  box-shadow: 0 1px 7px rgba(0, 0, 0, 0.3);
}
@media screen and (max-width: 740px) {
  body.notfound .canvas {
    width: auto;
    margin: 20px;
  }
}
body.notfound .title {
  padding: 82px 0 20px 0;
  margin: 0 25px 20px;
  border-bottom: 1px solid #bfbfbf;
}
@media screen and (max-width: 740px) {
  body.notfound .title {
    margin: 0 25px 20px;
    padding: 82px 0 20px 0;
  }
}
body.notfound .title h1 span {
  text-indent: -9999px;
  position: fixed;
  top: -100%;
  left: -100%;
  color: #ca0029;
  font-size: 24px;
}
body.notfound .logo {
  position: absolute;
  top: 18px;
  right: 16px;
}
@media screen and (max-width: 740px) {
  body.notfound .logo img {
    width: 56px;
    height: auto;
  }
}
body.notfound .btn--index {
  position: absolute;
  left: 0;
  top: 0;
}
@media screen and (max-width: 740px) {
  body.notfound .btn--index img {
    width: 99px;
    height: auto;
  }
}
body.notfound .btn--index a:hover {
  -moz-opacity: 0.6;
  -khtml-opacity: 0.6;
  -webkit-opacity: 0.6;
  opacity: 0.6;
}
body.notfound .content {
  margin: 0 25px;
  margin-bottom: 15px;
  box-sizing: border-box;
}
body.notfound .content--inner {
  position: relative;
}
body.notfound .content--inner:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
body.notfound .content--inner:after {
  clear: both;
  height: 0;
  visibility: hidden;
  font-size: 0;
  display: block;
  content: "";
}
@media screen and (min-width: 741px) {
  body.notfound .content--inner {
    padding-bottom: 20px;
  }
}
@media screen and (max-width: 740px) {
  body.notfound .content--inner {
    position: relative;
  }
}
@media screen and (min-height: 857px) {
  body.notfound .footer {
    position: fixed;
    bottom: 0;
  }
}
