/*! destyle.css v2.0.2 | MIT License | https://github.com/nicolas-cusan/destyle.css */
/* Reset box-model and set borders */
/* ============================================ */
*,
::after,
::before {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border-style: solid;
  border-width: 0; }

.sp_only {
  display: block;
}

.pc_only {
  display: none;
}
@media screen and (min-width: 767px) {
  .sp_only {
    display: none;
  }
  .pc_only {
    display: block;
  }
  
}
.pc_none {
  display: block;
}

/* Document */
/* ============================================ */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 * 3. Remove gray overlay on links for iOS.
 */
html {
  line-height: 1.15;
  /* 1 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
  -webkit-tap-highlight-color: transparent;
  /* 3*/ }

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

/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block; }

img {
  display: block;
}

/* Vertical rhythm */
/* ============================================ */
address,
blockquote,
dl,
figure,
form,
iframe,
p,
pre,
table {
  margin: 0; }

/* Headings */
/* ============================================ */
h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  line-height: inherit;
  font-weight: inherit;
  margin: 0; }

/* Lists (enumeration) */
/* ============================================ */
ol,
ul {
  margin: 0;
  padding: 0;
  list-style: none; }

/* Lists (definition) */
/* ============================================ */
dt {
  font-weight: bold; }

dd {
  margin-left: 0; }

/* Grouping content */
/* ============================================ */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */
  border-top-width: 1px;
  margin: 0;
  clear: both;
  color: inherit; }

/**
 * 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: inherit;
  /* 2 */ }

address {
  font-style: inherit; }

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

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  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: inherit;
  /* 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 */
/* ============================================ */
/**
 * Prevent vertical alignment issues.
 */
embed,
iframe,
img,
object {
  vertical-align: bottom; }

/* Forms */
/* ============================================ */
/**
 * Reset form fields to make them styleable
 */
button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: transparent;
  padding: 0;
  margin: 0;
  outline: 0;
  border-radius: 0;
  text-align: inherit; }

/**
 * Reset radio and checkbox appearance to preserve their look in iOS.
 */
[type="checkbox"] {
  -webkit-appearance: checkbox;
  -moz-appearance: checkbox;
       appearance: checkbox; }

[type="radio"] {
  -webkit-appearance: radio;
  -moz-appearance: radio;
       appearance: radio; }

/**
 * 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.
 */
[type="button"],
[type="reset"],
[type="submit"],
button {
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none; }

[type="button"][disabled],
[type="reset"][disabled],
[type="submit"][disabled],
button[disabled] {
  cursor: default; }

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

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

/**
 * Remove arrow in IE10 & IE11
 */
select::-ms-expand {
  display: none; }

/**
 * Remove padding
 */
option {
  padding: 0; }

/**
 * Reset to invisible
 */
fieldset {
  margin: 0;
  padding: 0;
  min-width: 0; }

/**
 * 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 {
  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; }

/**
 * 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 outline style in Safari.
 */
[type="search"] {
  outline-offset: -2px;
  /* 1 */ }

/**
 * 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 */ }

/**
 * Clickable labels
 */
label[for] {
  cursor: pointer; }

/* 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; }

/*
 * Remove outline for editable content.
 */
[contenteditable] {
  outline: none; }

/* Table */
/* ============================================ */
table {
  border-collapse: collapse;
  border-spacing: 0; }

caption {
  text-align: left; }

td,
th {
  vertical-align: top;
  padding: 0; }

th {
  text-align: left;
  font-weight: bold; }

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

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

html {
  font-size: 12px; }

body {
  position: relative;
  color: white; }

@font-face {
  font-family: font1;
  src: url(../font/MPLUSRounded1c-Light.ttf); }

@font-face {
  font-family: font2;
  src: url(../font/SourceSerifPro-Regular.ttf); }


.fade-in {
  opacity: 0;
  -webkit-transition-duration: 800ms;
          transition-duration: 800ms;
  -webkit-transition-property: opacity, -webkit-transform;
  transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform; }

.fade-in-up {
  -webkit-transform: translate(0, 100px);
          transform: translate(0, 100px); }

.scroll-in {
  opacity: 1;
  -webkit-transform: translate(0, 0);
          transform: translate(0, 0); }

.swiper-wrapper .swiper-slide {
  overflow: hidden;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden; }

