@charset "utf-8";

/* font読み込み */
/* m-plus-1p-regular - japanese_latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "M PLUS 1p";
  font-style: normal;
  font-weight: 400;
  src: url("../fonts/m-plus-1p-v33-japanese_latin-regular.woff2")
    format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* m-plus-1p-500 - japanese_latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "M PLUS 1p";
  font-style: normal;
  font-weight: 500;
  src: url("../fonts/m-plus-1p-v33-japanese_latin-500.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* m-plus-1p-700 - japanese_latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "M PLUS 1p";
  font-style: normal;
  font-weight: 700;
  src: url("../fonts/m-plus-1p-v33-japanese_latin-700.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* m-plus-1p-800 - japanese_latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "M PLUS 1p";
  font-style: normal;
  font-weight: 800;
  src: url("../fonts/m-plus-1p-v33-japanese_latin-800.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* montserrat-regular - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Montserrat";
  font-style: normal;
  font-weight: 400;
  src: url("../fonts/montserrat-v31-latin-regular.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* montserrat-700 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Montserrat";
  font-style: normal;
  font-weight: 700;
  src: url("../fonts/montserrat-v31-latin-700.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* montserrat-italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Montserrat";
  font-style: italic;
  font-weight: 400;
  src: url("../fonts/montserrat-v31-latin-italic.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* noto-sans-jp-regular - japanese_latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 400;
  src: url("../fonts/noto-sans-jp-v56-japanese_latin-regular.woff2")
    format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

:root {
  --font_m1: "M PLUS 1p";
  --font_monst: "Montserrat";
  --font_noto: "Noto Sans JP";
  --color_txtblk: #000;
  --color_txtblue: #26a6da;
  --color_bgblue: #6ed3ff;
  --color_bgblue_tp: rgba(110, 211, 255, 0.8);
  --color_footerblue: #009bdb;
  --fs12: 1.2rem;
  --fs14: 1.4rem;
  --fs16: 1.6rem;
  --fs18: 1.8rem;
  --fs20: 2rem;
  --fs22: 2.2rem;
  --fs24: 2.4rem;
  --fs26: 2.6rem;
  --fs30: 3rem;
  --fs50: 5rem;
}
@media only screen and (max-width: 374px) {
  :root {
  }
}

html {
  -webkit-text-size-adjust: 100%;
  font-size: 62.5%;
}

body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
form,
input,
button,
p {
  margin: 0px;
  padding: 0px;
  font-size: var(--fs12);
  font-family: var(--font_m1);
  font-weight: 400;
  font-style: normal;
  line-height: 100%;
  color: #000;
  word-wrap: break-word;
  overflow-wrap: break-word;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  word-break: break-all;
}

/*フォント系*/
.m1_r {
  font-family: "M PLUS 1p";
  font-style: normal;
  font-weight: 400;
}
.m1_m {
  font-family: "M PLUS 1p";
  font-style: normal;
  font-weight: 500;
}
.m1_b {
  font-family: "M PLUS 1p";
  font-style: normal;
  font-weight: 700;
}
.m1_eb {
  font-family: "M PLUS 1p";
  font-style: normal;
  font-weight: 800;
}
.monst_r {
  font-family: "Montserrat";
  font-style: normal;
  font-weight: 400;
  letter-spacing: 0.03em;
}
.monst_i {
  font-family: "Montserrat";
  font-style: italic;
  font-weight: 400;
  letter-spacing: 0;
}
.monst_b {
  font-family: "Montserrat";
  font-style: normal;
  font-weight: 700;
  letter-spacing: 0.03em;
}
.noto_r {
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 400;
  letter-spacing: 0;
}

.bold {
  font-weight: bold;
}

.normal {
  font-weight: normal;
}

/* input初期化 */
input[type="text"],
input[type="date"],
textarea {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

/*画像・動画*/
img {
  vertical-align: top;
  border: none;
  max-width: 100% !important;
  height: auto !important;
}

.pic {
  text-align: center;
}

.pic img {
  width: 100%;
}

/*ofiImg*/
.ofiImg img {
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100% !important;
  font-family: "object-fit: cover;";
  /*IE対策*/
}

.ofiImg.tc {
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
  -ms-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
  height: 100%;
  width: 100%;
}

.ofiImg.t60 {
  position: relative;
  padding-top: 60%;
  display: block;
}

.ofiImg.t60 img {
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
  -ms-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
  -o-object-position: top center;
  object-position: top center;
}

/*フレックス*/
.flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.flexc {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: justify;
  justify-content: center;
}
.flexb {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.columnreverse {
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
}

.rowreverse {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
}

.aic {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.reverse {
  -webkit-box-direction: reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
}

/*wrap*/
#wrapper {
  /* overflow: hidden; */
  overflow-x: hidden;
  min-width: 320px;
  margin: 0 auto;
}

/*common*/
a {
  text-decoration: none;
  color: inherit;
  -webkit-transition: all ease 0.3s;
  -o-transition: all ease 0.3s;
  transition: all ease 0.3s;
}
a:hover {
  opacity: 0.6;
}
a:hover {
  color: inherit;
  text-decoration: none;
}

a[href*="tel:"] {
  pointer-events: initial;
}

ul,
li {
  list-style: none;
  text-align: left;
  padding: 0;
  margin: 0;
}

dl,
dt,
dd {
  text-align: left;
  padding: 0;
  margin: 0;
}

span {
  word-wrap: break-word;
  overflow-wrap: break-word;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  word-break: break-all;
}
.z1 {
  position: relative;
  z-index: 1;
}

.z2 {
  position: relative;
  z-index: 2;
}

.tac {
  text-align: center;
}

.tal {
  text-align: left;
}

.tar {
  text-align: right;
}
.dib {
  display: inline-block;
}
.tbsp_only {
  display: none;
}
.sp_only {
  display: none;
}
a[href*="tel:"] {
  pointer-events: none !important;
}
@media only screen and (max-width: 1024px) {
  a {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    -webkit-transition: -webkit-transform ease 0.2s;
    transition: -webkit-transform ease 0.2s;
    -o-transition: transform ease 0.2s;
    transition: transform ease 0.2s;
    transition:
      transform ease 0.2s,
      -webkit-transform ease 0.2s;
  }
  a:active {
    -webkit-transform: scale(0.95);
    -ms-transform: scale(0.95);
    transform: scale(0.95);
  }
  .pc_only {
    display: none;
  }
  .tbsp_only {
    display: block;
  }
}
@media only screen and (max-width: 767px) {
  .pctb_only {
    display: none;
  }
  .sp_only {
    display: block;
  }
}

/*ここまでreset*/

/************html・body**************/
body.hidden {
  overflow: hidden;
  height: 100%;
}

/************header**************/
header {
  width: 100%;
  position: fixed;
  z-index: 900;
  top: 0;
  left: 0;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  /* min1025px-max1280px */
  padding: 0 clamp(1rem, calc(3.9216vw - 3.0196rem), 2rem) 0.5rem
    clamp(0.1rem, calc(3.5294vw - 3.5176rem), 1rem);
  /* padding: 0 2.5rem 0.5rem 1rem; */
  min-height: 0vw; /* Safari clamp関数対策 */
  background-color: #fff;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition:
    background-color 0.4s ease,
    -webkit-box-shadow 0.4s ease;
  transition:
    background-color 0.4s ease,
    -webkit-box-shadow 0.4s ease;
  -o-transition:
    background-color 0.4s ease,
    box-shadow 0.4s ease;

  .head {
    width: 100%;
  }
  .head_logo {
    width: 16rem;

    & a {
      display: inline-block;
      width: 14.5rem;
    }

    & img {
      width: 100%;
      -webkit-transition: all ease 0.4s;
      -o-transition: all ease 0.4s;
      transition: all ease 0.4s;
    }
    .logo_white {
      display: none;
    }
  }
}
header.fixed {
  -webkit-box-shadow: 0px 4px 10px 0px rgba(75, 75, 75, 0.3);
  box-shadow: 0px 4px 10px 0px rgba(75, 75, 75, 0.3);
}
@media only screen and (max-width: 1024px) {
  header {
    padding: 0.5rem 2rem 0.8rem 0.5rem;
    .head_logo {
      width: 50%;
    }
  }
}
@media only screen and (max-width: 767px) {
}

/************gnav**************/
#gnav {
  width: calc(100% - 16rem);
  text-align: right;

  .gnavinn {
    display: inline-block;
    margin-top: 1rem;
  }
  .navlogo {
    display: none;
  }
  .navlist {
    .navitem {
      /* min1025px-max1280px */
      /* margin-right: clamp(2rem, 14.12vw + -12.47rem, 5.6rem); */
      margin-right: clamp(1.5rem, calc(5.8824vw - 4.5294rem), 3rem);
      min-height: 0vw; /* Safari clamp関数対策 */
    }
    .navitem:last-of-type {
      margin-right: 0;
    }
    .navitem a,
    .navitem span,
    subnavitem a {
      display: inline-block;
      /* min1025px-max1280px */
      font-size: clamp(1.2rem, calc(0.3922vw + 0.798rem), 1.3rem);
      min-height: 0vw; /* Safari clamp関数対策 */
      letter-spacing: 0.065em;
    }
  }
  .subnavlist {
    /* min1025px-max1280px */
    margin-left: clamp(1rem, calc(1.9608vw - 1.0098rem), 1.5rem);
    min-height: 0vw; /* Safari clamp関数対策 */
    padding: 0.5rem 0;
    border-left: 0.1rem solid var(--color_txtblk);
    border-right: 0.1rem solid var(--color_txtblk);
    .subnavitem {
      display: inline-block;
      /* min1025px-max1380px */
      padding: 0.2rem clamp(1rem, calc(1.9608vw - 1.0098rem), 1.5rem);
      min-height: 0vw; /* Safari clamp関数対策 */
      border-right: 0.1rem solid var(--color_txtblk);

      & a {
        /* min1025px-max1280px */
        font-size: clamp(1rem, calc(0.7843vw + 0.1961rem), 1.2rem);
        min-height: 0vw; /* Safari clamp関数対策 */
      }
    }
    .subnavitem:last-of-type {
      border: none;
    }
  }
}
@media only screen and (min-width: 1280px) {
  #gnav {
    .navlist {
      .navitem {
        margin-right: 3.5rem;
      }
      .navitem a,
      .navitem span {
        font-size: 1.4rem;
      }
    }
    .subnavlist {
      .subnavitem {
        & a {
          font-size: 1.2rem;
        }
      }
    }
  }
}

