@charset "UTF-8";
/****************************************
Break Point Settings
****************************************/
.pc {
  display: block; }
  @media screen and (max-width: 767px) {
    .pc {
      display: none !important; } }

.sp {
  display: none !important; }
  @media screen and (max-width: 767px) {
    .sp {
      display: block !important; } }

/*********************************************************

					　　　　初期設定

**********************************************************/
html {
  box-sizing: border-box;
  scroll-behavior: smooth; }

body {
  line-height: 1.5;
  margin: 0 auto;
  width: 100%;
  font-family: "Zen Old Mincho", serif;
  font-weight: 400;
  color: #333;
  font-style: normal;
  font-feature-settings: "palt"; }

p {
  font-size: min(2.1vw,25px);
  line-height: 1.8; }
  @media screen and (max-width: 767px) {
    p {
      font-size: min(4.68vw,32px); } }

.eng {
  font-family: "Bebas Neue", sans-serif;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0.05em; }

.readtext {
  font-size: min(1.83vw,18px);
  font-feature-settings: "palt"; }
  @media screen and (max-width: 767px) {
    .readtext {
      font-size: min(4vw,24px); } }

.annotation {
  font-size: min(1.56vw,14px);
  line-height: 1.5;
  font-feature-settings: "palt"; }
  @media screen and (max-width: 767px) {
    .annotation {
      font-size: 10px; } }

.subtitle {
  font-size: 28px; }

h2 {
  font-size: min(4vw,50px);
  font-weight: 400;
  line-height: 1.5;
  margin: 0 auto;
  font-feature-settings: "palt"; }
  @media screen and (max-width: 767px) {
    h2 {
      font-size: 8vw; } }

h3 {
  font-size: min(3.64vw,40px);
  font-weight: 600;
  line-height: 1.5;
  margin: 0 auto;
  font-feature-settings: "palt"; }
  @media screen and (max-width: 767px) {
    h3 {
      font-size: 5.6vw; } }

h4 {
  font-size: min(3.12vw,35px);
  font-weight: 500;
  line-height: 1.5;
  margin: 0 auto;
  font-feature-settings: "palt"; }

h5 {
  font-size: min(1.95vw,23px);
  font-weight: 500;
  line-height: 1.5;
  margin: 0 auto;
  color: #901826;
  font-feature-settings: "palt"; }

.ex {
  transform: translateY(5vw);
  opacity: 0;
  transition: ease 0.7s; }
  .ex.delay {
    transition: linear 0.5s 0.15s; }
    @media screen and (max-width: 767px) {
      .ex.delay {
        transition: linear 0.5s; } }
  .ex.active {
    transform: translateY(0);
    opacity: 1; }

.splide__pagination {
  display: flex;
  justify-content: center;
  gap: 1rem;
  margin-top: 1rem; }
  @media screen and (max-width: 767px) {
    .splide__pagination {
      gap: 10px; } }

.splide__pagination__page {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background-color: #fff;
  border: 1px solid #3E281C;
  cursor: pointer;
  transition: background-color 0.3s; }
  @media screen and (max-width: 767px) {
    .splide__pagination__page {
      width: 10px;
      height: 10px; } }

