@charset "UTF-8";
/* media query */
@import url(https://fonts.googleapis.com/earlyaccess/notosansjapanese.css);
@import url(https://fonts.googleapis.com/earlyaccess/roundedmplus1c.css);
@import url(https://fonts.googleapis.com/css?family=Marcellus);
/* Reset Style */
/* =======================================

	Browser Reset CSS
	Last Up Date 09/09/28

========================================== */
@font-face {
  font-family: YuGothicM;
  src: local("Yu Gothic Medium"); }
body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, code, form, fieldset, legend, p, blockquote {
  margin: 0;
  padding: 0;
  vertical-align: bottom; }

body {
  background: #FFF;
  color: #4d4d4d;
  -webkit-text-size-adjust: none;
  letter-spacing: 1px; }

body {
  font-family: -apple-system, BlinkMacSystemFont, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
  font-size: 15px;
  line-height: 1.6em; }

* html body {
  font-size: small; }

*:first-child + html body {
  font-size: small; }

#wrapper {
  overflow: hidden; }

img {
  border: 0;
  vertical-align: bottom; }

h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  font-weight: normal; }

a {
  text-decoration: none;
  color: #4d4d4d; }

ul, dl, ol {
  text-indent: 0; }

ul li {
  list-style: none; }

address, caption, cite, code, dfn, em, var {
  font-style: normal;
  font-weight: normal; }

sup {
  vertical-align: text-top; }

sub {
  vertical-align: text-bottom; }

input, textarea, select {
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit; }

* html input, * html textarea, * html select {
  font-size: 100%; }

*:first-child + html + input, *:first-child html + textarea, *:first-child + html select {
  font-size: 100%; }

table {
  border-collapse: collapse;
  border-spacing: 0;
  font-size: inherit; }

th, td {
  text-align: left;
  vertical-align: top; }

pre, code, kbd, samp, tt {
  font-family: monospace; }

* html pre, * html code, * html kbd, * html samp, * html tt {
  font-size: 100%;
  line-height: 100%; }

*:first-child + html pre, *:first-child html + code, *:first-child html + kbd, *:first-child + html + samp, *:first-child + html tt {
  font-size: 108%;
  line-height: 100%; }

input, select, textarea {
  font-size: 100%;
  font-family: Verdana, Helvetica, sans-serif; }

/*! normalize.css v7.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
 *    IE on Windows Phone and in iOS.
 */
html {
  line-height: 1.15;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */ }

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers (opinionated).
 */
body {
  margin: 0; }

/**
 * Add the correct display in IE 9-.
 */
article,
aside,
footer,
header,
nav,
section {
  display: block; }

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em; }

/* Grouping content
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 * 1. Add the correct display in IE.
 */
figcaption,
figure,
main {
  /* 1 */
  display: block; }

/**
 * Add the correct margin in IE 8.
 */
figure {
  margin: 1em 40px; }

/**
 * 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
   ========================================================================== */
/**
 * 1. Remove the gray background on active links in IE 10.
 * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.
 */
a {
  background-color: transparent;
  /* 1 */
  -webkit-text-decoration-skip: objects;
  /* 2 */ }

/**
 * 1. Remove the bottom border in Chrome 57- and Firefox 39-.
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none;
  /* 1 */
  text-decoration: underline;
  /* 2 */
  text-decoration: underline dotted;
  /* 2 */ }

/**
 * Prevent the duplicate application of `bolder` by the next rule in Safari 6.
 */
b,
strong {
  font-weight: inherit; }

/**
 * 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 style in Android 4.3-.
 */
dfn {
  font-style: italic; }

/**
 * Add the correct background and color in IE 9-.
 */
mark {
  background-color: #ff0;
  color: #000; }

/**
 * 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
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 */
audio,
video {
  display: inline-block; }

/**
 * Add the correct display in iOS 4-7.
 */
audio:not([controls]) {
  display: none;
  height: 0; }

/**
 * Remove the border on images inside links in IE 10-.
 */
img {
  border-style: none; }

/**
 * Hide the overflow in IE.
 */
svg:not(:root) {
  overflow: hidden; }

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers (opinionated).
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: sans-serif;
  /* 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; }

/**
 * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`
 *    controls in Android 4.
 * 2. Correct the inability to style clickable types in iOS and Safari.
 */
button,
html [type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
  /* 2 */ }

/**
 * 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 */ }

/**
 * 1. Add the correct display in IE 9-.
 * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */ }

/**
 * Remove the default vertical scrollbar in IE.
 */
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 and cancel buttons in Chrome and Safari on macOS.
 */
[type="search"]::-webkit-search-cancel-button,
[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 IE 9-.
 * 1. Add the correct display in Edge, IE, and Firefox.
 */
details,
menu {
  display: block; }

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item; }

