@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; } }

/****************************************
表示切り替えクラス
****************************************/
.pc-none {
  display: block; }
  @media screen and (max-width: 767px) {
    .pc-none {
      display: none !important; } }

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

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

					　　　　初期設定

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

body {
  line-height: 1.5;
  margin: 0 auto;
  width: 100%;
  font-family: "游ゴシック体 Pr6N R", "\6E38\30B4\30B7\30C3\30AF\4F53", "YuGothic", "\6E38\30B4\30B7\30C3\30AF", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "meiryo", "Helvetica Neue", "arial", sans-serif;
  font-weight: 300;
  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); } }
  .readtext.small {
    font-size: min(1.64vw,16px); }
    @media screen and (max-width: 767px) {
      .readtext.small {
        font-size: min(3.75vw,16px); } }
  .readtext.big {
    font-size: min(2.01vw,20px); }
    @media screen and (max-width: 767px) {
      .readtext.big {
        font-size: min(4.375vw,20px); } }
  .readtext.big2 {
    font-size: min(2.41vw,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; }

/*  title
========================================================================*/
h1,
h2,
h3,
h4 {
  font-weight: inherit;
  font-size: inherit;
  font-family: "游ゴシック体 Pr6N B";
  letter-spacing: 0.05em;
}

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";
  font-weight: 600;}

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 #7d645d;
  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: #7d645d; }

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

					　　　　haeder

**********************************************************/
.header {
  width: 100vw;
  position: fixed;
  top: 0;
  left: 0;
  /*background: #fff;
  backdrop-filter: blur(3px);
  background-color: rgba(255, 255, 255, 0);*/
  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: #7d645d;
      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: #333333; }
        @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) {
          color: #333333;
          position: relative; }
 /*       .header .inner .menu li:nth-of-type(3) {
          background: #460f00; }
        .header .inner .menu li:nth-of-type(4) {
          background: #7d645d; }
        .header .inner .menu li:nth-of-type(5) {
          background: #505f6a; }
        .header .inner .menu li:nth-of-type(6) {
          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,.header .inner .menu li a.textlink-other,.header .inner .menu li a.textlink2 {
            height: auto; }
            @media screen and (max-width: 767px) {
              .header .inner .menu li a.textlink,.header .inner .menu li a.textlink-other,.header .inner .menu li a.textlink2 {
                margin-bottom: 0.5em;
                text-decoration: underline; } }

/* スクロールしたらヘッダーメニューのフォントカラー変更
.header .inner .menu li a.textlink.headerColorScroll {
  color: #333333;
  transition: color 0.4s ease-out;
} */

          .header .inner .menu li a:hover {
            opacity: 0.6; }
    .header .inner h1 {
      position: absolute;
      top: 0;
      left: 0;
      transform: translateY(-200%); }

