@charset "UTF-8";
/*
Copyright (c) 2008, Yahoo! Inc. All rights reserved.
Code licensed under the BSD License:
http://developer.yahoo.net/yui/license.txt
version: 2.5.0 + 03
*/
/*html{color:#000;background:#FFF;}*/
body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, code, form, fieldset, legend, input, textarea, p, blockquote {
  margin: 0;
  padding: 0;
}

/*table{border-collapse:collapse;border-spacing:0;}*/
fieldset, img {
  border: 0;
}

address, caption, cite, code, dfn, em, th, var {
  font-style: normal;
  font-weight: normal;
}

li {
  list-style: none;
}

caption, th {
  text-align: left;
}

h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  font-weight: normal;
}

q:before, q:after {
  content: '';
}

abbr, acronym {
  border: 0;
  font-variant: normal;
}

sup {
  vertical-align: text-top;
}

sub {
  vertical-align: text-bottom;
}

/*input,textarea,select{font-family:inherit;font-size:inherit;font-weight:inherit;}input,textarea,select{*font-size:100%;}*/
legend {
  color: #000;
}

table {
  font-size: inherit;
  font: 100%;
}

pre, code, kbd, samp, tt {
  font-family: monospace;
  *font-size: 108%;
  line-height: 100%;
}

/* green */
/* green yellow */
html, body {
  -webkit-text-size-adjust: none;
}

body {
  margin: 0;
  padding: 0;
  font-size: 13px;
  color: #453525;
  font-family: "游ゴシック", YuGothic, Verdana, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  font-weight: 500;
}

a {
  color: #00a364;
}

a:hover {
  color: #8bc120;
}

* {
  box-sizing: border-box;
}

*:before,
*:after {
  box-sizing: border-box;
}

a {
  text-decoration: none;
}

a:focus {
  outline: thin dotted;
  outline: 5px auto -webkit-focus-ring-color;
  outline-offset: -2px;
}

_:-ms-lang(x)::-ms-backdrop, *[srcset$=".svg"] {
  width: 100%;
}

/* IE11 */
_:-ms-lang(x)::-ms-backdrop, *[src$=".svg"] {
  width: 100%;
}

/* IE11 */
@font-face {
  font-family: 'tradegothic';
  /* お好きな名前にしましょう */
  src: url("font/tradegothicltstd-bdcn20-webfont.ttf") format("truetype");
  /* iOS, Android用 */
  font-weight: normal;
  /* 念の為指定しておきます */
  font-style: normal;
}
.spacer {
  width: 100%;
  clear: both;
  display: block;
  overflow: hidden;
}

.spacer.spacer-1 {
  height: 1px;
}

.spacer.spacer-10 {
  height: 10px;
}

.spacer.spacer-20 {
  height: 20px;
}

.spacer.spacer-30 {
  height: 30px;
}

.spacer.spacer-40 {
  height: 40px;
}

.spacer.spacer-50 {
  height: 50px;
}

.spacer.spacer-60 {
  height: 60px;
}

.spacer.spacer-70 {
  height: 70px;
}