@media only screen and (max-width: 1024px) {
  #gnav {
    width: 50%;

    .gnavtoggle {
      display: block !important;
      margin-left: auto;
      position: relative;
      width: 5rem;
      height: 5rem;
      cursor: pointer;
      z-index: 1000;
      -webkit-transition: all ease 0.5s;
      -o-transition: all ease 0.5s;
      transition: all ease 0.5s;
      -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    }
    .gnavtoggle span.n {
      display: block;
      background: var(--color_txtblk);
      height: 0.2rem;
      width: 2.6rem;
      border-radius: 0.5rem;
      top: 50%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
      transform: translate(-50%, -50%);
      position: absolute;
    }
    .gnavtoggle span.n:before {
      display: block;
      content: "";
      background: var(--color_txtblk);
      height: 0.2rem;
      width: 2.6rem;
      border-radius: 0.5rem;
      position: absolute;
      top: -1rem;
      left: 50%;
      -webkit-transform: translate(-50%, 0) rotate(0);
      -ms-transform: translate(-50%, 0) rotate(0);
      transform: translate(-50%, 0) rotate(0);
      -webkit-transition: all ease 0.5s;
      -o-transition: all ease 0.5s;
      transition: all ease 0.5s;
    }
    .gnavtoggle span.n:after {
      display: block;
      content: "";
      background: var(--color_txtblk);
      height: 0.2rem;
      width: 2.6rem;
      border-radius: 0.5rem;
      position: absolute;
      top: 1rem;
      left: 50%;
      -webkit-transform: translate(-50%, 0) rotate(0);
      -ms-transform: translate(-50%, 0) rotate(0);
      transform: translate(-50%, 0) rotate(0);
      -webkit-transition: all ease 0.5s;
      -o-transition: all ease 0.5s;
      transition: all ease 0.5s;
    }

    .gnavinn {
      visibility: hidden;
      position: fixed;
      margin-top: 0;
      top: -100dvh;
      left: 0;
      width: 100vw;
      height: 100dvh;
      -webkit-box-sizing: border-box;
      box-sizing: border-box;
      border: none;
      background: var(--color_bgblue_tp);
      overflow-y: auto;
      -webkit-overflow-scrolling: touch;
      z-index: 999;
      -webkit-transition:
        top 0.5s ease,
        visibility 0.5s ease;
      -o-transition:
        top 0.5s ease,
        visibility 0.5s ease;
      transition:
        top 0.5s ease,
        visibility 0.5s ease;
    }
    .gnavinn .navlogo {
      display: block;
      width: 14.5rem;
      margin: 0.5rem 0 0 0.5rem;
    }
    .navlist {
      padding: 7rem 4.5rem 4.5rem;
      width: 100%;
      max-width: 60rem;
      margin: 0 auto;

      .navitem {
        display: block;
        width: 100%;
        margin: 0 0 5rem 0;
        text-align: center;

        .tit {
          display: block;
          text-align: center;
        }

        & > a,
        > span {
          display: inline-block;
          font-size: var(--fs18) !important;
          color: #fff !important;
          letter-spacing: 0.3em !important;
        }
        & > a {
          text-decoration: underline;
          text-underline-offset: 0.5rem;
        }
      }
      .navitem:last-of-type {
        margin: 0;
      }
    }

    .subnavlist {
      border: none;
      margin: 0;
      padding: 0;

      .subnavitem {
        width: 100%;
        margin-top: 1rem;
        border: none;
        padding: 0;

        & a {
          display: block;
          width: 100%;
          border-radius: 1rem;
          color: var(--color_txtblk) !important;
          background: #fff;
          text-align: center;
          font-size: var(--fs14);
          letter-spacing: 0.065em;
          padding: 1.5rem 0;
          position: relative;

          &:after {
            content: "\f105";
            font-family: "Font Awesome 5 Free";
            font-weight: 900;
            color: var(--color_txtblue);
            display: inline-block;
            position: absolute;
            right: 1rem;
            top: 50%;
            -webkit-transform: translateY(-50%);
            -ms-transform: translateY(-50%);
            transform: translateY(-50%);
          }
        }
      }
    }
  }

  #gnav.open {
    .gnavtoggle span.n {
      background-color: transparent !important;

      &:before {
        top: 50%;
        background: #fff !important;
        -webkit-transform: translate(-50%, -50%) rotate(45deg);
        -ms-transform: translate(-50%, -50%) rotate(45deg);
        transform: translate(-50%, -50%) rotate(45deg);
        -webkit-transition: all ease 0.5s;
        -o-transition: all ease 0.5s;
        transition: all ease 0.5s;
      }
      &:after {
        top: 50%;
        background: #fff !important;
        -webkit-transform: translate(-50%, -50%) rotate(-45deg);
        -ms-transform: translate(-50%, -50%) rotate(-45deg);
        transform: translate(-50%, -50%) rotate(-45deg);
        -webkit-transition: all ease 0.5s;
        -o-transition: all ease 0.5s;
        transition: all ease 0.5s;
      }
    }
    .gnavinn {
      visibility: visible;
      top: 0;
      -webkit-transition:
        top 0.5s ease,
        visibility 0.5s ease;
      -o-transition:
        top 0.5s ease,
        visibility 0.5s ease;
      transition:
        top 0.5s ease,
        visibility 0.5s ease;
    }
  }
}
@media only screen and (max-width: 767px) {
  #gnav {
    .navlist {
      max-width: 40rem;
    }
  }
}