.splide__pagination__page.is-active {
  background-color: #3E281C; }

/*********************************************************

					　　　　haeder

**********************************************************/
.header {
  width: 100vw;
  position: fixed;
  top: 0;
  left: 0;
  background: #fff;
  z-index: 20; }
  .header .inner {
    width: calc(100% - 20px);
    margin-left: 20px;
    display: flex;
    justify-content: space-between;
    align-items: center; }
    @media screen and (max-width: 767px) {
      .header .inner {
        height: 10vw;
        max-height: 70px;
        min-height: 50px;
        width: calc(100% - 10px);
        margin-left: 10px; } }
    .header .inner a {
      height: 40px;
      width: auto; }
      @media screen and (max-width: 767px) {
        .header .inner a {
          height: 70%; } }
      .header .inner a .logo {
        height: 100%;
        width: auto; }
    .header .inner .sp-menu {
      display: none;
      position: absolute;
      top: 0;
      right: 0;
      width: auto;
      height: 100%;
      aspect-ratio: 1 / 1;
      background: #925A5B;
      cursor: pointer; }
    @media screen and (max-width: 767px) {
      .header .inner .sp-menu {
        display: block; }
        .header .inner .sp-menu span {
          font-size: min(2.3vw,12px);
          position: relative;
          width: 40%;
          height: 2px;
          background: #fff;
          display: block;
          margin-left: 30%;
          margin-top: calc(50% - 1px);
          transition: ease 0.3s; }
          .header .inner .sp-menu span::before, .header .inner .sp-menu span::after {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            transform-origin: center;
            display: block;
            background: #fff;
            transition: ease 0.3s; }
          .header .inner .sp-menu span::before {
            transform: translateY(1em); }
          .header .inner .sp-menu span::after {
            transform: translateY(-1em); }
        .header .inner .sp-menu:hover span {
          background: transparent; }
          .header .inner .sp-menu:hover span::before {
            transform: rotate(45deg); }
          .header .inner .sp-menu:hover span::after {
            transform: rotate(-45deg); }
      .header .inner #menu-open {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        transform: translateX(101%);
        transition: 0.3s;
        z-index: -1; }
        .header .inner #menu-open.active {
          transform: translateX(0); }
        .header .inner #menu-open .sp-menuback {
          width: 100%;
          height: 100%;
          background: rgba(255, 255, 255, 0.8);
          z-index: -1; } }
    .header .inner .menu {
      width: auto;
      display: flex;
      justify-content: flex-end;
      align-items: center; }
      @media screen and (max-width: 767px) {
        .header .inner .menu {
          position: absolute;
          top: 20%;
          left: 50%;
          transform: translateX(-50%);
          z-index: 2;
          width: 80%;
          max-width: 400px;
          display: block; } }
      .header .inner .menu li {
        font-size: min(1.83vw,18px);
        line-height: 1.4;
        height: 70px;
        width: 14vw;
        max-width: 14em;
        align-content: center;
        text-align: center;
        color: #fff; }
        @media screen and (max-width: 767px) {
          .header .inner .menu li {
            width: 100%;
            font-size: min(4.375vw,18px);
            max-width: none;
            height: 3.3em; } }
        .header .inner .menu li span {
          display: inline-block; }
        .header .inner .menu li:first-of-type {
          font-size: min(1.56vw,14px);
          text-align: right;
          margin-right: 1em;
          color: #333;
          width: auto; }
          @media screen and (max-width: 767px) {
            .header .inner .menu li:first-of-type {
              width: 100%;
              font-size: 4.375vw;
              margin-right: 0;
              text-align: center;
              height: auto; } }
        .header .inner .menu li:nth-of-type(2) {
          background: #3E281C;
          color: rgba(255, 255, 255, 0.2);
          pointer-events: none;
          position: relative; }
          .header .inner .menu li:nth-of-type(2)::before {
            content: 'COMING SOON';
            font-family: "Bebas Neue", sans-serif;
            position: absolute;
            top: 50%;
            left: 0;
            transform: translateY(-50%);
            width: 100%;
            font-size: 16px;
            line-height: 1;
            letter-spacing: 0.05em;
            font-weight: 600;
            color: #FFF9B1;
            white-space: nowrap;
            display: block; }
        .header .inner .menu li:nth-of-type(3) {
          background: #925A5B; }
        .header .inner .menu li:nth-of-type(4) {
          background: #5A87FF; }
        .header .inner .menu li:nth-of-type(5) {
          background: #00AA9B; }
        .header .inner .menu li a {
          width: 100%;
          height: 100%;
          display: block;
          align-content: center;
          transition: ease 0.5s; }
          .header .inner .menu li a.textlink {
            height: auto; }
            @media screen and (max-width: 767px) {
              .header .inner .menu li a.textlink {
                margin-bottom: 0.5em;
                text-decoration: underline; } }
          .header .inner .menu li a:hover {
            opacity: 0.6; }
    .header .inner h1 {
      position: absolute;
      top: 0;
      left: 0;
      transform: translateY(-200%); }

/*********************************************************

					　　　　main

**********************************************************/
.main {
  width: 100%;
  height: auto;
  margin: 0 auto; }
  .main #top {
    position: relative;
    width: 100%;
    height: auto; }
    .main #top li .imgbox {
      width: 100%;
      height: auto;
      max-height: 100vh;
      aspect-ratio: 16 / 10;
      display: block; }
      @media screen and (max-width: 767px) {
        .main #top li .imgbox {
          aspect-ratio: 750 / 991;
          margin-top: clamp(50px,10vw,70px); } }
      .main #top li .imgbox.i1 {
        background: url(../img/top-slide01.webp) no-repeat center/cover; }
        @media screen and (max-width: 767px) {
          .main #top li .imgbox.i1 {
            background: url(../img/top-slide01-sp.webp) no-repeat center/cover; } }
      .main #top li .imgbox.i2 {
        background: url(../img/top-slide02.webp) no-repeat center/cover; }
        @media screen and (max-width: 767px) {
          .main #top li .imgbox.i2 {
            background: url(../img/top-slide02-sp.webp) no-repeat center/cover; } }
    .main #top h2 {
      position: absolute;
      bottom: -0.4%;
      left: 50%;
      width: 93%;
      transform: translateX(-40%);
      max-width: 1600px;
      height: auto;
      opacity: 0;
      transition: ease 2s;
      mix-blend-mode: lighten; }
      .main #top h2 img {
        width: 100%;
        height: auto; }
      .main #top h2.loaded {
        transform: translateX(-50%);
        opacity: 0.8; }
  .main .sec01 {
    width: 100%; }
    .main .sec01 .wrap01 {
      padding: min(7.2vw,90px) 0; }
      @media screen and (max-width: 767px) {
        .main .sec01 .wrap01 {
          padding: 9.33vw 0; } }
      @media screen and (max-width: 767px) {
        .main .sec01 .wrap01 .inner {
          width: 100%;
          max-width: none; } }
      .main .sec01 .wrap01 .eng {
        text-align: center;
        line-height: 1;
        margin-bottom: 2em; }
        @media screen and (max-width: 767px) {
          .main .sec01 .wrap01 .eng {
            font-size: min(5.33vw,40px);
            margin-bottom: 1em; } }
      .main .sec01 .wrap01 .splide__pagination {
        margin-top: 50px; }
        @media screen and (max-width: 767px) {
          .main .sec01 .wrap01 .splide__pagination {
            margin-top: 6.5vw; } }
      .main .sec01 .wrap01 .list2 li {
        width: 30%; }
        .main .sec01 .wrap01 .list2 li a {
          width: 100%;
          height: auto;
          display: block; }
          .main .sec01 .wrap01 .list2 li a img {
            width: 100%;
            height: auto;
            padding: 0 4%; }
    .main .sec01 .wrap02 {
      padding: min(7.2vw,90px) 0;
      background: #3E281C;
      color: #fff; }
      @media screen and (max-width: 767px) {
        .main .sec01 .wrap02 {
          padding: 9.33vw 0 0; } }
      .main .sec01 .wrap02 .flex {
        display: flex;
        align-items: center;
        justify-content: space-between; }
        @media screen and (max-width: 767px) {
          .main .sec01 .wrap02 .flex {
            display: block; } }
        .main .sec01 .wrap02 .flex .flex-wrap01 {
          width: 50%; }
          @media screen and (max-width: 767px) {
            .main .sec01 .wrap02 .flex .flex-wrap01 {
              width: 100%; } }
          .main .sec01 .wrap02 .flex .flex-wrap01 .eng {
            text-align: left;
            margin-top: 0;
            margin-bottom: 0.5em;
            line-height: 1; }
            @media screen and (max-width: 767px) {
              .main .sec01 .wrap02 .flex .flex-wrap01 .eng {
                font-size: min(5.33vw,40px); } }
          .main .sec01 .wrap02 .flex .flex-wrap01 table {
            width: 100%; }
            @media screen and (max-width: 767px) {
              .main .sec01 .wrap02 .flex .flex-wrap01 table {
                border-top: 1px solid #fff;
                border-bottom: 1px solid #fff; } }
            .main .sec01 .wrap02 .flex .flex-wrap01 table tr:first-of-type {
              border-top: 1px solid #fff; }
              .main .sec01 .wrap02 .flex .flex-wrap01 table tr:first-of-type th, .main .sec01 .wrap02 .flex .flex-wrap01 table tr:first-of-type td {
                padding-top: 0.9em; }
              @media screen and (max-width: 767px) {
                .main .sec01 .wrap02 .flex .flex-wrap01 table tr:first-of-type {
                  border: 0; }
                  .main .sec01 .wrap02 .flex .flex-wrap01 table tr:first-of-type td {
                    padding-top: 0; } }
            .main .sec01 .wrap02 .flex .flex-wrap01 table tr:last-of-type {
              border-bottom: 1px solid #fff; }
              .main .sec01 .wrap02 .flex .flex-wrap01 table tr:last-of-type th, .main .sec01 .wrap02 .flex .flex-wrap01 table tr:last-of-type td {
                padding-bottom: 0.9em; }
              @media screen and (max-width: 767px) {
                .main .sec01 .wrap02 .flex .flex-wrap01 table tr:last-of-type th {
                  padding-bottom: 0; } }
            @media screen and (max-width: 767px) {
              .main .sec01 .wrap02 .flex .flex-wrap01 table tr:nth-of-type(4) td {
                padding-bottom: 0.9em; }
              .main .sec01 .wrap02 .flex .flex-wrap01 table tr:nth-of-type(5) {
                display: none; } }
            .main .sec01 .wrap02 .flex .flex-wrap01 table tr th, .main .sec01 .wrap02 .flex .flex-wrap01 table tr td {
              padding: 0.2em 0;
              font-size: min(1.30vw,15px); }
              @media screen and (max-width: 767px) {
                .main .sec01 .wrap02 .flex .flex-wrap01 table tr th, .main .sec01 .wrap02 .flex .flex-wrap01 table tr td {
                  font-size: min(3.75vw,20px);
                  display: block; } }
            .main .sec01 .wrap02 .flex .flex-wrap01 table tr td {
              padding-left: 1em; }
              @media screen and (max-width: 767px) {
                .main .sec01 .wrap02 .flex .flex-wrap01 table tr td {
                  padding-left: 0; } }
        .main .sec01 .wrap02 .flex .flex-wrap02 {
          width: 50%;
          text-align: right; }
          @media screen and (max-width: 767px) {
            .main .sec01 .wrap02 .flex .flex-wrap02 {
              width: 100%;
              padding: 13.33vw 0;
              text-align: center; } }
          .main .sec01 .wrap02 .flex .flex-wrap02 div {
            text-align: center;
            display: inline-grid; }
            .main .sec01 .wrap02 .flex .flex-wrap02 div p {
              line-height: 1;
              margin-top: 0.9em;
              display: inline-block; }
              @media screen and (max-width: 767px) {
                .main .sec01 .wrap02 .flex .flex-wrap02 div p {
                  margin-top: 0.6em; } }
            .main .sec01 .wrap02 .flex .flex-wrap02 div .readtext {
              margin-top: 1.1em;
              line-height: 1;
              display: inline-block; }
              @media screen and (max-width: 767px) {
                .main .sec01 .wrap02 .flex .flex-wrap02 div .readtext {
                  margin-top: 0.7em; } }
              .main .sec01 .wrap02 .flex .flex-wrap02 div .readtext.time {
                margin-top: 0; }
              .main .sec01 .wrap02 .flex .flex-wrap02 div .readtext:first-of-type {
                margin-top: 0; }
            .main .sec01 .wrap02 .flex .flex-wrap02 div .tel {
              position: relative;
              font-size: min(4.68vw,60px);
              padding-left: 1.3em;
              display: inline-block;
              line-height: 1;
              margin-top: 0.4em;
              margin-bottom: 0.5em; }
              @media screen and (max-width: 767px) {
                .main .sec01 .wrap02 .flex .flex-wrap02 div .tel {
                  font-size: min(10.66vw,80px); } }
              .main .sec01 .wrap02 .flex .flex-wrap02 div .tel::before {
                content: '';
                width: 1.1em;
                height: auto;
                aspect-ratio: 66 / 43;
                background: url(../img/tel.webp) no-repeat center/contain;
                display: block;
                position: absolute;
                top: 50%;
                left: 0;
                transform: translateY(-40%); }
    .main .sec01 .inner {
      width: 90%;
      max-width: 1100px;
      margin: 0 auto; }
      @media screen and (max-width: 767px) {
        .main .sec01 .inner {
          width: calc(100% - 20px);
          max-width: 650px; } }
  .main .sec02 {
    width: 100%;
    background: #F7F5F3 url(../img/back02.webp) no-repeat top/contain;
    overflow: hidden;
    padding-bottom: min(9.375vw,150px); }
    @media screen and (max-width: 767px) {
      .main .sec02 {
        padding-bottom: 13.33vw; } }
    .main .sec02 .inner {
      width: 90%;
      max-width: 1100px;
      margin: 0 auto; }
      @media screen and (max-width: 767px) {
        .main .sec02 .inner {
          width: calc(100% - 20px);
          max-width: 650px; } }
      .main .sec02 .inner .flex01 {
        position: relative;
        width: 100%;
        display: flex;
        align-items: center; }
        .main .sec02 .inner .flex01 .flex-wrap {
          font-size: min(4vw,50px);
          width: 16em;
          padding: min(9.375vw,150px) 0 min(8.125vw,130px); }
          @media screen and (max-width: 767px) {
            .main .sec02 .inner .flex01 .flex-wrap {
              padding: 13.33vw 0 50vw; }
              .main .sec02 .inner .flex01 .flex-wrap .eng {
                font-size: min(5.33vw,40px);
                line-height: 1; } }
          .main .sec02 .inner .flex01 .flex-wrap h2 {
            line-height: 1.3;
            padding: 0.4em 0 0.55em; }
          .main .sec02 .inner .flex01 .flex-wrap .readtext {
            line-height: 2; }
            @media screen and (max-width: 767px) {
              .main .sec02 .inner .flex01 .flex-wrap .readtext {
                font-size: 3.73vw;
                line-height: 1.7; } }
        .main .sec02 .inner .flex01 .map-gunma {
          position: absolute;
          left: 16em;
          top: 0;
          transform: translateY(-15%);
          width: auto;
          height: 110%;
          font-size: min(4vw,50px);
          filter: drop-shadow(0 0 0.2em rgba(138, 187, 255, 0.2)); }
          @media screen and (max-width: 767px) {
            .main .sec02 .inner .flex01 .map-gunma {
              left: auto;
              right: 0;
              top: auto;
              bottom: 0;
              height: auto;
              width: 55vw; } }
      @media screen and (max-width: 767px) {
        .main .sec02 .inner .sp-wrap {
          display: flex;
          justify-content: space-between;
          align-items: flex-start; }
          .main .sec02 .inner .sp-wrap .tatetext {
            width: 9.33vw; } }
      .main .sec02 .inner .flex02 {
        width: 100%;
        display: flex;
        justify-content: space-between;
        align-items: flex-start; }
        @media screen and (max-width: 767px) {
          .main .sec02 .inner .flex02 {
            flex-wrap: wrap;
            width: calc(100% - 17.33vw); } }
        .main .sec02 .inner .flex02 .flex-wrap {
          width: 38%; }
          @media screen and (max-width: 767px) {
            .main .sec02 .inner .flex02 .flex-wrap {
              width: 100%;
              margin-bottom: 12vw; }
              .main .sec02 .inner .flex02 .flex-wrap:first-of-type {
                order: 2; } }
          .main .sec02 .inner .flex02 .flex-wrap img {
            width: 100%;
            height: auto; }
          .main .sec02 .inner .flex02 .flex-wrap .eng {
            font-size: min(7.2vw,90px);
            color: #925A5B;
            line-height: 1;
            text-align: center;
            margin: 0.45em 0 0.25em; }
            @media screen and (max-width: 767px) {
              .main .sec02 .inner .flex02 .flex-wrap .eng {
                font-size: 13.33vw;
                margin: 0.4em 0 0.2em; } }
          .main .sec02 .inner .flex02 .flex-wrap .readtext {
            font-size: min(1.83vw,18px);
            line-height: 2.2;
            text-align: justify;
            width: 100%; }
            @media screen and (max-width: 767px) {
              .main .sec02 .inner .flex02 .flex-wrap .readtext {
                font-size: min(4vw,24px);
                line-height: 1.6; } }
        .main .sec02 .inner .flex02 .tatetext {
          width: 3.3%;
          height: auto; }
      .main .sec02 .inner .wrap01 {
        width: 100%;
        height: auto;
        padding: min(6.25vw,100px) 0 min(7.5vw,120px); }
        @media screen and (max-width: 767px) {
          .main .sec02 .inner .wrap01 {
            padding-top: 0; } }
        .main .sec02 .inner .wrap01 img {
          width: 103%;
          height: auto; }
          @media screen and (max-width: 767px) {
            .main .sec02 .inner .wrap01 img {
              width: 112%;
              margin-left: -2vw; } }
      .main .sec02 .inner .flex03 {
        width: 100%;
        display: flex;
        background: #fff;
        box-shadow: 0 0 20px rgba(146, 90, 91, 0.2); }
        @media screen and (max-width: 767px) {
          .main .sec02 .inner .flex03 {
            display: block; } }
        .main .sec02 .inner .flex03 .imgbox {
          width: 40%;
          height: auto;
          background: url(../img/section01_img05.webp) no-repeat center/cover; }
          @media screen and (max-width: 767px) {
            .main .sec02 .inner .flex03 .imgbox {
              width: 100%;
              aspect-ratio: 2 / 1;
              background-position: top; } }
        .main .sec02 .inner .flex03 .textbox {
          width: 60%;
          padding: 4% 6%; }
          @media screen and (max-width: 767px) {
            .main .sec02 .inner .flex03 .textbox {
              width: 100%;
              padding: 6% 2%;
              text-align: center; } }
          .main .sec02 .inner .flex03 .textbox h4 {
            margin-bottom: 0.7em; }
            @media screen and (max-width: 767px) {
              .main .sec02 .inner .flex03 .textbox h4 {
                font-size: min(5.33vw,40px); } }
          .main .sec02 .inner .flex03 .textbox .readtext {
            line-height: 2.2;
            text-align: justify; }
            @media screen and (max-width: 767px) {
              .main .sec02 .inner .flex03 .textbox .readtext {
                text-align: center;
                font-size: min(4vw,24px);
                line-height: 1.7; } }
            .main .sec02 .inner .flex03 .textbox .readtext a {
              color: #0076FF;
              text-decoration: underline;
              opacity: 1;
              transition: ease 0.5s; }
              .main .sec02 .inner .flex03 .textbox .readtext a:hover {
                opacity: 0.6; }
  .main .leaf-wrap {
    position: relative;
    width: 90%;
    max-width: 1100px;
    margin: 0 auto; }
    .main .leaf-wrap .laef01 {
      position: absolute;
      top: 0;
      right: 0;
      transform: translate(23%, -16%);
      width: 24%;
      height: auto; }
      @media screen and (max-width: 767px) {
        .main .leaf-wrap .laef01 {
          top: 70vw;
          right: 5vw; } }
  .main .sec03 {
    position: relative;
    width: 100%;
    padding: min(6.875vw,110px) 0 min(16.5vw,265px);
    overflow: hidden; }
    @media screen and (max-width: 767px) {
      .main .sec03 {
        padding: 13.33vw 0 36.66vw; } }
    .main .sec03 .back-img01 {
      position: absolute;
      top: 0;
      left: 0;
      width: 47%;
      height: auto;
      transform: translate(-5%, -35%); }
      @media screen and (max-width: 767px) {
        .main .sec03 .back-img01 {
          width: 59%;
          transform: translate(-6%, -24%); } }
    .main .sec03 .back-img02 {
      position: absolute;
      right: 0;
      bottom: 0;
      width: 47%;
      transform: translate(18%, 13%); }
      @media screen and (max-width: 767px) {
        .main .sec03 .back-img02 {
          width: 60%;
          transform: translate(25%, 3%); } }
    .main .sec03 .inner {
      width: 90%;
      max-width: 1100px;
      margin: 0 auto; }
      @media screen and (max-width: 767px) {
        .main .sec03 .inner {
          width: calc(100% - 20px);
          max-width: 650px; } }
      .main .sec03 .inner .flex {
        font-size: min(1.56vw,18px);
        position: relative; }
        .main .sec03 .inner .flex .flex-wrap {
          width: 29em;
          padding: min(10vw,160px) 0; }
          @media screen and (max-width: 767px) {
            .main .sec03 .inner .flex .flex-wrap {
              width: 100%;
              padding: 0 0 6.66vw; } }
          @media screen and (max-width: 767px) {
            .main .sec03 .inner .flex .flex-wrap .eng {
              font-size: min(5.33vw,40px);
              line-height: 1; } }
          .main .sec03 .inner .flex .flex-wrap h2 {
            font-size: min(3.125vw,30px);
            line-height: 1.8;
            margin: 0.3em 0 0.6em; }
            @media screen and (max-width: 767px) {
              .main .sec03 .inner .flex .flex-wrap h2 {
                font-size: min(5.33vw,40px);
                line-height: 1.5;
                margin: 0.4em 0 0.4em; } }
          .main .sec03 .inner .flex .flex-wrap .readtext {
            font-size: min(1.56vw,18px);
            line-height: 2.2; }
            @media screen and (max-width: 767px) {
              .main .sec03 .inner .flex .flex-wrap .readtext {
                font-size: min(4vw,24px);
                line-height: 1.7;
                text-align: justify; } }
        .main .sec03 .inner .flex img {
          position: absolute;
          top: 0;
          left: 22em;
          width: calc(100% - 19em); }
          @media screen and (max-width: 767px) {
            .main .sec03 .inner .flex img {
              position: static;
              width: 100%; } }
      .main .sec03 .inner .wrap {
        position: relative;
        width: 100%;
        text-align: center;
        padding-top: min(3.43vw,55px); }
        @media screen and (max-width: 767px) {
          .main .sec03 .inner .wrap.leaf {
            padding-top: 13.33vw; }
            .main .sec03 .inner .wrap.leaf::before {
              content: '';
              position: absolute;
              top: -8vw;
              right: 5%;
              width: 40vw;
              height: auto;
              aspect-ratio: 695 / 467;
              background: url(../img/leaves07.webp) no-repeat center/contain; } }
        .main .sec03 .inner .wrap .eng {
          margin-bottom: 0.8em; }
          @media screen and (max-width: 767px) {
            .main .sec03 .inner .wrap .eng {
              font-size: min(5.33vw,40px);
              line-height: 1;
              text-align: left;
              margin-bottom: 0.3em; } }
        .main .sec03 .inner .wrap img {
          width: 100%;
          height: auto; }
        .main .sec03 .inner .wrap h3 {
          font-size: min(3.125vw,30px);
          font-weight: 500;
          margin-top: 0.8em; }
          @media screen and (max-width: 767px) {
            .main .sec03 .inner .wrap h3 {
              font-size: min(5.33vw,40px);
              margin: 0.8em 0 0.6em;
              line-height: 1; } }
        .main .sec03 .inner .wrap .readtext {
          margin-top: 0.9em;
          line-height: 2.2;
          text-align: justify;
          display: inline-block; }
          @media screen and (max-width: 767px) {
            .main .sec03 .inner .wrap .readtext {
              font-size: min(4vw,24px);
              line-height: 1.7;
              text-align: justify;
              margin-top: 0; } }
      .main .sec03 .inner .flex02 {
        width: 100%;
        display: flex;
        justify-content: space-between; }
        @media screen and (max-width: 767px) {
          .main .sec03 .inner .flex02 {
            display: block;
            margin-top: 13.33vw; } }
        .main .sec03 .inner .flex02 .wrap {
          position: relative;
          width: 45.5%; }
          @media screen and (max-width: 767px) {
            .main .sec03 .inner .flex02 .wrap {
              width: 77%; }
              .main .sec03 .inner .flex02 .wrap:nth-of-type(2) {
                margin-left: 23%;
                margin-top: 10.66vw; } }
          .main .sec03 .inner .flex02 .wrap img {
            width: 100%;
            height: auto; }
          .main .sec03 .inner .flex02 .wrap h3 {
            font-size: min(3.125vw,30px);
            font-weight: 500;
            margin-top: 0.8em; }
            @media screen and (max-width: 767px) {
              .main .sec03 .inner .flex02 .wrap h3 {
                font-size: min(5.33vw,40px);
                margin: 0.8em 0 0.7em;
                line-height: 1; } }
          .main .sec03 .inner .flex02 .wrap .readtext {
            margin-top: 0.9em;
            line-height: 2.2;
            text-align: justify;
            display: inline-block; }
            @media screen and (max-width: 767px) {
              .main .sec03 .inner .flex02 .wrap .readtext {
                font-size: min(4vw,24px);
                line-height: 1.7;
                text-align: justify;
                margin-top: 0; } }
          .main .sec03 .inner .flex02 .wrap:nth-of-type(1)::after {
            content: '';
            position: absolute;
            left: 0;
            bottom: 0;
            transform: translate(-70%, 15%);
            width: 45%;
            height: auto;
            aspect-ratio: 260 / 376;
            background: url(../img/leaves04.webp) no-repeat center/contain;
            z-index: -1;
            opacity: 0.5; }
            @media screen and (max-width: 767px) {
              .main .sec03 .inner .flex02 .wrap:nth-of-type(1)::after {
                background: url(../img/leaves03.webp) no-repeat center/contain;
                aspect-ratio: 440 / 271;
                opacity: 1;
                left: 100%;
                bottom: 100%;
                transform: translate(-45%, 75%);
                z-index: 2; } }
          .main .sec03 .inner .flex02 .wrap:nth-of-type(2)::after {
            content: '';
            position: absolute;
            right: 0;
            top: 0;
            transform: translate(25%, -22%);
            width: 45%;
            height: auto;
            aspect-ratio: 440 / 271;
            background: url(../img/leaves03.webp) no-repeat center/contain; }
            @media screen and (max-width: 767px) {
              .main .sec03 .inner .flex02 .wrap:nth-of-type(2)::after {
                background: url(../img/leaves04.webp) no-repeat center/contain;
                aspect-ratio: 260 / 376;
                opacity: 0.35;
                z-index: -1;
                width: 75%;
                right: 100%;
                top: 100%;
                transform: translate(45%, -70%); } }
  .main .sec04 {
    position: relative;
    width: 100%;
    padding: 0; }
    .main .sec04 .tab-wrap {
      display: flex;
      justify-content: center;
      margin: 0 auto;
      border-bottom: 1px solid #333;
      width: 90%;
      max-width: 1300px;
      text-align: center;
      transform: translateY(-100%); }
      @media screen and (max-width: 767px) {
        .main .sec04 .tab-wrap {
          width: 100%;
          padding: 0 4%; } }
      .main .sec04 .tab-wrap li {
        position: relative;
        font-size: min(2.1vw,25px);
        line-height: 1;
        width: 14em;
        padding: 0.9em 0 0.8em;
        background: rgba(180, 132, 133, 0.2);
        border-left: 1px solid #333;
        border-top: 1px solid #333;
        align-content: center; }
        @media screen and (max-width: 767px) {
          .main .sec04 .tab-wrap li {
            font-size: min(4vw,24px);
            width: calc(100% / 3); } }
        .main .sec04 .tab-wrap li.cs {
          color: rgba(51, 51, 51, 0.3); }
          .main .sec04 .tab-wrap li.cs::after {
            content: 'coming soon';
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            color: #333;
            font-size: 0.95em;
            font-family: "Bebas Neue", sans-serif; }
        .main .sec04 .tab-wrap li:last-of-type {
          border-right: 1px solid #333; }
        .main .sec04 .tab-wrap li.active {
          background: #fff; }
          .main .sec04 .tab-wrap li.active::after {
            content: '';
            position: absolute;
            bottom: -2px;
            left: 0;
            width: 100%;
            height: 4px;
            background: #fff; }
        .main .sec04 .tab-wrap li span {
          font-size: min(1.83vw,18px); }
          @media screen and (max-width: 767px) {
            .main .sec04 .tab-wrap li span {
              font-size: 0.75em; } }
    .main .sec04 .wrap {
      width: 100%;
      display: none; }
      @media screen and (max-width: 767px) {
        .main .sec04 .wrap {
          margin-top: -8vw; } }
      .main .sec04 .wrap.active {
        display: block; }
      .main .sec04 .wrap .wrap01 {
        width: 100%; }
        .main .sec04 .wrap .wrap01 .img01a {
          width: 100%;
          height: auto;
          max-height: calc(90vh);
          aspect-ratio: 144 / 81;
          background: url(../img/section03_img01a.webp) no-repeat center/cover; }
          @media screen and (max-width: 767px) {
            .main .sec04 .wrap .wrap01 .img01a {
              aspect-ratio: 5 / 4;
              background: url(../img/section03_img01a-sp.webp) no-repeat center/cover; } }
        .main .sec04 .wrap .wrap01 .flex {
          width: 100%;
          display: flex;
          justify-content: space-between; }
          @media screen and (max-width: 767px) {
            .main .sec04 .wrap .wrap01 .flex {
              flex-wrap: wrap; } }
          .main .sec04 .wrap .wrap01 .flex img {
            width: 25%;
            height: auto; }
            @media screen and (max-width: 767px) {
              .main .sec04 .wrap .wrap01 .flex img {
                width: 50%; } }
      .main .sec04 .wrap .wrap02 {
        padding: min(7.5vw,120px) 0;
        width: 100%;
        background: #3E281C; }
        @media screen and (max-width: 767px) {
          .main .sec04 .wrap .wrap02 {
            padding: 10.66vw 0; } }
        .main .sec04 .wrap .wrap02 .inner {
          width: 90%;
          max-width: 1100px;
          margin: 0 auto;
          color: #fff;
          text-align: center; }
          @media screen and (max-width: 767px) {
            .main .sec04 .wrap .wrap02 .inner {
              width: calc(100% - 20px);
              max-width: 650px; } }
          .main .sec04 .wrap .wrap02 .inner p {
            line-height: 1.7; }
            @media screen and (max-width: 767px) {
              .main .sec04 .wrap .wrap02 .inner p {
                font-size: min(4.68vw,28px); } }
          .main .sec04 .wrap .wrap02 .inner .readtext {
            line-height: 2.2;
            margin-top: 2em;
            margin-bottom: 2em;
            font-size: min(1.76vw,18px); }
            @media screen and (max-width: 767px) {
              .main .sec04 .wrap .wrap02 .inner .readtext {
                font-size: min(3.4vw,24px);
                line-height: 1.7; } }
          .main .sec04 .wrap .wrap02 .inner .subtitle {
            font-size: min(2.4vw,30px);
            line-height: 1.7; }
            @media screen and (max-width: 767px) {
              .main .sec04 .wrap .wrap02 .inner .subtitle {
                font-size: min(4.68vw,30px); } }
      .main .sec04 .wrap .flex {
        width: 100%;
        display: flex; }
        @media screen and (max-width: 767px) {
          .main .sec04 .wrap .flex {
            flex-wrap: wrap; } }
        .main .sec04 .wrap .flex li {
          width: 50%;
          opacity: 1;
          transition: ease 0.5s; }
          @media screen and (max-width: 767px) {
            .main .sec04 .wrap .flex li {
              width: 100%; } }
          .main .sec04 .wrap .flex li:hover {
            opacity: 0.6; }
          .main .sec04 .wrap .flex li img {
            width: 100%;
            height: auto;
            display: block; }
      .main .sec04 .wrap .wrap03 {
        position: relative;
        width: 100%;
        padding: min(10.6vw,170px) 0; }
        @media screen and (max-width: 767px) {
          .main .sec04 .wrap .wrap03 {
            padding: 22vw 0;
            overflow: hidden; } }
        .main .sec04 .wrap .wrap03::before {
          content: '';
          position: absolute;
          bottom: 0;
          left: 0;
          transform: translate(-25%, 63%);
          width: 23%;
          height: auto;
          aspect-ratio: 1 / 1;
          max-width: 366px;
          background: url(../img/leaves06.webp) no-repeat center/contain; }
          @media screen and (max-width: 767px) {
            .main .sec04 .wrap .wrap03::before {
              width: 56%;
              max-width: none;
              transform: translate(-18%, 21%); } }
        .main .sec04 .wrap .wrap03::after {
          content: '';
          position: absolute;
          top: -1%;
          right: 3%;
          width: 23.4%;
          height: auto;
          aspect-ratio: 1 / 1;
          max-width: 375px;
          background: url(../img/leaves05.webp) no-repeat center/contain; }
          @media screen and (max-width: 767px) {
            .main .sec04 .wrap .wrap03::after {
              width: 56%;
              max-width: none;
              top: -5%;
              right: -4%;
              z-index: -1; } }
        .main .sec04 .wrap .wrap03 .inner {
          width: 90%;
          max-width: 1100px;
          margin: 0 auto;
          color: #fff;
          text-align: center; }
          @media screen and (max-width: 767px) {
            .main .sec04 .wrap .wrap03 .inner {
              width: calc(100% - 20px);
              max-width: 650px; } }
          .main .sec04 .wrap .wrap03 .inner .flex {
            display: flex;
            justify-content: space-between;
            align-items: center; }
            @media screen and (max-width: 767px) {
              .main .sec04 .wrap .wrap03 .inner .flex {
                display: block; } }
            .main .sec04 .wrap .wrap03 .inner .flex img {
              width: 57%;
              height: auto; }
              @media screen and (max-width: 767px) {
                .main .sec04 .wrap .wrap03 .inner .flex img {
                  width: 100%; } }
            .main .sec04 .wrap .wrap03 .inner .flex .textbox {
              width: 40%;
              color: #333;
              text-align: center; }
              @media screen and (max-width: 767px) {
                .main .sec04 .wrap .wrap03 .inner .flex .textbox {
                  width: 100%;
                  margin-top: 10.66vw; } }
              .main .sec04 .wrap .wrap03 .inner .flex .textbox .subtitle {
                font-size: min(2.24vw,28px);
                line-height: 1.7; }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap .wrap03 .inner .flex .textbox .subtitle {
                    font-size: min(6vw,45px);
                    line-height: 1.3; } }
              .main .sec04 .wrap .wrap03 .inner .flex .textbox .readtext {
                font-size: min(1.63vw,18px);
                margin-top: 0.5em; }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap .wrap03 .inner .flex .textbox .readtext {
                    font-size: min(4vw,28px);
                    line-height: 1.7;
                    margin-top: 0.75em; } }
              .main .sec04 .wrap .wrap03 .inner .flex .textbox .annotation {
                line-height: 1.8;
                margin-top: 2em; }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap .wrap03 .inner .flex .textbox .annotation {
                    font-size: min(3.43vw,20px);
                    margin-top: 0.75em;
                    margin-top: 3em; } }
              .main .sec04 .wrap .wrap03 .inner .flex .textbox .btn-flex {
                display: flex;
                flex-wrap: wrap;
                width: 100%;
                font-size: min(2.8vw,30px);
                color: #fff;
                gap: 0.6em;
                margin-top: 1em; }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap .wrap03 .inner .flex .textbox .btn-flex {
                    margin-top: 7vw;
                    font-size: min(5.6vw,42px); } }
                .main .sec04 .wrap .wrap03 .inner .flex .textbox .btn-flex button {
                  position: relative;
                  background: #925A5B;
                  width: calc(50% - 0.3em);
                  line-height: 1;
                  padding: 0.45em 0 0.55em;
                  cursor: pointer;
                  opacity: 1;
                  transition: ease 0.5s; }
                  .main .sec04 .wrap .wrap03 .inner .flex .textbox .btn-flex button:hover {
                    opacity: 0.6; }
                  .main .sec04 .wrap .wrap03 .inner .flex .textbox .btn-flex button span {
                    font-size: 0.65em; }
                  .main .sec04 .wrap .wrap03 .inner .flex .textbox .btn-flex button::after {
                    content: '';
                    position: absolute;
                    top: 50%;
                    right: 0.5em;
                    transform: translateY(-50%);
                    height: 25%;
                    width: auto;
                    aspect-ratio: 37 / 67;
                    background: url(../img/icon-arrow01.webp) no-repeat center/contain;
                    display: block; }
      .main .sec04 .wrap .linkbtn {
        position: relative;
        font-size: min(3.6vw,45px);
        line-height: 1.3;
        width: 80%;
        max-width: 18em;
        padding: 0.5em 0 0.9em;
        display: block;
        margin: 0 auto;
        background: #925A5B;
        color: #fff;
        text-align: center;
        opacity: 1;
        transition: ease 0.5s; }
        @media screen and (max-width: 767px) {
          .main .sec04 .wrap .linkbtn {
            width: calc(100% - 20px);
            max-width: 650px;
            font-size: min(4.8vw,36px);
            line-height: 1.4; } }
        .main .sec04 .wrap .linkbtn:hover {
          opacity: 0.6; }
        .main .sec04 .wrap .linkbtn::after {
          content: '';
          position: absolute;
          right: 0.75em;
          top: 50%;
          transform: translateY(-50%);
          height: 20%;
          width: auto;
          aspect-ratio: 37 / 67;
          background: url(../img/icon-arrow01.webp) no-repeat center/contain;
          display: block; }
        .main .sec04 .wrap .linkbtn span {
          font-size: 0.55em; }

/*********************************************************

					　　　　modal

**********************************************************/
.modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 30;
  visibility: hidden; }
  .modal.active {
    visibility: visible; }
    .modal.active .back {
      opacity: 1;
      transition: ease-in-out 0.5s; }
    .modal.active .modal-wrap {
      opacity: 1;
      transform: translate(-50%, -50%);
      transition: ease-in-out 0.5s; }
  .modal .back {
    width: 100%;
    height: 100%;
    background: rgba(62, 40, 28, 0.8);
    opacity: 0;
    transition: ease-in-out 0.5s 0.1s; }
  .modal .modal-wrap {
    position: absolute;
    top: 50vh;
    left: 50%;
    transform: translate(-50%, -40%);
    width: 75%;
    height: auto;
    aspect-ratio: 4 / 3;
    max-width: 1200px;
    display: block;
    transition: ease-in-out 0.5s;
    opacity: 0; }
    @media screen and (max-width: 767px) {
      .modal .modal-wrap {
        width: 90%; } }
    .modal .modal-wrap img {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: auto;
      display: block;
      opacity: 0;
      transition: 0.1s; }
      .modal .modal-wrap img.active {
        opacity: 1; }
    .modal .modal-wrap #modal-close {
      position: absolute;
      right: 0;
      bottom: 102%;
      width: 40px;
      height: 40px;
      display: block;
      cursor: pointer; }
      .modal .modal-wrap #modal-close::before, .modal .modal-wrap #modal-close::after {
        content: '';
        position: absolute;
        top: 19px;
        left: 0;
        width: 100%;
        height: 2px;
        background: #fff;
        transform-origin: center; }
      .modal .modal-wrap #modal-close::before {
        transform: rotate(45deg); }
      .modal .modal-wrap #modal-close::after {
        transform: rotate(-45deg); }