.bold {
  font-weight: bold;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

@media screen and (max-width: 750px) {
  .hidden-xs {
    display: none;
  }
}

@media (min-width: 751px), print {
  .visible-xs {
    display: none;
  }
}

.container {
  padding: 0 15px;
}
@media (min-width: 751px), print {
  .container {
    max-width: 900px;
    margin-left: auto;
    margin-right: auto;
  }
}

header {
  padding: 10px 15px;
  color: #fff;
  background: #323232;
  line-height: 1;
}
header .inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media screen and (max-width: 750px) {
  header .inner > * {
    width: 50%;
  }
}
header img {
  max-width: 100%;
  height: auto;
}
header nav {
  display: flex;
}
header nav a {
  display: inline-block;
  margin-left: 15px;
}
@media (min-width: 751px), print {
  header nav a {
    margin-left: 25px;
  }
}

.floating-nav {
  padding: 4.5% 0 0;
  text-align: center;
}
.floating-nav a {
  display: inline-block;
}
.floating-nav img {
  max-width: 37px;
}
@media screen and (max-width: 750px) {
  .floating-nav img {
    max-width: 6vw;
  }
}

header {
  padding: 10px 15px;
  color: #fff;
  background: #323232;
  line-height: 1;
}
header .inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media screen and (max-width: 750px) {
  header .inner > * {
    width: 50%;
  }
}
header img {
  max-width: 100%;
  height: auto;
}
header nav {
  display: flex;
}
header nav a {
  display: inline-block;
  margin-left: 15px;
}
@media (min-width: 751px), print {
  header nav a {
    margin-left: 25px;
  }
}

footer {
  margin-top: 4%;
  padding: 10px 15px;
  color: #fff;
  background: #323232;
  line-height: 1;
}
footer .inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media screen and (max-width: 750px) {
  footer .inner > * {
    width: 50%;
  }
}
@media (min-width: 751px), print {
  footer .logo {
    display: flex;
    align-items: flex-end;
  }
}
@media (min-width: 751px), print {
  footer .administrator {
    margin-left: 15px;
  }
}
@media screen and (max-width: 750px) {
  footer .administrator {
    margin-top: 5px;
    font-size: 12px;
    font-size: 1.6vw;
  }
}
footer .administrator a {
  position: relative;
  display: inline-block;
  padding-left: 1em;
  color: #fff;
  text-decoration: underline;
}
footer .administrator a:before {
  position: absolute;
  content: "・";
  left: 0;
  top: 0;
}
footer img {
  max-width: 100%;
  height: auto;
}
footer nav {
  display: flex;
}
footer nav a {
  display: inline-block;
  margin-left: 15px;
}
@media (min-width: 751px), print {
  footer nav a {
    margin-left: 25px;
  }
}

/*
footer {
  margin-top: 4%;
  .inner {
    max-width: 900px;
    margin-left: auto;
    margin-right: auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 15px;
    > * {
      @include max-xs {
        width: 50%;
      }
    }
  }
  img {
    max-width: 100%;
    height: auto;
  }
  @include min-sm {
    margin-top: 25px;
  }
  padding: 4.5% 0 12.5%;
  @include min-sm {
    padding-top: 30px;
    padding-bottom: 135px;
  }
  color: #fff;
  background: #323232;
  @include min-sm {
    background: #333d47;
  }
}
  nav {
    display: flex;
    a {
      display: inline-block;
      margin-left: 15px;
      @include min-sm {
        margin-left: 25px;
      }
    }
  }
*/
#featured {
  position: relative;
}
@media screen and (max-width: 750px) {
  #featured {
    margin-bottom: 60px;
  }
}
@media (min-width: 751px), print {
  #featured:before {
    content: "";
    display: block;
    position: absolute;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 13%;
    background: url(../img/featured_white_mask.png);
    background-size: 100% auto;
    z-index: 5;
  }
}
#featured .featured-image img {
  width: 100%;
  height: auto;
}
#featured .featured-copy {
  position: absolute;
  top: 11%;
  left: 0;
  z-index: 2;
}
@media screen and (max-width: 750px) {
  #featured .featured-copy {
    width: 100%;
    text-align: center;
    padding: 0 14%;
  }
}
@media (min-width: 751px), print {
  #featured .featured-copy {
    top: 15%;
    left: 9%;
    max-width: 45%;
  }
}
#featured .featured-text {
  color: #fff;
  background: #3b68a9;
  padding: 7.5% 13% 5.4%;
  z-index: 2;
  opacity: 0;
  -webkit-transition: all 0.7s;
  -o-transition: all 0.7s;
  transition: all 0.7s;
}
@media (min-width: 751px), print {
  #featured .featured-text {
    padding: 40px;
    position: absolute;
    width: 272px;
    padding: 25px 21px;
    left: 8%;
    top: 17vw;
    background: rgba(59, 104, 169, 0.8);
    transform: translateY(5%);
  }
  #featured .featured-text .lead {
    margin-bottom: 15px;
    font-size: 16px;
    font-weight: bold;
    line-height: 1.5;
  }
}
@media (max-width: 900px) and (min-width: 750px) {
  #featured .featured-text {
    top: 45%;
    width: 540px;
  }
}
#featured .featured-text .text {
  font-size: 12px;
  line-height: 1.7;
}
@media screen and (max-width: 750px) {
  #featured .featured-text .text {
    font-size: 24px;
    font-size: 3.2vw;
  }
}
#featured .featured-text:after {
  position: absolute;
  content: "";
  display: block;
  bottom: -15px;
  left: 0;
  width: 100%;
  height: 15px;
  background: linear-gradient(to top left, rgba(255, 255, 255, 0) 50%, rgba(59, 104, 169, 0.8) 50.5%) no-repeat top left/100% 100%;
}
@media screen and (max-width: 750px) {
  #featured .featured-text:after {
    bottom: -5%;
    height: 5%;
    background: linear-gradient(to top left, rgba(255, 255, 255, 0) 50%, #3b68a9 50.5%) no-repeat top left/100% 100%;
  }
}