li.header-cv-area{
	padding: 10px;
	color:#fff!important;}

a.header-request{
	background-color: #505f6a;}

a.header-reservation{
	background-color: #B39136;}


/* スクロールしたらロゴの色変更 */
.header-logo.headerLogoScroll.-before {
  display : none;
}

.header-logo.headerLogoScroll.-after {
  display : block;
}

.header-logo.-after {
  display : none;
}

.header-logo.headerLogoScroll.-before,.header-logo.headerLogoScroll.-after,.header-logo.-after,.header-logo.-before,.header-other {
	width: 25%;
    height: auto;
}

    @media screen and (min-width: 767px) {
		.textlink,.textlink2 {
			color: #FFFFFF;
		}

		.headerTextScroll{
			color: #333333 !important;
		}}

.headerBack{
	background-color: #FFFFFF;
}

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

					　　　　main

**********************************************************/
.main {
  width: 100%;
  height: auto;
  margin: 0 auto; }
  .main #top {
    position: relative;
    width: 100%;
    height: auto;
    padding-top: 70px;
	background: url(../img/main_background_image.webp) no-repeat center/cover; }
    @media screen and (max-width: 767px) {
      .main #top {
    padding-top: 10px; } }
    .main #top li .imgbox {
      width: 100%;
      height: auto;
      max-height: calc(100vh - 70px);
      aspect-ratio: 16 / 9.3;
      display: block; }
      @media screen and (max-width: 767px) {
        .main #top li .imgbox {
          aspect-ratio: 768 / 600;
          margin-top: clamp(50px,10vw,70px); } }
      .main #top li .imgbox.i1 {
        background: url(../img/top-slide01.webp) no-repeat center top/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-slide03.webp) no-repeat center/cover; }
        @media screen and (max-width: 767px) {
          .main #top li .imgbox.i2 {
            background: url(../img/top-slide03-sp.webp) no-repeat center/cover; } }
      .main #top li .imgbox.i3 {
        background: url("../img/top-slide02.webp") no-repeat center/cover; }
        @media screen and (max-width: 767px) {
          .main #top li .imgbox.i3 {
            background: url("../img/top-slide02-sp.webp") no-repeat center/cover; } }

  .main #top li img{
      width: 100%; }

  .main #top h2 {
      position: absolute;
      bottom: 0;
      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: 1; }
  .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 .banner {
        text-align: center; }
        @media screen and (max-width: 767px) {
          .main .sec01 .wrap01 .banner img {
            max-width: 80%; } }
      .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: url(../img/main_background_image.webp) no-repeat center/cover;
      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.inquiry {
              border: solid thin;
              padding: 8px;
              border-radius: 10px;
              font-size: 16px; }
              @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;
				font-size: 12px;}
              .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.2em; }
              @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: 0 0 min(7.5vw,265px); }
    /*@media screen and (max-width: 767px) {
      .main .sec02 {
        padding: 0 0 36.66vw; } }*/
    .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: 13vw 5vw 10vw 5vw; }
              .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,.main .sec02 .inner .flex02 .flex-wrap .readtext {
                line-height: 1.9;
				font-size: min(3.43vw, 14px);
				letter-spacing: 1px;}}
        .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-around;
        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: 0 6vw 5vw; }
              /*.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(4.2vw,90px);
            color: #7d645d;
            line-height: 1;
            text-align: center;
            margin: 0.45em 0 0.25em;
			font-weight: 500;
			font-family: "Hiragino Kaku Gothic ProN";}
            @media screen and (max-width: 767px) {
              .main .sec02 .inner .flex02 .flex-wrap .eng {
                font-size: 10.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%; }
          .main .sec02 .inner .flex02 .flex-wrap h3{
            color: #7d645d;
            text-align: center;
             padding-top: 20px;}
            /*@media screen and (max-width: 767px) {
              .main .sec02 .inner .flex02 .flex-wrap .readtext {
                font-size: min(4vw,24px);
                line-height: 1.6;
				padding: 0 20px;
				letter-spacing: 0.1em;} }*/
        .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: 100%; } }
      .main .sec02 .inner .flex03 {
        width: 100%;
        display: flex;
		background:#fff; }
		@media screen and (min-width: 767px) {
      	.main .sec04 .wrap#target03 .inner .wrap04 .flex04 {
        width: 100%;
        display: flex;
		background: url(../img/section04_img01.webp) no-repeat center/cover; }
      	.main .sec04 .wrap#target03 .inner .wrap04 .flex05 {
        width: 100%;
        display: flex;
		background: url(../img/section04_img02.webp) no-repeat center/cover; }}
        @media screen and (max-width: 767px) {
          .main .sec02 .inner .flex03,.main .sec04 .wrap#target03 .inner .wrap04 .flex04,.main .sec04 .wrap#target03 .inner .wrap04 .flex05 {
            display: block; }}
        .main .sec02 .inner .flex03 .imgbox {
          width: 40%;
          height: auto;
          background: url(../img/section01_img05.webp) no-repeat center/cover; }
        .main .sec04 .wrap#target03 .inner .wrap04 .flex04 .imgbox {
          width: 50%;}
          @media screen and (max-width: 767px) {
            .main .sec02 .inner .flex03 .imgbox {
              width: 100%;
              aspect-ratio: 2 / 1;
              background-position: top; }
            .main .sec04 .wrap#target03 .inner .wrap04 .flex04 .imgbox,.main .sec04 .wrap#target03 .inner .wrap04 .flex05 .imgbox {
              aspect-ratio: 2 / 1;
              background-position: top;
			  width: 100%;
          height: auto;
          background: url(../img/section04_img01.webp) no-repeat center/cover; }
            .main .sec04 .wrap#target03 .inner .wrap04 .flex05 .imgbox {
              aspect-ratio: 2 / 1;
              background-position: top;
			  width: 100%;
          height: auto;
          background: url(../img/section04_img02.webp) no-repeat center/cover; }}
        .main .sec02 .inner .flex03 .textbox,.main .sec04 .wrap#target03 .inner .wrap04 .flex04 .textbox,.main .sec04 .wrap#target03 .inner .wrap04 .flex05 .textbox {
          width: 60%;
          padding: 4%; }
          @media screen and (max-width: 767px) {
            .main .sec02 .inner .flex03 .textbox,.main .sec04 .wrap#target03 .inner .wrap04 .flex04 .textbox,.main .sec04 .wrap#target03 .inner .wrap04 .flex05 .textbox {
              width: 100%;
              padding: 6% 2%;
              text-align: center; } }
          .main .sec02 .inner .flex03 .textbox h4,.main .sec04 .wrap#target03 .inner .wrap04 .flex04 .textbox h4,.main .sec04 .wrap#target03 .inner .wrap04 .flex05 .textbox h4 {
            margin-bottom: 0.7em; }
            @media screen and (max-width: 767px) {
              .main .sec02 .inner .flex03 .textbox h4,.main .sec04 .wrap#target03 .inner .wrap04 .flex04 .textbox h4,.main .sec04 .wrap#target03 .inner .wrap04 .flex05 .textbox h4 {
                font-size: min(5.33vw,40px); } }
          .main .sec02 .inner .flex03 .textbox .readtext,.main .sec04 .wrap#target03 .inner .wrap04 .flex04 .textbox .readtext,.main .sec04 .wrap#target03 .inner .wrap04 .flex05 .textbox .readtext  {
            line-height: 2.2;
            text-align: justify; }
             /*@media screen and (max-width: 767px) {
             .main .sec02 .inner .flex03 .textbox .readtext,.main .sec04 .wrap#target03 .inner .wrap04 .flex04 .textbox .readtext,.main .sec04 .wrap#target03 .inner .wrap04 .flex05 .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(9.375vw,150px);
    overflow: hidden; }
    @media screen and (max-width: 767px) {
      .main .sec03 {
        padding: 13.33vw 0 0; } }
    .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 .wrap-center {
        width: 100%;
        text-align: center; }
        .main .sec03 .inner .wrap-center .logo {
          width: 25%;
          max-width: 273px;
          height: auto; }
          @media screen and (max-width: 767px) {
            .main .sec03 .inner .wrap-center .logo {
              width: 48%; } }
        .main .sec03 .inner .wrap-center .logotext {
          letter-spacing: 0.1em;
          margin-top: 1.5em; }
          @media screen and (max-width: 767px) {
            .main .sec03 .inner .wrap-center .logotext {
              font-size: min(3.75vw, 20px); } }
        .main .sec03 .inner .wrap-center h2 {
          font-size: min(2.85vw, 32px);
          letter-spacing: 0.8em;
          line-height: 1.9;
          font-feature-settings: "palt";
          margin-top: 1.6em; }
          .main .sec03 .inner .wrap-center h2 span {
            display: inline-block; }
          @media screen and (max-width: 767px) {
            .main .sec03 .inner .wrap-center h2 {
              font-size: min(4.375vw, 26px);
              letter-spacing: 0.5em; } }
        .main .sec03 .inner .wrap-center .h2-sub {
          font-size: min(1.81vw, 17px);
          letter-spacing: 0.03em;
          line-height: 1;
          margin-right: 1.5em;
          margin-top: 2.5em; }
          .main .sec03 .inner .wrap-center .h2-sub span {
            display: inline-block; }
          @media screen and (max-width: 767px) {
            .main .sec03 .inner .wrap-center .h2-sub {
              font-size: min(3.125vw, 12px);
              line-height: 1.5;
              margin-top: 1.5em;
              margin-right: 0.5em; } }
        .main .sec03 .inner .wrap-center .center-text {
          /*font-family: "\6E38\30B4\30B7\30C3\30AF\4F53", "YuGothic", "\6E38\30B4\30B7\30C3\30AF", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "meiryo", "Helvetica Neue", "arial", sans-serif;*/
          font-size: min(1.94vw, 23px);
          line-height: 2.8;
          letter-spacing: 0.07em;
          margin-top: 1.8em; }
          .main .sec03 .inner .wrap-center .center-text span {
            display: inline-block; }
          @media screen and (max-width: 767px) {
            .main .sec03 .inner .wrap-center .center-text {
              font-size: min(3.43vw, 14px); } }
        .main .sec03 .inner .wrap-center .logo2 {
          width: 100%;
          height: auto;
          margin-top: 100px; }
          @media screen and (max-width: 767px) {
            .main .sec03 .inner .wrap-center .logo2 {
              margin-top: 9vw; } }
        .main .sec03 .inner .wrap-center .map {
          width: 100%;
          height: auto;
          margin-top: 80px; }
          @media screen and (max-width: 767px) {
            .main .sec03 .inner .wrap-center .map {
              margin-top: 9vw;
              margin-left: calc(50% - 50vw);
              width: 100vw; } }
      .main .sec03 .inner .movie {
        margin-top: 100px; }
        @media screen and (max-width: 767px) {
          .main .sec03 .inner .movie {
            margin-top: 50px; } }
      .main .sec03 .inner video {
        max-width: 100%;
        display: block;
        margin: 0 auto; }
      .main .sec03 .inner .wrap {
        position: relative;
        width: 100%;
        text-align: center;
        margin-top: min(7.3vw,140px);
        background: #7d645d; }
        @media screen and (max-width: 767px) {
          .main .sec03 .inner .wrap {
            width: 100vw;
            margin-left: calc(50% - 50vw); } }
        .main .sec03 .inner .wrap .back-img01 {
          position: absolute;
          top: 0;
          left: 0;
          width: 45vw;
          height: auto;
          transform: translate(-65%, 5%);
          z-index: -1; }
          @media screen and (max-width: 767px) {
            .main .sec03 .inner .wrap .back-img01 {
              width: 59%;
              transform: translate(-39%, 2%); } }
        @media screen and (max-width: 767px) {
          .main .sec03 .inner .wrap.leaf {
            padding-top: 18.75vw; } }
        .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: 46%; }
          @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;
        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.coming {
          color: #443737 !important; }
        .main .sec04 .tab-wrap li.cs {
          color: #fff;
          cursor: pointer; }
          .main .sec04 .tab-wrap li.cs.off::after {
            content: 'coming soon';
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            color: #FFF;
            font-size: 0.95em;
            font-family: "Bebas Neue", sans-serif; }
        .main .sec04 .tab-wrap li:nth-of-type(1) {
          background: #7d645d; }
        .main .sec04 .tab-wrap li:nth-of-type(2) {
          background: #7d645d; }
        .main .sec04 .tab-wrap li:last-of-type {
          border-right: 1px solid #333;
          background: #7d645d; }
        .main .sec04 .tab-wrap li.active {
          background: #fff;
          color: #333333; }
          .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#target01 .wrap01 {
        width: 100%; }
        .main .sec04 .wrap#target01 .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#target01 .wrap01 .img01a {
              aspect-ratio: 5 / 4;
              background: url(../img/section03_img01a-sp.webp) no-repeat center/cover; } }
        .main .sec04 .wrap#target01 .wrap01 .flex {
          width: 100%;
          display: flex;
          justify-content: space-between; }
          @media screen and (max-width: 767px) {
            .main .sec04 .wrap#target01 .wrap01 .flex {
              flex-wrap: wrap; } }
          .main .sec04 .wrap#target01 .wrap01 .flex img {
            width: 25%;
            height: auto; }
            @media screen and (max-width: 767px) {
              .main .sec04 .wrap#target01 .wrap01 .flex img {
                width: 50%; } }
      .main .sec04 .wrap#target01 .wrap02 {
        padding: min(7.5vw,120px) 0;
        width: 100%;
        background: #7d645d; }
        @media screen and (max-width: 767px) {
          .main .sec04 .wrap#target01 .wrap02 {
            padding: 10.66vw 0; } }
        .main .sec04 .wrap#target01 .wrap02 .inner {
          width: 90%;
          max-width: 1100px;
          margin: 0 auto;
          color: #fff;
          text-align: center; }
          @media screen and (max-width: 767px) {
            .main .sec04 .wrap#target01 .wrap02 .inner {
              width: calc(100% - 20px);
              max-width: 650px; } }
          .main .sec04 .wrap#target01 .wrap02 .inner p {
            line-height: 1.7; }
            @media screen and (max-width: 767px) {
              .main .sec04 .wrap#target01 .wrap02 .inner p {
                font-size: min(4.68vw,28px); } }
          .main .sec04 .wrap#target01 .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#target01 .wrap02 .inner .readtext {
                font-size: min(3.4vw,24px);
                line-height: 1.7; } }
          .main .sec04 .wrap#target01 .wrap02 .inner .subtitle {
            font-size: min(2.4vw,30px);
            line-height: 1.7; }
            @media screen and (max-width: 767px) {
              .main .sec04 .wrap#target01 .wrap02 .inner .subtitle {
                font-size: min(4.68vw,30px); } }
      .main .sec04 .wrap#target01 .flex {
        width: 100%;
        display: flex; }
        @media screen and (max-width: 767px) {
          .main .sec04 .wrap#target01 .flex {
            flex-wrap: wrap; } }
        .main .sec04 .wrap#target01 .flex li {
          width: 50%;
          opacity: 1;
          transition: ease 0.5s; }
          @media screen and (max-width: 767px) {
            .main .sec04 .wrap#target01 .flex li {
              width: 100%; } }
          .main .sec04 .wrap#target01 .flex li:hover {
            opacity: 0.6; }
          .main .sec04 .wrap#target01 .flex li img {
            width: 100%;
            height: auto;
            display: block; }
      .main .sec04 .wrap#target01 .wrap03 {
        position: relative;
        width: 100%;
        padding: min(10.6vw,170px) 0; }
        @media screen and (max-width: 767px) {
          .main .sec04 .wrap#target01 .wrap03 {
            padding: 22vw 0;
            overflow: hidden; } }
        .main .sec04 .wrap#target01 .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#target01 .wrap03::before {
              width: 56%;
              max-width: none;
              transform: translate(-18%, 21%); } }
        .main .sec04 .wrap#target01 .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#target01 .wrap03::after {
              width: 56%;
              max-width: none;
              top: -5%;
              right: -4%;
              z-index: -1; } }
        .main .sec04 .wrap#target01 .wrap03 .inner {
          width: 90%;
          max-width: 1100px;
          margin: 0 auto;
          color: #fff;
          text-align: center; }
          @media screen and (max-width: 767px) {
            .main .sec04 .wrap#target01 .wrap03 .inner {
              width: calc(100% - 20px);
              max-width: 650px; } }
          .main .sec04 .wrap#target01 .wrap03 .inner .flex {
            display: flex;
            justify-content: space-between;
            align-items: center; }
            @media screen and (max-width: 767px) {
              .main .sec04 .wrap#target01 .wrap03 .inner .flex {
                display: block; } }
            .main .sec04 .wrap#target01 .wrap03 .inner .flex img {
              width: 57%;
              height: auto; }
              @media screen and (max-width: 767px) {
                .main .sec04 .wrap#target01 .wrap03 .inner .flex img {
                  width: 100%; } }
            .main .sec04 .wrap#target01 .wrap03 .inner .flex .textbox {
              width: 40%;
              color: #333;
              text-align: center; }
              @media screen and (max-width: 767px) {
                .main .sec04 .wrap#target01 .wrap03 .inner .flex .textbox {
                  width: 100%;
                  margin-top: 10.66vw; } }
              .main .sec04 .wrap#target01 .wrap03 .inner .flex .textbox .subtitle {
                font-size: min(2.24vw,28px);
                line-height: 1.7; }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap#target01 .wrap03 .inner .flex .textbox .subtitle {
                    font-size: min(6vw,45px);
                    line-height: 1.3; } }
              .main .sec04 .wrap#target01 .wrap03 .inner .flex .textbox .readtext {
                font-size: min(1.63vw,18px);
                margin-top: 0.5em; }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap#target01 .wrap03 .inner .flex .textbox .readtext {
                    font-size: min(4vw,28px);
                    line-height: 1.7;
                    margin-top: 0.75em; } }
              .main .sec04 .wrap#target01 .wrap03 .inner .flex .textbox .annotation {
                line-height: 1.8;
                margin-top: 2em; }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap#target01 .wrap03 .inner .flex .textbox .annotation {
                    font-size: min(3.43vw,20px);
                    margin-top: 0.75em;
                    margin-top: 3em; } }
              .main .sec04 .wrap#target01 .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#target01 .wrap03 .inner .flex .textbox .btn-flex {
                    margin-top: 7vw;
                    font-size: min(5.6vw,42px); } }
                .main .sec04 .wrap#target01 .wrap03 .inner .flex .textbox .btn-flex button {
                  position: relative;
                  background: #7d645d;
                  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#target01 .wrap03 .inner .flex .textbox .btn-flex button:hover {
                    opacity: 0.6; }
                  .main .sec04 .wrap#target01 .wrap03 .inner .flex .textbox .btn-flex button span {
                    font-size: 0.65em; }
                  .main .sec04 .wrap#target01 .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#target01 .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: #7d645d;
        color: #fff;
        text-align: center;
        opacity: 1;
        transition: ease 0.5s; }
        @media screen and (max-width: 767px) {
          .main .sec04 .wrap#target01 .linkbtn {
            width: calc(100% - 20px);
            max-width: 650px;
            font-size: min(4.8vw,36px);
            line-height: 1.4; } }
        .main .sec04 .wrap#target01 .linkbtn:hover {
          opacity: 0.6; }
          @media screen and (max-width: 767px) {
            .main .sec04 .wrap#target01 .linkbtn:hover {
              opacity: 1; } }
        .main .sec04 .wrap#target01 .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#target01 .linkbtn span {
          font-size: 0.55em; }
      .main .sec04 .wrap#target02 {
        text-align: center;
        overflow: hidden; }
        .main .sec04 .wrap#target02 .inner {
          width: 90%;
          max-width: 1100px;
          margin: 0 auto; }
        .main .sec04 .wrap#target02 h3,.main .sec02 .wrap#target03 h3 {
          position: relative;
          font-size: min(3.63vw, 40px);
          font-weight: 500;
          line-height: 1.7;
          color: #7d645d;
          margin-bottom: 0.3em; }
          @media screen and (max-width: 767px) {
            .main .sec04 .wrap#target02 h3 {
              font-size: min(6.25vw, 50px); } }
          .main .sec04 .wrap#target02 h3 span {
            font-size: min(1.83vw,18px);
            color: #333; }
            @media screen and (max-width: 767px) {
              .main .sec04 .wrap#target02 h3 span {
                font-size: min(5vw, 40px); } }
          .main .sec04 .wrap#target02 h3::after {
            content: '';
            position: absolute;
            right: 0;
            top: 0;
            width: 34%;
            height: auto;
            aspect-ratio: 1 / 1;
            background: url(../img/leaves08.webp) no-repeat center/contain;
            transform: translateX(50%);
            z-index: -1; }
            @media screen and (max-width: 767px) {
              .main .sec04 .wrap#target02 h3::after {
                transform: translateX(20%); } }
        .main .sec04 .wrap#target02 .readtext {
          line-height: 2; }
          .main .sec04 .wrap#target02 .readtext span {
            display: inline-block; }
            .main .sec04 .wrap#target02 .readtext span.annotation {
              margin-top: 1.5em; }
        .main .sec04 .wrap#target02 #mh {
          width: 100%;
          max-width: 900px;
          margin: min(5.2vw, 80px) auto 0; }
          .main .sec04 .wrap#target02 #mh img {
            width: 100%;
            height: auto; }
        .main .sec04 .wrap#target02 #mh2 {
          width: 100%;
          max-width: 900px;
          margin: min(5.2vw, 80px) auto 0; }
          .main .sec04 .wrap#target02 #mh2 img {
            width: 100%;
            height: auto; }
          .main .sec04 .wrap#target02 #mh2 .splide__arrows {
            position: absolute;
            top: 50%;
            left: 0;
            width: 100%;
            z-index: 2; }
          .main .sec04 .wrap#target02 #mh2 .splide__arrow {
            background-color: transparent;
            background-size: contain;
            background-repeat: no-repeat;
            width: 2%;
            height: auto;
            aspect-ratio: 11 / 21;
            border: none;
            text-indent: -9999px;
            /* テキスト非表示 */ }
            @media screen and (max-width: 767px) {
              .main .sec04 .wrap#target02 #mh2 .splide__arrow {
                width: 5%; } }
          .main .sec04 .wrap#target02 #mh2 .splide__arrow--prev {
            background-image: url("../img/splide_arrow-left.webp");
            position: absolute;
            left: 0;
            transform: translate(100%, -50%); }
          .main .sec04 .wrap#target02 #mh2 .splide__arrow--next {
            background-image: url("../img/splide_arrow-right.webp");
            position: absolute;
            right: 0;
            transform: translate(-100%, -50%); }
        .main .sec04 .wrap#target02 .wrap01 {
          position: relative;
          width: 100%;
          max-width: 900px;
          margin: min(5.2vw, 80px) auto 0; }
          .main .sec04 .wrap#target02 .wrap01::before {
            content: '';
            position: absolute;
            top: 0;
            right: 100%;
            z-index: -1;
            width: 33%;
            height: auto;
            aspect-ratio: 194 / 175;
            background: url(../img/leaves09.webp) no-repeat center/contain;
            transform: translate(-3%, -40%); }
            @media screen and (max-width: 767px) {
              .main .sec04 .wrap#target02 .wrap01::before {
                right: 77%;
                transform: translate(-3%, -52%); } }
          .main .sec04 .wrap#target02 .wrap01 img {
            width: 100%;
            height: auto; }
          .main .sec04 .wrap#target02 .wrap01 .btn-flex {
            /*position: absolute;*/
            font-size: min(2.59vw, 26px);
            bottom: 2em;
            left: 0;
            width: 100%;
            display: flex;
            justify-content: center;
            gap: 25px; }
            @media screen and (max-width: 767px) {
              .main .sec04 .wrap#target02 .wrap01 .btn-flex {
                font-size: min(3.43vw, 26px);
                gap: 10px; } }
            .main .sec04 .wrap#target02 .wrap01 .btn-flex .btn {
              position: relative;
              line-height: 1;
              background: #fff;
              color: #221714;
              border: 1px solid #221714;
              width: 10em;
              line-height: 1;
              padding: 0.4em 0 0.55em;
              box-sizing: border-box;
              cursor: pointer;
              opacity: 1;
              transition: ease 0.5s;
              align-content: center; }
              @media screen and (max-width: 767px) {
                .main .sec04 .wrap#target02 .wrap01 .btn-flex .btn {
                  width: 11em;
                  padding: 0; } }
              .main .sec04 .wrap#target02 .wrap01 .btn-flex .btn::after {
                content: '';
                position: absolute;
                right: 0.5em;
                top: 50%;
                transform: translateY(-50%);
                width: 0.5em;
                height: auto;
                aspect-ratio: 67 / 37;
                background: url(../img/icon-arrow02b.webp) no-repeat center/contain; }
              .main .sec04 .wrap#target02 .wrap01 .btn-flex .btn:hover {
                opacity: 0.6; }
              .main .sec04 .wrap#target02 .wrap01 .btn-flex .btn span {
                font-size: 0.7em; }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap#target02 .wrap01 .btn-flex .btn span {
                    font-size: max(0.7em, 10px); } }
        .main .sec04 .wrap#target02 .wrap02 {
          width: 100%;
          max-width: 900px;
          margin: min(5.2vw, 80px) auto 0; }
          .main .sec04 .wrap#target02 .wrap02 .btn-flex2 {
            font-size: min(3.9vw, 35px);
            width: 100%;
            display: flex;
            justify-content: center;
            gap: 25px;
            margin-top: 1em; }
            @media screen and (max-width: 767px) {
              .main .sec04 .wrap#target02 .wrap02 .btn-flex2 {
                font-size: min(4.375vw, 35px);
                gap: 20px; } }
            .main .sec04 .wrap#target02 .wrap02 .btn-flex2 .btn {
              position: relative;
              line-height: 1;
              background: #7d645d;
              color: #fff;
              width: 10em;
              line-height: 1;
              padding: 0.4em 0 0.55em;
              box-sizing: border-box;
              cursor: pointer;
              opacity: 1;
              transition: ease 0.5s; }
              @media screen and (max-width: 767px) {
                .main .sec04 .wrap#target02 .wrap02 .btn-flex2 .btn {
                  width: 11em; } }
              .main .sec04 .wrap#target02 .wrap02 .btn-flex2 .btn::after {
                content: '';
                position: absolute;
                right: 0.5em;
                top: 50%;
                transform: translateY(-50%);
                width: 0.5em;
                height: auto;
                aspect-ratio: 67 / 37;
                background: url(../img/icon-arrow02a.webp) no-repeat center/contain; }
              .main .sec04 .wrap#target02 .wrap02 .btn-flex2 .btn:hover {
                opacity: 0.6; }
              .main .sec04 .wrap#target02 .wrap02 .btn-flex2 .btn span {
                font-size: 0.7em; }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap#target02 .wrap02 .btn-flex2 .btn span {
                    font-size: max(0.7em, 10px); } }
      .main .sec04 .wrap#target03 {
        overflow: hidden; }
        .main .sec04 .wrap#target03 #new01 {
          width: 100%;
          max-width: 1100px;
          margin: 0 auto; }
          .main .sec04 .wrap#target03 #new01 img {
            width: 100%;
            height: auto;
            margin: 0 auto;
            display: block; }
        .main .sec04 .wrap#target03 .inner {
          width: 90%;
          max-width: 1100px;
          margin: 0 auto; }
          .main .sec04 .wrap#target03 .inner .flex {
            /*display: flex;*/
            justify-content: space-between;
            align-items: center;
            margin-top: min(5.2vw, 80px); }
            @media screen and (max-width: 767px) {
              .main .sec04 .wrap#target03 .inner .flex {
                flex-wrap: wrap; } }
            .main .sec04 .wrap#target03 .inner .flex img {
              width: 90%;
              height: auto;
              margin: auto;
              display: block;}
              @media screen and (max-width: 767px) {
                .main .sec04 .wrap#target03 .inner .flex img {
                  width: 100%;
                  order: 2;
                  margin: 7vw 0 5vw; } }
            .main .sec04 .wrap#target03 .inner .flex .textbox {
              position: relative;
              /*width: 42%;*/
              color: #333; }
              .main .sec04 .wrap#target03 .inner .flex .textbox::after {
                content: '';
                position: absolute;
                top: 0;
                right: 0;
                width: 75%;
                height: auto;
                aspect-ratio: 1 / 1;
                background: url(../img/leaves08.webp) no-repeat center/contain;
                z-index: -1;
                transform: translate(40%, -55%); }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap#target03 .inner .flex .textbox::after {
                    width: 33%;
                    transform: translate(21%, -15%); } }
              @media screen and (max-width: 767px) {
                .main .sec04 .wrap#target03 .inner .flex .textbox {
                  width: 100%;
                  order: 1;
				  margin-top: 70px;} }
              .main .sec04 .wrap#target03 .inner .flex .textbox h3 {
                font-size: min(3.63vw, 40px);
                color: #7d645d; }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap#target03 .inner .flex .textbox h3 {
                    text-align: center;
                    font-size: min(6.25vw, 50px);
                    line-height: 1.7; } }
                .main .sec04 .wrap#target03 .inner .flex .textbox h3 span {
                  font-size: 0.45em;
                  color: #333; }
                  @media screen and (max-width: 767px) {
                    .main .sec04 .wrap#target03 .inner .flex .textbox h3 span {
                      font-size: min(5vw, 40px); } }
              .main .sec04 .wrap#target03 .inner .flex .textbox .readtext {
                font-size: min(1.5vw, 18px);
                line-height: 2.7;
                margin-top: 3em; }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap#target03 .inner .flex .textbox .readtext {
                    font-size: min(3.43vw, 14px);
                    margin-top: 0.5em;
                    line-height: 2;
					letter-spacing: 0.05em;} }
          .main .sec04 .wrap#target03 .inner .wrap01 {
            position: relative;
            width: 100%;
            margin-top: min(5.2vw, 80px); }
            .main .sec04 .wrap#target03 .inner .wrap01::before {
              content: '';
              position: absolute;
              top: 0;
              right: 100%;
              width: 28%;
              height: auto;
              aspect-ratio: 194 / 175;
              background: url(../img/leaves09.webp) no-repeat center/contain;
              z-index: -1;
              transform: translate(25%, -8%); }
              @media screen and (max-width: 767px) {
                .main .sec04 .wrap#target03 .inner .wrap01::before {
                  width: 46%;
                  transform: translate(74%, -60%); } }
            .main .sec04 .wrap#target03 .inner .wrap01 .subtitle {
              text-align: center;
              font-size: min(2.59vw, 30px);
              line-height: 1.7; }
              @media screen and (max-width: 767px) {
                .main .sec04 .wrap#target03 .inner .wrap01 .subtitle {
                  font-size: min(4vw, 28px);
                  margin-top: 3em; } }
            .main .sec04 .wrap#target03 .inner .wrap01 .btn-flex {
              width: 100%;
              max-width: 900px;
              margin: min(2.6vw, 40px) auto 0;
              display: flex;
              flex-wrap: wrap;
              justify-content: center;
              gap: 1.2em; }
              @media screen and (max-width: 767px) {
                .main .sec04 .wrap#target03 .inner .wrap01 .btn-flex {
                  margin-top: 7vw;
                  font-size: min(5.6vw, 35px);
                  gap: 0.6em; } }
              .main .sec04 .wrap#target03 .inner .wrap01 .btn-flex a {
                position: relative;
                width: calc(100% / 2 - 0.8em);
                background: #7d645d;
                color: #fff;
                font-size: min(3.11vw, 35px);
                line-height: 1;
                text-align: center;
                padding: 0.4em 0 0.55em;
                transition: ease 0.5s;
				border-radius: 10px;
                /*&::after{
                    content: '';
                    position: absolute;
                    right: 0.5em;
                    top: 50%;
                    transform: translateY(-50%);
                    height: 0.5em;
                    width: auto;
                    aspect-ratio: 37 / 67;
                    background: url(../img/icon-arrow01.webp)no-repeat center / contain;
                }*/ }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap#target03 .inner .wrap01 .btn-flex a {
                    font-size: min(5.6vw, 35px);
                    width: calc(50% - 0.6em);
                    height: 55px;
                    align-content: center;
                    /* 20251110 */ } }
                .main .sec04 .wrap#target03 .inner .wrap01 .btn-flex a span:nth-of-type(1) {
                  font-size: 0.7em; }
                .main .sec04 .wrap#target03 .inner .wrap01 .btn-flex a span:nth-of-type(2) {
                  font-size: 0.5em;
                  color: #fff;
                  position: absolute;
                  right: 5%;
                  top: 50%;
                  transform: translate(0, -50%); }
                  @media screen and (max-width: 767px) {
                    .main .sec04 .wrap#target03 .inner .wrap01 .btn-flex a span:nth-of-type(2) {
                      font-size: 0.5em;
                      position: static;
                      display: block;
                      padding-top: 13%; } }
                .main .sec04 .wrap#target03 .inner .wrap01 .btn-flex a:hover {
                  opacity: 0.6; }
              .main .sec04 .wrap#target03 .inner .wrap01 .btn-flex .btn-sold {
                position: relative;
                width: calc(100% / 2 - 0.8em);
                background: #cccccc;
                color: #fff;
                font-size: min(3.11vw, 35px);
                line-height: 1;
                text-align: center;
                padding: 0.4em 0 0.55em;
                transition: ease 0.5s; }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap#target03 .inner .wrap01 .btn-flex .btn-sold {
                    font-size: min(5.6vw, 35px);
                    width: calc(50% - 0.6em);
                    height: 55px;
                    align-content: center; } }
                .main .sec04 .wrap#target03 .inner .wrap01 .btn-flex .btn-sold span:nth-of-type(1) {
                  font-size: 0.7em; }
                .main .sec04 .wrap#target03 .inner .wrap01 .btn-flex .btn-sold span:nth-of-type(2) {
                  font-size: 0.5em;
                  position: absolute;
                  right: 5%;
                  top: 50%;
                  transform: translate(0, -50%); }
                  @media screen and (max-width: 767px) {
                    .main .sec04 .wrap#target03 .inner .wrap01 .btn-flex .btn-sold span:nth-of-type(2) {
                      display: block;
                      position: static;
                      padding-top: 13%; } }
              .main .sec04 .wrap#target03 .inner .wrap01 .btn-flex .btn-model {
                position: relative;
                width: calc(100% / 2 - 0.8em);
                background: #000;
                color: #fff;
                font-size: min(3.11vw, 35px);
                line-height: 1;
                text-align: center;
                padding: 0.4em 0 0.55em;
                transition: ease 0.5s; }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap#target03 .inner .wrap01 .btn-flex .btn-model {
                    font-size: min(5.6vw, 35px);
                    width: calc(50% - 0.6em);
                    height: 55px;
                    align-content: center; } }
                .main .sec04 .wrap#target03 .inner .wrap01 .btn-flex .btn-model span:nth-of-type(1) {
                  font-size: 0.7em; }
                .main .sec04 .wrap#target03 .inner .wrap01 .btn-flex .btn-model span:nth-of-type(2) {
                  font-size: 0.5em;
                  padding-top: 2px;
                  display: inline;
                  text-align: right;
                  position: absolute;
                  right: 5%;
                  top: 50%;
                  transform: translate(0, -50%); }
                  @media screen and (max-width: 767px) {
                    .main .sec04 .wrap#target03 .inner .wrap01 .btn-flex .btn-model span:nth-of-type(2) {
                      display: block;
                      position: static;
                      text-align: center;
                      padding-top: 13%; } }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap#target03 .inner .wrap01 .btn-flex .btn-model .br-sp {
                    display: none; } }
                .main .sec04 .wrap#target03 .inner .wrap01 .btn-flex .btn-model:hover {
                  opacity: 0.6; }
            .main .sec04 .wrap#target03 .inner .wrap01 .kaiin {
              width: calc(100% - 2.4em);
              /*20251113 */
              max-width: calc(900px - 2.4em);
              margin: min(2.6vw, 40px) auto 0;
              display: block;
              text-align: center;
              gap: 1.2em;
              padding: 0; }
              @media screen and (max-width: 767px) {
                .main .sec04 .wrap#target03 .inner .wrap01 .kaiin {
                  margin-top: 7vw;
                  font-size: min(5.6vw, 35px); } }
              .main .sec04 .wrap#target03 .inner .wrap01 .kaiin a {
                display: block;
                width: 100%;
                margin: 0 auto min(1.2em, 20px);
                background: #fff;
                border: solid 1px #7d645d;
                color: #7d645d;
                font-size: min(3.11vw, 35px);
                line-height: 1;
                text-align: center;
                padding: 0.4em 0 0.55em;
                transition: ease 0.5s; }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap#target03 .inner .wrap01 .kaiin a {
                    font-size: min(5.6vw, 35px);
                    width: calc(100% - 0.5em);
                    /* 1.2→0.5 20251113 */ } }
                .main .sec04 .wrap#target03 .inner .wrap01 .kaiin a span {
                  font-size: 0.7em; }
                .main .sec04 .wrap#target03 .inner .wrap01 .kaiin a:hover {
                  opacity: 0.6; }
                .main .sec04 .wrap#target03 .inner .wrap01 .kaiin a::after {
                  content: '';
                  position: absolute;
                  right: 0.5em;
                  top: 50%;
                  transform: translateY(-50%);
                  height: 0.5em;
                  width: auto;
                  aspect-ratio: 37 / 67; }
          .main .sec04 .wrap#target03 .inner .wrap02 {
            margin-top: min(12.4vw, 160px); }
            .main .sec04 .wrap#target03 .inner .wrap02 h3.eng {
              font-size: min(2.1vw,25px);
              text-align: center; }
              @media screen and (max-width: 767px) {
                .main .sec04 .wrap#target03 .inner .wrap02 h3.eng,.main .sec04 .wrap#target03 .inner .wrap04 h3.eng {
                  font-size: min(5vw,40px); } }
            .main .sec04 .wrap#target03 .inner .wrap04 h3.eng {
			  margin-top: 150px;
              font-size: min(2.1vw,25px);
              text-align: center; }
              @media screen and (max-width: 767px) {
                .main .sec04 .wrap#target03 .inner .wrap04 h3.eng {
                  margin-top: 80px;
                  font-size: min(5vw,40px); } }
            .main .sec04 .wrap#target03 .inner .wrap02 .tab-wrap {
              font-size: min(1.94vw, 20px);
              display: flex;
              justify-content: center;
              margin: min(9vw, 100px) auto 0;
              border-bottom: 1px solid #333;
              width: 100%;
              max-width: 1100px;
              text-align: center;
              transform: translateY(-100%); }
              @media screen and (max-width: 767px) {
                .main .sec04 .wrap#target03 .inner .wrap02 .tab-wrap {
                  margin: min(15vw, 120px) auto 0; } }
              .main .sec04 .wrap#target03 .inner .wrap02 .tab-wrap li {
                font-size: 1em;
                line-height: 1.2;
				  width: 30%;}
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap#target03 .inner .wrap02 .tab-wrap li {
                    width: 33.3%;
                    font-size: min(3.43vw, 20px);
                    line-height: 1.2; } }
                .main .sec04 .wrap#target03 .inner .wrap02 .tab-wrap li.active {
                  background: #fff;
                  color: #333; }
            .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 {
              width: 100%;
              max-width: 960px;
              margin: 0 auto;
              display: none; }
              .main .sec04 .wrap#target03 .inner .wrap02 .wrap03.active {
                display: block; }
              .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .wrap03-wrap {
                width: 100%;
                padding: min(2.6vw, 40px) 0 min(7.8vw, 120px); }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .wrap03-wrap {
                    padding: 0 0 min(9vw, 120px);
                    margin-top: -5vw; } }
              .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .wrap03-wrap2 {
                width: 100%;
                padding: min(9vw, 120px) 0; }