:root {
  --swiper-theme-color: #707070; }

.footer {
  position: relative;
  z-index: 100;
  background: #1f7137;
  text-align: center;
  padding: 95px 0 40px; }
  .footer__text {
    width: 80%;
    margin: auto;
    font-family: font2;
    font-size: 13px;
    color: #1f7137;
    background: white;
    padding: 19px 20px; }
    @media screen and (min-width: 767px) {
      .footer__text {
        width: 30%;
        font-size: 15px; } }
  .footer__imgText {
    width: 65%;
    margin: 62px auto 0; }
    @media screen and (min-width: 767px) {
      .footer__imgText {
        width: 35%; } }
  .footer__img {
    width: 100%; }
  .footer__copy {
    font-family: font2;
    margin-top: 12px;
    font-size: 9px;
    font-weight: bold; }

.top {
  background: url(../image/main.jpg) center/cover;
  width: 100%;
  height: 100vh;
  height: calc(var(--vh, 1vh) * 100);
  text-align: center;
  position: relative;
  z-index: 99; }
  @media screen and (min-width: 767px) {
    .top {
      background: url(../image/pc/pc_main.jpg) top/cover; } }
  .top__box {
    width: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translateY(-50%) translateX(-50%);
            transform: translateY(-50%) translateX(-50%); }
  .top__title {
    font-size: 35px;
    font-family: font1; }
    @media screen and (min-width: 767px) {
      .top__title {
        font-size: 70px; } }
  .top__sabTitle {
    display: none;
    font-size: 17px;
    font-family: font1;
    /* -webkit-animation: delay 5s;
            animation: delay 5s;  */
          }

@-webkit-keyframes delay {
  0% {
    opacity: 0; }
  40% {
    opacity: 0; }
  55% {
    opacity: 1; } }

@keyframes delay {
  0% {
    opacity: 0; }
  40% {
    opacity: 0; }
  55% {
    opacity: 1; } }
    @media screen and (min-width: 767px) {
      .top__sabTitle {
        font-size: 28px; } }

.section01 {
  position: relative;
  z-index: 2;
  background: #1f7137;
  width: 100%;
  height: 100vh;
  /* height: calc(var(--vh, 1vh) * 100); */
  /* padding: 168px 0;  */
}
  .section01__imgText {
    /* vertical-align: middle; */
    width: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%);
    margin: auto; }
    @media screen and (min-width: 767px) {
      .section01__imgText {
        width: calc(100vh / 1.25);
        /* height: 80%; */
        position: absolute;
        top: 50%;
        left: 50%;
        -webkit-transform: translate(-50%, -50%);
                transform: translate(-50%, -50%); } }
  .section01__img {
    width: 90%;
    margin: auto;
    /* height: 100%; */
   }
  .section01__box {
    position: absolute;
    bottom: 45px;
    left: 22px; }
    @media screen and (min-width: 767px) {
      .section01__box {
        bottom: 50px;
        left: 50px; } }
    .section01__box-text {
      font-family: font1;
      border-bottom: 1px solid white; }
      .section01__box-text:not(:first-child) {
        margin-top: 13px; }
  .section01__title {
    /* position: absolute;
    bottom: 21%;
    right: -12%; */
    /* z-index: 10;
    font-size: 31px;
    font-family: font2;
    color: #2094c9;
    -webkit-transform: rotate(270deg)!important;
            transform: rotate(270deg)!important;  */
          }
    @media screen and (min-width: 767px) {
      .section01__title {
        /* -webkit-transform: rotate(0)!important;
                transform: rotate(0)!important;
        font-size: 42px; */
        /* bottom: 30%;
        right: 19%;  */
      } }

        /* .section01__title テキストアニメション */
        .ph01-wrap {
          width: 250px;
          position: relative;
          top: 68%;
          top: 68%;
          left: 45%;
          z-index: 10;
          font-size: 31px;
          font-family: font2;
          color: #2094c9;
          -webkit-transform: rotate(270deg)!important;
                  transform: rotate(270deg)!important; 
      }
      @media screen and (min-width: 767px) {
        .ph01-wrap {
          position: relative;
          width: 340px;
          top: 61%;
          left: 58%;
          z-index: 10;
          font-size: 42px;
          font-family: font2;
          color: #2094c9;
          -webkit-transform: rotate(0)!important;
                  transform: rotate(0)!important; 
        }
      }
       
      .photo-img-cross {
          position: relative;
          /* top: 68%; */
          overflow: hidden;
          width: 100%;
          /* width: 250px; */
          height: auto;
      }
      @media screen and (min-width: 767px) {
        .photo-img-cross {
          width: 100%;
        }
      }
       
      .photo-img-cross:before {
          content: "";
          display: block;
          position: absolute;
          /* top: 68%; */
          width: 0;
          height: 100%;
          background-color: #2094c9;
          z-index: 1;
          transform-origin: right center;
          transform: scaleX(1);
          transition: width 0.3s cubic-bezier(-0.1, 0.2, 0.22, 1) 0s, 
          transform 0.5s cubic-bezier(-0.1, 0.2, 0.22, 1) 0.4s;
      }

      @media screen and (min-width: 767px) {
        .photo-img-cross:before {
          content: "";
          display: block;
          position: absolute;
          width: 0;
          height: 100%;
          background-color: #2094c9;
          z-index: 1;
          transform-origin: right center;
          transform: scaleX(1);
          transition: width 0.3s cubic-bezier(0.19, 1, 0.22, 1) 0s, 
          transform 0.5s cubic-bezier(0.19, 1, 0.22, 1) 0.4s;
      }
      }


       
      /* .photo-img-cross img {
          position: relative;
          width: 100%;
          height: auto;
          opacity: 0;
          left: -100%;
          transition: 0.7s;
      } */
       
      /* .photo-move-cross img {
          opacity: 1;
          left: 0;
      } */
       
      .photo-move-cross.photo-img-cross:before {
          transform: scaleX(0);
          width: 100%;
      }