@media (min-width: 751px), print {
  #featured {
    overflow: hidden;
  }
}
#featured:after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 0%;
  height: 100%;
  background: #78a8af;
  z-index: 1;
  -webkit-transition: all 0.7s;
  -o-transition: all 0.7s;
  transition: all 0.7s;
}
#featured .featured-image {
  visibility: hidden;
}
#featured.s1:after {
  width: 100%;
}
#featured.s2 .featured-image {
  visibility: visible;
}
#featured.s2:after {
  left: 100%;
  width: 0;
}
#featured.s2 .featured-text {
  opacity: 1;
  transform: translateY(0);
}

#weather {
  margin-bottom: 60px;
}
@media (min-width: 751px), print {
  #weather {
    margin-bottom: 90px;
  }
}

@media (min-width: 751px), print {
  .weather-wrap {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-around;
    align-items: center;
  }
}
.weather-wrap .main-wrap {
  position: relative;
}
@media (max-width: 900px) and (min-width: 750px) {
  .weather-wrap .main-wrap {
    min-height: 70px;
  }
}
.weather-wrap .main-wrap .date-wrap {
  padding-right: 5px;
}
@media screen and (max-width: 750px) {
  .weather-wrap .main-wrap .date-wrap {
    text-align: center;
    margin-bottom: 8px;
  }
}
.weather-wrap .main-wrap .title {
  margin-bottom: 5px;
  line-height: 1;
  font-weight: bold;
}
@media screen and (max-width: 750px) {
  .weather-wrap .main-wrap .title {
    margin-bottom: 5px;
    font-size: 34px;
    font-size: 4.5333333333vw;
  }
}
.weather-wrap .main-wrap .date {
  font-size: 14px;
  font-family: 'Roboto', sans-serif;
  font-weight: bold;
}
@media (max-width: 900px) {
  .weather-wrap .main-wrap .date {
    font-size: 14px;
    font-size: 1.1666666667vw;
  }
}
@media screen and (max-width: 750px) {
  .weather-wrap .main-wrap .date {
    font-size: 36px;
    font-size: 4.8vw;
  }
}
.weather-wrap .main-wrap .date .number {
  padding-right: 10px;
}
.weather-wrap .main-wrap .time {
  font-size: 13px;
}
@media (max-width: 900px) {
  .weather-wrap .main-wrap .time {
    font-size: 13px;
    font-size: 1.0833333333vw;
  }
}
@media screen and (max-width: 750px) {
  .weather-wrap .main-wrap .time {
    font-size: 36px;
    font-size: 4.8vw;
  }
}
.weather-wrap .main-wrap .day-weather-wrap {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
}
@media (min-width: 751px), print {
  .weather-wrap .main-wrap .day-weather-wrap {
    justify-content: space-around;
  }
}
.weather-wrap .main-wrap .day-weather {
  padding-right: 5px;
}
@media (max-width: 900px) {
  .weather-wrap .main-wrap .day-weather {
    max-width: 8vw;
  }
}
@media screen and (max-width: 750px) {
  .weather-wrap .main-wrap .day-weather {
    max-width: inherit;
  }
}
.weather-wrap .main-wrap .temp {
  font-size: 15px;
}
@media (max-width: 900px) {
  .weather-wrap .main-wrap .temp {
    font-size: 15px;
    font-size: 1.25vw;
  }
}
@media (max-width: 850px) and (min-width: 750px) {
  .weather-wrap .main-wrap .temp {
    width: 5vw;
  }
}
@media screen and (max-width: 750px) {
  .weather-wrap .main-wrap .temp {
    font-size: 19px;
    font-size: 2.5333333333vw;
  }
}
.weather-wrap .main-wrap .temp .number, .weather-wrap .main-wrap .temp .split {
  font-size: 25px;
}
@media (max-width: 900px) {
  .weather-wrap .main-wrap .temp .number, .weather-wrap .main-wrap .temp .split {
    font-size: 25px;
    font-size: 2.0833333333vw;
  }
}
@media screen and (max-width: 750px) {
  .weather-wrap .main-wrap .temp .number, .weather-wrap .main-wrap .temp .split {
    font-size: 38px;
    font-size: 5.0666666667vw;
  }
}
.weather-wrap .main-wrap .temp .split {
  letter-spacing: -2px;
}
@media (min-width: 751px), print {
  .weather-wrap .main-wrap-row {
    display: flex;
  }
}
.weather-wrap .temp {
  font-family: 'Roboto', sans-serif;
  font-weight: bold;
}
.weather-wrap .weater-text {
  font-size: 8px;
  line-height: 1.3;
}
@media (max-width: 900px) {
  .weather-wrap .weater-text {
    font-size: 8px;
    font-size: 0.6666666667vw;
  }
}
@media screen and (max-width: 750px) {
  .weather-wrap .weater-text {
    font-size: 20px;
    font-size: 2.6666666667vw;
  }
}
@media (min-width: 751px), print {
  .weather-wrap .weater-text {
    position: absolute;
    left: 0;
    bottom: 0;
  }
}
@media screen and (max-width: 750px) {
  .weather-wrap .weater-text {
    margin-bottom: 20px;
    padding: 25px 0;
    display: flex;
    justify-content: space-around;
    border-bottom: 1px solid #323232;
  }
}
@media (min-width: 751px), print {
  .weather-wrap .week-wrap {
    padding-left: 20px;
    border-left: 1px solid #323232;
  }
}
.weather-wrap .week-items {
  display: flex;
  flex-wrap: nowrap;
}
@media screen and (max-width: 750px) {
  .weather-wrap .week-items {
    justify-content: space-around;
  }
}
.weather-wrap .week-items .item {
  padding: 0 2px;
  text-align: center;
}
@media (min-width: 751px), print {
  .weather-wrap .week-items .item {
    padding: 0 15px;
  }
}
.weather-wrap .week-items .item img {
  max-width: 60px;
  height: auto;
}
@media (max-width: 900px) {
  .weather-wrap .week-items .item img {
    max-width: 5vw;
  }
}
@media screen and (max-width: 750px) {
  .weather-wrap .week-items .item img {
    max-width: 50px;
  }
}
.weather-wrap .week-items .week {
  font-size: 11px;
  font-family: 'Roboto', sans-serif;
}
.weather-wrap .week-items .temp {
  font-size: 4px;
  font-family: 'Roboto', sans-serif;
}
@media (max-width: 900px) {
  .weather-wrap .week-items .temp {
    font-size: 4px;
    font-size: 0.3333333333vw;
  }
}
@media screen and (max-width: 750px) {
  .weather-wrap .week-items .temp {
    font-size: 5px;
  }
}
.weather-wrap .week-items .temp .number {
  font-size: 11px;
}
@media (max-width: 900px) {
  .weather-wrap .week-items .temp .number {
    font-size: 11px;
    font-size: 0.9166666667vw;
  }
}
@media screen and (max-width: 750px) {
  .weather-wrap .week-items .temp .number {
    font-size: 10px;
  }
}