/************footer**************/
footer {
  background-color: var(--color_bgblue);

  .foot {
    padding: 0 0 1rem;

    .foot_logo {
      width: 14.5rem;
      margin-right: 7.5rem;

      & a {
        display: block;
      }
    }
    .snsbox {
      margin: 1rem 0 0 7.5rem;
      .item {
        display: inline-block;
        margin: 0 1.5rem;

        & a {
          display: block;
          width: 2.1rem;
        }
      }
      .youtube {
        & a {
          width: 2.7rem;
        }
      }
    }
  }
  .copy {
    width: 100%;
    color: #fff;
    background: var(--color_footerblue);
    padding: 0.5rem 0;
  }
}
@media only screen and (max-width: 1024px) {
  footer {
    .foot {
      .foot_logo {
        margin-right: 4rem;
      }
      .snsbox {
        margin-left: 4rem;
      }
    }
    .copy {
      padding-bottom: 2rem;
    }
  }
}
@media only screen and (max-width: 767px) {
  footer {
    .foot {
      padding: 3.5rem 0 2.5rem;
      .foot_logo {
        margin: 1.5rem auto 0;
      }
      .snsbox {
        width: 100%;
        margin: 0;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;

        .item {
          margin: 0 2rem;
          & a {
            width: 3.2rem;
          }
        }
        .youtube {
          & a {
            width: 4rem;
          }
        }
      }
    }
  }
}

/************common**************/
.tit_ja {
  font-family: var(--font_m1);
  color: var(--color_txtblk);
  font-weight: 400;
  font-size: 2.3rem;
  letter-spacing: 0;
}
.w1180 {
  width: 95%;
  max-width: 118rem;
  margin: 0 auto;
}
.w840 {
  width: 95%;
  max-width: 84rem;
  margin: 0 auto;
}
.btn_white {
  font-family: var(--font_noto);
  display: inline-block;
  font-size: 1.8rem;
  background-color: #fff;
  letter-spacing: 0.065em;
  padding: 1.8rem 2.5rem;
  border-radius: 3rem;
  -webkit-box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.35);
  box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.35);
}
.bg_gray {
  background-color: #eee;
  padding: 8rem 0 5rem;
}

@media only screen and (max-width: 1024px) {
  .tit_ja {
    font-size: 1.8rem;
  }
  .w1180 {
    width: 88%;
  }
  .w840 {
    width: 88%;
  }
  .btn_white {
    font-size: 1.6rem;
  }
}
@media only screen and (max-width: 767px) {
  .tit_ja {
    font-size: 1.6rem;
  }
  .w1180 {
    width: 88%;
  }
  .w840 {
    width: 88%;
  }
  .btn_white {
    font-size: 1.2rem;
    padding: 1.2rem 1.7rem;
  }
}

/************loading**************/
#loadingarea {
  background-color: #fff;
  width: 100vw;
  height: 100svh;
  position: fixed;
  left: 0;
  top: 0;
  z-index: 999;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  .dot {
    width: 1.2rem;
    height: 1.2rem;
    margin: 0 5px;
    background-color: var(--color_bgblue);
    border-radius: 50%;
    -webkit-animation: dot-pulse 1.5s ease-in-out infinite;
    animation: dot-pulse 1.5s ease-in-out infinite;
  }
  .dot:nth-child(1) {
    -webkit-animation-delay: 0s;
    animation-delay: 0s;
  }
  .dot:nth-child(2) {
    -webkit-animation-delay: 0.2s;
    animation-delay: 0.2s;
  } /* Fixed delays for simplicity */
  .dot:nth-child(3) {
    -webkit-animation-delay: 0.4s;
    animation-delay: 0.4s;
  }
}

@-webkit-keyframes dot-pulse {
  0%,
  100% {
    -webkit-transform: scale(0.7);
    transform: scale(0.7);
    opacity: 0.7;
  }
  50% {
    -webkit-transform: scale(1);
    transform: scale(1);
    opacity: 1;
  }
}

@keyframes dot-pulse {
  0%,
  100% {
    -webkit-transform: scale(0.7);
    transform: scale(0.7);
    opacity: 0.7;
  }
  50% {
    -webkit-transform: scale(1);
    transform: scale(1);
    opacity: 1;
  }
}

/************TOP**************/
.top {
  #header {
    opacity: 0;
    background: transparent;
  }
  .head_logo {
    .logo_blue {
      display: none;
    }
    .logo_white {
      display: block;
    }
  }
  #gnav {
    .navitem a,
    .navitem span,
    subnavitem a {
      color: #fff;
    }
    .subnavlist {
      border-color: #fff;

      .subnavitem {
        border-color: #fff;
      }
    }
  }

  #header.fixed {
    background-color: #fff;
    .head_logo {
      .logo_blue {
        display: block;
      }
      .logo_white {
        display: none;
      }
    }
    #gnav {
      .navitem a,
      .navitem span,
      subnavitem a {
        color: var(--color_txtblk);
      }
      .subnavlist {
        border-color: var(--color_txtblk);

        .subnavitem {
          border-color: var(--color_txtblk);
        }
      }
    }
  }

  .mvarea {
    width: 100%;
    height: auto;
    background: var(--color_bgblue);
    position: relative;
    overflow: hidden;
    z-index: 2;

    #mv_illust {
      width: 100%;
      height: auto;
      position: relative;
      margin-top: 18.8rem;
    }
    .mvtxtarea {
      width: 100%;
      position: absolute;
      left: 0;
      top: 16rem;
      z-index: 3;
      text-align: center;

      .mvtxt {
        display: inline-block;
        width: 54.4rem;
        height: auto;
        opacity: 0;

        & img {
          width: 100%;
        }
      }
      .mvtxt_sp {
        display: none;
      }
    }
  }
}

@media only screen and (max-width: 1024px) {
  .top {
    .mvarea {
      width: 100%;
      height: 100svh;
      background: var(--color_bgblue);
      position: relative;
      overflow: hidden;
      z-index: 2;

      #mv_illust {
        width: 100%;
        height: auto;
        position: absolute;
        left: 0;
        bottom: 0;
      }
      .mvtxtarea {
        top: 11%;
        left: 0;

        .mvtxt {
          width: 3rem;
        }
        .mvtxt_pc {
          display: none;
        }
        .mvtxt_sp {
          display: block;
        }
      }
    }
    #header {
      #gnav {
        .gnavtoggle span.n {
          background-color: #fff;
        }
        .gnavtoggle span.n:before {
          background-color: #fff;
        }
        .gnavtoggle span.n:after {
          background-color: #fff;
        }
      }
    }
    #header.fixed {
      #gnav {
        .gnavtoggle span.n {
          background-color: var(--color_txtblk);
        }
        .gnavtoggle span.n:before {
          background-color: var(--color_txtblk);
        }
        .gnavtoggle span.n:after {
          background-color: var(--color_txtblk);
        }
      }
    }
  }
}
@media only screen and (max-width: 767px) {
  .top {
    .mvarea {
      .mvtxtarea {
        top: 15%;

        .mvtxt {
          width: 2rem;
        }
      }
    }
  }
}
@media only screen and (max-width: 359px) {
  .top {
    .mvarea {
      .mvtxtarea {
        .mvtxt {
          width: 1.5rem;
        }
      }
    }
  }
}