.section02 {
  position: relative;
  /* padding: 137px 0 150px; */
  width: 100%;
  height: 100vh;
  /* height: calc(var(--vh, 1vh) * 100); */
 }
  @media screen and (min-width: 767px) {
    .section02 {
      /* padding: 3%;  */
    } }
  .section02__imgText {
    width: 60%;
    margin: auto;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%); }

    @media screen and (min-width: 767px) {
      .section02__imgText {
        width: calc(100vh / 1.7);
        height: 90%;
        position: absolute;
        top: 50%;
        left: 50%;
        -webkit-transform: translate(-50%, -50%);
                transform: translate(-50%, -50%); } }
  .section02__img {
    width: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%);
    /* height: 100%;  */
  }
  @media screen and (min-width: 767px) {
    .section02__img {
      width: 83%;
    }
  }
  .section02__box {
    position: absolute;
    bottom: 11%;
    right: 7%;}
    @media screen and (min-width: 767px) {
      .section02__box {
        bottom: 50px;
        left: 50px; } }
    .section02__box-text {
      margin-top: 13px;
      font-family: font1;
      color: #1f7137;
      border-bottom: 1px solid #1f7137; }

.section03 {
  position: relative;
  z-index: 2;
  background: url(../image/3.jpg) center/cover;
  width: 100%;
  height: 100vh;
  /* height: calc(var(--vh, 1vh) * 100); */
 }
  @media screen and (min-width: 767px) {
    .section03 {
      background: url(../image/pc/pc_3.jpg) top/cover; } }
  .section03__box {
    position: absolute;
    bottom: 5%;
    right: 7%; }
    @media screen and (min-width: 767px) {
      .section03__box {
        bottom: 50px;
        left: 50px; } }
    .section03__box-text {
      font-family: font1;
      border-bottom: 1px solid white; }
      .section03__box-text:not(:first-child) {
        margin-top: 13px; }

.section04 {
  position: relative;
  height: 100vh;
  /* height: calc(var(--vh, 1vh) * 100); */
  /* padding: 110px 0; */
  overflow: hidden; }
  @media screen and (min-width: 767px) {
    .section04 {
      /* padding: 4% 0; */
    } }
  .section04__block {
    width: 100%;
    margin: auto; 
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%);}
    @media screen and (min-width: 767px) {
      .section04__block {
        width: calc(100vh / 1.7);
        /* height: 100%;  */
      } 
      }
    .section04__block-imgText {
      width: 100%;
      margin: auto; }
    .section04__block-img {
      margin: auto;
      width: 90%; }
    .section04__block-imgText2 {
      width: 100%;
      margin: auto; }
      @media screen and (min-width: 767px) {
        .section04__block-img {
          width: 100%;
        }
      }
  .section04__btn {
    bottom: -26px !important; }
    @media screen and (min-width: 767px) {
      .section04__btn {
        bottom:  -5%!important; } }
    
  .section04__box {
    position: absolute;
    bottom: 5%;
    left: 10%;
    z-index: 99; }
    @media screen and (min-width: 767px) {
      .section04__box {
       left: -30%;
       bottom: -4%;
        } 
      }
    @media screen and (min-width: 1024px) {
      .section04__box {
       left: -60%;
       bottom: -4%;
        } 
      }
      @media screen and (min-width: 1440px) {
        .section04__box {
          left: -100%;
          bottom: -3%;
           } 
      }
    .section04__box-text {
      font-family: font1;
      color: white;
      border-bottom: 1px solid white; }
      .section04__box-text:not(:first-child) {
        margin-top: 13px; }
      @media screen and (min-width: 767px) {
        .section04__box-text {
          color: #1f7137;
          border-bottom: 1px solid #1f7137; 
        } }

          .section04 .credit {

          }