.weather-quote {
  margin-top: 10px;
  font-size: 8px;
  text-align: right;
}

#home-route {
  margin-bottom: 17%;
}
@media (min-width: 751px), print {
  #home-route {
    margin-bottom: 100px;
  }
}
#home-route .inner {
  position: relative;
}
@media (min-width: 751px), print {
  #home-route .inner {
    max-width: 900px;
    height: 318px;
    margin-left: auto;
    margin-right: auto;
    background: url(../img/home_route_base.png) no-repeat center;
  }
}
#home-route .inner:after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: #fff;
  -webkit-transition: all 0.6s;
  -o-transition: all 0.6s;
  transition: all 0.6s;
}
#home-route.appeared .inner:after {
  width: 0%;
}
#home-route .image {
  z-index: 1;
}
@media screen and (max-width: 750px) {
  #home-route .image {
    position: relative;
    transform: translateX(-100%);
    -webkit-transition: all 0.4s;
    -o-transition: all 0.4s;
    transition: all 0.4s;
  }
}
@media (min-width: 751px), print {
  #home-route .image {
    position: absolute;
    top: -16px;
    left: 25px;
  }
}
@media screen and (max-width: 750px) {
  #home-route.appeared .image {
    transform: translateX(0);
  }
}
@media screen and (max-width: 750px) {
  #home-route .base {
    position: relative;
    margin-top: -4%;
    padding: 13% 12% 13%;
    color: #fff;
    font-size: 24px;
    font-size: 3.2vw;
    background: #78a8b0;
  }
  #home-route .base:after {
    position: absolute;
    content: "";
    display: block;
    bottom: -2.6%;
    left: 0;
    width: 100%;
    height: 2.6%;
    z-index: -1;
    background: linear-gradient(to top right, rgba(255, 255, 255, 0) 50%, #78a8b0 50.5%) no-repeat top right/100% 100%;
  }
}
@media (min-width: 751px), print {
  #home-route .base {
    padding-left: 450px;
    padding-right: 28px;
  }
}
#home-route .heading {
  margin-bottom: 5.5%;
}
@media (min-width: 751px), print {
  #home-route .heading {
    margin-bottom: 20px;
    padding-top: 100px;
  }
}
#home-route .text {
  color: #fff;
  font-size: 12px;
}
@media screen and (max-width: 750px) {
  #home-route .text {
    font-size: 24px;
    font-size: 3.2vw;
  }
}
#home-route .more {
  position: absolute;
  z-index: 1;
}
@media screen and (max-width: 750px) {
  #home-route .more {
    left: 0;
    bottom: -8%;
    width: 100%;
  }
}
@media (min-width: 751px), print {
  #home-route .more {
    right: 30px;
    bottom: -5px;
  }
}
#home-route .more a {
  display: block;
  padding: 15px 10px 15px 40px;
  color: #fff;
  font-weight: bold;
  line-height: 1;
  background: #9b1460;
  z-index: 1;
}
@media screen and (max-width: 750px) {
  #home-route .more a {
    width: 57%;
    margin-left: auto;
    margin-right: auto;
  }
}