/* Scripting
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 */
canvas {
  display: inline-block; }

/**
 * Add the correct display in IE.
 */
template {
  display: none; }

/* Hidden
   ========================================================================== */
/**
 * Add the correct display in IE 10-.
 */
[hidden] {
  display: none; }

body {
  position: relative; }
  @media all and (max-width: 668px) {
    body {
      font-size: 90%; } }

.pconly {
  display: block; }
  @media all and (max-width: 668px) {
    .pconly {
      display: none; } }

.sponly {
  display: none; }
  @media all and (max-width: 668px) {
    .sponly {
      display: block; } }

.w1100 {
  max-width: 1000px;
  width: calc(100% - 30px);
  margin: 0 auto; }

a:hover {
  opacity: 0.7;
  transition: 0.5s; }

img {
  max-width: 100%; }

.content {
  margin-top: 56px; }
  @media all and (max-width: 668px) {
    .content {
      margin-top: 48px; } }

.area_title {
  text-align: center;
  background: #F1F1F1;
  padding: 60px 0;
  margin: 0 15px; }
  .area_title .point {
    margin: 0 0 20px 0; }
    @media all and (max-width: 668px) {
      .area_title .point img {
        max-width: 70px; } }
  .area_title h2 {
    font-size: 150%;
    color: #184f92;
    font-weight: bold;
    letter-spacing: 5px;
    position: relative;
    padding: 0 0 20px 0;
    margin: 0 0 40px 0;
    line-height: 1.5em; }
    @media all and (max-width: 668px) {
      .area_title h2 {
        font-size: 130%; } }
    .area_title h2:before {
      content: '';
      position: absolute;
      bottom: -15px;
      display: inline-block;
      width: 30px;
      height: 1px;
      left: 50%;
      transform: translateX(-50%);
      background-color: #184f92;
      border-radius: 2px; }
  .area_title .txt {
    letter-spacing: 2px;
    line-height: 2em; }