.section05 {
  position: relative;
  background: #ece7db;
  z-index: 2;
  height: 100vh;
  /* height: calc(var(--vh, 1vh) * 100); */
  /* padding: 185px 0; */
 }
  .section05__block {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%);
  }
    .section05__block-imgText {
      width: 100%;
      margin: auto; }
      @media screen and (min-width: 767px) {
        .section05__block-imgText {
          width: 100%;
        } }
    .section05__block-img {
      position: absolute;
      width: 53%;
      top: 50%;
      left: 50%;
      transform: translateY(-50%) translateX(-50%);
      -webkit- transform: translateY(-50%) translateX(-50%);
      z-index: 10;
    }
  .section05__box {
    position: absolute;
    bottom: 50px;
    right: 7%; }
    @media screen and (min-width: 768px) {
      .section05__box {
        bottom: 50px;
        left: 50px; }
        .section05__block-img {
          width: 18%;
        } }
    .section05__box-text {
      font-family: font1;
      color: #1f7137;
      border-bottom: 1px solid #1f7137; }
      .section05__box-text:not(:first-child) {
        margin-top: 13px; }

        /* ループテキスト */
        /* .loop_text_wrap {
          width: 375px;
          overflow:hidden;
          white-space:nowrap;
        }
        .loop_text_wrap:nth-child(2) {
          padding-left: 50px;
        }
        .loop_text_wrap:nth-child(3) {
          padding-left: 100px;
        }
        @keyframes loop_text {
          0% { transform:translateX(4px); }
          100% { transform:translateX(-100%); }
        }
        .loop_text_wrap ul {
          display:inline-block;
          margin:0;
          padding:0;
          animation: loop_text 15s linear infinite;
        }
        .loop_text_wrap li {
          font-family: font2;
          color: #2094c9;
          display:inline-block;
          font-size: 60px;
          margin-left: 20px;
          margin: 10px;
        }

        @media screen and (min-width: 768px) {
          .loop_text_wrap {
            max-width: 1440px;
            width: 100vw;
          }
        } */

        .loop_text {
          position: relative;
          display: -webkit-flex;
          display: flex;
          -webkit-box-align: center;
          -webkit-align-items: center;
          align-items: center;
          width: 100vw;
          height: auto;
          color: #2094c9;
          /* background-color: #f2f2f2; */
          overflow: hidden;
        }
      
        .loop_text div {
          flex: 0 0 auto;
          padding: 12px;
          font-size: 2.4rem;
          font-size: 4rem;
          font-family: font2;
          white-space: nowrap;
          will-change: transform;
        }
      
        @media screen and ( min-width: 900px ) {
          .loop_text div {
            font-size: 4rem;
          }
        }
      
        .loop_text div:nth-child(odd) {
          /* -webkit-animation: loop 50s -25s linear infinite; */
          -webkit-animation: loop 10s -5s linear infinite;
          /* animation: loop 50s -25s linear infinite; */
          animation: loop 10s -5s linear infinite;
          -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
          will-change: transform;
        }
      
        .loop_text div:nth-child(even) {
          /* -webkit-animation: loop2 50s  linear infinite; */
          -webkit-animation: loop2 10s  linear infinite;
          /* animation: loop2 50s linear infinite; */
          animation: loop2 10s linear infinite;
        }
      
        @-webkit-keyframes loop {
          0% {
            -webkit-transform: translateX(100%);
            -ms-transform: translateX(100%);
            transform: translateX(100%);
          }
          to {
            -webkit-transform: translateX(-100%);
            -ms-transform: translateX(-100%);
            transform: translateX(-100%);
          }
        }
      
        @keyframes loop {
          0% {
            -webkit-transform: translateX(100%);
            -ms-transform: translateX(100%);
            transform: translateX(100%);
          }
          to {
            -webkit-transform: translateX(-100%);
            -ms-transform: translateX(-100%);
            transform: translateX(-100%);
          }
        }
      
        @-webkit-keyframes loop2 {
          0% {
            -webkit-transform: translateX(0);
            -ms-transform: translateX(0);
            transform: translateX(0);
          }
          to {
            -webkit-transform: translateX(-200%);
            -ms-transform: translateX(-200%);
            transform: translateX(-200%);
          }
        }
      
        @keyframes loop2 {
          0% {
            -webkit-transform: translateX(0);
            -ms-transform: translateX(0);
            transform: translateX(0);
          }
          to {
            -webkit-transform: translateX(-200%);
            -ms-transform: translateX(-200%);
            transform: translateX(-200%);
          }
        }

.section06 {
  position: relative;
  z-index: 2;
  background: white;
  /* padding: 204px 0; */
  height: 100vh;
  /* height: calc(var(--vh, 1vh) * 100); */
  overflow: hidden; }
  @media screen and (min-width: 767px) {
    .section06 {
      /* padding: 5% 0;  */
    } }
  .section06__block {
    width: 90%;
    position: absolute;
  /* top: 50%; */
  top: 40%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit- transform: translateY(-50%) translateX(-50%);
    margin: auto; }
    @media screen and (min-width: 767px) {
      .section06__block {
        top: 50%;
        width: calc(100vh / 0.99);
        /* height: 100%; */
       } }
  .section06__imgText {
    width: 100%;
    margin: auto; }
  .section06__img {
    width: 100%; }
  .section06__imgText2 {
    width: 100%;
    margin: auto; }
    @media screen and (min-width: 767px) {
      .section06__imgText2 {
        width: 50%; } }
  .section06__btn {
    bottom: -26px !important; }
    @media screen and (min-width: 767px) {
      .section06__btn {
        bottom: -5% !important; } }
    
  .section06__box {
    position: absolute;
    bottom: 12%;
    right: 5%;
    z-index: 100; }
    @media screen and (min-width: 767px) {
      .section06__box {
        bottom: 50px;
        left: 50px; } }
    .section06__box-text {
      font-family: font1;
      color: #1f7137;
      border-bottom: 1px solid #1f7137; }
      .section06__box-text:not(:first-child) {
        margin-top: 13px; }

.section07 {
  position: relative;
  z-index: 2;
  background: #1f7137;
  height: 100vh;
  /* height: calc(var(--vh, 1vh) * 100); */
  /* padding: 116px 0; */
 }
  @media screen and (min-width: 767px) {
    .section07 {
      /* padding: 1.8% 0; */
     } }
  .section07__imgText {
    width: 75%;
    position: absolute;
  top: 45%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit- transform: translateY(-50%) translateX(-50%);
    margin: auto; }
    @media screen and (min-width: 767px) {
      .section07__imgText {
        width: calc(100vh /1.7);
        height: 90%;
        position: absolute;
        top: 50%;
        left: 50%;
        -webkit-transform: translate(-50%, -50%);
                transform: translate(-50%, -50%); } }
  .section07__img {
    width: 100%;
    /* height: 100%; */
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%);
  }
  /* @media screen and (min-width: 767px) {
    .section07__img {
      top: 50%;
    }
  } */
  .section07__box {
    position: absolute;
    bottom: 11%;
    right: 12%; }
    @media screen and (min-width: 767px) {
      .section07__box {
        bottom: 50px;
        left: 50px; } }
    .section07__box-text {
      border-bottom: 1px solid white;
      font-family: font1; }
      .section07__box-text:not(:first-child) {
        margin-top: 13px; }

.section08 {
  overflow-y: hidden;
  position: relative;
  background: white;
  z-index: 3;
  /* padding: 128px 0; */
  height: 100vh;
  /* height: calc(var(--vh, 1vh) * 100); */
 }
  @media screen and (min-width: 767px) {
    .section08 {
      /* padding: 8% 0;  */
    } }
  @media screen and (min-width: 767px) {
    .section08__block {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      width: 43%;
      /* height: 60%; */
      position: absolute;
      top: 50%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%);
              transform: translate(-50%, -50%); } }
  .section08__imgText {
    width: 90%;
    margin: auto;
    /* position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%);  */
  }
  .section08 .img_wrap {
    position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit- transform: translateY(-50%) translateX(-50%);
  }
     @media screen and (min-width: 767px) {
      .section08__imgText {
        width: 100%;
        /* height: 100%;  */
      } }
  .section08__img {
    width: 100%;
    /* position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%); */
    }