@media (min-width: 751px), print {
  #facebook {
    margin-bottom: 80px;
  }
}
#facebook .heading {
  margin-bottom: 40px;
  text-align: center;
}
@media screen and (max-width: 750px) {
  #facebook .heading {
    width: 30%;
    margin-left: auto;
    margin-right: auto;
  }
}
#facebook .facebook-wrap {
  display: flex;
  flex-direction: column-reverse;
}
@media (min-width: 751px), print {
  #facebook .facebook-wrap {
    flex-direction: row;
  }
}
#facebook .timeline {
  overflow: hidden;
  position: relative;
}
@media (min-width: 751px), print {
  #facebook .timeline {
    width: 50%;
  }
}
@media screen and (max-width: 750px) {
  #facebook .timeline {
    margin-bottom: 90px;
  }
}
#facebook .timeline .title {
  margin-bottom: 40px;
  padding: 23px 0;
  color: #2f3746;
  line-height: 1.7;
  font-weight: bold;
  border-top: 1px solid #323232;
  border-bottom: 1px solid #323232;
}
@media screen and (max-width: 750px) {
  #facebook .timeline .title {
    width: 80%;
    margin-left: auto;
    margin-right: auto;
    padding: 4.4% 0;
    text-align: center;
    line-height: 1.5;
    font-size: 34px;
    font-size: 4.5333333333vw;
  }
}
@media (min-width: 751px), print {
  #facebook .timeline .title {
    font-size: 16px;
  }
}
@media (min-width: 751px), print {
  #facebook .timeline:first-child {
    padding-right: 30px;
  }
}
@media (min-width: 751px), print {
  #facebook .timeline:last-child {
    padding-left: 30px;
  }
}
#facebook .fb-container {
  text-align: center;
}