.gototop {
  position: fixed;
  right: 20px;
  bottom: 20px;
  width: 80px;
  height: 80px;
  background: rgba(180, 132, 133, 0.8);
  border: solid 2px #fff;
  box-sizing: border-box;
  border-radius: 5px;
  display: block;
  z-index: 20;
  transition: 0.1s;
  opacity: 0;
  transform: translateY(-20%); }
  @media screen and (max-width: 767px) {
    .gototop {
      width: 60px;
      height: 60px;
      bottom: calc(16vw + 10px); } }
  .gototop.active {
    opacity: 1;
    transform: translateY(0); }
  .gototop:hover {
    background: #b48485; }
  .gototop img {
    width: 100%;
    height: 100%; }

/**/
.link-top {
  display: block;
  text-align: center;
  margin: 0px auto;
  font-size: 24px;
  text-decoration: underline;
  color: #333; }
  .link-top:hover {
    text-decoration: none;
    opacity: 0.8; }

/*********************************************************

					　　　　footer

**********************************************************/
.footer {
  position: relative;
  z-index: 2;
  width: 100%;
  text-align: center;
  padding-top: 40px; }
  .footer .bg_img {
    position: relative; }
    .footer .bg_img .bg_img01 {
      padding-top: 12vw;
      width: 100%;
      height: auto; }
      @media screen and (max-width: 767px) {
        .footer .bg_img .bg_img01 {
          padding-top: 31vw;
          object-fit: cover;
          height: 81vw; } }
    .footer .bg_img .bg_img02 {
      position: absolute;
      top: 10%;
      left: 50%;
      transform: translateX(-50%);
      width: 20%; }
      @media screen and (max-width: 767px) {
        .footer .bg_img .bg_img02 {
          width: 48%; } }
  .footer .bg {
    width: 100%;
    height: auto;
    background: #3E281C;
    padding: min(5.625vw,90px) 0 min(4vw,65px); }
    @media screen and (max-width: 767px) {
      .footer .bg {
        padding: 16vw 0; } }
    .footer .bg .inner {
      width: 90%;
      max-width: 1100px;
      margin: 0 auto; }
      @media screen and (max-width: 767px) {
        .footer .bg .inner {
          width: calc(100% - 20px);
          max-width: 650px; } }
      .footer .bg .inner .banner {
        display: flex;
        justify-content: space-between;
        padding-bottom: min(4.68vw,75px);
        width: 80%;
        max-width: 880px;
        margin: 0 auto; }
        .footer .bg .inner .banner .banner_blue {
          position: relative;
          width: 47%;
          padding: 20px;
          background: #5A87FF;
          color: #fff;
          opacity: 1; }
          .footer .bg .inner .banner .banner_blue p {
            line-height: 1;
            font-size: min(2.35vw,25px); }
            .footer .bg .inner .banner .banner_blue p span {
              font-size: 0.56em;
              line-height: 1; }
            .footer .bg .inner .banner .banner_blue p:hover {
              transition: .1s ease;
              opacity: .6; }
            .footer .bg .inner .banner .banner_blue p::after {
              position: absolute;
              content: '';
              top: 50%;
              right: 10%;
              transform: translateY(-50%);
              width: 0.6em;
              height: 0.6em;
              background: url(../img/icon-arrow01.webp) no-repeat center/contain; }
        .footer .bg .inner .banner .banner_green {
          position: relative;
          width: 47%;
          padding: 20px;
          color: #fff;
          background: #03AA9B; }
          .footer .bg .inner .banner .banner_green p {
            font-size: min(2.35vw,25px);
            line-height: 1; }
            .footer .bg .inner .banner .banner_green p span {
              font-size: 0.56em;
              line-height: 1; }
            .footer .bg .inner .banner .banner_green p:hover {
              transition: .1s ease;
              opacity: .6; }
            .footer .bg .inner .banner .banner_green p::after {
              position: absolute;
              content: '';
              top: 50%;
              right: 10%;
              transform: translateY(-50%);
              width: 0.6em;
              height: 0.6em;
              background: url(../img/icon-arrow01.webp) no-repeat center/contain; }
      .footer .bg .inner .bg_logo {
        margin: 0 auto;
        width: 24%;
        max-width: 180px;
        height: auto; }
        @media screen and (max-width: 767px) {
          .footer .bg .inner .bg_logo {
            width: 100%;
            max-width: none;
            margin-bottom: 16vw; } }
        .footer .bg .inner .bg_logo a {
          display: block; }
          .footer .bg .inner .bg_logo a img {
            width: 100%; }
            @media screen and (max-width: 767px) {
              .footer .bg .inner .bg_logo a img {
                width: 41vw; } }
      .footer .bg .inner .inquiry {
        color: #fff;
        padding-top: min(2.5vw,40px); }
        @media screen and (max-width: 767px) {
          .footer .bg .inner .inquiry {
            padding-top: 0; } }
        .footer .bg .inner .inquiry .inq01 {
          font-size: min(1.83vw,18px);
          padding-bottom: 20px;
          line-height: 1; }
          @media screen and (max-width: 767px) {
            .footer .bg .inner .inquiry .inq01 {
              font-size: min(4.06vw,24px);
              padding-bottom: 3vw; } }
        .footer .bg .inner .inquiry .inq02 {
          font-size: min(2.6vw,24px);
          line-height: 1; }
          @media screen and (max-width: 767px) {
            .footer .bg .inner .inquiry .inq02 {
              font-size: 32px;
              font-size: min(5vw,32px);
              padding-bottom: 3vw; } }
        .footer .bg .inner .inquiry .inq03 {
          font-size: min(1.56vw,16px);
          line-height: 1; }
          @media screen and (max-width: 767px) {
            .footer .bg .inner .inquiry .inq03 {
              font-size: 20px;
              font-size: min(3.75vw,20px); } }
        .footer .bg .inner .inquiry .tel {
          position: relative;
          display: inline-block;
          font-size: min(5.2vw,60px);
          line-height: 1;
          letter-spacing: 0.2rem;
          margin-bottom: 0.5em;
          margin-top: 0.4em;
          padding-left: 1.4em; }
          .footer .bg .inner .inquiry .tel::before {
            position: absolute;
            top: 50%;
            left: 0;
            transform: translateY(-40%);
            content: '';
            background: url(../img/tel.webp) no-repeat center/contain;
            aspect-ratio: 10 / 7;
            display: block;
            height: .8em;
            width: auto; }
          @media screen and (max-width: 767px) {
            .footer .bg .inner .inquiry .tel {
              font-size: 80px;
              font-size: min(11vw,80px);
              margin-bottom: 4vw;
              letter-spacing: 0;
              margin-top: 0; } }
  .footer .copy {
    font-size: 14px;
    font-size: min(1.56vw,14px);
    margin: 1em auto; }
    @media screen and (max-width: 767px) {
      .footer .copy {
        font-size: 12px;
        font-size: min(3.15vw,12px);
        margin: 2em auto; } }
  @media screen and (max-width: 767px) {
    .footer .sp-dammy {
      height: 16vw;
      background: #fff; } }
  .footer .sp_banner {
    display: none; }
    @media screen and (max-width: 767px) {
      .footer .sp_banner {
        position: fixed;
        display: flex;
        bottom: 0;
        left: 0;
        height: min(25vw,110px);
        width: 100%;
        height: 16vw;
        z-index: 10;
        transition: .3s ease;
        transform: translateY(101%);
        background-color: #fff; }
        .footer .sp_banner.active {
          transform: translateY(0); }
        .footer .sp_banner .banner_blue {
          position: relative;
          display: block;
          width: 50%;
          align-content: center;
          background: #5A87FF;
          color: #fff;
          opacity: 1; }
          .footer .sp_banner .banner_blue p {
            line-height: 1;
            font-size: min(4.66vw,35px); }
            .footer .sp_banner .banner_blue p span {
              font-size: min(3.4vw,20px);
              line-height: 1; }
            .footer .sp_banner .banner_blue p::after {
              position: absolute;
              content: '';
              top: 50%;
              right: 10%;
              transform: translateY(-50%);
              width: 0.75em;
              height: 0.75em;
              background: url(../img/icon-arrow01.webp) no-repeat center/contain; }
          .footer .sp_banner .banner_blue:hover {
            opacity: 0.6; }
        .footer .sp_banner .banner_green {
          position: relative;
          display: block;
          width: 50%;
          align-content: center;
          color: #fff;
          background: #03AA9B; }
          .footer .sp_banner .banner_green p {
            line-height: 1;
            font-size: min(4.66vw,35px); }
            .footer .sp_banner .banner_green p span {
              font-size: min(3.4vw,20px);
              line-height: 1; }
            .footer .sp_banner .banner_green p::after {
              position: absolute;
              content: '';
              top: 50%;
              right: 10%;
              transform: translateY(-50%);
              width: 0.75em;
              height: 0.75em;
              background: url(../img/icon-arrow01.webp) no-repeat center/contain; }
          .footer .sp_banner .banner_green:hover {
            opacity: 0.6; } }

/*********************************************************

					　　　　outline

**********************************************************/
.outline {
  width: 100%;
  margin-top: 70px; }
  @media screen and (max-width: 767px) {
    .outline {
      margin-top: clamp(50px, 10vw, 70px); } }
  .outline .sec {
    width: 100%;
    font-size: 16px;
    font-family: "Zen Kaku Gothic Antique", sans-serif;
    font-weight: 400;
    font-style: normal;
    padding: min(7.2vw, 90px) 0; }
    @media screen and (max-width: 767px) {
      .outline .sec {
        font-size: min(4vw,16px);
        padding: 9.33vw 0; } }
    .outline .sec .inner {
      width: 90%;
      max-width: 1100px;
      margin: 0 auto; }
      .outline .sec .inner table {
        border-collapse: collapse; }
        .outline .sec .inner table caption {
          font-size: 18px;
          font-weight: 500;
          margin-top: 2em;
          margin-bottom: 1em; }
        .outline .sec .inner table th {
          background: #ebeced;
          font-weight: 400;
          padding: 1em;
          line-height: 1.8;
          border: 1px solid #dddedf;
          width: 20%; }
          @media screen and (max-width: 767px) {
            .outline .sec .inner table th {
              width: 6em;
              padding: 0.7em; } }
        .outline .sec .inner table td {
          font-weight: 400;
          padding: 1em;
          line-height: 1.8;
          border: 1px solid #dddedf;
          width: 80%; }
          @media screen and (max-width: 767px) {
            .outline .sec .inner table td {
              width: calc(100% - 6em);
              padding: 0.7em; } }
          .outline .sec .inner table td .notice {
            font-size: 0.8em; }
          .outline .sec .inner table td a {
            text-decoration: underline; }
            .outline .sec .inner table td a:hover {
              text-decoration: none; }
          .outline .sec .inner table td .table__addressButtonWrap {
            display: flex;
            align-items: center; }
            @media screen and (max-width: 767px) {
              .outline .sec .inner table td .table__addressButtonWrap {
                display: block; } }
          .outline .sec .inner table td .table__addressButton {
            position: relative;
            font-size: 0.7em;
            line-height: 1;
            display: inline-block;
            align-items: center;
            color: #111;
            background-color: #ebeced;
            box-shadow: 0 1px 0 #ebeced, inset 0 -1px 0 #dddedf;
            border-radius: 0.2em;
            font-weight: 500;
            text-decoration: none;
            padding: 0.55em 2em 0.5em 0.7em;
            margin-left: 0.5em; }
            .outline .sec .inner table td .table__addressButton:hover {
              color: #4ca535; }
            .outline .sec .inner table td .table__addressButton::after {
              content: "";
              position: absolute;
              top: 50%;
              right: 0.5em;
              transform: translateY(-50%);
              display: block;
              width: 1em;
              height: 1em;
              background: url(../img/map.svg) no-repeat center/contain;
              margin-left: .11rem; }

/*********************************************************

					　　　location

**********************************************************/
.location {
  width: 100%;
  margin-top: 70px; }
  @media screen and (max-width: 767px) {
    .location {
      margin-top: clamp(50px, 10vw, 70px); } }
  .location .sec {
    width: 100%;
    font-size: 16px;
    font-family: "Zen Kaku Gothic Antique", sans-serif;
    font-weight: 400;
    font-style: normal;
    padding: min(7.2vw, 90px) 0;
    text-align: center; }
    @media screen and (max-width: 767px) {
      .location .sec {
        font-size: min(4vw,16px);
        padding: 9.33vw 0; } }
    .location .sec .inner {
      width: 90%;
      max-width: 1100px;
      margin: 0 auto; }
      .location .sec .inner h2 {
        font-size: 24px;
        font-weight: 500;
        margin-bottom: 1em; }
        @media screen and (max-width: 767px) {
          .location .sec .inner h2 {
            font-size: 17px; } }
      .location .sec .inner .readtext {
        font-size: 16px;
        margin-bottom: 1.7em; }
        @media screen and (max-width: 767px) {
          .location .sec .inner .readtext {
            font-size: 14px; } }
      .location .sec .inner .gmap-wrap {
        width: 100vw;
        height: auto;
        max-height: 650px;
        aspect-ratio: 14 / 6.5;
        margin-left: calc(50% - 50vw); }
        .location .sec .inner .gmap-wrap iframe {
          width: 100%;
          height: 100%; }
      .location .sec .inner .obitext {
        background: #F7F5F3;
        width: 100vw;
        margin-left: calc(50% - 50vw);
        font-size: 16px;
        line-height: 1;
        padding: 1em 0; }
        @media screen and (max-width: 767px) {
          .location .sec .inner .obitext {
            font-size: 14px; } }
      .location .sec .inner .subtitle {
        background: #925A5B;
        color: #fff;
        font-size: 20px;
        font-weight: 500;
        line-height: 1;
        padding: 1em 0;
        margin-top: 4em; }
        @media screen and (max-width: 767px) {
          .location .sec .inner .subtitle {
            font-size: 14px; } }
      .location .sec .inner .flex {
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
        margin-top: 20px;
        flex-wrap: wrap; }
        @media screen and (max-width: 767px) {
          .location .sec .inner .flex {
            margin-top: 0; } }
        .location .sec .inner .flex .wrap {
          width: calc(25% - 15px);
          height: auto;
          text-align: center; }
          @media screen and (max-width: 767px) {
            .location .sec .inner .flex .wrap {
              width: calc(50% - 1.7vw);
              margin-top: 3.4vw; } }
          .location .sec .inner .flex .wrap .imgbox {
            width: 100%;
            height: auto;
            aspect-ratio: 3 / 2; }
            .location .sec .inner .flex .wrap .imgbox.i1a {
              background: url(../img/location-img01a.webp) no-repeat center/cover; }
            .location .sec .inner .flex .wrap .imgbox.i1b {
              background: url(../img/location-img01b.webp) no-repeat center/cover; }
            .location .sec .inner .flex .wrap .imgbox.i1c {
              background: url(../img/location-img01c.webp) no-repeat center/cover; }
            .location .sec .inner .flex .wrap .imgbox.i1d {
              background: url(../img/location-img01d.webp) no-repeat center/cover; }
            .location .sec .inner .flex .wrap .imgbox.i2a {
              background: url(../img/location-img02a.webp) no-repeat center/cover; }
            .location .sec .inner .flex .wrap .imgbox.i2b {
              background: url(../img/location-img02b.webp) no-repeat center/cover; }
            .location .sec .inner .flex .wrap .imgbox.i2c {
              background: url(../img/location-img02c.webp) no-repeat center/cover; }
            .location .sec .inner .flex .wrap .imgbox.i3a {
              background: url(../img/location-img03a.webp) no-repeat center/cover; }
            .location .sec .inner .flex .wrap .imgbox.i3b {
              background: url(../img/location-img03b.webp) no-repeat center/cover; }
            .location .sec .inner .flex .wrap .imgbox.i3c {
              background: url(../img/location-img03c.webp) no-repeat center/cover; }
            .location .sec .inner .flex .wrap .imgbox.i3d {
              background: url(../img/location-img03d.webp) no-repeat center/cover; }
            .location .sec .inner .flex .wrap .imgbox.i4a {
              background: url(../img/location-img04a.webp) no-repeat center/cover; }
            .location .sec .inner .flex .wrap .imgbox.i4b {
              background: url(../img/location-img04b.webp) no-repeat center/cover; }
            .location .sec .inner .flex .wrap .imgbox.i4c {
              background: url(../img/location-img04c.webp) no-repeat center/cover; }
          .location .sec .inner .flex .wrap .name {
            font-size: 14px;
            line-height: 1.3;
            font-weight: 500;
            margin-top: 1em; }
            @media screen and (max-width: 767px) {
              .location .sec .inner .flex .wrap .name {
                font-size: min(3.75vw, 14px); } }
            .location .sec .inner .flex .wrap .name span {
              display: inline-block; }
          .location .sec .inner .flex .wrap .location {
            font-size: 13px;
            line-height: 1.3;
            margin-top: 0.5em; }
            @media screen and (max-width: 767px) {
              .location .sec .inner .flex .wrap .location {
                font-size: min(3.75vw, 13px); } }
            .location .sec .inner .flex .wrap .location span {
              display: inline-block; }