.section09 {
  position: relative;
  background: url(../image/8_0.jpg) center/cover;
  height: 100vh;
  /* height: calc(var(--vh, 1vh) * 100); */
  /* padding: 231px 0; */
  overflow: hidden; }
  @media screen and (min-width: 767px) {
    .section09 {
      background: url(../image/pc/pc_8_0.jpg) center/cover;
      /* padding: 9% 0;  */
    } }
  .section09__block {
    width: 75%;
    position: absolute;
  top: 40%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit- transform: translateY(-50%) translateX(-50%);
    margin: auto; }
    @media screen and (min-width: 767px) {
      .section09__block {
        width: calc(100vh /1.25);
        top: 50%;
        /* height: 100%;  */
      } }
  .section09__imgText {
    width: 100%;
    margin: auto; }
  .section09__img {
    width: 100%;
    /* height: 100%; */
    margin: auto; }
  .section09__imgText2 {
    width: 75%;
    margin: auto; }
    @media screen and (min-width: 767px) {
      .section09__imgText2 {
        width: 40%; } }
  .section09__btn {
    bottom: -26px !important; }
    @media screen and (min-width: 767px) {
      .section09__btn {
        bottom: calc(169 / 155 *-5%) !important; } }
    @media screen and (max-height: 570px) {
      .section09__btn {
        bottom: calc(169 / 155 *-5%) !important; } }
    @media screen and (max-height: 550px) {
      .section09__btn {
        bottom: calc(169 / 155 *-8%) !important; } }
    @media screen and (max-height: 500px) {
      .section09__btn {
        bottom: calc(169 / 155 *-10%) !important; } }
    @media screen and (max-height: 460px) {
      .section09__btn {
        bottom: calc(169 / 155 *-15%) !important; } }
    @media screen and (max-height: 370px) {
      .section09__btn {
        bottom: calc(169 / 155 *-30%) !important; } }
  .section09__box {
    position: absolute;
    bottom: 19%;
    right: 12%;
    z-index: 100; }
    @media screen and (min-width: 767px) {
      .section09__box {
        bottom: 50px;
        left: 50px; } }
    .section09__box-text {
      font-family: font1;
      color: #1f7137;
      border-bottom: 1px solid #1f7137; }
      .section09__box-text:not(:first-child) {
        margin-top: 13px; }

.section10 {
  position: relative;
  z-index: 2;
  background: white;
  /* padding: 155px 0; */
  height: 100vh;
  /* height: calc(var(--vh, 1vh) * 100); */
 }

  @media screen and (min-width: 767px) {
    .section10 {
      /* padding: 7% 0; */
     } }
  .section10__imgText {
    width: 70%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%);
    margin: auto; }
    @media screen and (min-width: 767px) {
      .section10__imgText {
        width: calc(100vh /1.9);
        /* height: 100%; */
       } }
  .section10__img {
    width: 100%;
    /* height: 100%; */
   }