.main .sec04 .wrap#target03 .inner .wrap02 p.attension{
	font-size: 14px;
	color: red;
	text-align: center;
}
                @media screen and (max-width: 767px) {
					.main .sec04 .wrap#target03 .inner .wrap02 p.attension{
						font-size: 12px;
						padding-bottom: 10px;
					}}
              .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 h4 {
                font-size: min(3.24vw, 35px);
                line-height: 1.7;
                border-bottom: 1px solid #333; }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 h4 {
                    font-size: min(6.25vw, 50px); } }
                .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 h4 span {
                  font-size: 0.7em;
                  font-weight: 300;
                  line-height: 1;
                  transform: translateY(-18%);
                  display: inline-block; }
                  @media screen and (max-width: 767px) {
                    .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 h4 span {
                      font-size: 0.6em; } }
              .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex01 {
                width: 100%;
                display: flex;
                justify-content: space-between;
                align-items: flex-start;
                margin-top: min(3.9vw, 60px); }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex01 {
                    margin: min(3.9vw, 60px) auto 0;
                    flex-wrap: wrap; } }
                .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex01 .imgbox01 {
                  width: 65.5%;
                  height: auto;
                  aspect-ratio: 20 / 13;
                  background: #eee; }
                  @media screen and (max-width: 767px) {
                    .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex01 .imgbox01 {
                      width: 100%; } }
                  .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex01 .imgbox01 img {
                    width: 100%;
                    height: 100%;
                    object-fit: cover; }
                .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex01 .readtext {
                  text-align: justify;
                  width: 31%;
                  line-height: 2.2; }
                  @media screen and (max-width: 767px) {
                    .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex01 .readtext {
                      width: 100%;
                      margin-top: 1em;
                      line-height: 2;
                      font-size: min(4vw, 21px); } }
                .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex01.f2 {
                  align-items: stretch; }
                  .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex01.f2 .imgbox01 {
                    width: 45%;
                    height: auto;
                    aspect-ratio: 5 / 7; }
                    @media screen and (max-width: 767px) {
                      .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex01.f2 .imgbox01 {
                        width: 63%; } }
                  .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex01.f2 .textbox {
                    position: relative;
                    width: 50%; }
                    @media screen and (max-width: 767px) {
                      .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex01.f2 .textbox {
                        width: 32%;
                        line-height: 1.8; } }
                    .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex01.f2 .textbox .readtext {
                      width: 100%; }
                      .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex01.f2 .textbox .readtext.big {
                        margin-bottom: 0.5em; }
                        @media screen and (max-width: 767px) {
                          .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex01.f2 .textbox .readtext.big {
                            font-size: min(3.6vw, 21px);
                            margin-top: 0;
                            line-height: 1.5; }
                            .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex01.f2 .textbox .readtext.big .break {
                              display: block;
                              margin-left: 1.2em; } }
                    .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex01.f2 .textbox div {
                      position: absolute;
                      bottom: 0; }
                      @media screen and (max-width: 767px) {
                        .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex01.f2 .textbox div {
                          position: relative; }
                          .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex01.f2 .textbox div .small {
                            font-size: min(3.43vw, 18px); } }
              .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex02 {
                position: relative;
                width: 100%;
                display: flex;
                flex-wrap: wrap;
                justify-content: flex-start;
                align-items: flex-start;
                padding: min(3.9vw, 60px) 0 0;
                gap: 3%; }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex02 {
                    flex-wrap: wrap;
                    gap: 7vw;
                    padding: 10vw 0 0; } }
                .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex02 .box {
                  width: 31%; }
                  @media screen and (max-width: 767px) {
                    .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex02 .box {
                      width: 100%;
                      /*display: flex;*/
                      justify-content: space-between;
                      align-items: stretch; }
                      .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex02 .box:nth-of-type(even) .imgbox02 {
                        order: 2; }
                      .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex02 .box:nth-of-type(even) .textbox02 {
                        order: 1; } }
                  .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex02 .box .imgbox02 {
                    width: 100%;
                    height: auto;
                    aspect-ratio: 20 / 13; }
                    @media screen and (max-width: 767px) {
                      .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex02 .box .imgbox02 {
                        width: 51%;
                        aspect-ratio: auto;
						float: left;
        				padding-right: 10px;}
                        .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex02 .box .imgbox02.i01c img {
                          object-position: right; } }
                    .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex02 .box .imgbox02 img {
                      width: 100%;
                      /*height: 100%;*/
                      object-fit: cover; }
                  /*@media screen and (max-width: 767px) {
                    .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex02 .box .textbox02 {
                      width: 44%; } }*/
                  .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex02 .box .textbox02 .big {
                    text-align: center;
                    line-height: 1;
                    margin-top: 1.5em; }
                    @media screen and (max-width: 767px) {
                      .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex02 .box .textbox02 .big {
                        text-align: left;
                        font-size: min(4.375vw, 31px);
                        margin-top: 0; } }
                  .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex02 .box .textbox02 .small {
                    line-height: 2;
                    text-align: justify;
                    margin-top: 1.2em; }
                    @media screen and (max-width: 767px) {
                      .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .flex02 .box .textbox02 .small {
                        font-size: min(3.43vw, 20px);
                        margin-top: 0.7em;
                        line-height: 1.8; } }
              .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .wide-wrap {
                width: 100vw;
                margin-left: calc(50% - 50vw);
                background: #7d645d;
                padding: min(7.8vw, 120px) 0; }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .wide-wrap .inner {
                    width: 76%; } }
                .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .wide-wrap h4 {
                  color: #fff;
                  border: 0;
                  text-align: center;
                  line-height: 1.4;
                  margin-bottom: 1.5em; }
                  @media screen and (max-width: 767px) {
                    .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .wide-wrap h4 {
                      margin-bottom: 1em; } }
                .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .wide-wrap .common .splide__arrows {
                  position: absolute;
                  top: 50%;
                  left: -5%;
                  width: 110%;
                  z-index: 2;
                  transform: translateY(-50%); }
                  @media screen and (max-width: 767px) {
                    .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .wide-wrap .common .splide__arrows {
                      width: 120%;
                      left: -10%; } }
                .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .wide-wrap .common .splide__arrow {
                  background-color: transparent;
                  background-size: contain;
                  background-repeat: no-repeat;
                  width: 2%;
                  height: auto;
                  aspect-ratio: 11 / 21;
                  border: none;
                  text-indent: -9999px;
                  /* テキスト非表示 */ }
                  @media screen and (max-width: 767px) {
                    .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .wide-wrap .common .splide__arrow {
                      width: 5%; } }
                /*.main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .wide-wrap .common .splide__arrow--prev {
                  background-image: url("../img/splide_arrow-left.webp"); }
                .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .wide-wrap .common .splide__arrow--next {
                  background-image: url("../img/splide_arrow-right.webp");
                  position: absolute;
                  right: 0; }*/
                .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .wide-wrap .common .splide__slide {
                  padding: 20px;
                  background-color: #fff; }
                  @media screen and (max-width: 767px) {
                    .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .wide-wrap .common .splide__slide {
                      padding: 5%; } }
                  .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .wide-wrap .common .splide__slide span {
                    width: 100%;
                    height: auto;
                    aspect-ratio: 20 / 13;
                    overflow: hidden;
                    display: block; }
                    @media screen and (max-width: 767px) {
                      .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .wide-wrap .common .splide__slide span {
                        aspect-ratio: 54 / 35; } }
                    .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .wide-wrap .common .splide__slide span.border {
                      border: 1px solid #333; }
                    .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .wide-wrap .common .splide__slide span img {
                      width: 100%;
                      height: 100%;
                      object-fit: contain; }
                  .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .wide-wrap .common .splide__slide .big {
                    text-align: center;
                    line-height: 1;
                    margin-top: 1.5em; }
                    @media screen and (max-width: 767px) {
                      .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .wide-wrap .common .splide__slide .big {
                        font-size: min(4.375vw, 31px);
                        margin-top: 1em; } }
                    .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .wide-wrap .common .splide__slide .big span {
                      display: inline-block;
                      aspect-ratio: auto; }
                  .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .wide-wrap .common .splide__slide .small {
                    line-height: 2;
                    text-align: justify;
                    margin-top: 1.2em; }
                    @media screen and (max-width: 767px) {
                      .main .sec04 .wrap#target03 .inner .wrap02 .wrap03 .wide-wrap .common .splide__slide .small {
                        font-size: min(3.43vw, 20px);
                        margin-top: 0.9em;
                        line-height: 1.8; } }
              .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .imgbox01 {
                width: 64%;
                aspect-ratio: 31 / 26; }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .imgbox01 {
                    width: 100%;
                    height: auto;
                    aspect-ratio: 65 / 42; } }
              .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .textbox {
                width: 29%; }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .textbox {
                    width: 100%; } }
                .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .textbox img {
                  width: 100%;
                  height: auto; }
                  @media screen and (max-width: 767px) {
                    .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .textbox img {
                      max-width: 500px;
                      margin: 5vw auto 0;
                      display: block; } }
                .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .textbox .readtext {
                  width: 100%;
                  margin-bottom: 1em;
                  line-height: 2; }
                  @media screen and (max-width: 767px) {
                    .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .textbox .readtext {
                      font-size: min(4vw, 21px);
                      margin-top: 0; } }
                .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .textbox .big2 {
                  margin-bottom: 0.5em; }
                  @media screen and (max-width: 767px) {
                    .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .textbox .big2 {
                      font-size: min(5.625vw, 35px);
                      margin-top: 0.3em;
                      margin-bottom: 0; } }
                .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .textbox .small {
                  margin-bottom: 0;
                  margin-top: 1.2em;
                  line-height: 1.7; }
                  @media screen and (max-width: 767px) {
                    .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .textbox .small {
                      max-width: 500px;
                      margin: 1.5em auto 0;
                      font-size: min(3.43vw, 16px); } }
              .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .flex02 {
                align-items: stretch; }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .flex02 {
                    display: block; }
                    .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .flex02 .readtext {
                      font-size: min(4vw, 21px);
                      text-align: justify; }
                    .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .flex02 .big2 {
                      font-size: min(5.625vw, 35px);
                      margin-top: 0.3em;
                      margin-bottom: 0;
                      line-height: 2; } }
                .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .flex02 .imgbox01 {
                  width: 60%;
                  aspect-ratio: 573 / 384; }
                      .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .flex02 .imgbox01 .big-img {
                        width: 100%; }
                  @media screen and (max-width: 767px) {
                    .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .flex02 .imgbox01 {
                      position: relative;
                      display: flex;
                      justify-content: space-between;
                      align-items: flex-end;
                      width: 100%;
                      aspect-ratio: auto; }
                      .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .flex02 .imgbox01 .big-img {
                        width: 74%; }
                      .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .flex02 .imgbox01 .small {
                        position: absolute;
                        bottom: 28vw;
                        left: 0;
                        width: 6em;
                        font-size: min(3.43vw, 18px);
                        line-height: 1.5; }
                      .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .flex02 .imgbox01 .small-img {
                        position: relative;
                        left: 0;
                        bottom: 0;
                        width: 21%;
                        height: auto;
                        transform-origin: left bottom;
                        transform: scale(1.8); } }
                .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .flex02 .textbox {
                  position: relative;
                  width: 35%; }
                .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .flex02 .small-img {
                  position: absolute;
                  left: 55%;
                  bottom: 0;
                  width: 75%;
                  height: auto; }
                .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target02 .flex02 .small {
                  position: absolute;
                  bottom: 0;
                  left: 0;
                  width: 50%; }
              .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target03 .imgbox01 {
                width: 64%;
                /*aspect-ratio: 31 / 35;*/ }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target03 .imgbox01 {
                    width: 100%; } }
              .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target03 .textbox01 {
                width: 29%; }
                @media screen and (max-width: 767px) {
                  .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target03 .textbox01 {
                    width: 100%; }
                    .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target03 .textbox01 .sp-flex {
                      display: flex;
                      justify-content: space-between;
                      margin-top: 7vw; }
                      .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target03 .textbox01 .sp-flex .sp-imgbox {
                        width: 48%;
                        height: auto;
                        aspect-ratio: 31 / 36;
                        order: 2;
                        margin-top: 0;
                        background: url(../img/new_security-img02-sp.webp) no-repeat center/cover; }
                      .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target03 .textbox01 .sp-flex div {
                        width: 47%;
                        order: 1; }
                        .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target03 .textbox01 .sp-flex div .big {
                          font-size: min(4.375vw, 30px);
                          text-align: left;
                          line-height: 1.5;
                          margin-top: 0; }
                        .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target03 .textbox01 .sp-flex div .small {
                          font-size: min(3.75vw, 21px); } }
                .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target03 .textbox01 img {
                  width: 100%;
                  height: auto;
                  margin-top: 20px; }
                .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target03 .textbox01 .readtext {
                  width: 100%; }
                  .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target03 .textbox01 .readtext.big {
                    text-align: center;
                    margin-top: 0.6em; }
                  .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target03 .textbox01 .readtext.small {
                    line-height: 1.7;
                    margin-top: 0.4em; }
              .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target03 .box .big {
                text-align: center;
                margin-top: 1.5em;
                line-height: 1; }
              .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target03 .box .small {
                margin-top: 1.2em; }
              @media screen and (max-width: 767px) {
                /*.main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target03 .box div {
                  width: 45%; }*/
                  .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target03 .box div .big {
                    font-size: min(4.375vw, 30px);
                    text-align: left;
                    line-height: 1.5;
                    margin-top: 0; }
                  .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target03 .box div .small {
                    font-size: min(3.75vw, 21px);
                    margin-top: 0.4em; }
                .main .sec04 .wrap#target03 .inner .wrap02 .wrap03#new-target03 .box .imgbox02 {
                  width: 51%;
				  float: left;
				  padding-right: 10px;} }

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

					　　　　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: none;
      opacity: 0;
      transition: 0.1s; }
      .modal .modal-wrap img.active {
        opacity: 1;
        display: block; }
    .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); }
  .modal#modal2 .modal-wrap {
    max-height: calc(100vh - 140px);
    height: 90%; }
    .modal#modal2 .modal-wrap .scroll {
      width: 100%;
      height: 100%;
      overflow: scroll;
      display: block;
      position: relative; }
  .modal#modal2 #modal-close2 {
    position: absolute;
    right: 0;
    bottom: calc(100% + 10px);
    width: 40px;
    height: 40px;
    display: block;
    cursor: pointer; }
    .modal#modal2 #modal-close2::before, .modal#modal2 #modal-close2::after {
      content: '';
      position: absolute;
      top: 19px;
      left: 0;
      width: 100%;
      height: 2px;
      background: #fff;
      transform-origin: center; }
    .modal#modal2 #modal-close2::before {
      transform: rotate(45deg); }
    .modal#modal2 #modal-close2::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: #7d645d;*/
    padding: min(5.625vw,90px) 0 min(4vw,65px); }
    @media screen and (max-width: 767px) {
      .footer .bg {
        padding-top: 16vw; } }
    .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: #505f6a;
          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: #B39136; }
          .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.5em; }
          .footer .bg .inner .inquiry .tel::before {
            position: absolute;
            top: 50%;
            left: 0;
            transform: translateY(-40%);
            content: '';
            background: url(../img/tel2.webp) no-repeat center/contain;
            aspect-ratio: 7 / 4;
            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-bottom: 7em; } }
  /*@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: #505f6a;
          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: #B39136; }
          .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; }
  .outline p {
    font-size: min(16px);
    line-height: 1.8; }
  @media screen and (max-width: 767px) {
    .outline {
      margin-top: clamp(50px, 10vw, 70px); } }
  .outline .outlineList .estate_detail_outline_body_title {
    margin: 20px auto;
    font-weight: 500;
    font-size: 18px; }
    .outline .outlineList .estate_detail_outline_body_title P {
      font-size: 18px; }
  .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; }

/*概要_敷地面積の"～"*/
.tableSiteArea__item + .tableSiteArea__item::before {
  content: "\301C";
  display: block;
  /*position: absolute;
  left: 0;*/ }