.top01 {
  background-color: var(--color_bgblue);

  .itemlist {
  }

  .item {
    display: block;
    width: 100%;
    position: relative;
    z-index: 1;
  }
  .wrap {
    display: inline-block;
    position: relative;
  }
  .txtcontents {
    display: inline-block;
    position: relative;
    /* z-index: 2; */
    .tit {
      font-size: 2.5rem;
      line-height: 160%;
      letter-spacing: 0.115em;
    }

    .txt {
      font-size: 1.9rem;
      line-height: 160%;
      letter-spacing: 0;
    }
    & dd {
      margin-top: 3.5rem;
    }
  }

  .item:nth-of-type(1) {
    padding-top: 12rem;

    .small-cloud {
      width: 20.7rem;
      position: absolute;
      top: 7rem;
      right: 28rem;
      & img {
        width: 100%;
      }
    }
    .wrap {
      .bgarea {
        width: 104.5rem;
        position: absolute;
        top: -25rem;
        left: -33.5rem;
      }
      .bg {
        width: 100%;
      }
      .illust {
        width: 27.8rem;
        position: absolute;
        right: 24rem;
        bottom: 3rem;
      }
      .txtcontents {
        padding-left: 13rem;
      }
    }
  }
  .item:nth-of-type(2) {
    z-index: 2;
    padding: 9.5rem 0 15.2rem;
    text-align: right;
    .small-cloud {
      width: 18rem;
      position: absolute;
      bottom: 0;
      left: -6rem;
      & img {
        width: 100%;
      }
    }
    .wrap {
      .bgarea {
        width: 69.3rem;
        position: absolute;
        top: -14rem;
        left: -7rem;
      }
      .bg {
        width: 100%;
      }
      .illust {
        width: 33.3rem;
        position: absolute;
        right: 17rem;
        bottom: 0rem;
      }
      .txtcontents {
        padding-right: 7.8rem;
      }
    }
  }
  .item:nth-of-type(3) {
    padding: 2.5rem 0 7rem;
    .small-cloud {
      width: 15.1rem;
      position: absolute;
      bottom: 0;
      right: -5rem;
      & img {
        width: 100%;
      }
    }
    .wrap {
      .bgarea {
        width: 62rem;
        position: absolute;
        top: -12rem;
        left: 8.8rem;
      }
      .bg {
        width: 100%;
      }
      .illust {
        width: 21.4rem;
        position: absolute;
        right: 20rem;
        bottom: -1.5rem;
      }
      .txtcontents {
        padding-left: 19.6rem;
      }
    }
  }
  .item:nth-of-type(4) {
    padding: 13rem 0 0;
    text-align: right;

    .wrap {
      .bgarea {
        width: 65.5rem;
        position: absolute;
        top: -7.5rem;
        left: -16rem;
      }
      .bg {
        width: 100%;
      }
      .illust {
        width: 42rem;
        position: absolute;
        left: 7rem;
        bottom: -1rem;
      }
      .txtcontents {
        padding-right: 13rem;
      }
    }
    .btnarea {
      margin-top: 3rem;
      .btn {
        display: inline-block;
        background-color: var(--color_bgblue);
        font-size: 1.8rem;
        line-height: 100%;
        letter-spacing: 0.065em;
        padding: 1.5rem 2.5rem;
        border-radius: 3rem;
      }
    }
  }
}
@media only screen and (max-width: 1259px) {
  .top01 {
    .item:nth-of-type(1) {
      .small-cloud {
        right: 10rem;
      }
    }
    .item:nth-of-type(2) {
      padding-top: 25rem;
    }
    .item:nth-of-type(3) {
      padding-top: 15rem;
    }
    .item:nth-of-type(4) {
      padding-top: 16rem;
    }
  }
}
@media only screen and (max-width: 1024px) {
  .top01 {
    .txtcontents {
      .tit {
        font-size: 2.2rem;
      }
      .txt {
        font-size: 1.7rem;
      }
      & dd {
        margin-top: 2.5rem;
      }
    }

    .item:nth-of-type(1) {
      padding-top: 9rem;

      .small-cloud {
        width: 15rem;
        right: 3rem;
        top: 4rem;
      }
      .wrap {
        .bgarea {
          width: 80rem;
          left: -20rem;
          top: -17rem;
        }

        .illust {
          width: 22rem;
          right: 22rem;
          bottom: 0;
        }
        .txtcontents {
          padding-left: 8rem;
        }
      }
    }
    .item:nth-of-type(2) {
      padding: 25rem 0 0;
      .small-cloud {
        width: 15rem;
      }
      .wrap {
        .bgarea {
          width: 60rem;
          left: -7rem;
          top: -12rem;
        }

        .illust {
          width: 30rem;
          right: 12rem;
          bottom: 0;
        }
        .txtcontents {
          padding-right: 6rem;
        }
      }
    }
    .item:nth-of-type(3) {
      padding: 25rem 0 0;
      .small-cloud {
        width: 15rem;
      }
      .wrap {
        .bgarea {
          width: 55rem;
          left: -7rem;
          top: -9rem;
        }

        .illust {
          width: 15rem;
          right: 20rem;
          bottom: 0;
        }
        .txtcontents {
          padding-left: 9rem;
        }
      }
    }
    .item:nth-of-type(4) {
      padding: 18rem 0 0;
    }
  }
}

@media only screen and (max-width: 767px) {
  .top01 {
    .txtcontents {
      .tit {
        font-size: 1.8rem;
      }
      .txt {
        font-size: 1.2rem;
      }
      & dd {
        margin-top: 2rem;
      }
    }

    .item:nth-of-type(1) {
      padding-top: 6rem;

      .small-cloud {
        width: 8rem;
        right: -2.2rem;
        top: 2rem;
      }
      .wrap {
        .bgarea {
          width: 50.5rem;
          left: -14rem;
          top: -8rem;
        }

        .illust {
          width: 17rem;
          right: 11rem;
          bottom: 0.5rem;
        }
        .txtcontents {
          padding-left: 1.8rem;
        }
      }
    }
    .item:nth-of-type(2) {
      padding: 15.5rem 0 0;
      .small-cloud {
        width: 8rem;
        left: -3rem;
        bottom: 2rem;
      }
      .wrap {
        .bgarea {
          width: 38rem;
          left: -5rem;
          top: -7rem;
        }

        .illust {
          width: 18.3rem;
          right: 11rem;
          bottom: -1rem;
        }
        .txtcontents {
          padding-right: 3rem;
        }
      }
    }
    .item:nth-of-type(3) {
      padding: 15.6rem 0 0;
      .small-cloud {
        width: 10rem;
        right: -3.5rem;
      }
      .wrap {
        .bgarea {
          width: 33.5rem;
          left: -8rem;
          top: -6rem;
        }

        .illust {
          width: 12rem;
          right: -4rem;
          bottom: 1rem;
        }
        .txtcontents {
          padding-left: 2.5rem;
        }
      }
    }
    .item:nth-of-type(4) {
      padding: 14rem 0 0;

      .wrap {
        .bgarea {
          width: 43.1rem;
          left: -9rem;
          top: -4.6rem;
        }
        .illust {
          width: 23rem;
          right: -5rem;
          bottom: 0;
        }
        .txtcontents {
          padding-right: 3rem;
        }
        .btnarea {
          margin-top: 2rem;
          .btn {
            font-size: 1.2rem;
            padding: 1rem 1.5rem;
          }
        }
      }
    }
  }
}
@media only screen and (max-width: 359px) {
  .top01 {
    .small-cloud {
      display: none;
    }
  }
}