#page-title {
  position: relative;
}
@media (min-width: 751px), print {
  #page-title:before {
    content: "";
    display: block;
    position: absolute;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 20%;
    background: url(../img/pagetitle_white_mask.png);
    background-size: 100% auto;
    z-index: 2;
  }
}
@media (min-width: 751px), print {
  #page-title:after {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    width: 0%;
    height: 100%;
    background: #78a8af;
    z-index: 1;
    -webkit-transition: all 0.7s;
    -o-transition: all 0.7s;
    transition: all 0.7s;
  }
}
#page-title.s1:after {
  width: 100%;
}
#page-title.s2 .page-title-bg .page-title-bg__img {
  visibility: visible;
}
#page-title.s2:after {
  left: 100%;
  width: 0;
}
#page-title .page-title-bg {
  position: relative;
}
#page-title .page-title-bg .page-title-bg__img {
  width: 100%;
  visibility: hidden;
}
@media screen and (max-width: 750px) {
  #page-title .page-title-bg:after {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    width: 0%;
    height: 100%;
    background: #78a8af;
    z-index: 1;
    -webkit-transition: all 0.7s;
    -o-transition: all 0.7s;
    transition: all 0.7s;
  }
}
#page-title.s1 .page-title-bg:after {
  width: 100%;
}
#page-title.s2 .page-title-bg .page-title-bg__img {
  visibility: visible;
}
#page-title.s2 .page-title-bg:after {
  left: 100%;
  width: 0;
}
#page-title .page-title-line {
  margin-top: -10%;
  z-index: -1;
}
#page-title .page-title-line img {
  width: 100%;
}
#page-title .page-title {
  position: absolute;
}
@media screen and (max-width: 750px) {
  #page-title .page-title {
    top: 16%;
    left: 0;
    width: 100%;
    text-align: center;
    z-index: 2;
  }
  #page-title .page-title img {
    max-width: 58%;
  }
}
@media (min-width: 751px), print {
  #page-title .page-title {
    top: 34%;
    left: 7%;
    z-index: 2;
  }
}
@media screen and (max-width: 750px) {
  #page-title .page-title-route {
    position: relative;
    padding-top: 4%;
    color: #fff;
    text-align: center;
    background: #78a8b0;
  }
  #page-title .page-title-route img {
    max-width: 43%;
  }
}
@media (min-width: 751px), print {
  #page-title .page-title-route {
    position: absolute;
    bottom: 16%;
    left: 13%;
    z-index: 2;
  }
}
@media (min-width: 751px) and (max-width: 915px), print and (max-width: 915px) {
  #page-title .page-title-route img {
    max-width: 360px;
  }
}