.outline_link{
	display: flex;
    justify-content: center;
    margin-bottom: 50px;
}

.outline_link a{
    border: 1px solid #666;
    padding: 10px 80px;
    font-size: 1.2em;
    text-align: center;
    margin: 20px auto;
	background-color: #f7f6f3;
}

  @media screen and (max-width: 767px) {
.outline_link a{
    padding: 0.5em 2em;
}
.title3 p {
    font-size: 4.5vw;
}
}

.outline_link a:hover{
	background:#816B65;
 	color:#fff;
	transition : 0.7s;
}

.title3 p{
	text-align: center;
}

  @media screen and (min-width: 767px) {
.title3 p{
	font-size: 1.5vw;
}}

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

					　　　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: #7d645d;
        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;
        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;
          padding-top: 25px;}
          @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.i1e {
              background: url(../img/location-img01e.webp) no-repeat center/cover; }
            .location .sec .inner .flex .wrap .imgbox.i1f {
              background: url(../img/location-img01f.webp) no-repeat center/cover; }
            .location .sec .inner .flex .wrap .imgbox.i1g {
              background: url(../img/location-img01g.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; }

.trainaccess_index{
    font-size: 30px;
    font-family: "Zen Old Mincho", serif;
    border-bottom: solid;
    padding-bottom: 10px;
    margin: 100px 0 40px 0;
	text-align: start;
}

@media screen and (min-width: 767px) {
.trainaccess{
	display: flex;
	justify-content: center;
}

.train-left{
	width: 60%;
}

.trainaccess_index{
    font-size: 40px;
    font-family: "Zen Old Mincho", serif;
    border-bottom: solid;
    padding-bottom: 10px;
    margin: 100px 0 40px 0;
	text-align: start;
}
.train-right img{
	width: 90%;
}
}
	

.train-left{
	font-family: "Zen Old Mincho", serif;
}

p.train-text{
	text-align: left;
	margin-bottom: 40px;
	line-height: 1.5;
}

.train_time{
	text-align: left;
	line-height: 1.4;
}

.direct_line{
    display: flex;
	font-size: 30px;
	align-items: baseline;
}

@media screen and (max-width: 767px) {
.train-right img{
	margin-top: 40px;
	width: 100%;
}
}

.train_time_required{
	color: #9a696c;
	font-size: 40px;
}

.train_time_required span{
	color: #FFFFFF;
	background-color: #9a696c;
	padding: 2px 18px;
	font-size: 14px;
	margin: 0 10px 0 20px;
}

.direct_line span.sta{
	font-size: 20px;
}

.train_nanasato p,.train_omiya p{
	font-size: min(4.48vw, 17px);
	margin-top: 30px;
}

p.attention{
	font-size: 12px;
	text-align: left;
    padding-top: 20px;
}

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

					　　　　footer

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

footer {
  padding-top: 90px;
  position: relative; }
  @media screen and (max-width: 479px) {
    footer {
      padding-top: 50px; } }

  footer .footer_bottom {
    border-top: 1px solid #8a8180;
    padding-top: 72px; }
    /*@media screen and (max-width: 1044px) {
      footer .footer_bottom {
        padding-bottom: 60px; } }*/
    @media screen and (max-width: 479px) {
      footer .footer_bottom {
        margin-top: 50px;
        padding-top: 10px; } }
    @media screen and (max-width: 479px) {
      footer .footer_bottom .flex {
        display: block; } }

    footer .footer_bottom .flex .bunjo_navi {
      flex-basis: 20%; }

    @media screen and (max-width: 479px) {
    footer .footer_bottom .flex .bunjo_navi {
      padding-top: 30px; } }

@media screen and (min-width: 767px) {
      footer .footer_bottom .flex .bunjo_navi a {
        display: flex;
        align-items: center; }}

    footer .bg .data.fadeUpTrigger .flex .data {
      flex: 1;
      padding-right: 70px; }
      @media screen and (max-width: 479px) {
        footer .bg .data.fadeUpTrigger .flex .data {
          margin-top: 30px;
          padding-right: 0; } }

@media screen and (min-width: 767px) {
      footer .bg  .data.fadeUpTrigger .flex {
		display: flex;
        justify-content: flex-end; }}
        @media screen and (max-width: 479px) {
          footer .bg  .data.fadeUpTrigger .flex {
            display: flex; } }

        footer .bg  .data.fadeUpTrigger .flex .logo {
          flex-basis: 130px;
          /*margin-right: 50px;
          margin-left: 10%;*/ }
          @media screen and (max-width: 767px) {
            footer .bg  .data.fadeUpTrigger .flex .logo {
              /*flex-basis: 80px;
              margin-right: 30px;*/
			  display: none;} }

        footer .bg .data.fadeUpTrigger .flex .tel {
          text-align: center; }
          @media screen and (max-width: 479px) {
            footer .bg .data.fadeUpTrigger .flex .tel {
              flex: 1; } }

          footer .bg .data.fadeUpTrigger .flex .tel .md {
            font-size: 14px; }
            @media screen and (max-width: 479px) {
              footer .bg .data.fadeUpTrigger .flex .tel .md {
                font-size: 10px; } }

          footer .bg .data.fadeUpTrigger .flex .tel .sm {
            font-size: 12px; }

          footer .bg .data.fadeUpTrigger .flex .tel .num {
            font-size: 28px; }
            @media screen and (max-width: 479px) {
              footer .bg .data.fadeUpTrigger .flex .tel .num {
                font-size: 20px; } }

            footer .bg .data.fadeUpTrigger .flex .tel .num:before {
              content: "";
              width: 34px;
              height: 19px;
              background-image: url(../img/tel2.webp);
              background-position: center;
              background-repeat: no-repeat;
              background-size: contain;
              display: inline-block;
              margin-right: 5px; }
              @media screen and (max-width: 479px) {
                footer .bg .data.fadeUpTrigger .flex .tel .num:before {
                  width: 24px;
                  height: 14px; } }

@media screen and (min-width: 767px) {
      footer .bg .data.fadeUpTrigger .open {
        font-size: 14px;
        text-align: right;
        margin-top: 15px;
        width: 380px;}}
        @media screen and (max-width: 479px) {
          footer .bg .data.fadeUpTrigger .open {
            font-size: 10px; } }

  footer small {
    display: block;
    background-color: #b8c2c0;
    margin-top: 50px;
    text-align: center;
    padding: 10px; }


@media screen and (min-width: 767px) {
footer .footer_bottom .flex .bunjo_navi {
	width: 20%;
}}
@media screen and (max-width: 767px) {
footer .footer_bottom .flex .bunjo_navi img {
	width: 41vw;
}}

@media screen and (min-width: 767px) {
footer .bg .inner.inner1100.footer_bottom .flex{
	display: flex;
    justify-content: space-between;
}}
	
 @media screen and (max-width: 767px) {
            footer .bg  .data.fadeUpTrigger {
				padding-top: 40px;}}


/* 改行　*/
.br-sp {
  display: none;
}

@media screen and (max-width: 767px) {
  .br-pc {
    display: none;
  }

  .br-sp {
    display: inline-block;
  }
}