.top02 {
  background-color: var(--color_bgblue);
  padding: 20.5rem 0 9.5rem;

  .titbox {
    position: relative;
    .subtit {
      width: 55.1rem;
      position: absolute;
      top: 0;
      left: -8rem;
    }
    & h2.tit {
      font-size: 2.3rem;
      letter-spacing: 0;
      position: relative;
      z-index: 2;
      padding-top: 8.5rem;
    }
  }
  .list {
    margin-top: 5rem;
  }
  .swiper-wrapper {
    -webkit-transition-timing-function: linear !important;
    -o-transition-timing-function: linear !important;
    transition-timing-function: linear !important;
  }
  .item {
    width: 37.3rem !important;
    height: 34rem;
    background-color: #fff;
    padding: 2.5rem 0;
    border-radius: 1rem;
  }
  .pic {
    width: 75%;
    margin: 0 auto;
  }
  & dt {
    margin: 0.8rem 0 0 2.5rem;

    .subtit {
      display: block;
      color: var(--color_txtblue);
      font-size: 1.1rem;
      letter-spacing: 0;
    }
    .tit {
      display: block;
      color: var(--color_txtblue);
      font-size: 1.6rem;
      line-height: 160%;
      letter-spacing: 0.3em;
      margin-top: 0.3rem;
    }
  }
  .box {
    margin: 1.5rem 0 0 2.5rem;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
  .txtarea {
    width: calc(100% - 13.8rem);
  }
  .txtitem {
    display: block;
    width: 48.5%;
    background-color: #bbdcf4;
    font-size: 1rem;
    margin: 0 0 0.5rem;
    padding: 0.7rem 0;
    text-align: center;
  }
  .txtitem:nth-last-of-type(-n + 2) {
    margin-bottom: 0;
  }
  .txt {
    font-size: 1rem;
    line-height: 160%;
  }
  .btnarea {
    width: 13.8rem;
    text-align: right;

    & a {
      width: 13rem;
      height: 5.3rem;
      display: inline-block;
      color: #fff;
      background-color: var(--color_txtblue);
      font-size: 1.2rem;
      text-align: center;
      position: relative;
      right: -1rem;

      &:after {
        content: "";
        width: 0;
        height: 0;
        border-top: 1rem solid #0092c5; /* 上方向の辺 */
        border-right: 1rem solid transparent; /* 右方向の辺 */
        border-left: 0;
        border-bottom: 0;
        position: absolute;
        right: 0;
        bottom: -1rem;
      }

      & span {
        display: inline-block;
        position: relative;
        padding-right: 1.8em;
        line-height: 5.3rem;

        &:after {
          content: "\f105";
          font-family: "Font Awesome 5 Free";
          font-size: 1.6rem;
          font-weight: 900;
          color: #fff;
          display: inline-block;
          position: absolute;
          right: 0;
          top: 50%;
          -webkit-transform: translateY(-50%);
          -ms-transform: translateY(-50%);
          transform: translateY(-50%);
        }
      }
    }
  }
}
@media only screen and (max-width: 1024px) {
  .top02 {
    padding-bottom: 5rem;
    .titbox {
      .subtit {
        width: 40rem;
        position: absolute;
      }
      & h2.tit {
        font-size: 1.8rem;
        padding-top: 6rem;
      }
    }
  }
}
@media only screen and (max-width: 767px) {
  .top02 {
    padding-bottom: 3.5rem;
    .titbox {
      .subtit {
        width: 30.8rem;
        position: absolute;
        left: -4rem;
      }
      & h2.tit {
        font-size: 1.4rem;
        padding-top: 5rem;
      }
    }
    .list {
      margin-top: 2.5rem;
    }
    .item {
      width: 30rem !important;
      height: 27.5rem;
      padding: 2rem 0;
    }
    & dt {
      margin: 0.5rem 0 0 2rem;

      .subtit {
        font-size: 0.9rem;
      }
      .tit {
        font-size: 1.4rem;
      }
    }
    .box {
      margin: 0.5rem 0 0 2rem;
    }
    .txtarea {
      width: calc(100% - 11.8rem);
    }
    .txtitem {
      font-size: 0.8rem;
    }
    .txt {
      font-size: 1rem;
      line-height: 160%;
    }
    .btnarea {
      width: 11.8rem;
      text-align: right;

      & a {
        width: 11rem;
        height: 4.7rem;
        font-size: 1rem;

        & span {
          line-height: 4.7rem;
        }
      }
    }
  }
}

.top03 {
  background-color: var(--color_bgblue);
  padding: 14rem 0 0;
  position: relative;

  .bg {
    width: 100%;
    height: 69.6rem;
    position: absolute;
    top: 0;
    left: 0;
  }

  .top03area {
    background-color: #fff;
    padding-bottom: 15rem;
  }
  .titbox {
    .tit {
      font-size: 2.3rem;
      letter-spacing: 0;
    }
    .subtit {
      margin-top: 2.5rem;

      & img {
        display: inline-block;
        width: 37.3rem;
      }
    }
  }
  .txtarea {
    width: 88%;
    margin: 4rem auto;

    & dt {
      color: var(--color_txtblue);
      font-size: 2.5rem;
      letter-spacing: 0.02em;
      line-height: 160%;
    }
    & dd {
      font-size: 1.9rem;
      letter-spacing: 0.065em;
      line-height: 160%;
      margin-top: 4rem;
    }
  }
  .infoarea {
    margin-top: 8rem;

    .btn_white {
      padding: 1.8rem 26rem;
      cursor: pointer;
      position: relative;

      &:after {
        content: "\f107";
        font-family: "Font Awesome 5 Free";
        font-weight: 900;
        color: var(--color_txtblk);
        display: inline-block;
        position: absolute;
        right: 3rem;
        top: 50%;
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
        -webkit-transition: all ease 0.3s;
        -o-transition: all ease 0.3s;
        transition: all ease 0.3s;
      }
    }
    .btn_white.open {
      &:after {
        -webkit-transform: translateY(-50%) rotate(180deg);
        -ms-transform: translateY(-50%) rotate(180deg);
        transform: translateY(-50%) rotate(180deg);
      }
    }
    .listarea {
      display: none;
    }
    .listwrap {
      width: 93rem;
      margin: 8rem auto 0;
    }
    .list {
      width: 50%;
    }
    .list:nth-of-type(1) {
      padding-right: 5rem;
      border-right: 0.1rem solid var(--color_txtblue);
    }
    .list:nth-of-type(2) {
      padding-left: 5rem;
    }
    .item {
      border-top: 0.1rem solid var(--color_txtblue);
      padding: 1.2rem 0;
    }
    .tit {
      width: 9rem;
      font-size: 1.3rem;
      color: var(--color_txtblue);
      letter-spacing: 0.1em;
      line-height: 140%;
    }
    .info {
      width: calc(100% - 9rem);
      font-size: 1.3rem;
      letter-spacing: 0.065em;
      line-height: 160%;
    }
  }
}

@media only screen and (max-width: 1024px) {
  .top03 {
    padding: 10rem 0 0;

    .bg {
      height: 45rem;
    }

    .top03area {
    }
    .titbox {
      .tit {
        font-size: 1.8rem;
      }
      .subtit {
        margin-top: 2rem;
        & img {
          width: 32rem;
        }
      }
    }
    .txtarea {
      margin-top: 3rem;

      & dt {
        font-size: 2.2rem;
      }
      & dd {
        font-size: 1.6rem;
        margin-top: 3rem;
      }
    }
    .infoarea {
      .btn_white {
        padding: 1.8rem 22rem;
      }
      .listwrap {
        margin: 6rem auto 0;
        max-width: 60rem;
      }
      .list {
        width: 100%;
      }
      .list:nth-of-type(1) {
        padding: 0;
        border: none;
      }
      .list:nth-of-type(2) {
        padding: 0;
      }
    }
  }
}
@media only screen and (max-width: 767px) {
  .top03 {
    padding: 8.5rem 0 0;

    .bg {
      height: 27rem;
    }
    .top03area {
      padding-bottom: 8rem;
    }

    .titbox {
      .tit {
        font-size: 1.4rem;
      }
      .subtit {
        margin-top: 1.5rem;
        & img {
          width: 90%;
          max-width: 30.2rem !important;
        }
      }
    }
    .txtarea {
      margin-top: 3rem;

      & dt {
        font-size: 1.6rem;
      }
      & dd {
        font-size: 1.2rem;
        margin-top: 2.5rem;
      }
    }
    .infoarea {
      margin-top: 4.5rem;
      .btn_white {
        width: 80%;
        min-width: 30rem;
        padding: 1.2rem 0;
      }
      .listwrap {
        margin: 5rem auto 0;
        width: 88%;
      }
      .item {
        padding: 1rem 0;
      }
      .tit {
        width: 7rem;
        font-size: 1.1rem;
      }
      .info {
        width: calc(100% - 7rem);
        font-size: 1.1rem;
      }
    }
  }
}

/* パンくずリスト */
#breadcrumbarea {
  margin-top: 10.4rem;
  .item {
    display: inline-block;
    font-family: var(--font_noto);
    color: var(--color_txtblk);
    font-size: 1.2rem;
    font-weight: 400;
    line-height: 100%;
    letter-spacing: 0;
    padding-right: 2rem;
    margin-right: 1rem;
    position: relative;

    &:after {
      content: ">";
      font-size: 1.6rem;
      right: 0;
      position: absolute;
    }

    & a {
      display: inline-block;
      font-size: inherit;
      font-family: inherit;
      color: inherit;
      font-size: inherit;
    }
  }
  .item:last-of-type:after {
    display: none;
  }
}
@media only screen and (max-width: 1024px) {
}
@media only screen and (max-width: 767px) {
  #breadcrumbarea {
    .item {
      font-size: 1rem;
      padding-right: 1.5rem;
      margin-right: 0.5rem;

      &:after {
        font-size: 1.4rem;
      }
    }
  }
}

