@charset "UTF-8";
/*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  line-height: 1.15;
  /* 1 */
  -webkit-text-size-adjust: 100%;
  /* 2 */ }

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0; }

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0; }

/* Grouping content
   ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */ }

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */ }

/* Text-level semantics
   ========================================================================== */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent; }

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none;
  /* 1 */
  text-decoration: underline;
  /* 2 */
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
  /* 2 */ }

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder; }

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */ }

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%; }

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sub {
  bottom: -0.25em; }

sup {
  top: -0.5em; }

/* Embedded content
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10.
 */
img {
  border-style: none; }

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  /* 1 */
  font-size: 100%;
  /* 1 */
  line-height: 1.15;
  /* 1 */
  margin: 0;
  /* 2 */ }

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
  /* 1 */
  overflow: visible; }

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
  /* 1 */
  text-transform: none; }

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button; }

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0; }

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText; }

/**
 * Correct the padding in Firefox.
 */
fieldset {
  padding: 0.35em 0.75em 0.625em; }

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  box-sizing: border-box;
  /* 1 */
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 3 */
  white-space: normal;
  /* 1 */ }

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline; }

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto; }

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type="checkbox"],
[type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */ }

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto; }

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  outline-offset: -2px;
  /* 2 */ }

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */ }

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block; }

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item; }

/* Misc
   ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
  display: none; }

/**
 * Add the correct display in IE 10.
 */
[hidden] {
  display: none; }