@media screen and (max-width: 750px) {
  #page-title .page-title-route:after {
    position: absolute;
    content: "";
    display: block;
    bottom: -50%;
    left: 0;
    width: 100%;
    height: 50%;
    background: linear-gradient(to top left, rgba(255, 255, 255, 0) 50%, #78a8b0 50.5%) no-repeat top left/100% 100%;
  }
}
#page-title .page-title-note {
  position: relative;
}
@media screen and (max-width: 750px) {
  #page-title .page-title-note {
    padding-top: 15%;
    padding-bottom: 7%;
    color: #fff;
    background: #323232;
    z-index: -1;
  }
}
@media (min-width: 751px), print {
  #page-title .page-title-note {
    position: absolute;
    bottom: 12%;
    right: 5%;
    padding: 35px 20px 30px;
    color: #fff;
    background: rgba(63, 63, 63, 0.8);
    z-index: 2;
  }
}
#page-title .page-title-note:after {
  position: absolute;
  content: "";
  display: block;
  bottom: -10px;
  left: 0;
  width: 100%;
  height: 10px;
  background: linear-gradient(to top left, rgba(255, 255, 255, 0) 50%, rgba(63, 63, 63, 0.8) 50.5%) no-repeat top left/100% 100%;
}
@media screen and (max-width: 750px) {
  #page-title .page-title-note:after {
    bottom: -13%;
    height: 13%;
    background: linear-gradient(to top right, rgba(255, 255, 255, 0) 50%, #323232 50.5%) no-repeat top right/100% 100%;
  }
}
@media screen and (max-width: 750px) {
  #page-title .page-title-note .wrap {
    display: flex;
    justify-content: space-around;
  }
}
@media screen and (max-width: 750px) {
  #page-title .page-title-note .wrap dl {
    text-align: center;
  }
}
@media (min-width: 751px), print {
  #page-title .page-title-note .wrap dl {
    display: flex;
    align-items: center;
    margin-bottom: 10px;
    line-height: 1;
  }
}
#page-title .page-title-note .wrap dt {
  font-size: 24px;
  font-size: 3.2vw;
}
@media (min-width: 751px), print {
  #page-title .page-title-note .wrap dt {
    width: 6em;
    font-size: 15px;
    font-weight: bold;
  }
}
#page-title .page-title-note .wrap .number, #page-title .page-title-note .wrap .unit {
  font-size: 53px;
  font-size: 7.0666666667vw;
  font-family: 'Roboto', sans-serif;
  letter-spacing: 1px;
}
@media (min-width: 751px), print {
  #page-title .page-title-note .wrap .number, #page-title .page-title-note .wrap .unit {
    font-size: 26px;
  }
}
@media screen and (max-width: 750px) {
  #page-title .page-title-note .wrap .unit-time {
    font-size: 17px;
    font-size: 2.2666666667vw;
  }
}

#course-mission {
  padding: 10% 12% 10%;
  font-size: 24px;
  font-size: 3.2vw;
  line-height: 1.8;
  color: #2f3746;
}
@media (min-width: 751px), print {
  #course-mission {
    padding: 0 0 70px;
    font-size: 14px;
    text-align: center;
    line-height: 2;
  }
}

#course-map {
  margin-bottom: 20px;
}
@media (min-width: 751px), print {
  #course-map {
    margin-bottom: 45px;
  }
}
#course-map .inner {
  background: #fff;
  box-shadow: 0 20px 20px rgba(216, 216, 216, 0.8);
}
@media (min-width: 751px), print {
  #course-map .inner {
    max-width: 900px;
    margin-left: auto;
    margin-right: auto;
  }
}
#course-map .map-container {
  position: relative;
}
#course-map .map-container .map-btn {
  position: absolute;
  left: 2vw;
  bottom: 20%;
}
@media screen and (max-width: 750px) {
  #course-map .map-container .map-btn {
    max-width: 29vw;
  }
}
@media (min-width: 751px), print {
  #course-map .map-container .map-btn {
    left: 15px;
    bottom: 95px;
  }
}
#course-map iframe {
  width: 100%;
  height: 485px;
  border: 0;
  vertical-align: bottom;
}
@media screen and (max-width: 750px) {
  #course-map .map-icons {
    padding: 3% 5%;
    text-align: center;
  }
}
@media (min-width: 751px), print {
  #course-map .map-icons {
    flex: 1;
  }
}

#cource-map-points .inner {
  padding-left: 15px;
  padding-right: 15px;
}
@media (min-width: 751px), print {
  #cource-map-points .inner {
    max-width: 900px;
    margin-left: auto;
    margin-right: auto;
  }
}