.section11 {
  position: relative;
  background: #eae3d7;
  height: 100vh;
  /* height: calc(var(--vh, 1vh) * 100); */
  /* padding: 231px 0; */
  overflow: hidden; }
  @media screen and (min-width: 767px) {
    .section11 {
      /* padding: 8% 0;  */
    } }
  .section11__block {
    width: 75%;
    margin: auto; 
    position: absolute;
    top: 40%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%);
    }
    @media screen and (min-width: 767px) {
      .section11__block {
        top: 50%;
        width: calc(100vh / 1.05);
        /* height: 100%; */
        
       } }
  .section11__imgText {
    width: 100%;
    margin: auto; }
  .section11__img {
    width: 100%;
    /* height: 100%;  */
  }
  .section11__imgText2 {
    width: 100%;
    margin: auto; }
    @media screen and (min-width: 767px) {
      .section11__imgText2 {
        width: 40%; } }
  .section11__btn {
    bottom: -26px !important; }
    @media screen and (min-width: 767px) {
      .section11__btn {
        bottom: calc(169 / 155 *-5%) !important; } }
    @media screen and (max-height: 570px) {
      .section11__btn {
        bottom: calc(169 / 155 *-8%) !important; } }
    @media screen and (max-height: 550px) {
      .section11__btn {
        bottom: calc(169 / 155 *-8%) !important; } }
    @media screen and (max-height: 500px) {
      .section11__btn {
        bottom: calc(169 / 155 *-8%) !important; } }
    @media screen and (max-height: 460px) {
      .section11__btn {
        bottom: calc(169 / 155 *-8%) !important; } }
    @media screen and (max-height: 370px) {
      .section11__btn {
        bottom: calc(169 / 155 *-15%) !important; } }
  .section11__box {
    position: absolute;
    bottom: 26%;
    right: 12%; 
    z-index: 100;}
    @media screen and (min-width: 767px) {
      .section11__box {
        bottom: 50px;
        left: 50px; } }
    .section11__box-text {
      font-family: font1;
      color: #1f7137;
      border-bottom: 1px solid #1f7137; }
      .section11__box-text:not(:first-child) {
        margin-top: 13px; }

.section12 {
  position: relative;
  background: url(../image/sp_12.gif) center/cover;
  height: 100vh;
  /* height: calc(var(--vh, 1vh) * 100); */
  /* padding: 231px 0; */
  overflow: hidden; }
  @media screen and (min-width: 767px) {
    .section12 {
      background: url(../image/pc/pc_12.gif) center/cover;
      /* padding: 9% 0;  */
    } }

  .section12__imgText {
    width: 100%;
    margin: auto; }
    @media screen and (min-width: 767px) {
      .section12__imgText {
        width: 100%;
        /* height: 100%; */
        position: absolute;
        top: 50%;
        left: 50%;
        -webkit-transform: translate(-50%, -50%);
                transform: translate(-50%, -50%); } }
  .section12__img {
    width: 100%;
    margin: auto;
    /* height: 100%;  */
  }
  .section12__box {
    position: absolute;
    bottom: 50px;
    right: 7%;
   }
    @media screen and (min-width: 767px) {
      .section12__box {
        bottom: 50px;
        left: 50px; } }
    .section12__box-text {
      font-family: font1;
      color: #1f7137;
      border-bottom: 1px solid #1f7137; }
      .section12__box-text:not(:first-child) {
        margin-top: 13px; }

.section13 {
  overflow-y: hidden;
  position: relative;
  z-index: 2;
  background: url(../image/13_0.jpg) center/cover;
  height: 100vh; }
  .section13::before {
    z-index: 0;
    background: inherit;
    -webkit-filter: blur(3px);
            filter: blur(3px); }
  @media screen and (min-width: 767px) {
    .section13 {
      background: url(../image/pc/pc_13_0.jpg) center/cover; } }
  .section13__imgText {
    width: 80%;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%); 
    z-index: 99; }
    @media screen and (min-width: 767px) {
      .section13__imgText {
        width: 40%;} }
  .section13__img {
    width: 100%;
    /* height: 100%; */
   }
  .section13 .credit {
    position: absolute;
    z-index: 99;
    bottom: 24%;
    right: 10%; }
    @media screen and (min-width: 767px) {
      .section13 .credit  {
        bottom: 50px;
        left: 50px; } }
    .section13__box-text {
      font-family: font1;
      border-bottom: 1px solid white; }
      .section13__box-text:not(:first-child) {
        margin-top: 13px; }

        .credit {
          display: inline-block;
        }

        .credit li {
          margin-top: 13px;
        }

        .soon {
          opacity: .6;
          pointer-events: none;
          text-decoration: none;
          border-bottom: none; }
        
        .sp_right {
          text-align: right;
        }
        @media screen and (min-width: 767px) {
          .sp_right {
            text-align-last: left;
          }
        }

        /* swiperのpagination上書き */
        .swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
          margin: 0 8px;
          width: 5px;
          height: 5px;
        }