/* 下層ページ共通 */
#wrapper.under {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  min-height: 100vh;
}
.under #main {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}
.under {
  opacity: 0;

  .tit_ja_blue {
    font-family: var(--font_m1);
    color: var(--color_txtblue);
    font-weight: 500;
    font-size: 2.6rem;
    letter-spacing: 0.3em;
    line-height: 140%;
  }

  .titbox {
    margin: 8rem auto 6rem;

    .subtit {
      color: var(--color_txtblue);
      font-size: 1rem;
      letter-spacing: 0;
      line-height: 100%;
      margin-bottom: 1rem;
    }
  }
  .txt {
    font-size: 1.4rem;
    letter-spacing: 0;
    line-height: 200%;
  }
  & h3.tit {
    text-align: center;
    font-size: 2.2rem;
    margin-top: 7.8rem;
    letter-spacing: 0;
    line-height: 140%;
    padding: 1rem 0;
    border-top: 0.1rem solid var(--color_txtblue);
    border-bottom: 0.1rem solid var(--color_txtblue);
  }
  .btnarea {
    margin-top: 5rem;
    text-align: center;
  }
  .single {
    .pictxtarea {
      margin-top: 2.5rem;
      .left {
        width: 45%;
      }
      .right {
        width: 53%;
      }
    }
    & dt.tit {
      display: inline-block;
      color: var(--color_txtblue);
      font-size: 2rem;
      line-height: 140%;
      letter-spacing: 0;
      text-decoration: underline;
      text-underline-offset: 0.8rem;
    }
    & dd.txt {
      margin-top: 1.2rem;
    }
  }
  .list01 {
    .pictxtarea {
      margin-top: 2.5rem;
      .left {
        width: 45%;
      }
      .right {
        width: 53%;
      }
    }
    & dt.tit {
      color: var(--color_txtblue);
      font-size: 1.8rem;
      line-height: 140%;
      letter-spacing: 0;

      & span {
        display: block;
        padding-left: 1em;
        position: relative;

        &:after {
          content: "・";
          position: absolute;
          left: 0;
        }
      }
    }
    & dd.txt {
      margin-top: 1.2rem;
    }
    .txtarea {
      margin-top: 2.5rem;

      & dt.tit {
        text-align: center;
      }
    }
  }
  .list02 {
    .item {
      background-color: #fff;
      width: 31.6%;
      margin: 5% 2.6% 0 0;
      padding: 5rem 2.5rem 3rem;
      position: relative;
      border-top: 0.3rem solid var(--color_txtblue);

      .tit {
        color: var(--color_txtblue);
        font-size: 1.9rem;
        letter-spacing: 0;
        line-height: 140%;
      }
      .txt {
        margin-top: 2rem;
      }
      .icon {
        width: 6rem;
        position: absolute;
        top: -3rem;
        left: 50%;
        -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
        transform: translateX(-50%);
      }
    }

    .item:nth-of-type(3n) {
      margin-right: 0;
    }
  }
  .list03 {
    .item {
      width: calc(50% - 6rem);
      margin: 8rem 3rem 0;
    }
    & dt.tit {
      color: var(--color_txtblue);
      font-size: 1.9rem;
      letter-spacing: 0;
      line-height: 140%;
      padding: 0 0 2rem 4.5rem;
      border-bottom: 0.3rem solid var(--color_txtblue);
      position: relative;

      .number {
        display: inline-block;
        font-size: 5rem;
        position: absolute;
        top: 0;
        left: 0;
      }
    }
    & dd.txt {
      margin-top: 2rem;

      .att {
        font-family: inherit;
        font-weight: inherit;
        letter-spacing: inherit;
        line-height: 140%;
        font-size: 1rem;
        margin-top: 2.5rem;
      }
    }
  }
}
@media only screen and (max-width: 1024px) {
  .under {
    .titbox {
      margin: 6rem auto 4rem;
    }
    .txt {
      font-size: 1.3rem;
    }
    & h3.tit {
      font-size: 2rem;
      margin-top: 6.5rem;
    }

    .list01 {
      .pictxtarea {
        margin-top: 2rem;

        .left {
          width: calc(98% - 42rem);
        }
        .right {
          width: 42rem;
        }
      }
      & dt.tit {
        font-size: 1.6rem;
      }
      .txtarea {
        margin-top: 2rem;

        & dt.tit {
          text-align: center;
        }
      }
    }
    .list02 {
      .item {
        width: 48%;
        margin: 7% 4% 0 0;
      }
      .item:nth-of-type(3n) {
        margin-right: 4%;
      }
      .item:nth-of-type(2n) {
        margin-right: 0;
      }
    }
    .list03 {
      .item {
        width: calc(50% - 5rem);
        margin: 7rem 2.5rem 0;
      }
      & dt.tit {
        font-size: 1.8rem;
        .number {
          font-size: 4.5rem;
        }
      }
    }
  }
}
@media only screen and (max-width: 767px) {
  .under {
    .tit_ja_blue {
      font-size: 2.3rem;
      text-align: left;
    }
    .titbox {
      margin: 3rem auto;

      .subtit {
        text-align: left;
      }
    }
    .txt {
      font-size: 1.2rem;
    }
    & h3.tit {
      font-size: 2rem;
    }
    .single {
      .pictxtarea {
        margin-top: 1rem;

        .left {
          width: 100%;
        }
        .right {
          width: 100%;
          margin-top: 1.5rem;
          text-align: center;
        }
      }
      & dt.tit {
        font-size: 1.8rem;
      }
      .txtarea {
        margin-top: 1rem;

        & dt.tit {
          text-align: left;
        }
      }
    }
    .list01 {
      .pictxtarea {
        margin-top: 1rem;

        .left {
          width: 100%;
        }
        .right {
          width: 100%;
          margin-top: 1.5rem;
        }
      }
      & dt.tit {
        font-size: 1.6rem;
      }
      .txtarea {
        margin-top: 1rem;

        & dt.tit {
          text-align: left;
        }
      }
    }
    .list02 {
      .item {
        width: 100%;
        margin: 0 0 5rem 0 !important;
        padding: 4rem 1.5rem 1.5rem;

        .tit {
          font-size: 1.6rem;
          height: auto !important;
          -webkit-box-sizing: border-box;
          box-sizing: border-box;
        }
        .txt {
          margin-top: 1.5rem;
        }
        .icon {
          width: 5rem;
          top: -2.5rem;
        }
      }
      .item:last-of-type {
        margin-bottom: 0 !important;
      }
    }
    .list03 {
      margin-top: 6.5rem;

      .item {
        width: 100%;
        margin: 5rem 0 0;
      }
      .item:first-of-type {
        margin-top: 0;
      }
      & dt.tit {
        font-size: 1.6rem;
        padding: 0 0 1.5rem 4rem;

        .number {
          font-size: 4.2rem;
        }
      }
      & dd.txt {
        margin-top: 1.5rem;
      }
    }
  }
}

/* development */
.development02 {
  margin-top: 10rem;
}

/* management */
.management02 {
  margin-top: 10rem;

  .list02 {
    margin-top: 2rem;
  }
}

@media only screen and (max-width: 767px) {
  .management02 {
    .list02 {
      margin-top: 6rem;
    }
  }
}

/*  reform*/
.reform01 {
  margin-bottom: 8rem;
}

/* mediation */
.mediation01 {
  margin-bottom: 8rem;
}
.mediation02 {
  margin-bottom: 8rem;
}
.mediation02area {
  padding-top: 8rem;
  border-top: 0.3rem solid #eee;
}

@media only screen and (max-width: 1024px) {
}
@media only screen and (max-width: 767px) {
}

/* parking */
.parking02 {
  margin-top: 7rem;
  padding-top: 4rem;

  & h3.tit {
    margin-top: 0;
  }
}

@media only screen and (max-width: 767px) {
  .parking02 {
    .list02 {
      margin-top: 6rem;
    }
  }
}

/* contact */
.contact01 {
  padding: 2rem 0 12.5rem;
}
@media only screen and (max-width: 1024px) {
  .contact {
    .tit_ja_blue {
      text-align: center;
    }
  }
}

@media only screen and (max-width: 767px) {
  .contact01 {
    padding: 2rem 0 8rem;
  }
}