body {
  font-size: 16px;
  line-height: 2;
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, sans-serif;
  font-weight: 500;
  overflow-x: hidden;
  color: #2D2529; }

ul {
  padding: 0; }

li {
  list-style: none; }

a {
  color: #04407E;
  text-decoration: none; }

img {
  max-width: 100%; }

a img {
  transition: 0.5s; }
  a img:hover {
    transition: 0.5s;
    opacity: 0.7 !important; }

figure {
  margin: 0; }

.wrapper {
  opacity: 0; }
  @media (max-width: 640px) {
    .wrapper {
      margin-top: -35px; } }

.loading {
  background-color: #449B95;
  position: absolute;
  z-index: 10000;
  top: 50%;
  display: none;
  left: 50%;
  transform: translate(-50%, -50%);
  margin: 0;
  padding: 0;
  line-height: 0;
  text-align: center; }
  @media (max-width: 640px) {
    .loading {
      top: 62%; } }
  .loading img {
    margin-top: 50%; }
    @media (max-width: 640px) {
      .loading img {
        width: 30%; } }
  .loading canvas {
    margin-top: -20%;
    padding: 0; }

.pagetop {
  position: fixed;
  bottom: 50px;
  right: 20px;
  z-index: 60; }

.tit-h1 {
  color: #06417e;
  font-size: 32px;
  text-align: center;
  padding: 80px 20px 20px;
  letter-spacing: 0.2rem; }
  @media (max-width: 640px) {
    .tit-h1 {
      padding: 40px 20px 0;
      font-size: 24px; } }

.l-container {
  position: relative; }

@media (max-width: 640px) {
  .link-hover-action01 {
    border-bottom: 1px solid #06417e; } }

@media screen and (min-width: 641px) {
  .link-hover-action01 {
    position: relative;
    padding: 0.1em 0.3em;
    transition: all 0.3s ease;
    text-decoration: none;
    color: #06417e; }
  .link-hover-action01::before {
    position: absolute;
    content: '';
    left: 0;
    bottom: 0;
    width: 100%;
    height: 1%;
    transition: all 0.3s ease;
    opacity: 0;
    background-color: #06417e;
    border-radius: 50px; }
  .link-hover-action01::after {
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 100%;
    height: 2px;
    content: '';
    transition: all 0.3s ease;
    border-bottom: 1px solid #06417e;
    opacity: 1; }
  .link-hover-action01:hover::before {
    height: 100%;
    opacity: 0.2; }
  .link-hover-action01:hover::after {
    left: 50%;
    right: 50%;
    width: 0%;
    opacity: 0; } }

.sa {
  opacity: 0;
  transition: all .5s ease; }

.sa.show {
  opacity: 1;
  transform: none; }

.sa--lr {
  transform: translate(-100px, 0); }

.sa--rl {
  transform: translate(100px, 0); }

.sa--up {
  transform: translate(0, 50px); }

.sa--down {
  transform: translate(0, -100px); }

.sa--scaleUp {
  transform: scale(0.5); }

.sa--scaleDown {
  transform: scale(1.5); }

.sa--rotateL {
  transform: rotate(180deg); }

.sa--rotateR {
  transform: rotate(-180deg); }

.hidden-pc {
  display: none; }

@media (max-width: 640px) {
  .hidden-pc {
    display: block; }
  .hidden-sp {
    display: none; } }

.tit-border01 {
  border-bottom: 3px solid #00336C;
  max-width: 380px;
  margin: auto;
  font-size: 32px;
  line-height: 1.5;
  padding-bottom: 25px;
  letter-spacing: 0.2rem; }

.area-access {
  background-color: #EEF5F0;
  padding: 10px 0 100px;
  margin-top: 100px; }

.bor-top-none {
  border-top: none !important; }

.bor-bottom-none {
  border-bottom: none !important; }

h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  padding: 0;
  font-weight: normal;
  font-size: 1rem; }

/* ---------------------------------------------
	preset margin
--------------------------------------------- */
.mt00 {
  margin-top: 0 !important; }

.mt05 {
  margin-top: 5px !important; }

.mt10 {
  margin-top: 10px !important; }

.mt12 {
  margin-top: 12px !important; }

.mt15 {
  margin-top: 15px !important; }

.mt20 {
  margin-top: 20px !important; }

.mt25 {
  margin-top: 25px !important; }

.mt30 {
  margin-top: 30px !important; }

.mt35 {
  margin-top: 35px !important; }

.mt40 {
  margin-top: 40px !important; }

.mt45 {
  margin-top: 45px !important; }

.mt50 {
  margin-top: 50px !important; }

.mr00 {
  margin-right: 0 !important; }

.mr05 {
  margin-right: 5px !important; }

.mr10 {
  margin-right: 10px !important; }

.mr12 {
  margin-right: 12px !important; }

.mr15 {
  margin-right: 15px !important; }

.mr20 {
  margin-right: 20px !important; }

.mr25 {
  margin-right: 25px !important; }

.mr30 {
  margin-right: 30px !important; }

.mr35 {
  margin-right: 35px !important; }

.mr40 {
  margin-right: 40px !important; }

.mr45 {
  margin-right: 45px !important; }

.mr50 {
  margin-right: 50px !important; }

.mb00 {
  margin-bottom: 0 !important; }

.mb05 {
  margin-bottom: 5px !important; }

.mb10 {
  margin-bottom: 10px !important; }

.mb12 {
  margin-bottom: 12px !important; }

.mb15 {
  margin-bottom: 15px !important; }

.mb20 {
  margin-bottom: 20px !important; }

.mb25 {
  margin-bottom: 25px !important; }

.mb30 {
  margin-bottom: 30px !important; }

.mb35 {
  margin-bottom: 35px !important; }

.mb40 {
  margin-bottom: 40px !important; }

.mb45 {
  margin-bottom: 45px !important; }

.mb50 {
  margin-bottom: 50px !important; }

.ml00 {
  margin-left: 0 !important; }

.ml05 {
  margin-left: 5px !important; }

.ml10 {
  margin-left: 10px !important; }

.ml12 {
  margin-left: 12px !important; }

.ml15 {
  margin-left: 15px !important; }

.ml20 {
  margin-left: 20px !important; }

.ml25 {
  margin-left: 25px !important; }

.ml30 {
  margin-left: 30px !important; }

.ml30 {
  margin-left: 35px !important; }

.ml40 {
  margin-left: 40px !important; }

.ml45 {
  margin-left: 45px !important; }

.ml50 {
  margin-left: 50px !important; }

/* ---------------------------------------------
	preset padding
--------------------------------------------- */
.pt00 {
  padding-top: 0 !important; }

.pt05 {
  padding-top: 5px !important; }

.pt10 {
  padding-top: 10px !important; }

.pt12 {
  padding-top: 12px !important; }

.pt15 {
  padding-top: 15px !important; }

.pt20 {
  padding-top: 20px !important; }

.pt25 {
  padding-top: 25px !important; }

.pt30 {
  padding-top: 30px !important; }

.pt35 {
  padding-top: 35px !important; }

.pt40 {
  padding-top: 40px !important; }

.pt45 {
  padding-top: 45px !important; }

.pt50 {
  padding-top: 50px !important; }

.pr00 {
  padding-right: 0 !important; }

.pr05 {
  padding-right: 5px !important; }

.pr10 {
  padding-right: 10px !important; }

.pr12 {
  padding-right: 12px !important; }

.pr15 {
  padding-right: 15px !important; }

.pr20 {
  padding-right: 20px !important; }

.pr25 {
  padding-right: 25px !important; }

.pr30 {
  padding-right: 30px !important; }

.pr35 {
  padding-right: 35px !important; }

.pr40 {
  padding-right: 40px !important; }

.pr45 {
  padding-right: 45px !important; }

.pr50 {
  padding-right: 50px !important; }

.pb00 {
  padding-bottom: 0 !important; }

.pb05 {
  padding-bottom: 5px !important; }

.pb10 {
  padding-bottom: 10px !important; }

.pb12 {
  padding-bottom: 12px !important; }

.pb15 {
  padding-bottom: 15px !important; }

.pb20 {
  padding-bottom: 20px !important; }

.pb25 {
  padding-bottom: 25px !important; }

.pb30 {
  padding-bottom: 30px !important; }

.pb35 {
  padding-bottom: 35px !important; }

.pb40 {
  padding-bottom: 40px !important; }

.pb45 {
  padding-bottom: 45px !important; }

.pb50 {
  padding-bottom: 50px !important; }

.pl00 {
  padding-left: 0 !important; }

.pl05 {
  padding-left: 5px !important; }

.pl10 {
  padding-left: 10px !important; }

.pl12 {
  padding-left: 12px !important; }

.pl15 {
  padding-left: 15px !important; }

.pl20 {
  padding-left: 20px !important; }

.pl25 {
  padding-left: 25px !important; }

.pl30 {
  padding-left: 30px !important; }

.pl30 {
  padding-left: 35px !important; }

.pl40 {
  padding-left: 40px !important; }

.pl45 {
  padding-left: 45px !important; }

.pl50 {
  padding-left: 50px !important; }

.inlineR {
  text-align: right; }

.inlineC {
  text-align: center; }

.inlineL {
  text-align: left; }

.center {
  margin: 0 auto;
  display: block; }

.fNormal {
  font-weight: normal; }

.fBold {
  font-weight: bold; }

.fSSS {
  font-size: 70%; }

.fSS {
  font-size: 78%; }

.fS {
  font-size: 85%; }

.fM {
  font-size: 100%; }

.fL {
  font-size: 115%; }

.fLL {
  font-size: 130%; }

.fLLL {
  font-size: 143%; }

.txt-deco-none {
  text-decoration: none; }

.w100 {
  width: 100%; }

.clearfix::after {
  content: "";
  display: block;
  clear: both; }

@media (min-width: 960px) {
  .pc-f32 {
    font-size: 32px; } }

.br-sp {
  display: none; }

.br-tab {
  display: none; }

.br-pc {
  display: block; }

@media (max-width: 640px) {
  .br-sp {
    display: block; }
  .br-pc {
    display: none; } }

@media (max-width: 959px) {
  .br-tab {
    display: block; } }

.bg-white {
  background-color: #fff; }

.wrapper {
  overflow-x: hidden; }

.l-column {
  flex: 0 1 1300px;
  margin: 0 auto;
  padding: 0 20px;
  max-width: 1300px; }
  @media (max-width: 640px) {
    .l-column {
      padding: 0 10px; } }

.l-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  max-width: 960px;
  margin: 0 auto; }

.l-halfColumn {
  flex: 1 0;
  padding: 20px; }

@media (max-width: 959px) {
  .l-halfColumn {
    display: block;
    flex: 1 1 100%;
    max-width: none;
    margin-right: 0;
    margin-bottom: 30px;
    padding: 0 25px !important; } }

.l-wrapper {
  max-width: 960px;
  margin: 0 auto; }
  @media (max-width: 959px) {
    .l-wrapper {
      padding: 0 15px; } }

.three-float {
  padding: 0;
  overflow: hidden; }
  @media (min-width: 960px) {
    .three-float {
      margin-left: -50px; } }
  @media (max-width: 959px) {
    .three-float {
      margin-left: -30px; } }
  .three-float li {
    float: left;
    box-sizing: border-box; }
    .three-float li img {
      width: 100%; }
    @media (min-width: 960px) {
      .three-float li {
        padding: 0px 0 30px 50px;
        width: 33.3333%; }
        .three-float li:nth-of-type(3n+1) {
          clear: both; } }
    @media (max-width: 959px) {
      .three-float li {
        padding: 0px 0 30px 30px;
        width: 33.3333%; } }
    @media (max-width: 640px) {
      .three-float li {
        width: 50%; }
        .three-float li:nth-of-type(2n+1) {
          clear: both; } }

.top-hero {
  padding-bottom: 70%;
  z-index: -100; }
  @media (max-width: 640px) {
    .top-hero {
      padding-bottom: 125%; } }

.top-mainimg {
  position: absolute;
  z-index: -10;
  top: 80px;
  left: 0;
  text-align: center;
  width: 100%; }
  .top-mainimg img {
    width: 100%; }
  .top-mainimg-logo {
    position: absolute;
    z-index: 10;
    top: 24%;
    left: 25%; }
    @media (max-width: 640px) {
      .top-mainimg-logo {
        top: 11%;
        left: 6%; }
        .top-mainimg-logo img {
          width: 64%; } }

.mor01 {
  position: relative;
  opacity: 0.2;
  z-index: 100000; }
  .mor01 canvas {
    position: absolute;
    top: 70px;
    right: -102px; }

.mor02 {
  opacity: 0.2;
  z-index: 100; }
  .mor02 canvas {
    position: absolute;
    top: -7%;
    left: -102px; }

.mor03 {
  opacity: 0.1;
  z-index: 100; }
  .mor03 canvas {
    position: absolute;
    top: 17%;
    right: 10%; }

.mor04 {
  opacity: 0.2;
  z-index: 100; }
  .mor04 canvas {
    position: absolute;
    top: 48%;
    right: 31%; }

.mor05 {
  opacity: 0.2;
  z-index: 100; }
  .mor05 canvas {
    position: absolute;
    top: 64%;
    left: 4%; }

.mor-map {
  z-index: -1;
  position: absolute;
  top: 100%;
  left: -26%; }
  @media (max-width: 640px) {
    .mor-map {
      display: none; } }

.mor06 {
  opacity: 0.1;
  z-index: 100; }
  .mor06 canvas {
    position: absolute;
    top: 60%;
    right: 1%; }

.top-lead {
  margin: 0 auto;
  padding: 20px;
  max-width: 600px;
  line-height: 2;
  z-index: 10;
  position: relative; }
  .top-lead-wrapper {
    background-color: #fff;
    padding-bottom: 100px; }
  @media (max-width: 640px) {
    .top-lead {
      text-align: left; } }

.top-lead-under {
  margin: 0 auto;
  padding: 20px;
  max-width: 600px;
  z-index: 10;
  position: relative;
  margin-top: 292px;
  line-height: 2; }
  .top-lead-under-tit {
    font-size: 32px;
    letter-spacing: 0.2rem;
    text-align: center;
    color: #06417e;
    margin-bottom: 30px; }
  @media (max-width: 640px) {
    .top-lead-under {
      margin: 50px auto; } }

.mor-swimming {
  position: absolute;
  top: 40%;
  right: 12%; }
  @media (max-width: 959px) {
    .mor-swimming {
      width: 182px;
      top: 41%;
      right: 7%; } }

.mor-swimming-txt {
  position: absolute;
  top: 45%;
  right: 5%; }
  @media (max-width: 959px) {
    .mor-swimming-txt {
      width: 182px; } }

.sp-mor-swimming {
  display: none; }
  @media (max-width: 640px) {
    .sp-mor-swimming {
      display: block;
      padding: 20px 0 20px; } }
  .sp-mor-swimming-txt {
    margin-left: 100px;
    margin-top: -48px; }

.swim-action {
  animation-name: anim_s;
  transform: rotate(10deg);
  animation-duration: 5s;
  animation-iteration-count: infinite; }

@keyframes anim_s {
  50% {
    transform: rotate(-10deg); }
  100% {
    transform: rotate(10deg); } }

.tit-top-h2 {
  text-align: center;
  margin: 70px 20px;
  font-size: 24px;
  line-height: 2.7;
  color: #00336C; }
  .tit-top-h2 p {
    margin: 5px auto; }

.top-order {
  position: relative;
  max-width: 960px;
  margin: auto;
  min-height: 750px; }
  .top-order-img-tit img {
    margin: 20px;
    max-width: 454px; }
  @media (max-width: 959px) {
    .top-order-img-tit {
      display: none; } }
  .top-order-content {
    position: absolute;
    background-color: #fff;
    top: 150px;
    padding: 50px;
    transition: 0.5s; }
    @media (max-width: 640px) {
      .top-order-content {
        position: static;
        margin: -10px 0 70px; } }
    @media (min-width: 960px) {
      .top-order-content {
        max-width: 440px; } }
    .top-order-content:hover {
      transition: 0.5s; }
    .top-order-content-subtit {
      font-size: 18px;
      margin: 0;
      text-align: left; }
    .top-order-content-tit {
      font-size: 32px;
      line-height: 1.5;
      margin: 20px 0;
      text-align: left; }
    .top-order-content-area {
      text-align: left; }
  .top-order-content.left:hover {
    background-color: #DAEDCC; }
  .top-order:nth-of-type(2n+1) {
    right: 0; }
    .top-order:nth-of-type(2n+1) a {
      color: #449B95; }
    .top-order:nth-of-type(2n+1) .top-order-content {
      right: 0; }
      .top-order:nth-of-type(2n+1) .top-order-content:hover {
        background-color: #DAF1E8; }
    .top-order:nth-of-type(2n+1) .active {
      background-color: #DAF1E8; }
  .top-order:nth-of-type(2n+0) {
    text-align: right; }
    .top-order:nth-of-type(2n+0) a {
      color: #56A22D; }
    .top-order:nth-of-type(2n+0) .top-order-content {
      left: 0; }
      .top-order:nth-of-type(2n+0) .top-order-content:hover {
        background-color: #DAEDCC; }
    .top-order:nth-of-type(2n+0) .active {
      background-color: #DAEDCC; }
  .top-order a {
    text-decoration: none; }

button.viewmore {
  line-height: 1.65;
  border: none;
  padding: 0.2em 50% 0.3em 0;
  border-bottom: 1px solid #2D2529;
  background-color: transparent;
  padding: 0 30px 0 0; }

button.viewmore {
  display: block;
  position: relative;
  overflow: hidden;
  z-index: 1;
  cursor: pointer;
  transition: all .2s; }

button.viewmore::before {
  content: '';
  display: block;
  height: 1px;
  width: 20px;
  background: #2D2529;
  position: absolute;
  bottom: 0;
  right: 0;
  bottom: -2px;
  transform: rotate(45deg);
  transform-origin: right bottom; }

button.viewmore::after {
  content: '';
  position: absolute;
  z-index: -1;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  transform: scale(1, 1) skew(45deg, 0);
  transform-origin: right bottom;
  background: transparent; }

.top-bnr {
  display: flex;
  margin-top: 100px;
  padding: 0; }
  @media (min-width: 960px) {
    .top-bnr {
      justify-content: space-between; } }
  @media (max-width: 959px) {
    .top-bnr {
      flex-wrap: wrap; } }
  .top-bnr li {
    box-sizing: border-box;
    margin-bottom: 60px; }
    .top-bnr li p {
      margin: 0 auto;
      max-width: 210px; }
    @media (min-width: 960px) {
      .top-bnr li {
        width: 25%; } }
    @media (max-width: 959px) {
      .top-bnr li {
        width: 50%; } }
    @media (max-width: 640px) {
      .top-bnr li {
        width: 50%; }
        .top-bnr li p {
          padding: 0 10px; } }
  .top-bnr-list-img a img:hover {
    opacity: 1 !important;
    transition: all 2s ease; }
  .top-bnr-list-tit {
    position: relative;
    line-height: 1.25;
    margin-bottom: 10px !important; }
  .top-bnr-list-txt {
    color: #444; }
  @media (max-width: 640px) {
    .top-bnr-list-txt a {
      text-decoration: underline; } }

.top-bnr-list-img-ticket {
  margin: 0 10px 10px; }
  .top-bnr-list-img-ticket a {
    width: 100%;
    height: 210px;
    background: url("../images/bnr-ticket@2x.jpg") no-repeat center bottom;
    background-size: contain;
    display: block;
    margin-bottom: 10px;
    transition: 0.5s;
    text-indent: -9999px; }
  .top-bnr-list-img-ticket a:hover {
    transition: 0.5s;
    background-image: url("../images/bnr-ticket@2x.png"); }

.top-bnr-list-img-bar {
  margin: 0 10px 10px; }
  .top-bnr-list-img-bar a {
    width: 100%;
    height: 210px;
    background: url("../images/bnr-bar@2x.jpg") no-repeat center bottom;
    background-size: contain;
    display: block;
    margin-bottom: 10px;
    transition: 0.5s;
    text-indent: -9999px; }
  .top-bnr-list-img-bar a:hover {
    transition: 0.5s;
    background-image: url("../images/bnr-bar@2x.png"); }

.top-bnr-list-img-casa {
  margin: 0 10px 10px; }
  .top-bnr-list-img-casa a {
    width: 100%;
    height: 210px;
    background: url("../images/bnr-casa@2x.jpg") no-repeat center bottom;
    background-size: contain;
    display: block;
    margin-bottom: 10px;
    transition: 0.5s;
    text-indent: -9999px; }
  .top-bnr-list-img-casa a:hover {
    transition: 0.5s;
    background-image: url("../images/bnr-casa@2x.png"); }

.top-bnr-list-img-depart {
  margin: 0 10px 10px; }
  .top-bnr-list-img-depart a {
    width: 100%;
    height: 210px;
    background: url("../images/bnr-depart@2x.jpg") no-repeat center bottom;
    background-size: contain;
    display: block;
    margin-bottom: 10px;
    transition: 0.5s;
    text-indent: -9999px; }
  .top-bnr-list-img-depart a:hover {
    transition: 0.5s;
    background-image: url("../images/bnr-depart@2x.png"); }

.top-bnr-list-img-ticket-sp,
.top-bnr-list-img-bar-sp,
.top-bnr-list-img-casa-sp,
.top-bnr-list-img-depart-sp {
  display: none; }

@media (max-width: 640px) {
  .top-bnr-list-img-ticket,
  .top-bnr-list-img-bar,
  .top-bnr-list-img-casa,
  .top-bnr-list-img-depart {
    display: none; }
  .top-bnr-list-img-ticket-sp,
  .top-bnr-list-img-bar-sp,
  .top-bnr-list-img-casa-sp,
  .top-bnr-list-img-depart-sp {
    display: block; } }

.top-magazine {
  padding: 0; }
  @media (min-width: 960px) {
    .top-magazine {
      margin-left: -50px; } }
  @media (max-width: 959px) {
    .top-magazine {
      margin-left: -30px; } }
  .top-magazine li {
    float: left;
    box-sizing: border-box; }
    .top-magazine li img {
      width: 100%; }
    @media (min-width: 960px) {
      .top-magazine li {
        padding: 0px 0 30px 50px;
        width: 33.3333%; } }
    @media (max-width: 959px) {
      .top-magazine li {
        padding: 0px 0 30px 30px;
        width: 33.3333%; } }
    @media (max-width: 640px) {
      .top-magazine li {
        width: 50%; } }
  .top-magazine-list-tit {
    line-height: 1.5; }
    .top-magazine-list-tit a {
      color: #444344;
      text-decoration: underline; }

.top-tit-magazine {
  font-size: 24px;
  color: #131D68;
  margin: 50px 0 20px;
  text-align: center; }

.viewall * {
  transition-duration: .6s;
  transition-timing-function: ease;
  text-align: center; }

.viewall .btn {
  color: #131D68;
  cursor: pointer;
  display: block;
  margin: 0 auto 2em;
  max-width: 960px;
  font-size: 24px;
  position: relative;
  text-decoration: none;
  text-transform: uppercase;
  width: 100%;
  line-height: 45px; }
  @media (max-width: 640px) {
    .viewall .btn {
      font-size: 16px; } }

.viewall .btn-2 {
  letter-spacing: 0; }

.viewall .btn-2:hover,
.viewall .btn-2:active {
  letter-spacing: 5px; }
  @media (max-width: 640px) {
    .viewall .btn-2:hover,
    .viewall .btn-2:active {
      letter-spacing: 0; } }

.viewall .btn-2:after,
.viewall .btn-2:before {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  border: 1px solid rgba(255, 255, 255, 0);
  bottom: 0px;
  content: " ";
  display: block;
  margin: 0 auto;
  position: relative;
  transition: all 280ms ease-in-out;
  width: 0; }

.viewall .btn-2:hover:after,
.viewall .btn-2:hover:before {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  border-color: #131D68;
  transition: width 350ms ease-in-out;
  width: 70%; }

.viewall .btn-2:hover:before {
  bottom: auto;
  top: 0;
  width: 70%; }

.sp-viewall {
  display: none; }

@media (max-width: 640px) {
  .viewall {
    display: none; }
  .sp-viewall {
    display: block;
    padding: 10px 10px;
    text-align: center;
    border: 1px solid #04407E;
    transition: 0.5s; }
    .sp-viewall:hover {
      background-color: #04407E;
      transition: 0.5s; }
      .sp-viewall:hover a {
        color: #fff; } }

.top-topics {
  background-color: #EEF5F0;
  padding: 20px 0 100px;
  margin-top: 100px; }
  .top-topics-list {
    max-width: 660px;
    margin: auto; }
    @media (max-width: 959px) {
      .top-topics-list {
        padding: 0 20px; } }
    .top-topics-list dd {
      margin-left: 0; }

.parallax-window {
  min-height: 600px;
  background: transparent; }

.sp-top-mainimg {
  display: none;
  position: absolute;
  z-index: -10;
  top: 6px;
  left: 0;
  text-align: center;
  width: 100%; }
  @media (max-width: 640px) {
    .sp-top-mainimg {
      display: block; } }

@media (max-width: 640px) {
  .top-mainimg {
    display: none; } }

.sp-top-morphing {
  display: none; }

.sp-img-mor-map {
  display: none; }

@media (max-width: 640px) {
  .sp-top-morphing {
    display: block;
    position: relative; }
  .sp-img-mor01 {
    width: 36%;
    height: auto;
    position: absolute;
    top: 38px;
    right: -7%;
    z-index: 10; }
  .sp-img-mor02 {
    width: 53%;
    height: auto;
    position: absolute;
    top: 300px;
    left: -19%;
    z-index: 10; }
  .sp-img-mor-map {
    display: block;
    margin: auto;
    width: 70%; } }

.top-category-list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-left: -30px; }
  @media (max-width: 640px) {
    .top-category-list {
      display: none; } }
  .top-category-list img {
    width: 100%; }
  .top-category-list li {
    width: 33.3333%;
    padding: 0 0 30px 30px;
    box-sizing: border-box; }
  .top-category-list p {
    line-height: 1.5; }
  .top-category-list-viewmore {
    text-align: right;
    margin-bottom: 0; }

.sp-top-category-list {
  display: none; }
  @media (max-width: 640px) {
    .sp-top-category-list {
      display: block; } }
  .sp-top-category-list li {
    padding-left: 1.2em;
    text-indent: -1.2em;
    margin-bottom: 1rem; }
  .sp-top-category-list-color {
    color: #04407E; }

@media (max-width: 640px) {
  .top-body::before {
    content: "";
    background: url(../images/sp-top-mainimg@2x.jpg) no-repeat center center;
    background-size: cover;
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: -1; }
  .top-hero {
    z-index: 0; } }

@media (max-width: 640px) {
  .top-tit-experience {
    margin-top: -70px; }
  #experience {
    padding-bottom: 50px; } }

.active button.viewmore {
  color: #2D2529;
  padding-left: 70px; }

.tit-page-h1 {
  color: #04407E;
  font-size: 32px;
  text-align: center;
  margin: 6% 20px 4%;
  letter-spacing: 0.3rem; }
  @media (max-width: 640px) {
    .tit-page-h1 {
      letter-spacing: 0.1rem;
      line-height: 2;
      font-size: 26px; } }
  .tit-page-h1 span {
    display: inline-block; }

.page-mainimg {
  text-align: center;
  margin-top: 100px; }
  @media (max-width: 640px) {
    .page-mainimg {
      margin-top: 6px; } }

.page-lead {
  text-align: left;
  max-width: 600px;
  margin: auto; }

.about .page-lead {
  text-align: left; }

.tit-page-h2 {
  text-align: center;
  margin: 10% 20px 6%;
  font-size: 24px;
  line-height: 2.7;
  color: #00336C; }
  @media (max-width: 640px) {
    .tit-page-h2 {
      margin-top: 20%; } }
  .tit-page-h2 p {
    margin: 5px auto; }

.tit-page-h2 {
  letter-spacing: 0.4rem; }
  @media (max-width: 640px) {
    .tit-page-h2 {
      letter-spacing: 0; } }

.tit-page-h3 {
  text-align: center;
  margin: 0 20px 6%;
  font-size: 24px;
  line-height: 1.5;
  color: #06417e; }

.mainimg-area {
  position: relative; }
  .mainimg-area a {
    color: #F6D60A;
    padding: 5px 10px;
    transition: 0.5s;
    background-color: rgba(246, 214, 10, 0);
    border-radius: 20px;
    font-size: 20px;
    text-decoration: underline; }
    @media (max-width: 959px) {
      .mainimg-area a {
        font-size: 18px; } }
  .mainimg-area a:hover {
    color: #fff;
    background-color: #F6D60A;
    border-radius: 20px;
    transition: 0.5s;
    text-decoration: none; }
  .mainimg-area-gujo {
    position: absolute;
    top: 41%;
    left: 49%; }
  .mainimg-area-mino {
    position: absolute;
    top: 52%;
    left: 48%; }
  .mainimg-area-gifu {
    position: absolute;
    top: 63%;
    left: 44%; }
  .mainimg-area-seki {
    position: absolute;
    top: 59%;
    left: 50%; }
    @media (max-width: 959px) {
      .mainimg-area-seki {
        top: 57%; } }

@media (max-width: 640px) {
  .area .page-lead {
    text-align: left; } }

.bnr-7story {
  margin: 60px auto;
  text-align: center; }

.area-list-tit {
  font-size: 20px;
  line-height: 1.5;
  margin: 7px 5px 0; }

.area-gifu-list {
  margin-top: 8%; }
  .area-gifu-list-underimg ul {
    display: flex;
    justify-content: space-between; }
    @media (max-width: 640px) {
      .area-gifu-list-underimg ul {
        flex-direction: column; } }
  .area-gifu-list-underimg01 {
    margin-top: 5%; }
    @media (max-width: 640px) {
      .area-gifu-list-underimg01 {
        text-align: right;
        margin-top: 0; } }
  .area-gifu-list-underimg02 {
    margin-right: 5%; }
    @media (max-width: 640px) {
      .area-gifu-list-underimg02 {
        margin-top: 5%; } }
  .area-gifu-list-underimg03 {
    margin-top: 7%; }
    @media (max-width: 640px) {
      .area-gifu-list-underimg03 {
        text-align: right;
        margin-top: -5%; } }

.area-seki-list {
  margin-top: 8%; }
  .area-seki-list-underimg ul {
    display: flex;
    justify-content: space-around; }
    @media (max-width: 640px) {
      .area-seki-list-underimg ul {
        flex-direction: column; } }
  .area-seki-list-underimg01 {
    margin-top: 5%;
    margin-right: 5%; }
    @media (max-width: 640px) {
      .area-seki-list-underimg01 {
        margin-top: 0;
        text-align: right; } }
  @media (max-width: 640px) {
    .area-seki-list-underimg02 {
      margin-top: 5%; } }

.area-mino-list {
  margin-top: 8%; }
  .area-mino-list-underimg ul {
    display: flex;
    justify-content: center; }
    @media (max-width: 640px) {
      .area-mino-list-underimg ul {
        flex-direction: column; } }
  @media (max-width: 640px) {
    .area-mino-list-underimg01 {
      margin-top: 0;
      text-align: right; } }
  .area-mino-list-underimg02 {
    margin-left: 5%; }
    @media (max-width: 640px) {
      .area-mino-list-underimg02 {
        margin-left: -4%;
        margin-top: -5%; } }

.area-gujo-list {
  margin-top: 8%; }
  .area-gujo-list-underimg ul {
    display: flex;
    justify-content: space-around; }
    @media (max-width: 640px) {
      .area-gujo-list-underimg ul {
        flex-direction: column; } }
  @media (max-width: 640px) {
    .area-gujo-list-underimg01 {
      margin-top: 0;
      margin-left: 4%; } }
  .area-gujo-list-underimg02 {
    margin-top: 15%; }
    @media (max-width: 640px) {
      .area-gujo-list-underimg02 {
        text-align: right;
        margin-top: 0%;
        margin-right: 4%; } }
  .area-gujo-list-underimg03 {
    margin-top: 5%;
    margin-left: 4%; }
    @media (max-width: 640px) {
      .area-gujo-list-underimg03 {
        margin-left: 4%; } }

.area-access01 {
  display: flex;
  line-height: 1.5; }
  @media (max-width: 640px) {
    .area-access01 {
      flex-direction: column; } }
  .area-access01 li {
    padding: 5px;
    margin-bottom: 6%;
    width: 50%;
    box-sizing: border-box; }
    .area-access01 li img {
      display: inline-block;
      margin: auto; }
    @media (max-width: 640px) {
      .area-access01 li {
        width: 100%; } }
  .area-access01 h3 {
    font-size: 18px;
    margin: 2rem 0 1rem; }

.sp-area-icon {
  display: none;
  justify-content: space-around; }
  @media (max-width: 640px) {
    .sp-area-icon {
      display: flex; } }
  .sp-area-icon li {
    padding: 2% 3% 0; }

.about-lead-logo {
  text-align: center;
  padding: 7% 0 7%; }

.btn-contact-right {
  position: fixed;
  right: 0;
  top: 50vh;
  z-index: 1000; }
  @media (max-width: 640px) {
    .btn-contact-right {
      display: none; } }
  .btn-contact-right a {
    width: 93px;
    height: 230px;
    background: url("../images/btn-contact-right-off.svg") no-repeat center bottom;
    background-size: contain;
    display: block;
    transition: 0.5s;
    text-indent: -9999px; }
  .btn-contact-right a:hover {
    transition: 0.5s;
    background-image: url("../images/btn-contact-right-on.svg"); }

.btn-contact-right02 {
  position: fixed;
  right: 0;
  top: 30vh;
  z-index: 1000; }
  @media (max-width: 640px) {
    .btn-contact-right02 {
      display: none; } }
  .btn-contact-right02 a {
    width: 92px;
    height: 306px;
    background: url("../images/btn-contact-right02-off.svg") no-repeat center bottom;
    background-size: contain;
    display: block;
    transition: 0.5s;
    text-indent: -9999px; }
  .btn-contact-right02 a:hover {
    transition: 0.5s;
    background-image: url("../images/btn-contact-right02-on.svg"); }

.about-testimonials {
  max-width: 600px;
  margin: auto; }
  .about-testimonials h3 {
    color: #1ba4b0;
    font-size: 18px;
    margin-top: 50px; }
  .about-testimonials ul {
    margin-left: 15px; }
  .about-testimonials li {
    list-style-type: disc; }

.about-company .tit-border01 {
  max-width: 420px;
  line-height: 1.5;
  padding-bottom: 25px; }

.about-company dl,
.about-company dt,
.about-company dd {
  box-sizing: border-box; }

.about-company dl {
  background: #fff;
  max-width: 600px;
  margin: auto; }

.about-company dt,
.about-company dd {
  padding: 10px 10px 0 0;
  border-top: 1px solid #a2a1a2; }

.about-company dt {
  width: 30%;
  float: left; }

.about-company dd {
  background: #fff;
  margin-left: 30%;
  padding-bottom: 10px; }

.about-company dd:after {
  content: '';
  display: block;
  clear: both; }

.about-terms .tit-border01 {
  max-width: 450px; }

.about-cancel li {
  list-style-type: disc; }

.about-cancel-dt01 dl,
.about-cancel-dt01 dt,
.about-cancel-dt01 dd {
  box-sizing: border-box; }

.about-cancel-dt01 dl {
  background: #fff;
  max-width: 600px;
  margin: auto; }

.about-cancel-dt01 dt,
.about-cancel-dt01 dd {
  padding: 0 10px 0 0; }

.about-cancel-dt01 dt {
  width: 25%;
  float: left;
  font-weight: bold; }

.about-cancel-dt01 dd {
  background: #fff;
  margin-left: 30%;
  padding-bottom: 10px; }

.about-cancel-dt01 dd:after {
  content: '';
  display: block;
  clear: both; }

.about-cancel-dt02 dl,
.about-cancel-dt02 dt,
.about-cancel-dt02 dd {
  box-sizing: border-box; }

.about-cancel-dt02 dl {
  background: #fff;
  border-bottom: 1px solid #a2a1a2;
  max-width: 600px;
  margin: auto; }

.about-cancel-dt02 dt,
.about-cancel-dt02 dd {
  padding: 10px 10px 0 0;
  border-top: 1px solid #a2a1a2; }

.about-cancel-dt02 dt {
  width: 75%;
  float: left;
  font-weight: normal; }

.about-cancel-dt02 dd {
  background: #fff;
  margin-left: 75%;
  padding-bottom: 10px;
  text-align: right; }

.about-cancel-dt02 dd:after {
  content: '';
  display: block;
  clear: both; }

.about-service {
  max-width: 600px; }
  .about-service .about-service-dl p {
    margin: 0; }
  .about-service dt {
    margin-top: 40px;
    font-weight: bold; }
  .about-service dd {
    margin-left: 0; }

.about-privacy {
  max-width: 600px; }
  .about-privacy .about-privacy-dl p {
    margin: 0; }
  .about-privacy dt {
    margin-top: 40px;
    font-weight: bold; }
  .about-privacy dd {
    margin-left: 0; }

.ticket-icon {
  display: flex;
  justify-content: space-between; }

.ticket-howtouse-list {
  display: flex;
  flex-wrap: wrap; }
  @media (max-width: 640px) {
    .ticket-howtouse-list {
      justify-content: space-around; } }
  .ticket-howtouse-list p {
    font-size: 18px;
    line-height: 1.5; }
  .ticket-howtouse-list img {
    display: block;
    margin: auto; }
  .ticket-howtouse-list li {
    width: 259px; }
  .ticket-howtouse-list-arrow {
    display: flex;
    align-items: center;
    padding: 20px;
    width: 50px !important; }
    @media (max-width: 640px) {
      .ticket-howtouse-list-arrow {
        transform: rotate(90deg); } }

.ticket-daypass-list {
  display: flex;
  justify-content: space-around;
  flex-wrap: wrap; }
  .ticket-daypass-list li {
    width: 250px; }

.ticket-list-tit {
  text-align: center;
  margin: 75px 0 75px; }

.ticket-list {
  display: flex;
  justify-content: space-around;
  flex-wrap: wrap; }
  .ticket-list p {
    line-height: 1.6;
    margin: 0 0 5px; }
  .ticket-list li {
    width: 270px;
    padding: 10px;
    margin-bottom: 50px;
    box-sizing: border-box; }

.ticket-gifu-list-tit {
  color: #0099d4; }

.ticket-seki-list-tit {
  color: #00aeba; }

.ticket-mino-list-tit {
  color: #645799; }

.ticket-gujo-list-tit {
  color: #da518e; }

.ticket-buy-tit {
  margin: 70px auto 50px;
  text-align: center; }
  .ticket-buy-tit-gifu {
    color: #0099d4;
    font-size: 24px;
    font-weight: bold; }
  .ticket-buy-tit-seki {
    color: #00aeba;
    font-size: 24px;
    font-weight: bold; }
  .ticket-buy-tit-mino {
    color: #645799;
    font-size: 24px;
    font-weight: bold; }
  .ticket-buy-tit-gujo {
    color: #da518e;
    font-size: 24px;
    font-weight: bold; }

.ticket-buy-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around; }
  .ticket-buy-list p {
    line-height: 1.5;
    margin: 0 0 5px; }
  .ticket-buy-list li {
    width: 210px;
    padding: 10px;
    margin-bottom: 30px;
    box-sizing: border-box; }

.gifu-color {
  color: #0099d4; }

.ticket-notes {
  border-top: 3px solid #ec6433;
  border-bottom: 3px solid #ec6433;
  margin-bottom: 100px; }
  .ticket-notes-dotted {
    border-top: dashed 2px #f39c71;
    background-color: #fff; }
  .ticket-notes h3 {
    color: #ec6433;
    font-size: 24px;
    font-weight: bold;
    margin-top: 15px; }
  .ticket-notes p {
    margin: 0 0 15px; }

.post-order-wrapper {
  position: fixed;
  top: 80px;
  left: 0;
  overflow: hidden;
  width: 100%;
  height: 100%;
  left: 50%;
  transform: translateX(-50%);
  max-width: 1300px;
  z-index: -1; }

@media screen and (max-width: 1300px) {
  .post-order-mainimg-border {
    border-left: 20px solid white;
    z-index: 2;
    position: absolute;
    left: 0;
    top: 0;
    display: block;
    width: 100%;
    height: 100%;
    transition: 0.5s; } }

.post-order-mainimg {
  position: absolute;
  top: 0;
  left: 0;
  overflow: hidden;
  width: 100%;
  height: 100%;
  transition: 0.5s; }

.post-order-main {
  max-width: 1300px;
  margin: auto; }
  @media (max-width: 640px) {
    .post-order-main {
      margin-top: 10px; } }

.post-order-content {
  position: relative;
  width: 400px;
  z-index: 10;
  background-color: #fff;
  padding: 30px 100px 30px 30px;
  margin: 0 0 0 auto; }
  .post-order-content p {
    margin-top: 0; }
  @media (max-width: 640px) {
    .post-order-content {
      width: 100%;
      box-sizing: border-box;
      padding: 20px; } }
  .post-order-content .area {
    color: #e5804b; }
  .post-order-content .subtitle {
    color: #229ca7; }
  .post-order-content .title {
    color: #229ca7;
    font-size: 32px;
    margin-bottom: 30px;
    letter-spacing: 0.2rem; }
  .post-order-content .bg-aqua {
    background-color: #f2f7f7;
    padding: 15px; }
  .post-order-content .bg-white {
    background-color: #fff;
    padding: 5px 15px; }
  .post-order-content p.fLL {
    margin: 0; }
  .post-order-content .f24 {
    font-size: 24px; }
  .post-order-content .color-blue {
    color: #06417e; }
  .post-order-content .button-contact a {
    margin: 60px auto 50px;
    padding: 6px;
    font-size: 24px;
    color: #06417e;
    background-color: #fff;
    border: 1px solid #06417e;
    max-width: 240px;
    display: block;
    text-align: center;
    transition: 0.5s; }
    .post-order-content .button-contact a:hover {
      color: #fff;
      background-color: #06417e; }
  .post-order-content .list-cancel {
    border-top: 1px solid #a2a1a2;
    width: 100%;
    border-collapse: collapse; }
    .post-order-content .list-cancel th {
      font-weight: normal;
      text-align: left; }
    .post-order-content .list-cancel td {
      width: 6em;
      text-align: right; }
    .post-order-content .list-cancel td,
    .post-order-content .list-cancel th {
      border-bottom: 1px solid #a2a1a2; }
    .post-order-content .list-cancel span {
      display: inline-block; }
  .post-order-content .title-motto {
    position: relative;
    display: inline-block;
    margin: 1.5em 0;
    width: 100%;
    color: #fff;
    font-size: 28px;
    background: #1ba4b0;
    text-align: center;
    letter-spacing: 0.3rem; }
  .post-order-content .title-motto:before {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -15px;
    border: 15px solid transparent;
    border-top: 15px solid #1ba4b0; }
  .post-order-content .title-motto p {
    margin: 0;
    padding: 0; }
  .post-order-content .title-tanoshimu {
    position: relative;
    display: inline-block;
    margin: 1.5em 0;
    width: 100%;
    color: #fff;
    font-size: 28px;
    background: #EC6235;
    text-align: center;
    letter-spacing: 0.3rem; }
  .post-order-content .title-tanoshimu:before {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -15px;
    border: 15px solid transparent;
    border-top: 15px solid #EC6235; }
  .post-order-content .title-tanoshimu p {
    margin: 0;
    padding: 0; }
  .post-order-content iframe {
    margin-bottom: 20px; }

.right-mask {
  position: absolute;
  right: 0;
  height: 100%;
  background-color: #fff;
  z-index: 5; }

.post-order-mainimg-lefttitle {
  position: absolute;
  color: #fff;
  padding: 60px;
  transition: 1.5s;
  text-shadow: black 1px 1px 10px; }
  .post-order-mainimg-lefttitle-sub {
    font-size: 21px;
    margin-bottom: 15px;
    line-height: 1.6; }
  .post-order-mainimg-lefttitle-main {
    font-size: 36px;
    margin: 0 0 10px;
    line-height: 1.4; }
    @media (max-width: 959px) {
      .post-order-mainimg-lefttitle-main {
        font-size: 30px; } }

.sp-bnr-order-contact {
  position: fixed;
  bottom: 0;
  z-index: 60;
  background-color: #18a3ae; }

.post-order-list-long p {
  margin-bottom: 10px;
  line-height: 1.75; }

.post-order-list-long img {
  margin-bottom: 20px; }

.post-order-list-long a {
  text-decoration: underline; }

.post-order-list {
  line-height: 1.5;
  display: flex;
  flex-wrap: wrap;
  margin-left: -30px; }
  .post-order-list li {
    width: 50%;
    overflow: hidden;
    box-sizing: border-box;
    padding: 0 0 5px 30px; }
    .post-order-list li img {
      min-width: 100%;
      height: auto; }
      @media (max-width: 640px) {
        .post-order-list li img {
          width: 100%;
          height: auto; } }
    .post-order-list li a {
      text-decoration: underline; }
  .post-order-list-tit {
    margin: 5px 0 1rem; }
  .post-order-list .top-bnr-list-img-ticket {
    margin: 0; }
  .post-order-list .top-bnr-list-img-bar {
    margin: 0; }
  .post-order-list .top-bnr-list-img-casa {
    margin: 0; }
  .post-order-list .top-bnr-list-img-depart {
    margin: 0; }
  .post-order-list .top-bnr-list-img-ticket a {
    margin-top: -30px; }
  .post-order-list .top-bnr-list-img-bar a {
    margin-top: -30px; }
  .post-order-list .top-bnr-list-img-casa a {
    margin-top: -30px; }
  .post-order-list .top-bnr-list-img-depart a {
    margin-top: -30px; }

@media (max-width: 640px) {
  p.top-bnr-list-img-ticket-sp {
    margin: 0; }
  p.top-bnr-list-img-bar-sp {
    margin: 0; }
  p.top-bnr-list-img-casa-sp {
    margin: 0; }
  p.top-bnr-list-img-depart-sp {
    margin: 0; } }

.square-tit {
  font-weight: bold;
  margin-bottom: 0; }

.post-order-content video {
  width: 100%; }

/* モーダルウィンドウのスタイル */
.modal {
  position: fixed;
  width: 100%;
  height: 100vh;
  top: 0;
  left: 0;
  display: none; }

/* オーバーレイのスタイル */
.overLay {
  position: absolute;
  top: 0;
  left: 0;
  background: white;
  width: 100%;
  height: 100vh;
  z-index: 10; }

/* モーダルウィンドウの中身のスタイル */
.modal .inner {
  position: absolute;
  z-index: 11;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%); }

.bnr-video {
  text-align: center;
  margin-top: 30px !important; }
  @media (max-width: 640px) {
    .bnr-video {
      display: none; } }

.sp-youtube {
  display: none;
  margin: 30px 0 0 !important; }
  @media (max-width: 640px) {
    .sp-youtube {
      display: block; } }

footer {
  position: relative;
  background-color: #06417e;
  z-index: 50; }

.footer {
  color: #fff;
  max-width: 960px;
  margin: auto;
  padding: 37px 0; }
  .footer a {
    color: #fff; }
  @media (max-width: 959px) {
    .footer {
      padding: 37px 20px; } }
  @media (max-width: 640px) {
    .footer {
      text-align: center; } }

.l-footer {
  display: flex;
  align-items: flex-end;
  justify-content: space-between; }
  @media (max-width: 640px) {
    .l-footer {
      flex-direction: column;
      align-items: center;
      justify-content: center; } }

.copyright {
  font-size: 14px;
  margin: 0; }

.footer-sns {
  display: flex;
  align-items: center; }
  .footer-sns li {
    padding-left: 15px; }
    .footer-sns li:first-child {
      padding-left: 0; }

.gnav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: 960px;
  width: 960px; }
  @media (max-width: 640px) {
    .gnav {
      justify-content: flex-start;
      margin-top: 43px; } }
  @media (max-width: 959px) {
    .gnav {
      padding: 10px; } }
  .gnav ul {
    margin: 0;
    padding: 0;
    list-style: none;
    text-align: center;
    line-height: 1; }
  .gnav ul li {
    display: inline-block;
    white-space: nowrap;
    margin: 0;
    padding: 0; }
  .gnav ul li a {
    position: relative;
    display: inline-block;
    padding: 1px 1px;
    font-size: 11px;
    color: #06417e;
    background-color: #fff;
    line-height: 1;
    text-decoration: none;
    overflow: hidden;
    width: 93px;
    margin: 0; }
  .gnav ul li a::after {
    position: absolute;
    top: 0;
    left: 0;
    content: attr(data-hover);
    display: block;
    width: 100%;
    padding: 1px 1px;
    transition: .3s ease-in-out;
    transform: translateY(-1.4em);
    background-color: #06417e;
    color: #fff; }
  .gnav ul li a span {
    display: inline-block;
    transition: .3s ease-in-out; }
  .gnav ul li a:hover::after,
  .gnav ul li a:focus::after {
    transform: translateY(0); }
  .gnav ul li a:hover span,
  .gnav ul li a:focus span {
    transform: translateY(1.4em); }
  .gnav .active::after {
    transform: translateY(0); }
  .gnav .active span {
    transform: translateY(1.4em); }

.gnav-language {
  font-size: 11px;
  white-space: nowrap;
  color: #999; }
  @media (max-width: 640px) {
    .gnav-language {
      display: none; } }
  .gnav-language a {
    color: #131D68;
    text-decoration: none; }
    @media (max-width: 640px) {
      .gnav-language a {
        font-size: 12px; } }

.gnav-wrapper {
  width: 100%;
  height: 100px;
  position: fixed;
  background-color: white;
  z-index: 1000;
  top: 0px;
  left: 0px;
  display: flex;
  justify-content: center;
  align-items: center; }
  @media (max-width: 640px) {
    .gnav-wrapper {
      position: relative;
      line-height: 0; } }

.navToggle {
  display: none; }

.main-logo {
  margin: 0;
  line-height: 0; }

@media (max-width: 959px) {
  .main-logo {
    width: 47%; } }

@media (max-width: 640px) {
  .gnav-list {
    display: none; }
  .navToggle {
    display: block; }
  .main-logo {
    width: 74%;
    height: auto;
    line-height: 0; } }

nav.globalMenuSp {
  position: fixed;
  z-index: 2;
  top: 0;
  left: 0;
  color: #fff;
  text-align: center;
  transform: translateY(-100%);
  transition: all 0.6s;
  width: 100%; }

nav.globalMenuSp ul {
  background: rgba(24, 164, 174, 0.8);
  margin: 0 auto;
  padding: 40px 0 0;
  width: 100%;
  height: 100vh;
  line-height: 1.5; }

nav.globalMenuSp ul li {
  font-size: 1.1em;
  list-style-type: none;
  padding: 0;
  text-align: center;
  border-bottom: 1px solid #fff;
  width: 50%;
  display: inline-block;
  margin: auto; }

nav.globalMenuSp ul li a {
  display: block;
  color: #fff;
  padding: .7em 0;
  text-decoration: none;
  width: 100%;
  margin: auto; }

nav.globalMenuSp ul li:last-child {
  border-bottom: none; }

.globalMenuSp-lang {
  margin-top: 30px !important; }
  .globalMenuSp-lang a {
    display: inline !important; }

/* このクラスを、jQueryで付与・削除する */
nav.globalMenuSp.active {
  transform: translateY(0%); }

.navToggle {
  position: fixed;
  /* bodyに対しての絶対位置指定 */
  right: 13px;
  top: 18px;
  width: 40px;
  height: 40px;
  cursor: pointer;
  z-index: 3;
  text-align: center; }

.navToggle span {
  display: block;
  position: absolute;
  /* .navToggleに対して */
  width: 30px;
  border-bottom: solid 2px #003364;
  transition: .35s ease-in-out;
  left: 5px; }

.navToggle.active span {
  border-bottom: solid 2px #fff; }

.navToggle span:nth-child(1) {
  top: 9px; }

.navToggle span:nth-child(2) {
  top: 18px; }

.navToggle span:nth-child(3) {
  top: 27px; }

/* 最初のspanをマイナス45度に */
.navToggle.active span:nth-child(1) {
  top: 18px;
  left: 6px;
  transform: rotate(-45deg); }

/* 2番目と3番目のspanを45度に */
.navToggle.active span:nth-child(2),
.navToggle.active span:nth-child(3) {
  top: 18px;
  transform: rotate(45deg); }

.top-morphing {
  z-index: 1000; }
  @media (max-width: 640px) {
    .top-morphing {
      display: none; } }

.gnav-list {
  margin-left: auto !important;
  margin-right: 20px !important; }


/*.btn-agts {*/
/*  top: 50vh;*/
/*}*/