#spot .heading {
  padding: 15% 0 7%;
  text-align: center;
  color: #3b68a9;
  font-weight: bold;
  font-size: 34px;
  font-size: 4.5333333333vw;
}
@media (min-width: 751px), print {
  #spot .heading {
    font-size: 30px;
  }
}
#spot .items {
  overflow: hidden;
}
@media screen and (max-width: 750px) {
  #spot .items {
    overflow: hidden;
    padding-bottom: 4%;
  }
}
@media (min-width: 751px), print {
  #spot .items {
    background: url(../img/spot_bg.png) no-repeat;
    background-size: 100% 100%;
  }
}
#spot .item {
  background: #fff;
  box-shadow: 0 20px 20px rgba(0, 0, 0, 0.2);
  transform: translateX(-100vw);
  -webkit-transition: all 0.4s;
  -o-transition: all 0.4s;
  transition: all 0.4s;
}
#spot .item:nth-child(2n) {
  transform: translateX(100vw);
}
#spot .item.appeared {
  transform: translateX(0);
}
@media screen and (max-width: 750px) {
  #spot .item {
    margin-bottom: 6vw;
    display: flex;
    flex-direction: column-reverse;
  }
}
@media (min-width: 751px), print {
  #spot .item {
    max-width: 900px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 60px;
    display: flex;
  }
  #spot .item > * {
    width: 50%;
  }
}
@media (min-width: 751px), print {
  #spot .item:nth-child(2n) {
    flex-direction: row-reverse;
  }
}
#spot .item .body {
  color: #323232;
  font-size: 24px;
  font-size: 3.2vw;
  line-height: 1.7;
  padding: 3.3vw 13% 6vw;
}
@media (min-width: 751px), print {
  #spot .item .body {
    position: relative;
    padding: 25px 35px;
    font-size: 13px;
    line-height: 1.65;
  }
}
#spot .item .title {
  margin-bottom: 2.6vw;
  font-size: 35px;
  font-size: 4.6666666667vw;
  font-weight: bold;
  line-height: 1;
}
@media (min-width: 751px), print {
  #spot .item .title {
    margin-bottom: 12px;
    font-size: 22px;
  }
}
#spot .item .title small {
  display: inline-block;
  margin-right: 5px;
  color: #fff;
  font-family: 'Roboto', sans-serif;
  background: #3b68a9;
  width: 1.5em;
  height: 1.5em;
  font-size: .8em;
  line-height: 1.5;
  text-align: center;
  vertical-align: text-top;
  border-radius: 50%;
}
@media screen and (max-width: 750px) {
  #spot .item .text {
    margin-bottom: 5vw;
  }
}
@media (min-width: 751px) and (max-width: 900px), print and (max-width: 900px) {
  #spot .item .text-bottom {
    padding-top: 30%;
  }
}

#spot .item .icons {
  display: flex;
  margin: 0 0 2vw;
}
@media (min-width: 751px), print {
  #spot .item .icons {
    margin: 0 35px 8px;
  }
}
#spot .item .icons .icon {
  display: flex;
  align-items: center;
  margin-right: 10px;
}
@media screen and (max-width: 750px) {
  #spot .item .icons .icon img {
    max-width: 6vw;
  }
}
#spot .item .icons .icon p {
  color: #3b68a9;
  line-height: 1.1;
  font-size: 16px;
  font-size: 2.1333333333vw;
}
@media (min-width: 751px), print {
  #spot .item .icons .icon p {
    font-size: 11px;
  }
}
@media (min-width: 751px), print {
  #spot .item .more {
    position: absolute;
    left: 0;
    bottom: 20px;
    width: 100%;
  }
}
#spot .item .more a {
  display: block;
  padding: 1.7vw;
  text-align: center;
  line-height: 1;
  background: #9b1460;
}
@media (min-width: 751px), print {
  #spot .item .more a {
    padding: 8px;
    margin: 0 35px;
  }
}
#spot .item .more a img {
  max-width: 24vw;
}

/*# sourceMappingURL=style.css.map */