/* check(moveout・contact確認画面)  */
.check {
  .titbox {
    margin: 20rem auto 6rem;
  }
}
.check01 {
  margin-bottom: 12rem;

  .subtit {
    font-size: 2.2rem;
    letter-spacing: 0;
  }
  .formarea {
    margin-top: 11rem;
  }
  .infoarea {
    & * {
      font-family: var(--font_noto);
      font-weight: 400;
      letter-spacing: 0;
      line-height: 140%;
    }
    .item {
      margin-bottom: 2rem;
      padding-bottom: 2rem;
      border-bottom: 0.1rem solid var(--color_txtblue);
    }
    .tit {
      font-size: 1.4rem;
    }
    .info {
      font-size: 1.6rem;
      margin-top: 1rem;
    }
    .smallitem {
      margin-bottom: 1rem;
      .smalltit {
        display: block;
        width: 10rem;
        font-family: var(--font_noto);
        font-size: 1.4rem;
        font-weight: 400;
        letter-spacing: 0;
        line-height: 140%;
        position: relative;

        &:after {
          content: "：";
          position: absolute;
          right: 1rem;
          top: 50%;
          -webkit-transform: translateY(-50%);
          -ms-transform: translateY(-50%);
          transform: translateY(-50%);
        }
      }

      .smallinfo {
        width: calc(100% - 10rem);
        font-size: 1.6rem;
      }
    }
  }
  .btnarea {
    width: 100%;
    margin-top: 10rem;
    & li {
      width: 100%;
      text-align: center;
    }
    .backbtnarea {
      margin-bottom: 7rem;
    }
    .backbtn {
      display: inline-block;
      font-size: 1.4rem;
      letter-spacing: 0;
      padding-left: 2em;
      position: relative;

      &:before {
        content: "\f104";
        font-size: 1.9rem;
        font-family: "Font Awesome 5 Free";
        font-weight: 900;
        color: var(--color_txtblk);
        display: inline-block;
        position: absolute;
        left: 0;
        top: 50%;
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
      }
    }

    .send_btn {
      cursor: pointer;
      display: inline-block;
      width: 70%;
      max-width: 59rem;
      font-size: 1.8rem;
      background-color: #fff;
      letter-spacing: 0.065em;
      padding: 1.8rem 2.5rem;
      border: none;
      border-radius: 3rem;
      -webkit-box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.35);
      box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.35);
      -webkit-transition: all ease 0.3s;
      -o-transition: all ease 0.3s;
      transition: all ease 0.3s;
      position: relative;

      &:hover {
        opacity: 0.6;
      }

      &:after {
        content: "\f105";
        font-size: 1.9rem;
        font-family: "Font Awesome 5 Free";
        font-weight: 900;
        color: var(--color_txtblk);
        display: inline-block;
        position: absolute;
        right: 3rem;
        top: 50%;
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
      }
    }
  }
}
@media only screen and (max-width: 1024px) {
  .check {
    .titbox {
      margin: 18rem auto 4rem;

      .tit_ja_blue {
        text-align: center;
      }
    }
  }
  .check01 {
    .subtit {
      font-size: 2rem;
    }
    .formarea {
      max-width: 70rem;
      margin: 8rem auto 0;
    }
  }
}
@media only screen and (max-width: 767px) {
  .check {
    margin-bottom: 10rem;
    .titbox {
      margin: 15rem auto 4rem;
    }
  }
  .check01 {
    .subtit {
      font-size: 1.6rem;
    }
    .formarea {
      max-width: 50rem;
      margin: 4rem auto 0;
    }
    .infoarea {
      .tit {
        font-size: 1.2rem;
      }
      .info {
        font-size: 1.4rem;
      }

      .smallitem {
        .smalltit {
          width: 8.5rem;
          font-size: 1.2rem;
        }
        .smallinfo {
          width: calc(100% - 8.5rem);
          font-size: 1.4rem;
        }
      }
    }
    .btnarea {
      margin-top: 5rem;

      .backbtnarea {
        margin-bottom: 3rem;
      }
      .send_btn {
        font-size: 1.4rem;
        width: 100%;
        padding: 1.5rem;

        &:after {
          font-size: 1.6rem;
          right: 2rem;
        }
      }
    }
  }
}

/* contact-end・moveout-end */
.end {
  .titbox {
    margin: 20rem auto 6rem;
  }
  .end01 {
    padding: 4rem 0 10rem;
  }
  .txtarea {
    .tit {
      font-size: 2.2rem;
      letter-spacing: 0;
    }
    .btn {
      margin-top: 4rem;
      text-align: center;

      & a {
        display: inline-block;
        background-color: var(--color_bgblue);
        font-size: 1.8rem;
        line-height: 100%;
        letter-spacing: 0.065em;
        padding: 1.5rem 8rem;
        border-radius: 3rem;
      }
    }
  }
}
@media only screen and (max-width: 1024px) {
  .end {
    .titbox {
      margin: 18rem auto 4rem;

      .tit_ja_blue {
        text-align: center;
      }
    }
    .txtarea {
      .tit {
        font-size: 2rem;
      }
      .btn {
        & a {
        }
      }
    }
  }
}
@media only screen and (max-width: 767px) {
  .end {
    .titbox {
      margin: 15rem auto 4rem;
    }
    .txtarea {
      .tit {
        font-size: 1.6rem;
      }
      .btn {
        & a {
          font-size: 1.6rem;
        }
      }
    }
  }
}

/* moveout */
.moveout01 {
  .txtitem {
    margin-top: 5.5rem;
  }
  .txtitem:last-of-type {
    padding-bottom: 7.5rem;
    border-bottom: 0.3rem solid var(--color_txtblue);
  }
  .tit {
    color: var(--color_txtblue);
    font-size: 1.9rem;
    letter-spacing: 0;
    line-height: 140%;
    padding-bottom: 1.5rem;
    border-bottom: 0.3rem solid var(--color_txtblue);
  }
  .txtarea {
    margin-top: 2.5rem;

    .txt {
      font-size: 1.4rem;
      letter-spacing: 0;
      line-height: 175%;
    }
    & li.txt {
      position: relative;
      padding-left: 1.2em;
      margin-bottom: 3rem;

      &:before {
        content: "■";
        position: absolute;
        left: 0;
      }
    }
    & li.txt:last-of-type {
      margin-bottom: 0;
    }
  }
}
.moveout02 {
  margin: 8rem 0 12rem;
}
@media only screen and (max-width: 1024px) {
  .moveout {
    .tit_ja_blue {
      text-align: center;
    }
  }
  .moveout01 {
    max-width: 70rem;
    margin: 5.5rem auto 0;
  }
}
@media only screen and (max-width: 767px) {
  .moveout01 {
    max-width: 50rem;
    margin: 6rem auto 0;

    .txtitem:last-of-type {
      padding-bottom: 7rem;
    }

    .tit {
      font-size: 1.6rem;
      padding-bottom: 1.2rem;
    }
    .txtarea {
      margin-top: 1.5rem;

      .txt {
        font-size: 1.2rem;
      }
    }
  }
  .moveout02 {
    margin: 7rem 0 8rem;
  }
}

/* form */
.formarea {
  .att {
    color: red;
    font-size: 1.4rem;
    letter-spacing: 0;
    line-height: 100%;
  }
}