.area_main {
  height: 350px;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center; }
  @media all and (max-width: 668px) {
    .area_main {
      height: 280px;
      padding: 0 20px;
      box-sizing: border-box; } }
  .area_main.bg01 {
    background: url("../images/main02.jpg") no-repeat center center/cover; }
  .area_main.bg02 {
    background: url("../images/main03.jpg") no-repeat center center/cover; }
  .area_main.bg03 {
    background: url("../images/main04.jpg") no-repeat center center/cover; }
  .area_main ul li {
    color: #fff; }
    .area_main ul li.eigo {
      margin: 0 0 30px 0; }
    .area_main ul li.title {
      margin: 0 0 30px 0; }
      .area_main ul li.title h3 {
        font-size: 150%;
        line-height: 1.3em;
        font-weight: bold;
        letter-spacing: 15px;
        position: relative;
        padding: 0 0 5px 0; }
        @media all and (max-width: 668px) {
          .area_main ul li.title h3 {
            font-size: 130%;
            letter-spacing: 10px; } }
        .area_main ul li.title h3:before {
          content: '';
          position: absolute;
          bottom: -15px;
          display: inline-block;
          width: 30px;
          height: 1px;
          left: 50%;
          transform: translateX(-50%);
          background-color: #fff;
          border-radius: 2px; }
    .area_main ul li.txt {
      letter-spacing: 2px;
      line-height: 1.8em; }
      @media all and (max-width: 668px) {
        .area_main ul li.txt {
          text-align: left; } }

.block_accordion {
  background: #fff;
  margin: 0 0 10px 0;
  border: 1px solid #fff; }
  .block_accordion .accordion {
    cursor: pointer; }
  .block_accordion .accordion-inner {
    display: none;
    padding: 30px;
    box-sizing: border-box;
    position: relative;
    width: 99vw;
    bottom: 0;
    background: #184f92;
    color: #fff; }

.btn_language {
  position: absolute;
  right: 80px;
  top: 50%;
  transform: translateY(-50%); }
  @media all and (max-width: 668px) {
    .btn_language {
      right: 56px; } }
  .btn_language a {
    display: block;
    color: #fff;
    border: 2px solid #fff;
    padding: 5px 10px; }
    @media all and (max-width: 668px) {
      .btn_language a {
        font-size: 12px;
        padding: 2px 4px; } }

.main {
  position: relative; }
  .main img {
    max-width: auto !important;
    width: 100%; }
  .main .copy_top {
    position: absolute;
    transform: rotate(-90deg);
    transform-origin: right bottom 0;
    right: 10px;
    top: 5%;
    color: #fff;
    font-size: 1vw; }
    @media all and (max-width: 800px) {
      .main .copy_top {
        display: none; } }
  .main .scroll_icon {
    position: absolute;
    bottom: -30px;
    left: 48.5%;
    z-index: 2;
    display: inline-block;
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    text-decoration: none;
    padding-top: 70px;
    font-size: 13px;
    font-family: 'Noto Sans Japanese'; }
    @media all and (max-width: 668px) {
      .main .scroll_icon {
        left: 45%; } }
    .main .scroll_icon span {
      position: absolute;
      top: 0;
      left: 50%;
      width: 24px;
      height: 24px;
      margin-left: -12px;
      border-left: 1px solid #4d4d4d;
      border-bottom: 1px solid #4d4d4d;
      -webkit-transform: rotate(-45deg);
      transform: rotate(-45deg);
      -webkit-animation: sdb 1.5s infinite;
      animation: sdb 1.5s infinite;
      box-sizing: border-box; }
@-webkit-keyframes sdb {
  0% {
    -webkit-transform: rotate(-45deg) translate(0, 0);
    opacity: 0; }
  50% {
    opacity: 1; }
  100% {
    -webkit-transform: rotate(-45deg) translate(-20px, 20px);
    opacity: 0; } }
@keyframes sdb {
  0% {
    transform: rotate(-45deg) translate(0, 0);
    opacity: 0; }
  50% {
    opacity: 1; }
  100% {
    transform: rotate(-45deg) translate(-20px, 20px);
    opacity: 0; } }
.intro {
  background: url("../images/bg.png") repeat-y top center;
  background-attachment: fixed; }
  .intro .area_title {
    background: none; }
  .intro .area_column .sec_column {
    padding: 50px 0 80px 0;
    position: relative; }
    @media all and (max-width: 800px) {
      .intro .area_column .sec_column {
        padding: 30px 0;
        margin: 0 0 30px 0; } }
    .intro .area_column .sec_column.pb {
      padding: 50px 0 180px 0; }
      @media all and (max-width: 800px) {
        .intro .area_column .sec_column.pb {
          padding: 30px 0; } }
    .intro .area_column .sec_column.reverse {
      padding: 50px 0; }
      .intro .area_column .sec_column.reverse.md_none .block_column {
        margin-bottom: -50px; }
        @media all and (max-width: 800px) {
          .intro .area_column .sec_column.reverse.md_none .block_column {
            margin-bottom: 0; } }
      .intro .area_column .sec_column.reverse:before {
        right: 0; }
      .intro .area_column .sec_column.reverse .block_column {
        position: relative; }
        .intro .area_column .sec_column.reverse .block_column .block_txt {
          max-width: 700px;
          width: 60vw;
          position: absolute;
          top: 0;
          right: 0; }
          @media all and (max-width: 800px) {
            .intro .area_column .sec_column.reverse .block_column .block_txt {
              width: 100%;
              position: relative;
              top: 0; } }
          .intro .area_column .sec_column.reverse .block_column .block_txt .en_copy {
            padding: 0 0 0 200px;
            box-sizing: border-box; }
            @media all and (max-width: 1100px) {
              .intro .area_column .sec_column.reverse .block_column .block_txt .en_copy {
                padding: 0 0 0 20%; } }
            @media all and (max-width: 800px) {
              .intro .area_column .sec_column.reverse .block_column .block_txt .en_copy {
                padding: 0; } }
          .intro .area_column .sec_column.reverse .block_column .block_txt .main_copy li {
            padding: 2px 2px 2px 200px;
            box-sizing: border-box; }
            @media all and (max-width: 1100px) {
              .intro .area_column .sec_column.reverse .block_column .block_txt .main_copy li {
                padding: 2px 2px 2px 20%; } }
            @media all and (max-width: 800px) {
              .intro .area_column .sec_column.reverse .block_column .block_txt .main_copy li {
                padding: 2px 5px; } }
          .intro .area_column .sec_column.reverse .block_column .block_txt .txt {
            display: block;
            max-width: 100%;
            padding: 0 0 0 200px;
            box-sizing: border-box; }
            @media all and (max-width: 1100px) {
              .intro .area_column .sec_column.reverse .block_column .block_txt .txt {
                padding: 0 0 0 20%; } }
            @media all and (max-width: 800px) {
              .intro .area_column .sec_column.reverse .block_column .block_txt .txt {
                max-width: 100%;
                padding: 0; } }
          .intro .area_column .sec_column.reverse .block_column .block_txt .icon_list {
            margin: 50px 0 0 0;
            max-width: 100%;
            padding: 0 0 0 200px;
            box-sizing: border-box; }
            @media all and (max-width: 1100px) {
              .intro .area_column .sec_column.reverse .block_column .block_txt .icon_list {
                padding: 0 0 0 20%; } }
            @media all and (max-width: 800px) {
              .intro .area_column .sec_column.reverse .block_column .block_txt .icon_list {
                max-width: 100%;
                padding: 0;
                margin: 30px 0 0 0; } }
          .intro .area_column .sec_column.reverse .block_column .block_txt .btn_more {
            margin: 30px 0 0 200px; }
            @media all and (max-width: 800px) {
              .intro .area_column .sec_column.reverse .block_column .block_txt .btn_more {
                margin: 30px 0 0 0; } }
        .intro .area_column .sec_column.reverse .block_column .block_img {
          position: relative;
          max-width: 40%;
          top: -50px;
          z-index: 1; }
          @media all and (max-width: 800px) {
            .intro .area_column .sec_column.reverse .block_column .block_img {
              max-width: 100%;
              top: 0;
              margin: 0 0 30px 0; } }
    .intro .area_column .sec_column.bg_h:before {
      height: 500px; }
      @media all and (max-width: 800px) {
        .intro .area_column .sec_column.bg_h:before {
          width: 50vw;
          height: 85%; } }
    .intro .area_column .sec_column:before {
      content: "";
      display: block;
      width: 70vw;
      background: rgba(62, 124, 200, 0.2);
      height: 350px;
      position: absolute;
      z-index: -1;
      top: 0; }
      @media all and (max-width: 800px) {
        .intro .area_column .sec_column:before {
          width: 50vw;
          height: 85%; } }
    .intro .area_column .sec_column .block_column {
      position: relative; }
      .intro .area_column .sec_column .block_column .block_txt {
        max-width: 800px;
        width: 70%; }
        @media all and (max-width: 800px) {
          .intro .area_column .sec_column .block_column .block_txt {
            width: 100%; } }
        .intro .area_column .sec_column .block_column .block_txt .en_copy {
          color: #184f92;
          font-family: 'Noto Sans Japanese';
          font-size: 120%;
          margin: 0 0 20px 0; }
          @media all and (max-width: 800px) {
            .intro .area_column .sec_column .block_column .block_txt .en_copy {
              margin: 0 0 15px 0; } }
        .intro .area_column .sec_column .block_column .block_txt .main_copy {
          margin: 0 0 20px 0; }
          .intro .area_column .sec_column .block_column .block_txt .main_copy li {
            padding: 2px 5px;
            box-sizing: border-box;
            margin: 0 0 10px 0;
            font-size: 200%;
            font-weight: bold;
            line-height: 1.3em;
            background: #fff; }
            @media all and (max-width: 800px) {
              .intro .area_column .sec_column .block_column .block_txt .main_copy li {
                font-size: 150%; } }
        .intro .area_column .sec_column .block_column .block_txt .txt {
          display: block;
          max-width: 70%; }
          @media all and (max-width: 800px) {
            .intro .area_column .sec_column .block_column .block_txt .txt {
              max-width: 100%; } }
        .intro .area_column .sec_column .block_column .block_txt .icon_list {
          margin: 50px 0 0 0;
          max-width: 70%; }
          @media all and (max-width: 800px) {
            .intro .area_column .sec_column .block_column .block_txt .icon_list {
              max-width: 100%;
              text-align: center;
              margin: 30px 0 0 0; }
              .intro .area_column .sec_column .block_column .block_txt .icon_list img {
                max-width: 500px;
                width: 100%; } }
        .intro .area_column .sec_column .block_column .block_txt .btn_more {
          display: block;
          padding: 15px;
          box-sizing: border-box;
          background: #4d4d4d;
          color: #fff;
          text-align: center;
          border-radius: 50px;
          max-width: 300px;
          margin: 30px 0 0 0;
          position: relative; }
          @media all and (max-width: 800px) {
            .intro .area_column .sec_column .block_column .block_txt .btn_more {
              max-width: 100%; } }
          .intro .area_column .sec_column .block_column .block_txt .btn_more:after {
            font-family: "Font Awesome 5 Free";
            content: "\f054";
            font-weight: 900;
            position: absolute;
            right: 20px; }
      .intro .area_column .sec_column .block_column .block_img {
        position: absolute;
        top: -50px;
        right: 0;
        max-width: 38%; }
        @media all and (max-width: 800px) {
          .intro .area_column .sec_column .block_column .block_img {
            top: 0;
            position: relative;
            max-width: 100%;
            text-align: center;
            margin: 0 0 30px 0; }
            .intro .area_column .sec_column .block_column .block_img img {
              margin: 0 auto; } }
  .intro .area_column .txt_s {
    font-size: 80%; }
  .intro .area_pay {
    padding: 30px;
    box-sizing: border-box;
    border: 1px solid #ccc;
    background: #fff;
    text-align: center;
    position: relative;
    z-index: 2;
    margin: 80px auto 0 auto;
    max-width: 1000px; }
    @media all and (max-width: 800px) {
      .intro .area_pay {
        margin: 30px auto 0 auto; } }
    .intro .area_pay p {
      font-weight: bold;
      font-size: 120%;
      margin: 0 0 20px 0; }
    .intro .area_pay ul {
      display: flex;
      justify-content: space-between; }
      @media all and (max-width: 800px) {
        .intro .area_pay ul {
          flex-wrap: wrap; } }
      @media all and (max-width: 800px) {
        .intro .area_pay ul li:first-child {
          margin: 0 0 15px 0; } }

.manifest {
  background: #F1F1F1; }

.column {
  padding: 70px 0; }
  .column h4 {
    text-align: center;
    margin: 0 0 50px 0;
    font-size: 120%;
    letter-spacing: 10px; }
    @media all and (max-width: 668px) {
      .column h4 {
        letter-spacing: 5px; } }
  .column .area_list {
    margin: 0 0 50px 0; }
    @media all and (max-width: 668px) {
      .column .area_list {
        margin: 0 0 30px 0; } }
    .column .area_list:last-child {
      margin: 0; }
    .column .area_list.infection .panel {
      height: 400px; }
      @media all and (max-width: 800px) {
        .column .area_list.infection .panel {
          height: auto; } }
      .column .area_list.infection .panel.height_w {
        height: 600px; }
        @media all and (max-width: 800px) {
          .column .area_list.infection .panel.height_w {
            height: 700px; } }
        @media all and (max-width: 668px) {
          .column .area_list.infection .panel.height_w {
            height: auto; } }
        .column .area_list.infection .panel.height_w .inner_tab > dl {
          height: 500px; }
          @media all and (max-width: 668px) {
            .column .area_list.infection .panel.height_w .inner_tab > dl {
              height: auto; } }
      @media all and (max-width: 668px) {
        .column .area_list.infection .panel .inner_tab {
          padding: 30px 0; } }
      .column .area_list.infection .panel .inner_tab > dl {
        width: 100%;
        height: 280px;
        display: flex;
        justify-content: center; }
        @media all and (max-width: 800px) {
          .column .area_list.infection .panel .inner_tab > dl {
            height: auto;
            padding: 30px 0; } }
        @media all and (max-width: 668px) {
          .column .area_list.infection .panel .inner_tab > dl {
            flex-wrap: wrap; } }
        .column .area_list.infection .panel .inner_tab > dl > dt {
          margin: 0 30px 0 0;
          width: 25%; }
          @media all and (max-width: 668px) {
            .column .area_list.infection .panel .inner_tab > dl > dt {
              width: 100%;
              height: 150px;
              text-align: center;
              margin: 0 0 30px 0; } }
          .column .area_list.infection .panel .inner_tab > dl > dt img {
            object-fit: cover;
            font-family: 'object-fit: cover;';
            width: 100%;
            height: auto; }
            @media all and (max-width: 668px) {
              .column .area_list.infection .panel .inner_tab > dl > dt img {
                height: 100%; } }
            .column .area_list.infection .panel .inner_tab > dl > dt img.img_left {
              object-position: 0 100%; }
        .column .area_list.infection .panel .inner_tab > dl > dd {
          width: 75%;
          text-align: left; }
          @media all and (max-width: 668px) {
            .column .area_list.infection .panel .inner_tab > dl > dd {
              width: 100%; } }
          .column .area_list.infection .panel .inner_tab > dl > dd div {
            width: 100%; }
          .column .area_list.infection .panel .inner_tab > dl > dd dl {
            display: flex;
            margin: 0 0 20px 0; }
            .column .area_list.infection .panel .inner_tab > dl > dd dl dt {
              margin: 0 20px 0 0;
              max-width: 80px;
              width: 100%;
              text-align: center; }
              @media all and (max-width: 668px) {
                .column .area_list.infection .panel .inner_tab > dl > dd dl dt {
                  display: none; } }
              .column .area_list.infection .panel .inner_tab > dl > dd dl dt.img_height img {
                width: auto;
                height: 60px; }
              .column .area_list.infection .panel .inner_tab > dl > dd dl dt.img_width {
                max-width: 100px; }
                .column .area_list.infection .panel .inner_tab > dl > dd dl dt.img_width img {
                  width: auto; }
              .column .area_list.infection .panel .inner_tab > dl > dd dl dt img {
                width: 80px; }
            .column .area_list.infection .panel .inner_tab > dl > dd dl dd {
              width: 100%;
              display: flex;
              align-items: center; }
              .column .area_list.infection .panel .inner_tab > dl > dd dl dd p {
                font-weight: bold;
                display: block;
                width: 100%;
                font-size: 120%;
                border-bottom: 1px solid #000;
                padding: 0 0 5px 0; }
                @media all and (max-width: 668px) {
                  .column .area_list.infection .panel .inner_tab > dl > dd dl dd p {
                    text-align: center; } }
          .column .area_list.infection .panel .inner_tab > dl > dd ul.w50 {
            display: flex;
            justify-content: space-between;
            flex-wrap: wrap; }
            .column .area_list.infection .panel .inner_tab > dl > dd ul.w50 li {
              width: 46%; }
              @media all and (max-width: 668px) {
                .column .area_list.infection .panel .inner_tab > dl > dd ul.w50 li {
                  width: 100%; } }
          .column .area_list.infection .panel .inner_tab > dl > dd ul li {
            text-indent: -1.2em;
            margin: 0 0 0 1.2em;
            padding: 2px 0;
            font-size: 95%;
            letter-spacing: 0.5px; }
            @media all and (max-width: 668px) {
              .column .area_list.infection .panel .inner_tab > dl > dd ul li {
                letter-spacing: 0px;
                line-height: 1.5em; } }
            .column .area_list.infection .panel .inner_tab > dl > dd ul li:before {
              content: "●";
              color: #C6B25C;
              margin: 0 3px 0 0; }
            .column .area_list.infection .panel .inner_tab > dl > dd ul li.width {
              letter-spacing: 0px;
              width: 47%; }
              @media all and (max-width: 668px) {
                .column .area_list.infection .panel .inner_tab > dl > dd ul li.width {
                  width: 100%;
                  letter-spacing: 0.5px; } }
    .column .area_list .box_tab {
      display: flex;
      justify-content: flex-start;
      max-width: 900px;
      width: calc(100% - 20px);
      margin: 0 auto 50px auto; }
      @media all and (max-width: 668px) {
        .column .area_list .box_tab {
          max-width: 100%;
          margin: 0 auto 30px auto; } }
      .column .area_list .box_tab .tab {
        text-align: center;
        cursor: pointer;
        max-width: 300px;
        width: 100%; }
        @media all and (max-width: 668px) {
          .column .area_list .box_tab .tab {
            width: 33%;
            box-sizing: border-box; } }
        .column .area_list .box_tab .tab:nth-child(2) {
          border-right: 1px solid #ccc;
          border-left: 1px solid #ccc; }
          @media all and (max-width: 668px) {
            .column .area_list .box_tab .tab:nth-child(2) {
              border: none; } }
        .column .area_list .box_tab .tab:hover {
          opacity: 0.7;
          transition: 0.5s; }
        @media all and (max-width: 668px) {
          .column .area_list .box_tab .tab .img {
            margin: 0 auto;
            max-width: 90px; } }
        .column .area_list .box_tab .tab b {
          margin: 10px 0 0 0;
          display: block;
          line-height: 1.5em; }
          @media all and (max-width: 668px) {
            .column .area_list .box_tab .tab b {
              font-size: 90%;
              letter-spacing: 0px; }
              .column .area_list .box_tab .tab b.small {
                font-size: 85%;
                letter-spacing: -0.5px; } }
    .column .area_list .panel {
      display: none;
      height: 220px;
      background: #fff; }
      @media all and (max-width: 668px) {
        .column .area_list .panel {
          height: 250px; } }
      .column .area_list .panel.info {
        height: 350px; }
        @media all and (max-width: 668px) {
          .column .area_list .panel.info {
            height: auto; } }
      .column .area_list .panel .inner_tab {
        text-align: center;
        display: flex;
        justify-content: center;
        align-items: center;
        height: 100%;
        max-width: 1100px;
        width: calc(100% - 30px);
        margin: 0 auto;
        position: relative; }
        @media all and (max-width: 668px) {
          .column .area_list .panel .inner_tab {
            text-align: left; } }
        .column .area_list .panel .inner_tab:before {
          position: absolute;
          top: 0;
          right: 0;
          left: 0;
          margin: 0 auto;
          content: "";
          width: 0;
          height: 0;
          border-style: solid;
          border-width: 20px 20px 0 20px;
          border-color: #F1F1F1 transparent transparent transparent; }
        .column .area_list .panel .inner_tab.left:before {
          position: absolute;
          top: 0;
          left: -55%;
          content: "";
          width: 0;
          height: 0;
          border-style: solid;
          border-width: 20px 20px 0 20px; }
          @media all and (max-width: 1100px) {
            .column .area_list .panel .inner_tab.left:before {
              left: -65vw; } }
          @media all and (max-width: 668px) {
            .column .area_list .panel .inner_tab.left:before {
              left: -60vw; } }
        .column .area_list .panel .inner_tab.right:before {
          position: absolute;
          top: 0;
          right: -55%;
          content: "";
          width: 0;
          height: 0;
          border-style: solid;
          border-width: 20px 20px 0 20px; }
          @media all and (max-width: 1100px) {
            .column .area_list .panel .inner_tab.right:before {
              right: -65vw; } }
          @media all and (max-width: 668px) {
            .column .area_list .panel .inner_tab.right:before {
              right: -60vw; } }
        .column .area_list .panel .inner_tab .title {
          display: block;
          text-align: center;
          padding: 0 0 15px 0;
          border-bottom: 1px solid #000;
          font-weight: bold;
          font-size: 110%;
          margin: 0 0 10px 0; }
          .column .area_list .panel .inner_tab .title.small img {
            max-height: 30px; }
          .column .area_list .panel .inner_tab .title img {
            margin: 0 10px 0 0;
            max-height: 40px;
            position: relative;
            top: 5px; }
        @media all and (max-width: 668px) {
          .column .area_list .panel .inner_tab p {
            letter-spacing: 0px; } }
        .column .area_list .panel .inner_tab p .caption {
          display: block;
          font-size: 90%;
          line-height: 1.4em;
          margin: 10px 0 0 0; }
  .column .block_info ul {
    max-width: 850px;
    margin: 15px 0 0 0; }
    .column .block_info ul li {
      text-indent: -1.2em;
      margin: 0 0 0 1.2em;
      text-align: left; }
      @media all and (max-width: 668px) {
        .column .block_info ul li {
          line-height: 1.5em;
          margin: 0 0 5px 1.2em; } }
      .column .block_info ul li:before {
        content: "●";
        color: #5A9ADA;
        margin: 0 3px 0 0; }

.hotel {
  position: relative;
  padding: 0 0 50px 0; }
  .hotel:before {
    content: "";
    display: block;
    width: 100%;
    height: 250px;
    background: #F1F1F1;
    position: absolute;
    bottom: 27%;
    z-index: -1; }
    @media all and (max-width: 668px) {
      .hotel:before {
        display: none; } }
  .hotel .area_main {
    height: 300px; }
    .hotel .area_main ul li {
      color: #4d4d4d; }
      .hotel .area_main ul li.eigo img {
        max-width: 150px; }
      .hotel .area_main ul li.title h3 {
        font-size: 130%;
        letter-spacing: 10px;
        line-height: 1.5em; }
        @media all and (max-width: 668px) {
          .hotel .area_main ul li.title h3 {
            letter-spacing: 3px;
            font-size: 120%; } }
      .hotel .area_main ul li.btn a {
        display: block;
        width: 180px;
        text-align: center;
        color: #fff;
        background: #4d4d4d;
        margin: 0 auto;
        padding: 5px;
        box-sizing: border-box;
        border-radius: 20px;
        position: relative; }
        .hotel .area_main ul li.btn a:after {
          font-family: "Font Awesome 5 Free";
          content: "\f054";
          font-weight: 900;
          position: absolute;
          right: 10px; }
  .hotel .area_hotel {
    display: flex;
    justify-content: center;
    flex-wrap: wrap; }
    .hotel .area_hotel a {
      display: block;
      width: 30%;
      margin: 15px;
      height: 280px;
      display: flex;
      justify-content: center; }
      @media all and (max-width: 668px) {
        .hotel .area_hotel a {
          width: 100%;
          height: 200px;
          margin: 0 0 20px 0; } }
      .hotel .area_hotel a:nth-child(1) {
        background: url("../images/img_foot01.jpg") no-repeat center center/cover; }
      .hotel .area_hotel a:nth-child(2) {
        background: url("../images/img_foot02.jpg") no-repeat center center/cover; }
      .hotel .area_hotel a:nth-child(3) {
        background: url("../images/img_foot03.jpg") no-repeat center center/cover; }
      .hotel .area_hotel a:nth-child(4) {
        background: url("../images/img_foot04.jpg") no-repeat center center/cover; }
      .hotel .area_hotel a:nth-child(5) {
        background: url("../images/img_foot06.jpg") no-repeat center center/cover; }
      .hotel .area_hotel a p {
        display: block;
        padding: 0 30px;
        box-sizing: border-box;
        height: 100%;
        background: rgba(255, 255, 255, 0.5);
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;
        text-align: center;
        font-family: 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
        font-weight: bold;
        font-size: 120%;
        color: #000 !important; }
        @media all and (max-width: 668px) {
          .hotel .area_hotel a p {
            font-size: 110%; } }

header {
  background: #184f92;
  position: fixed;
  width: 100%;
  z-index: 101; }
  header .area_nav {
    display: flex;
    justify-content: space-between;
    padding: 10px 0; }
    header .area_nav .block_logo {
      display: flex;
      align-items: center; }
      header .area_nav .block_logo img {
        padding: 0 10px;
        max-width: 250px; }
        @media all and (max-width: 668px) {
          header .area_nav .block_logo img {
            padding: 0;
            max-width: 200px; } }
  header .sp_menu {
    height: 100%; }
    header .sp_menu .menu-trigger {
      display: inline-block;
      width: 36px;
      height: 25px;
      vertical-align: middle;
      cursor: pointer;
      position: fixed;
      top: 15px;
      right: 10px;
      z-index: 102; }
      @media all and (max-width: 668px) {
        header .sp_menu .menu-trigger {
          top: 12px; } }
      header .sp_menu .menu-trigger.active span {
        background-color: #fff; }
        header .sp_menu .menu-trigger.active span:nth-of-type(1) {
          transform: translateY(11px) rotate(-45deg); }
        header .sp_menu .menu-trigger.active span:nth-of-type(2) {
          opacity: 0; }
        header .sp_menu .menu-trigger.active span:nth-of-type(3) {
          transform: translateY(-12px) rotate(45deg); }
      header .sp_menu .menu-trigger span {
        display: inline-block;
        box-sizing: border-box;
        position: absolute;
        left: 0;
        width: 100%;
        height: 2px;
        background-color: #fff;
        transition: all .5s; }
        header .sp_menu .menu-trigger span:nth-of-type(1) {
          top: 0; }
        header .sp_menu .menu-trigger span:nth-of-type(2) {
          top: 11px; }
        header .sp_menu .menu-trigger span:nth-of-type(3) {
          bottom: 0; }
    header .sp_menu nav {
      width: 100%;
      height: calc(100% - 56px);
      background-color: #fff;
      position: fixed;
      top: 56px;
      right: 0;
      z-index: 100;
      transform: translate(100%);
      transition: all .5s;
      display: flex;
      justify-content: center;
      align-items: center;
      padding: 0 20px;
      box-sizing: border-box; }
      header .sp_menu nav.open {
        transform: translateZ(0); }
      header .sp_menu nav ul li {
        text-align: center; }
        header .sp_menu nav ul li.border {
          position: relative;
          margin: 0 0 30px 0;
          font-size: 110%;
          padding: 0 0 10px 0; }
          @media all and (max-width: 800px) {
            header .sp_menu nav ul li.border {
              margin: 0; } }
          header .sp_menu nav ul li.border:before {
            content: '';
            position: absolute;
            bottom: -15px;
            display: inline-block;
            width: 30px;
            height: 1px;
            left: 50%;
            -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
            background-color: black;
            border-radius: 2px; }
            @media all and (max-width: 800px) {
              header .sp_menu nav ul li.border:before {
                display: none; } }
        @media all and (max-width: 800px) {
          header .sp_menu nav ul li:nth-child(1) {
            border-top: 1px solid #4d4d4d;
            border-bottom: 1px solid #4d4d4d;
            padding: 15px 0;
            margin: 0 0 15px 0; }
          header .sp_menu nav ul li:nth-child(6) {
            border-top: 1px solid #4d4d4d;
            border-bottom: 1px solid #4d4d4d;
            margin: 15px 0 0 0; } }
        header .sp_menu nav ul li a {
          padding: 15px 0;
          display: block; }
          header .sp_menu nav ul li a b {
            font-size: 110%; }
          header .sp_menu nav ul li a span {
            display: block;
            font-size: 80%;
            color: #184f92;
            font-family: 'Marcellus', serif; }
        header .sp_menu nav ul li input[type="checkbox"].on-off {
          display: none; }
        header .sp_menu nav ul li input[type="checkbox"].on-off + ul {
          height: 0;
          overflow: hidden; }

.overlay {
  content: "";
  display: block;
  width: 0;
  height: 0;
  background-color: rgba(0, 0, 0, 0.5);
  position: absolute;
  top: 0;
  left: 0;
  z-index: 100;
  opacity: 0;
  transition: opacity .5s; }
  .overlay.open {
    width: 100%;
    height: 100%;
    opacity: 1; }

footer {
  background: #323246;
  padding: 40px 0; }
  footer .area_foot {
    display: flex;
    justify-content: space-between; }
    @media all and (max-width: 668px) {
      footer .area_foot {
        flex-wrap: wrap-reverse;
        justify-content: center; } }
    footer .area_foot li {
      color: #fff; }
      @media all and (max-width: 668px) {
        footer .area_foot li {
          text-align: center;
          font-size: 90%;
          margin: 0 0 10px 0; } }
      footer .area_foot li .copyright {
        font-size: 80%;
        margin: 10px 0 0 0; }
        @media all and (max-width: 668px) {
          footer .area_foot li .copyright {
            font-size: 10px;
            letter-spacing: 0px;
            margin: 0; } }
  footer #pagetop {
    position: fixed;
    right: 30px;
    z-index: 99; }
    footer #pagetop a {
      overflow: hidden;
      outline: none; }

/* iOSでのデフォルトスタイルをリセット */
input[type="submit"], input[type="button"] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box; }
  input[type="submit"]::-webkit-search-decoration, input[type="button"]::-webkit-search-decoration {
    display: none; }
  input[type="submit"]::focus, input[type="button"]::focus {
    outline-offset: -2px; }