#form {
  margin-top: 4.5rem;
  & * {
    font-family: var(--font_noto);
    font-weight: 400;
    font-size: 1.4rem;
    letter-spacing: 0;
    line-height: 140%;
  }

  .item {
    width: 46%;
    margin-bottom: 4.5rem;
  }
  .w100 {
    width: 100%;
  }
  .w46 {
    width: 46%;
  }
  .item:last-of-type {
    margin-bottom: 0;
  }
  .tit {
    .req {
      color: red;
    }
  }
  .infoarea {
    margin-top: 1rem;

    & input,
    textarea {
      width: 100%;
      background-color: #f0f0f0;
      border-radius: 0.5rem;
      border: none;
      padding: 1.2rem 1rem;
      -webkit-box-sizing: border-box;
      box-sizing: border-box;
    }
    & input[type="date"] {
      min-height: 4.5rem;
    }
    & input[type="date"]::-webkit-date-and-time-value {
      -webkit-box-sizing: border-box;
      box-sizing: border-box;
      -webkit-appearance: none;
      -moz-appearance: none;
      appearance: none;
      text-align: left !important;
    }

    & input[type="checkbox"] {
      background-color: #fff;
      width: 2rem;
      height: 2rem;
      border: 0.1rem solid var(--color_txtblk);
      border-radius: 0;
      margin-right: 1rem;
      padding: 0;
      position: relative;
      -webkit-box-sizing: border-box;
      box-sizing: border-box;
      -webkit-appearance: none;
      -moz-appearance: none;
      appearance: none;

      &:after {
        content: "";
        display: block;
        position: absolute;
        width: 0.5rem;
        height: 1rem;
        border-right: 3px solid var(--color_txtblue);
        border-bottom: 3px solid var(--color_txtblue);
        left: 0.5rem;
        top: 0.1rem;
        -webkit-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
        transform: rotate(45deg);
        opacity: 0;
      }
    }
    & input[type="checkbox"]:checked {
      &:after {
        opacity: 1;
      }
    }
    .select {
      position: relative;
      height: 100%;

      &:after {
        content: "\f107";
        font-family: "Font Awesome 5 Free";
        font-weight: 900;
        color: var(--color_txtblk);
        display: inline-block;
        position: absolute;
        right: 2rem;
        top: 50%;
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
        -webkit-transition: all ease 0.3s;
        -o-transition: all ease 0.3s;
        transition: all ease 0.3s;
      }

      & select {
        width: 100%;
        height: 100%;
        min-height: 4.5rem;
        background-color: #f0f0f0;
        border-radius: 0.5rem;
        border: none;
        padding: 1.2rem 1rem;
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
        -webkit-appearance: none;
        -moz-appearance: none;
        appearance: none;
      }
    }
  }

  & ::-webkit-input-placeholder {
    color: #a7a7a7;
  }

  & ::-moz-placeholder {
    color: #a7a7a7;
  }

  & :-ms-input-placeholder {
    color: #a7a7a7;
  }

  & ::-ms-input-placeholder {
    color: #a7a7a7;
  }

  & ::placeholder {
    color: #a7a7a7;
  }

  .infoarea.flexb {
    & input {
      width: 49%;
    }
  }
  .infoarea.flexb.inner {
    .infoinner {
      margin-bottom: 2rem;
    }
    .subtit {
      display: inline-block;
      width: 7.5rem;
    }
    & input,
    .select {
      width: calc(100% - 7.5rem);
    }
  }
  & textarea {
    resize: vertical;
    height: 25rem;
  }
  .btnarea {
    width: 100%;
    margin-top: 10rem;
  }
  & li {
    width: 100%;
    text-align: center;
  }
  .send_btn {
    cursor: pointer;
    display: inline-block;
    width: 70%;
    max-width: 59rem;
    font-size: 1.8rem;
    background-color: #fff;
    letter-spacing: 0.065em;
    padding: 1.8rem 2.5rem;
    border: none;
    border-radius: 3rem;
    -webkit-box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.35);
    box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.35);
    -webkit-transition: all ease 0.3s;
    -o-transition: all ease 0.3s;
    transition: all ease 0.3s;
    position: relative;

    &:hover {
      opacity: 0.6;
    }

    &:after {
      content: "\f105";
      font-size: 1.9rem;
      font-family: "Font Awesome 5 Free";
      font-weight: 900;
      color: var(--color_txtblk);
      display: inline-block;
      position: absolute;
      right: 3rem;
      top: 50%;
      -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
      transform: translateY(-50%);
    }
  }
}
@media only screen and (max-width: 1024px) {
  .formarea {
    width: 100%;
    max-width: 70rem;
    margin: 0 auto;
  }
  #form {
    .item {
      width: 100%;
    }
    .w46 {
      width: 100%;
    }
  }
}
@media only screen and (max-width: 767px) {
  .formarea {
    max-width: 50rem;
    .att {
      font-size: 1.2rem;
    }
  }

  #form {
    margin-top: 3.5rem;

    & * {
      font-size: 1.2rem;
    }

    .item {
      margin-bottom: 3.5rem;
    }

    & textarea {
      height: 20rem;
    }
    .btnarea {
      margin-top: 8rem;
    }
    .send_btn {
      font-size: 1.4rem;
      width: 100%;
      padding: 1.5rem;

      &:after {
        font-size: 1.6rem;
        right: 2rem;
      }
    }
  }
}
@media only screen and (max-width: 359px) {
  #form {
    .infoarea.flexb {
      & input {
        width: 100%;
        margin-bottom: 0.5rem;
      }
    }
  }
}

/* contact・moveoutヘッダー固定 */
.contact #header,
.moveout header {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
}
.contact #header.fixed,
.moveout header.fixed {
  -webkit-box-shadow: none;
  box-shadow: none;
}

/* contact_list */
.common_contacts_area {
  padding: 0 0 14rem;
  .contact_titbox {
    .subtit {
      font-size: var(--fs18);
      color: #a7a7a7;
      margin-bottom: 2.5rem;
    }
  }

  .list {
    position: relative;

    &:after {
      content: "";
      width: 100%;
      height: 0.1rem;
      background-color: var(--color_txtblue);
      position: absolute;
      left: 0;
      top: 29rem;
    }
  }
  .item {
    width: 33.3%;
    margin-top: 8rem;
    padding: 1.5rem;
    border-right: 0.1rem solid var(--color_txtblue);

    .tit {
      font-size: var(--fs18);
      color: var(--color_txtblue);
      line-height: 150%;

      & span {
        display: block;
        text-align: center;
      }
    }

    .txtarea {
      margin-top: 1.6rem;

      & span {
        /* min1025px-max1100px */
        font-size: clamp(1.3rem, 1.33vw + -0.06rem, 1.4rem);
        min-height: 0vw; /* Safari clamp関数対策 */
        letter-spacing: 0.065em;
      }
      .txt {
        /* min1025px-max1100px */
        font-size: clamp(1.3rem, 1.33vw + -0.06rem, 1.4rem);
        min-height: 0vw; /* Safari clamp関数対策 */
        letter-spacing: 0.065em;
        line-height: 160%;
        margin-bottom: 2.5rem;
      }
      .time {
        margin-top: 1rem;
        /* min1025px-max1100px */
        font-size: clamp(1.3rem, 1.33vw + -0.06rem, 1.4rem);
        min-height: 0vw; /* Safari clamp関数対策 */
        letter-spacing: 0.065em;
      }
      .att {
        margin-top: 1.8rem;
        letter-spacing: 0.065em;
      }
    }
    .btn {
      margin-top: auto;
      & a {
        display: inline-block;
        font-size: var(--fs14);
        background-color: var(--color_bgblue);
        /* min1025px-max1100px */
        padding: 1.5rem clamp(6.4rem, 13.33vw + -7.26rem, 7.4rem);
        min-height: 0vw; /* Safari clamp関数対策 */
        letter-spacing: 0.086em;
        border-radius: 1rem;
        position: relative;
        background-image: url(../images/arrow02.svg);
        background-repeat: no-repeat;
        background-position: right 2rem center;
        background-size: 1.2rem 1.2rem;
      }
    }
  }
  .item:nth-last-of-type(-n + 2) {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
  .item:nth-of-type(3),
  .item:nth-of-type(5) {
    border-right: none;
  }
  .item:nth-of-type(5) .tit {
    margin-top: 5rem;
  }
}
@media only screen and (max-width: 1024px) {
  .common_contacts_area {
    .contact_titbox {
      .subtit {
        font-size: 1.4rem;
        margin-bottom: 2rem;
      }
    }

    .list {
      max-width: 50rem;
      margin: 0 auto;
      &:after {
        display: none;
      }
    }
    .item {
      width: 100%;
      border-right: none;
      border-bottom: 0.1rem solid var(--color_txtblue);
      padding: 3.5rem 0;
      margin: 0;

      .tit {
        & span {
          display: inline-block;
        }
      }
      .txtarea {
        .txt {
          margin-bottom: 0;
        }
      }
      .btn {
        margin-top: 1.5rem;
      }
    }
    .item:last-of-type {
      display: block;
      border-bottom: none;
      margin: auto;
      .tit {
        margin-top: 0;
      }
    }
  }
}

@media only screen and (max-width: 767px) {
  .contact_list {
    .titbox {
      .subtit {
        text-align: center;
      }
      .tit_ja_blue {
        text-align: center;
      }
    }
  }
  .common_contacts_area {
    padding: 0 0 5rem;
    .contact_titbox {
      .subtit {
        font-size: 1.2rem;
      }
    }

    .item {
      padding: 4rem 0;

      .tit {
        font-size: 1.6rem;
      }
      .txtarea {
        margin-top: 1.2rem;

        .att {
          font-size: 1.3rem;
          margin-top: 1.5rem;
        }
      }
      .btn {
        & a {
          font-size: 1.3rem;
        }
      }
    }
  }
}
