@charset "UTF-8";
/*$bg-color01  : rgba(19,23,51,.05);
$bg-color02  : rgba(202,178,124,.15);*/
@import url("https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Roboto+Condensed:ital,wght@0,100..900;1,100..900&family=Roboto:ital,wght@0,100;0,300;0,400;0,500;0,700;0,900;1,100;1,300;1,400;1,500;1,700;1,900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&display=swap");
html {
  scroll-behavior: smooth;
  /* 任意 */
  scroll-padding-top: 5.5em;
  /* ヘッダー高さ */ }

section {
  scroll-margin-top: 5.5em;
  /* どちらかでもOK */ }

main {
  overflow: hidden; }
  main sup {
    color: red; }
  main a {
    display: inline-block;
    padding-right: 1.5em;
    box-sizing: border-box;
    position: relative;
    z-index: 1; }
    main a svg {
      width: 1em;
      border-color: #fff;
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      right: 0; }
      main a svg.blank {
        fill: none;
        stroke: currentcolor; }
  main .inner {
    width: 83.3333333333vw;
    max-width: 1200px;
    margin: 0 auto; }
  main .parallax {
    position: relative;
    width: 100%;
    height: 100%; }
    main .parallax .parallax-bg {
      position: fixed;
      top: 0;
      left: 0;
      width: 100vw;
      height: 100vh;
      z-index: -2; }
      main .parallax .parallax-bg img {
        display: none; }
  main .header {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    z-index: 99;
    width: fit-content;
    transition: all .3s ease; }
    main .header .inner {
      width: 93.8194444444vw;
      max-width: 1351px;
      padding: 2.5em 0;
      margin: 0 auto;
      display: flex;
      justify-content: space-between;
      align-items: center; }
      main .header .inner--logo h1 {
        width: 13.6111111111vw;
        max-width: 196px; }
      main .header .inner .contact {
        font-size: clamp(12px, 1.3888888889vw, 20px); }
        main .header .inner .contact a {
          transition: all .3s ease; }
          main .header .inner .contact a p {
            position: relative;
            padding-right: 2.5em; }
            main .header .inner .contact a p:after {
              content: '';
              display: block;
              position: absolute;
              width: 1.8em;
              height: 1.8em;
              background: url("../images/common/icon_arrow.svg") no-repeat center center/cover;
              top: 50%;
              right: 0;
              transform: translateY(-50%);
              transition: all .3s ease; }
          main .header .inner .contact a:hover p:after {
            right: -.5em; }
  main .footer--block {
    background-color: #fff;
    color: #6F7773;
    padding: 2.5em 0; }
    main .footer--block .inner {
      width: 76.3888888889vw;
      max-width: 1100px;
      display: flex;
      justify-content: space-between;
      align-items: center; }
      main .footer--block .inner .logo {
        width: 20.8333333333vw;
        max-width: 300px; }
      main .footer--block .inner--category {
        width: 70%;
        display: flex;
        justify-content: flex-end;
        align-items: center;
        font-size: clamp(11px, 0.9027777778vw, 13px);
        font-weight: 400; }
        main .footer--block .inner--category ul {
          display: flex; }
          main .footer--block .inner--category ul li:nth-of-type(n+2) {
            margin-left: 5em; }
          main .footer--block .inner--category ul li a {
            color: #6F7773;
            padding-right: 0; }
        main .footer--block .inner--category .copyright {
          margin-left: 5em; }

#pagetop {
  width: 3.4722222222vw;
  height: 3.4722222222vw;
  max-width: 50px;
  max-height: 50px;
  position: fixed;
  right: 1.5%;
  z-index: 200;
  /*&.is-inview{
      position: absolute;
  }*/ }
  #pagetop a {
    transition: all .3s ease;
    padding: 0; }
    #pagetop a:hover {
      opacity: 1;
      transform: scale(1.04); }

@media screen and (max-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none; } }
@media screen and (max-width: 767px) {
  html {
    scroll-padding-top: 4em; }

  section {
    scroll-margin-top: 4em; }

  main .inner {
    width: 90vw; }
  main .header .inner {
    width: 89.7435897436vw;
    padding: 1.5em 0; }
    main .header .inner--logo h1 {
      width: 50.2564102564vw; }
  main .footer--block {
    padding: 3.5em 0; }
    main .footer--block .inner {
      width: 84.6153846154vw;
      flex-direction: column; }
      main .footer--block .inner .logo {
        width: 76.9230769231vw; }
      main .footer--block .inner--category {
        width: 100%;
        justify-content: center;
        flex-direction: column;
        font-size: clamp(11px, 3.3333333333vw, 13px); }
        main .footer--block .inner--category ul {
          flex-direction: column; }
          main .footer--block .inner--category ul li {
            margin-top: 4em; }
            main .footer--block .inner--category ul li:nth-of-type(n+2) {
              margin: 2.5em auto 0; }
        main .footer--block .inner--category .copyright {
          margin: 2.5em auto 0; }

  #pagetop {
    width: 12.8205128205vw;
    height: 12.8205128205vw; } }
/* =========================================================
 * reset　　　    /*リセット
========================================================= */
blockquote, body, div, dl, dt, dd, fieldset, form, h1, h2, h3, h4, h5, h6, input, li, ol, p, pre, select, span, textarea, td, th, ul, figure, figcaption {
  margin: 0px;
  padding: 0px; }

fieldset, img {
  border: 0; }

h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  font-weight: bold; }

ol {
  list-style-type: none; }

ul {
  list-style-type: none; }
  ul li {
    list-style-type: none; }
    ul li img {
      line-height: 0;
      font-size: 0;
      vertical-align: top; }
  ul.decimal-list li {
    list-style-type: decimal;
    margin: .5em 0 0 1.5em; }
  ul.dot-list li {
    margin-top: .5em;
    padding-left: 1em;
    position: relative; }
    ul.dot-list li:before {
      content: "";
      display: block;
      position: absolute;
      width: .5em;
      height: .5em;
      border-radius: 50%;
      background-color: #EFFAF3;
      top: .7em;
      left: 0; }

img {
  border: none;
  vertical-align: bottom; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

caption, th {
  text-align: left; }

iframe {
  border: none; }

a:focus {
  outline: none; }

address, caption, cite, code, dfn, em, strong, th, var {
  font-style: normal;
  font-weight: normal; }

/* IE */
* html ul li dl, * html ol li dl {
  display: inline; }
*:first-child + html ul li dl, *:first-child + html ol li dl {
  display: inline; }

/* =========================================================
 * default settings      　   /*デフォルトセッティング 全体の設定
========================================================= */
* {
  box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  word-break: break-all;
  /*CJK (中国語、台湾語、日本語、韓国語) 以外のテキストにおいて、単語中などでの文字の改行に関する禁則処理を解除し、どの文字の間でも改行するようにします。*/ }

html, body {
  font-size: 62.5%;
  overflow: auto; }
  html.active, body.active {
    overflow: hidden; }

body {
  overflow: hidden;
  -webkit-text-size-adjust: 100%;
  font: inherit;
  font-size: clamp(12px, 1.0416666667vw, 15px);
  font-family: "Noto Sans JP", YuGothic, "Yu Gothic medium", "Yu Gothic", "Hiragino Sans", Meiryo, "sans-serif";
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: .2em;
  color: #FAF7F2;
  background: #fff; }

main {
  display: block; }

/*リンクテキスト全般の設定*/
a {
  width: 100%;
  height: 100%;
  padding-right: 0 !important;
  display: block !important;
  text-decoration: none;
  color: #fff;
  -webkit-transition: opacity 0.3s ease-out;
  -moz-transition: opacity 0.3s ease-out;
  -ms-transition: opacity 0.3s ease-out;
  transition: opacity 0.3s ease-out;
    /*&:hover{
		opacity: 0.7;
        -webkit-opacity: .7;
        -moz-opacity: .7;
        filter: alpha(opacity = 70);
        -ms-filter: "alpha(opacity=70)";
    }*/ }

.disabled {
  pointer-events: none; }

.soon {
  pointer-events: none;
  opacity: .5; }

.hide,
.hidden {
  visibility: hidden; }

/*テキスト周りのタグ*/
p {
  line-break: strict; }

.txt-center {
  text-align: center; }

/*画像全般の設定*/
img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
  border: none; }

/*videoタグ*/
video {
  max-width: 100%; }

/*iframeタグ*/
iframe {
  width: 100%; }

/*pointer;*/
.none-pointer {
  pointer-events: none; }

/*レスポンシブ切り替え表示の設定*/
.pc {
  display: block; }

.sp {
  display: none; }

/* =========================================================
 * modal
========================================================= */
.mfp-bg {
  background-color: rgba(0, 0, 0, 0.8);
  -webkit-transition: all 0.15s ease-out;
  -moz-transition: all 0.15s ease-out;
  transition: all 0.15s ease-out; }

.mfp-close {
  text-indent: -9999px;
  font-family: serif;
  font-size: 64px;
  right: -10px !important;
  padding-right: 0 !important;
  top: -50px !important; }

/* overlay animate in */
.mfp-bg.mfp-ready {
  opacity: 0.8; }

/* overlay animate out */
.mfp-bg.mfp-removing {
  opacity: 0; }

/* content at start */
.mfp-wrap .modal-content {
  transform: translateY(-30px);
  opacity: 0;
  -webkit-transition: all 0.3s ease-out;
  -moz-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out; }

/* content animate it */
.mfp-wrap.mfp-ready .modal-content {
  transform: translateY(0);
  opacity: 1; }

/* content animate out */
.mfp-wrap.mfp-removing .modal-content {
  transform: translateY(30px);
  opacity: 0; }

.mfp-iframe-holder .mfp-content {
  width: 125vmin !important;
  max-width: 90% !important; }

@media screen and (max-width: 767px) {
  /*.mfp-container{
  	padding: 0;
  }
  .modal-content{
  	max-width: 94%;
  	margin: 15vw auto;
  	.popup-modal-close{
  		cursor: pointer;
  		position: absolute;
  		right: 0;
  		top: -41px;
  		span{
  			img{
  				max-width: 31px;
  			}
  		}
  	}
  	&--inner{
  		background-color: #fff;
  		padding: 15px 5% 30px 5%;
  		.team{
  			p{
  				@include fz_vw(11);
  			}
  		}
  		.content{
  			margin-top: 20px;
  			h2{
  				letter-spacing: .04em;
  				@include fz_vw(16);
  			}
  			p{
  				margin-top: 20px;
  				@include fz_vw(12);
  			}
  		}
  		.contact{
  			margin-top: 30px;
  			p{
  				@include fz_vw(12);
  				a{
  					&.tel{
  						pointer-events: visible;
  						text-decoration: underline;
  					}
  				}
  			}
  		}
  	}
  }*/ }
@media screen and (max-width: 767px) {
  body {
    font-size: clamp(12px, 3.8461538462vw, 15px);
    -webkit-text-size-adjust: 100%;
    background: #fff;
    min-width: 100%; }

  /*リンクテキスト全般の設定*/
  a {
    -webkit-transition: none;
    -moz-transition: none;
    -ms-transition: none;
    transition: none; }
    a:hover {
      opacity: 1;
      -webkit-opacity: 1;
      -moz-opacity: 1;
      filter: alpha(opacity=100);
      /* IE lt 8 */
      -ms-filter: "alpha(opacity=100)";
      /* IE 8 */ }

  /*画像全般の設定*/
  img {
    width: 100%; }

  /*テキスト周りのタグ*/
  .att {
    font-size: 3vw !important;
    font-weight: 400;
    line-height: 1 !important;
    margin-bottom: 1em; }

  /*レスポンシブ切り替え表示の設定*/
  .pc {
    display: none; }

  .sp {
    display: block; } }
@media (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none; } }
@media all and (-ms-high-contrast: none) {
  .noise {
    display: none; } }
/* =========================================================
 * font
========================================================= */
/*Montserrat
*/
/*Roboto Condensed & Roboto*/
/*Noto Sans Japanese*/
.montserrat {
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-style: normal; }

.roboto-condensed {
  font-family: "Roboto Condensed", sans-serif;
  font-optical-sizing: auto;
  font-style: normal; }

.roboto {
  font-family: "Roboto", sans-serif;
  font-optical-sizing: auto; }

.noto-sans-jp {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal; }

.noto-serif-jp {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-style: normal; }

/* =========================================================
 * clearfix　　   /*クリアフィックス
========================================================= */
.clearfix {
  zoom: 1; }
  .clearfix:before {
    content: "";
    display: table; }
  .clearfix:after {
    content: "";
    display: table;
    clear: both; }

/* =========================================================
 * fade Animation　　   /*フェード アニメーション
========================================================= */
.fade,
.fadein,
.fadein-top,
.fadein-left,
.fadein-right,
.opening,
.fadein-popup {
  position: relative;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.875s ease-in-out , transform 0.875s ease-in-out; }

.fade {
  transform: translate(0, 0); }

.fadein {
  transform: translate(0, 50px); }

.fadein-top {
  transform: translate(0, -50px); }

.fadein-left {
  transform: translate(-50px, 0); }

.fadein-right {
  transform: translate(50px, 0); }

.fadein-popup {
  translate: none;
  rotate: none;
  scale: none;
  transform: translateY(20px) scale(0.8) !important;
  transition: opacity 0.5s ease-in-out , transform 0.5s ease-in-out; }

.fade.scrollin,
.fadein.scrollin,
.fadein-top.scrollin,
.fadein-left.scrollin,
.fadein-right.scrollin,
.opening.active {
  opacity: 1;
  visibility: visible;
  transform: translate(0, 0); }

.fadein-popup.scrollin {
  transform: translate(0, 0) scale(1) !important;
  animation: popup 0.55s cubic-bezier(0.22, 1, 0.36, 1) forwards; }

/* =========================================================
 * fade Animation　　   /*フェード アニメーション
========================================================= */
@keyframes topleft {
  0% {
    transform: translate(-50%, -50%); }
  100% {
    transform: translate(250%, 250%); } }
@keyframes topright {
  0% {
    transform: translate(50%, 50%); }
  100% {
    transform: translate(-100%, 200%); } }
@keyframes bottomleft {
  0% {
    transform: translate(-50%, -50%); }
  100% {
    transform: translate(150%, -250%); } }
@keyframes bottomright {
  0% {
    transform: translate(50%, 50%); }
  100% {
    transform: translate(-150%, 250%); } }
@keyframes popup {
  0% {
    opacity: 0; }
  80%, 100% {
    opacity: 1; } }
.fadein-topleft {
  animation: topleft 10s infinite linear 1s both; }

.fadein-topright {
  animation: topright 6.3s infinite linear 1s both; }

.fadein-topright02 {
  animation: topright 9.5s infinite linear 1s both; }

.fadein-bottomleft {
  animation: bottomleft 5.5s infinite linear 1s both; }

.fadein-bottomright {
  animation: bottomright 5.5s infinite linear 1s both; }

/* =========================================================
 * CSS Animation　　   /*CSS アニメション
========================================================= */
/*メインビジュのSCROLL*/
@keyframes arrow-move {
  0% {
    top: -100%; }
  50% {
    top: 0; }
  100% {
    top: 100%; } }
@-webkit-keyframes arrow-move {
  0% {
    top: -100%; }
  50% {
    top: 0; }
  100% {
    top: 100%; } }
@keyframes animationZoom {
  100% {
    transform: scale(1.1); } }
@keyframes slideshow {
  0% {
    opacity: 0;
    transform: scale(1.2, 1.2); }
  10% {
    opacity: 1;
    transform: scale(1, 1); }
  28% {
    opacity: 1;
    transform: scale(1, 1); }
  38% {
    opacity: 0;
    transform: scale(1, 1); }
  100% {
    opacity: 0;
    transform: scale(1, 1); } }
.top article {
  position: relative; }
  .top article .parallax-bg {
    background: #187545 url("../images/common/img_noise.png") no-repeat center center/cover; }
  .top article .gold {
    color: #9A9055; }
  .top article .en {
    font-family: "Montserrat", sans-serif;
    font-weight: 600; }
  .top article .uppercase {
    text-transform: uppercase; }
  .top article p {
    text-align: justify; }
  .top article .txt-right {
    text-align: right !important; }
  .top article .splide .splide__track {
    width: 100%;
    height: 100%; }
    .top article .splide .splide__track .splide__list .splide__slide {
      position: relative;
      transition: opacity 4000ms cubic-bezier(0.25, 1, 0.5, 1) !important; }
      .top article .splide .splide__track .splide__list .splide__slide img {
        max-width: inherit;
        height: 100%; }
  .top article .btn-pdf {
    overflow: hidden;
    width: 17em;
    border-radius: 5em;
    margin: 5em auto 0;
    font-size: clamp(16px, 1.3888888889vw, 20px); }
    .top article .btn-pdf a {
      background-color: #fff;
      padding: 1em;
      transition: all .3s ease; }
      .top article .btn-pdf a p {
        width: fit-content;
        position: relative;
        font-weight: bold;
        text-align: center;
        color: #187545;
        padding-right: 2.5em;
        margin: 0 auto; }
        .top article .btn-pdf a p:after {
          content: '';
          display: block;
          position: absolute;
          width: 1.5em;
          height: 1.8em;
          background: url("../images/common/icon_pdf.svg") no-repeat center center/cover;
          top: 50%;
          right: 0;
          transform: translateY(-50%);
          transition: all .3s ease; }
      .top article .btn-pdf a:hover {
        background-color: #187545; }
        .top article .btn-pdf a:hover P {
          color: #fff; }
        .top article .btn-pdf a:hover:after {
          right: -.5em; }
  .top article .btn-more {
    overflow: hidden;
    width: 18em;
    border: 1px solid #187545;
    border-radius: 5em;
    margin: 2.5em auto 0;
    font-size: clamp(16px, 1.1111111111vw, 16px); }
    .top article .btn-more a {
      color: #187545;
      background-color: #fff;
      padding: 1.1em;
      transition: all .3s ease; }
      .top article .btn-more a p {
        width: fit-content;
        position: relative;
        text-align: center;
        padding-right: 2.5em;
        margin: 0 auto; }
        .top article .btn-more a p:after {
          content: '';
          display: block;
          position: absolute;
          width: 1.6em;
          height: 1.6em;
          background: url("../images/common/icon_arrow-green.svg") no-repeat center center/cover;
          top: 50%;
          right: 0;
          transform: translateY(-50%);
          transition: all .3s ease; }
      .top article .btn-more a:hover {
        color: #fff;
        background-color: #187545; }
        .top article .btn-more a:hover p:after {
          background: url("../images/common/icon_arrow.svg") no-repeat center center/cover;
          right: -.5em; }
  .top article .contact {
    font-size: clamp(12px, 1.3888888889vw, 20px); }
    .top article .contact a {
      transition: all .3s ease; }
      .top article .contact a p {
        position: relative;
        padding-right: 2.5em; }
        .top article .contact a p:after {
          content: '';
          display: block;
          position: absolute;
          width: 1.8em;
          height: 1.8em;
          background: url("../images/common/icon_arrow.svg") no-repeat center center/cover;
          top: 50%;
          right: 0;
          transform: translateY(-50%);
          transition: all .3s ease; }
      .top article .contact a:hover p:after {
        right: -.5em; }
  .top article .contact-bnr {
    background-color: #EFFAF3;
    border-radius: 2em;
    padding: 2.5em 0;
    margin-top: 8.5em; }
    .top article .contact-bnr h2 {
      font-size: clamp(20px, 2.2222222222vw, 32px);
      text-align: center;
      color: #135233; }
    .top article .contact-bnr .contact {
      overflow: hidden;
      width: 17em;
      border-radius: 5em;
      margin: 1em auto 0; }
      .top article .contact-bnr .contact a {
        background-color: #01CA60;
        padding: 1em; }
        .top article .contact-bnr .contact a p {
          text-align: center;
          padding-right: 1.5em; }
          .top article .contact-bnr .contact a p:after {
            right: 2em; }
        .top article .contact-bnr .contact a:hover {
          background-color: #009444; }
          .top article .contact-bnr .contact a:hover p:after {
            right: 1.5em; }
    .top article .contact-bnr .tel {
      display: flex;
      justify-content: center;
      align-items: center;
      color: #135233;
      margin-top: 1.5em; }
      .top article .contact-bnr .tel .texts {
        font-size: clamp(12px, 0.9027777778vw, 18px);
        font-weight: 400;
        position: relative;
        padding-left: 2em; }
        .top article .contact-bnr .tel .texts:after {
          content: '';
          display: block;
          position: absolute;
          width: 1.4em;
          height: 1.4em;
          background: url("../images/common/icon_tel.svg") no-repeat center center/cover;
          top: 50%;
          left: 0;
          transform: translateY(-50%); }
      .top article .contact-bnr .tel .number {
        font-size: clamp(16px, 1.3888888889vw, 20px);
        line-height: 1;
        letter-spacing: .1em;
        margin: 0 .3em; }
        .top article .contact-bnr .tel .number a {
          color: #135233;
          position: relative;
          padding-left: 2em; }
          .top article .contact-bnr .tel .number a:after {
            content: '';
            display: block;
            position: absolute;
            width: 1.4em;
            height: 1.4em;
            background: url("../images/common/icon_tel.svg") no-repeat center center/cover;
            top: 50%;
            left: 0;
            transform: translateY(-50%); }
      .top article .contact-bnr .tel .time {
        font-size: clamp(11px, 0.9722222222vw, 14px);
        font-weight: 400; }
  .top article .main {
    width: 100vw;
    height: 62.5vw;
    max-height: 900px;
    position: relative; }
    .top article .main:before {
      content: "";
      display: block;
      position: absolute;
      background: url("../images/common/img_noise.png") no-repeat center center/cover;
      width: 100%;
      height: 100%; }
    .top article .main .splide {
      width: 93.8194444444vw;
      height: 55.9027777778vw;
      max-width: 1351px;
      max-height: 805px;
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      /*.splide__track{
          width: 100%;
          height: 100%;
          .splide__list{
              .splide__slide{
                  position: relative;
                  transition: opacity 4000ms cubic-bezier(0.25, 1, 0.5, 1)!important;
                  img{
                      max-width: inherit;
                      height: 100%;
                  }
              }
          }
      }*/ }
    .top article .main .inner {
      width: 93.8194444444vw;
      height: 100%;
      max-width: 1351px;
      position: relative;
      z-index: 2; }
      .top article .main .inner--title {
        position: absolute;
        bottom: 2em;
        left: 2.5%; }
        .top article .main .inner--title h2 {
          font-size: clamp(26px, 2.9166666667vw, 42px);
          line-height: 1.6;
          margin-top: .5em; }
        .top article .main .inner--title h3 {
          font-size: clamp(18px, 2.0833333333vw, 30px); }
      .top article .main .inner .contact {
        position: absolute;
        top: 2.5em;
        right: 0; }
      .top article .main .inner .scroll {
        position: absolute;
        top: 72.5%;
        right: 2.5%;
        transform: translateY(-50%);
        z-index: 9;
        font-size: clamp(9px, 0.7638888889vw, 11px);
        line-height: 1;
        letter-spacing: .1em;
        text-transform: uppercase;
        writing-mode: sideways-lr;
        /* 縦書きにする */
        text-align: left; }
        .top article .main .inner .scroll--inner {
          position: relative; }
          .top article .main .inner .scroll--inner span {
            box-sizing: border-box;
            font-feature-settings: normal;
            display: inline;
            box-sizing: border-box; }
          .top article .main .inner .scroll--inner .bar {
            width: 2px;
            height: 10em;
            margin: 1em auto 0;
            overflow: hidden;
            position: absolute;
            top: 4em;
            left: 50%;
            transform: translateX(-50%); }
            .top article .main .inner .scroll--inner .bar:before {
              content: '';
              display: block;
              position: absolute;
              width: 1px;
              height: 100%;
              top: 0;
              left: 50%;
              border-left: 1px solid #fff;
              transform: translateX(-50%);
              -webkit-animation: arrow-move 2.2s 0.5s ease-in-out infinite;
              animation: arrow-move 2.2s 0.5s ease-in-out infinite; }
  .top article .container {
    width: 100vw;
    padding-bottom: 8.5em;
    margin-top: 8.5em;
    position: relative; }
    .top article .container:before, .top article .container:after {
      content: "";
      display: block;
      position: absolute;
      width: 100%;
      height: 100%;
      top: 0;
      left: 50%;
      transform: translateX(-50%);
      z-index: -1; }
    .top article .container .splide {
      width: 83.3333333333vw;
      height: 31.25vw;
      max-width: 1200px;
      max-height: 450px; }
    .top article .container.container01 {
      overflow: hidden;
      border-bottom-left-radius: 10em;
      border-bottom-right-radius: 10em;
      z-index: 2; }
      .top article .container.container01:before {
        background: url("../images/top/img_bg01.png") no-repeat center 0/cover;
        top: 12.5%; }
      .top article .container.container01 .inner--wrap--category {
        display: flex;
        justify-content: space-around;
        margin-top: 8.2em; }
        .top article .container.container01 .inner--wrap--category .image {
          width: 54.5%; }
        .top article .container.container01 .inner--wrap--category--texts {
          width: 32%; }
          .top article .container.container01 .inner--wrap--category--texts h2 {
            font-size: clamp(30px, 3.3333333333vw, 48px);
            letter-spacing: .3em;
            white-space: nowrap;
            position: relative;
            margin-top: .3em; }
          .top article .container.container01 .inner--wrap--category--texts p {
            line-height: 2.2;
            letter-spacing: .05em;
            margin-top: 5em; }
        .top article .container.container01 .inner--wrap--category:nth-of-type(odd) {
          flex-direction: row-reverse; }
        .top article .container.container01 .inner--wrap--category:nth-of-type(even) {
          flex-direction: row; }
          .top article .container.container01 .inner--wrap--category:nth-of-type(even) .inner--wrap--category--texts h2 {
            right: 57.5%; }
    .top article .container.container02 {
      padding: 17em 0;
      margin-top: -8.5em; }
      .top article .container.container02:before {
        height: 147.9166666667vw;
        background: url("../images/top/img_bg02.png") no-repeat center top/cover; }
      .top article .container.container02:after {
        background: #135233 url("../images/common/img_noise.png") repeat center center;
        z-index: -2; }
      .top article .container.container02 .inner .catchphrase {
        font-size: clamp(30px, 2.9166666667vw, 42px);
        line-height: 1.6;
        text-align: center;
        margin-top: 2.5em; }
      .top article .container.container02 .inner--block--wrap {
        margin-top: 8.5em; }
        .top article .container.container02 .inner--block--wrap--title h2,
        .top article .container.container02 .inner--block--wrap--title p {
          text-align: center; }
        .top article .container.container02 .inner--block--wrap--title h2 {
          font-size: clamp(30px, 2.2222222222vw, 32px); }
        .top article .container.container02 .inner--block--wrap--title p {
          font-size: clamp(42px, 4.4444444444vw, 64px); }
          .top article .container.container02 .inner--block--wrap--title p.lead {
            font-size: clamp(22px, 2.0833333333vw, 30px);
            line-height: 2;
            margin-top: 2.5em; }
        .top article .container.container02 .inner--block--wrap--category {
          background-color: #FAF7F2;
          border-radius: 2.5em;
          padding: 5em 5em 7.5em;
          margin-top: 5em; }
          .top article .container.container02 .inner--block--wrap--category--content:nth-of-type(n+2) {
            border-top: 1px solid #d8d8d8;
            padding-top: 5em;
            margin-top: 5em; }
          .top article .container.container02 .inner--block--wrap--category--content--title {
            color: #135233; }
            .top article .container.container02 .inner--block--wrap--category--content--title h3,
            .top article .container.container02 .inner--block--wrap--category--content--title p {
              text-align: center; }
            .top article .container.container02 .inner--block--wrap--category--content--title h3 {
              font-size: clamp(20px, 1.9444444444vw, 28px); }
            .top article .container.container02 .inner--block--wrap--category--content--title p {
              font-size: clamp(30px, 2.9166666667vw, 42px); }
              .top article .container.container02 .inner--block--wrap--category--content--title p.comment {
                font-size: clamp(16px, 1.3888888889vw, 20px);
                margin-top: 1em; }
          .top article .container.container02 .inner--block--wrap--category--content .figure {
            margin-top: 2.5em; }
          .top article .container.container02 .inner--block--wrap--category--content--box {
            display: flex;
            justify-content: space-between;
            flex-wrap: wrap; }
            .top article .container.container02 .inner--block--wrap--category--content--box .map {
              width: 29.2%;
              margin-top: 5em;
              order: 2; }
            .top article .container.container02 .inner--block--wrap--category--content--box .price {
              width: 67.6%;
              margin-top: 5em;
              order: 1; }
            .top article .container.container02 .inner--block--wrap--category--content--box .comment {
              width: 100%;
              font-size: clamp(12px, 0.9722222222vw, 14px);
              margin-top: 1em;
              color: #135233;
              order: 3; }
            .top article .container.container02 .inner--block--wrap--category--content--box .option {
              width: 100%;
              order: 4; }
              .top article .container.container02 .inner--block--wrap--category--content--box .option--title {
                color: #135233;
                display: flex;
                align-items: center;
                margin-top: 3.5em; }
                .top article .container.container02 .inner--block--wrap--category--content--box .option--title h4 {
                  font-size: clamp(16px, 1.1111111111vw, 16px);
                  margin-left: 1em; }
                .top article .container.container02 .inner--block--wrap--category--content--box .option--title p {
                  font-size: clamp(24px, 1.6666666667vw, 24px);
                  letter-spacing: .05em; }
              .top article .container.container02 .inner--block--wrap--category--content--box .option--wrap {
                display: flex;
                flex-wrap: wrap;
                margin-top: 1em; }
                .top article .container.container02 .inner--block--wrap--category--content--box .option--wrap--info {
                  overflow: hidden;
                  display: flex;
                  align-items: center;
                  width: 30.5%;
                  font-size: clamp(14px, 0.9722222222vw, 14px);
                  letter-spacing: .05em;
                  text-align: center;
                  color: #2E2D29;
                  background-color: #fff;
                  border: 1px solid #d8d8d8;
                  border-radius: .5em;
                  margin: 1em 4.25% 0 0; }
                  .top article .container.container02 .inner--block--wrap--category--content--box .option--wrap--info:nth-of-type(3n) {
                    margin-right: 0; }
                  .top article .container.container02 .inner--block--wrap--category--content--box .option--wrap--info dt {
                    width: 55%;
                    height: 100%;
                    font-feature-settings: "palt";
                    background-color: #d8d8d8;
                    padding: 1em 0; }
                  .top article .container.container02 .inner--block--wrap--category--content--box .option--wrap--info dd {
                    width: 45%; }
                    .top article .container.container02 .inner--block--wrap--category--content--box .option--wrap--info dd span {
                      font-size: clamp(16px, 1.1111111111vw, 16px);
                      font-family: "Montserrat", sans-serif; }
          .top article .container.container02 .inner--block--wrap--category--content.use-info {
            display: flex;
            justify-content: space-between;
            flex-wrap: wrap;
            color: #135233; }
            .top article .container.container02 .inner--block--wrap--category--content.use-info h4,
            .top article .container.container02 .inner--block--wrap--category--content.use-info table,
            .top article .container.container02 .inner--block--wrap--category--content.use-info p {
              font-size: clamp(24px, 1.6666666667vw, 24px); }
            .top article .container.container02 .inner--block--wrap--category--content.use-info h4 {
              width: 100%; }
            .top article .container.container02 .inner--block--wrap--category--content.use-info p {
              font-weight: bold;
              letter-spacing: .05em;
              margin-top: 1em; }
              .top article .container.container02 .inner--block--wrap--category--content.use-info p span {
                font-family: "Montserrat", sans-serif; }
            .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box {
              width: 47%; }
              .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box dl {
                font-size: clamp(16px, 1.1111111111vw, 16px); }
                .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box dl dt {
                  margin-top: 1.5em; }
                  .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box dl dt span {
                    display: inline-block;
                    background-color: #187545;
                    color: #EFFAF3;
                    border-radius: .5em;
                    padding: .5em 1em; }
                .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box dl dd {
                  padding-left: 1em;
                  margin-top: 1.5em; }
              .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table {
                width: 100%;
                margin-top: 1em; }
                .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tbody,
                .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tfoot {
                  width: 100%; }
                  .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tbody tr,
                  .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tfoot tr {
                    width: 100%; }
                    .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tbody tr th,
                    .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tbody tr td,
                    .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tfoot tr th,
                    .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tfoot tr td {
                      font-weight: bold;
                      letter-spacing: .05em;
                      padding: .3em 0; }
                      .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tbody tr th span,
                      .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tbody tr td span,
                      .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tfoot tr th span,
                      .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tfoot tr td span {
                        font-family: "Montserrat", sans-serif; }
                    .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tbody tr th,
                    .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tfoot tr th {
                      width: 50%;
                      padding-left: 1em !important; }
                    .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tbody tr td,
                    .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tfoot tr td {
                      width: 40%;
                      text-align: right;
                      padding-right: 1.5em !important; }
                .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tbody tr:last-of-type th,
                .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tbody tr:last-of-type td {
                  padding: 0 0 .8em; }
                .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tfoot {
                  border-top: 1px solid #135233;
                  padding-top: 1.5em;
                  margin-top: 1.5em; }
                  .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tfoot tr:first-of-type th,
                  .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tfoot tr:first-of-type td {
                    padding: .8em 0; }
                  .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tfoot tr th {
                    text-align: right; }
              .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box .map {
                width: 75%;
                margin: 2.5em auto 0; }
          .top article .container.container02 .inner--block--wrap--category--content.meeting-room .inner--block--wrap--category--content--box--info {
            width: 47%;
            margin-top: 5em;
            /*.image{
                width: 46.6%;
                margin-top: 5em;
            }*/ }
            .top article .container.container02 .inner--block--wrap--category--content.meeting-room .inner--block--wrap--category--content--box--info .map {
              width: 75%;
              margin: 2.5em auto 0; }
            .top article .container.container02 .inner--block--wrap--category--content.meeting-room .inner--block--wrap--category--content--box--info .texts {
              /*width: 47.2%;
              margin-top: 5em;*/ }
              .top article .container.container02 .inner--block--wrap--category--content.meeting-room .inner--block--wrap--category--content--box--info .texts h4 {
                color: #135233;
                font-size: clamp(20px, 1.6666666667vw, 24px); }
              .top article .container.container02 .inner--block--wrap--category--content.meeting-room .inner--block--wrap--category--content--box--info .texts .comment {
                font-size: clamp(13px, 1.1111111111vw, 16px);
                margin-top: 1em; }
            .top article .container.container02 .inner--block--wrap--category--content.meeting-room .inner--block--wrap--category--content--box--info ul li {
              font-size: clamp(14px, 1.25vw, 18px);
              line-height: 1;
              text-align: center;
              color: #fff;
              background-color: #187545;
              border-radius: 1em;
              padding: 1em;
              margin-top: 2.5em; }
              .top article .container.container02 .inner--block--wrap--category--content.meeting-room .inner--block--wrap--category--content--box--info ul li:nth-of-type(n+2) {
                margin-top: 1em; }
              .top article .container.container02 .inner--block--wrap--category--content.meeting-room .inner--block--wrap--category--content--box--info ul li span {
                font-size: clamp(22px, 1.9444444444vw, 28px); }
          .top article .container.container02 .inner--block--wrap--category--content.meeting-room .inner--block--wrap--category--content--box .notice {
            display: flex;
            justify-content: space-between;
            flex-wrap: wrap; }
            .top article .container.container02 .inner--block--wrap--category--content.meeting-room .inner--block--wrap--category--content--box .notice dl {
              width: 47.5%;
              color: #135233;
              display: flex;
              justify-content: space-between;
              align-items: flex-start;
              flex-wrap: wrap;
              letter-spacing: 0;
              margin-top: 3.5em; }
              .top article .container.container02 .inner--block--wrap--category--content.meeting-room .inner--block--wrap--category--content--box .notice dl dt {
                width: 20%;
                font-size: clamp(13px, 1.1111111111vw, 16px);
                text-align: center;
                border: 1px solid #135233;
                padding: 1em .5em; }
              .top article .container.container02 .inner--block--wrap--category--content.meeting-room .inner--block--wrap--category--content--box .notice dl dd {
                width: 75%; }
                .top article .container.container02 .inner--block--wrap--category--content.meeting-room .inner--block--wrap--category--content--box .notice dl dd p {
                  margin-top: .5em; }
                  .top article .container.container02 .inner--block--wrap--category--content.meeting-room .inner--block--wrap--category--content--box .notice dl dd p span {
                    display: block;
                    text-indent: -1em;
                    padding-left: 1em; }
        .top article .container.container02 .inner--block--wrap.wrap03 .inner--block--wrap--pictures {
          display: flex;
          justify-content: space-between;
          flex-wrap: wrap; }
          .top article .container.container02 .inner--block--wrap.wrap03 .inner--block--wrap--pictures--category {
            width: 30.2%;
            margin-top: 5em; }
            .top article .container.container02 .inner--block--wrap.wrap03 .inner--block--wrap--pictures--category p {
              font-size: clamp(18px, 1.25vw, 18px);
              text-align: center;
              margin-top: 1em; }
      .top article .container.container02 .inner .notice {
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap; }
        .top article .container.container02 .inner .notice dl {
          width: 48%;
          color: #C6CBCA;
          display: flex;
          justify-content: space-between;
          align-items: flex-start;
          flex-wrap: wrap;
          letter-spacing: 0;
          margin-top: 5em; }
          .top article .container.container02 .inner .notice dl dt {
            width: 20%;
            font-size: clamp(13px, 1.1111111111vw, 16px);
            text-align: center;
            border: 1px solid #C6CBCA;
            padding: 1em .5em; }
          .top article .container.container02 .inner .notice dl dd {
            width: 75%; }
            .top article .container.container02 .inner .notice dl dd p {
              margin-top: .5em; }
              .top article .container.container02 .inner .notice dl dd p span {
                display: block;
                text-indent: -1em;
                padding-left: 1em; }
    .top article .container.container03 {
      overflow: hidden;
      background: #EFFAF3 url("../images/common/img_noise.png") repeat center center;
      border-top-left-radius: 10em;
      border-top-right-radius: 10em;
      padding: 0 0 17em;
      margin-top: -8.5em; }
      .top article .container.container03 .inner--block--wrap {
        color: #135233;
        margin-top: 5em; }
        .top article .container.container03 .inner--block--wrap--title h2,
        .top article .container.container03 .inner--block--wrap--title p {
          text-align: center; }
        .top article .container.container03 .inner--block--wrap--title h2 {
          font-size: clamp(30px, 2.2222222222vw, 32px); }
        .top article .container.container03 .inner--block--wrap--title p {
          font-size: clamp(42px, 4.4444444444vw, 64px); }
        .top article .container.container03 .inner--block--wrap--category--content {
          display: flex;
          justify-content: space-around;
          flex-direction: row-reverse;
          margin-top: 5em; }
          .top article .container.container03 .inner--block--wrap--category--content .image {
            width: 54.5%; }
          .top article .container.container03 .inner--block--wrap--category--content--texts {
            width: 32%; }
            .top article .container.container03 .inner--block--wrap--category--content--texts h3 {
              font-size: clamp(30px, 3.3333333333vw, 48px);
              letter-spacing: .3em;
              white-space: nowrap;
              position: relative;
              margin-top: .3em; }
            .top article .container.container03 .inner--block--wrap--category--content--texts p {
              line-height: 2.2;
              letter-spacing: .05em;
              margin-top: 5em; }
            .top article .container.container03 .inner--block--wrap--category--content--texts .btn-pdf a p {
              line-height: 1;
              letter-spacing: .2em;
              margin-top: 0; }
    .top article .container.container04 {
      overflow: hidden;
      background: #eee url("../images/common/img_noise.png") repeat center center;
      border-top-left-radius: 10em;
      border-top-right-radius: 10em;
      margin-top: -8.5em; }
      .top article .container.container04 .inner--block--wrap {
        color: #135233;
        margin-top: 5em; }
        .top article .container.container04 .inner--block--wrap--title h2,
        .top article .container.container04 .inner--block--wrap--title p {
          text-align: center; }
        .top article .container.container04 .inner--block--wrap--title h2 {
          font-size: clamp(30px, 2.2222222222vw, 32px); }
        .top article .container.container04 .inner--block--wrap--title p {
          font-size: clamp(42px, 4.4444444444vw, 64px); }
          .top article .container.container04 .inner--block--wrap--title p.lead {
            font-size: clamp(22px, 2.0833333333vw, 30px);
            line-height: 2;
            margin-top: 2.5em; }
        .top article .container.container04 .inner--block--wrap--lead h3,
        .top article .container.container04 .inner--block--wrap--lead p {
          text-align: center; }
        .top article .container.container04 .inner--block--wrap--lead h3 {
          font-size: clamp(28px, 1.9444444444vw, 28px);
          margin-top: 2em; }
        .top article .container.container04 .inner--block--wrap--lead p {
          font-size: clamp(16px, 1.25vw, 18px);
          line-height: 1.8;
          margin-top: 1em; }
        .top article .container.container04 .inner--block--wrap--category .image {
          margin-top: 5em; }
        .top article .container.container04 .inner--block--wrap--category h4 {
          font-size: clamp(18px, 1.5277777778vw, 22px);
          text-align: center;
          margin-top: 4em; }
        .top article .container.container04 .inner--block--wrap--category .btn-more a p {
          line-height: 1;
          margin-top: 0; }

@media screen and (max-width: 767px) {
  .top article .btn-pdf {
    font-size: clamp(16px, 4.1025641026vw, 20px); }
    .top article .btn-pdf a {
      padding: 1.3em 1em; }
  .top article .btn-more {
    font-size: clamp(16px, 4.1025641026vw, 16px); }
  .top article .contact {
    font-size: clamp(14px, 4.6153846154vw, 20px); }
  .top article .contact-bnr {
    margin-top: 4em; }
    .top article .contact-bnr h2 {
      font-size: clamp(20px, 5.1282051282vw, 32px); }
    .top article .contact-bnr .contact {
      width: 15em; }
      .top article .contact-bnr .contact a {
        padding: 1em .5em; }
        .top article .contact-bnr .contact a p:after {
          right: 1em; }
    .top article .contact-bnr .tel {
      flex-direction: column; }
      .top article .contact-bnr .tel .texts {
        font-size: clamp(13px, 3.3333333333vw, 18px); }
      .top article .contact-bnr .tel .number {
        font-size: clamp(16px, 6.1538461538vw, 24px);
        margin: .5em 0 0; }
      .top article .contact-bnr .tel .time {
        font-size: clamp(11px, 3.8461538462vw, 15px);
        margin-top: 1em; }
  .top article .main {
    width: 100vw;
    height: 217.9487179487vw;
    max-height: inherit; }
    .top article .main .splide {
      width: 89.7435897436vw;
      height: 150.5128205128vw;
      top: 37.5%;
      left: 50%; }
    .top article .main .inner {
      width: 89.7435897436vw; }
      .top article .main .inner--title {
        top: 77.5%;
        bottom: inherit;
        left: 2.5%; }
        .top article .main .inner--title h2 {
          font-size: clamp(22px, 6.6666666667vw, 42px); }
        .top article .main .inner--title h3 {
          font-size: clamp(17px, 4.6153846154vw, 30px); }
      .top article .main .inner .contact {
        top: 148.7179487179vw; }
      .top article .main .inner .scroll {
        top: 40%;
        font-size: clamp(9px, 2.8205128205vw, 11px); }
  .top article .container {
    padding-bottom: 5em;
    margin-top: 5em; }
    .top article .container .splide {
      width: 89.7435897436vw;
      height: 60.7692307692vw; }
    .top article .container.container01 {
      border-bottom-left-radius: 5em;
      border-bottom-right-radius: 5em;
      margin-top: 0; }
      .top article .container.container01:before {
        background: url("../images/top/img_bg01_sp.png") no-repeat center 30.7692307692vw/cover; }
      .top article .container.container01 .inner--wrap--category {
        flex-direction: column !important;
        margin-top: 4em; }
        .top article .container.container01 .inner--wrap--category .image {
          width: 100%; }
        .top article .container.container01 .inner--wrap--category--texts {
          width: 100%; }
          .top article .container.container01 .inner--wrap--category--texts h2 {
            font-size: clamp(27px, 7.6923076923vw, 48px);
            letter-spacing: .05em;
            text-align: center;
            white-space: normal;
            margin-top: 1em; }
          .top article .container.container01 .inner--wrap--category--texts p {
            margin-top: 2em; }
        .top article .container.container01 .inner--wrap--category:nth-of-type(even) .inner--wrap--category--texts h2 {
          right: inherit; }
    .top article .container.container02 {
      padding: 10em 0;
      margin-top: -5em; }
      .top article .container.container02:before {
        display: none; }
      .top article .container.container02 .inner .catchphrase {
        font-size: clamp(24px, 7.6923076923vw, 42px); }
      .top article .container.container02 .inner--block--wrap {
        margin-top: 5em; }
        .top article .container.container02 .inner--block--wrap--title h2 {
          font-size: clamp(24px, 7.6923076923vw, 32px); }
        .top article .container.container02 .inner--block--wrap--title p {
          font-size: clamp(34px, 10.7692307692vw, 64px);
          letter-spacing: 0; }
          .top article .container.container02 .inner--block--wrap--title p.lead {
            font-size: clamp(18px, 5.641025641vw, 30px);
            line-height: 1.6;
            letter-spacing: .1em;
            margin-top: 1.5em; }
        .top article .container.container02 .inner--block--wrap--category {
          padding: 2.5em 1.5em 5em;
          margin-top: 2.5em; }
          .top article .container.container02 .inner--block--wrap--category--content--title h3 {
            font-size: clamp(16px, 5.1282051282vw, 28px); }
          .top article .container.container02 .inner--block--wrap--category--content--title p {
            font-size: clamp(24px, 7.6923076923vw, 42px);
            letter-spacing: .02em; }
            .top article .container.container02 .inner--block--wrap--category--content--title p.comment {
              font-size: clamp(13px, 4.1025641026vw, 20px); }
          .top article .container.container02 .inner--block--wrap--category--content .figure {
            margin-top: 2.5em; }
          .top article .container.container02 .inner--block--wrap--category--content--box .map {
            width: 100%;
            margin-top: 2.5em;
            order: 1; }
          .top article .container.container02 .inner--block--wrap--category--content--box .price {
            width: 100%;
            margin-top: 2.5em;
            overflow-x: scroll;
            overflow-y: hidden !important;
            scrollbar-height: auto;
            padding-bottom: 1em;
            order: 2; }
            .top article .container.container02 .inner--block--wrap--category--content--box .price img {
              width: 200vw;
              max-width: inherit;
              height: auto; }
            .top article .container.container02 .inner--block--wrap--category--content--box .price::-webkit-scrollbar {
              height: .5em; }
            .top article .container.container02 .inner--block--wrap--category--content--box .price::-webkit-scrollbar-track {
              border-radius: .5em;
              background-color: #eee; }
            .top article .container.container02 .inner--block--wrap--category--content--box .price::-webkit-scrollbar-thumb {
              background-color: #009944;
              border-radius: .5em; }
          .top article .container.container02 .inner--block--wrap--category--content--box .comment {
            font-size: clamp(11px, 3.0769230769vw, 14px); }
          .top article .container.container02 .inner--block--wrap--category--content--box .option {
            width: 100%; }
            .top article .container.container02 .inner--block--wrap--category--content--box .option--title h4,
            .top article .container.container02 .inner--block--wrap--category--content--box .option--title p {
              letter-spacing: 0; }
            .top article .container.container02 .inner--block--wrap--category--content--box .option--title h4 {
              font-size: clamp(13px, 4.1025641026vw, 16px); }
            .top article .container.container02 .inner--block--wrap--category--content--box .option--title p {
              font-size: clamp(19px, 6.1538461538vw, 24px); }
            .top article .container.container02 .inner--block--wrap--category--content--box .option--wrap--info {
              width: 100%;
              font-size: clamp(11px, 3.5897435897vw, 14px);
              margin: 1em 0 0; }
              .top article .container.container02 .inner--block--wrap--category--content--box .option--wrap--info dd span {
                font-size: clamp(13px, 4.1025641026vw, 16px); }
          .top article .container.container02 .inner--block--wrap--category--content.use-info h4,
          .top article .container.container02 .inner--block--wrap--category--content.use-info p {
            font-size: clamp(16px, 5.641025641vw, 24px);
            letter-spacing: .05em; }
          .top article .container.container02 .inner--block--wrap--category--content.use-info h4 {
            line-height: 1.8;
            text-align: justify; }
          .top article .container.container02 .inner--block--wrap--category--content.use-info p {
            font-size: clamp(16px, 4.6153846154vw, 24px);
            text-align: center; }
          .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box {
            width: 100%; }
            .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box dl {
              width: 100%;
              font-size: clamp(14px, 3.5897435897vw, 16px);
              text-align: center; }
              .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box dl dd {
                padding-left: 0; }
            .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table {
              width: 100%;
              font-size: clamp(13px, 4.1025641026vw, 24px); }
              .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tbody tr th,
              .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tfoot tr th {
                width: 60%;
                padding-left: 1em !important; }
              .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tbody tr td,
              .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tfoot tr td {
                width: 35%;
                text-align: right;
                padding-right: 1.5em !important; }
              .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box table tfoot tr th {
                padding-right: 1em !important; }
            .top article .container.container02 .inner--block--wrap--category--content.use-info .inner--block--wrap--category--content--box .map {
              width: 100%; }
          .top article .container.container02 .inner--block--wrap--category--content.meeting-room .inner--block--wrap--category--content--box--info {
            width: 100%;
            margin-top: 2.5em; }
            .top article .container.container02 .inner--block--wrap--category--content.meeting-room .inner--block--wrap--category--content--box--info .map {
              width: 100%;
              margin: 2.5em auto 0; }
            .top article .container.container02 .inner--block--wrap--category--content.meeting-room .inner--block--wrap--category--content--box--info .texts h4 {
              font-size: clamp(14px, 4.6153846154vw, 24px);
              letter-spacing: .05em;
              text-align: center; }
            .top article .container.container02 .inner--block--wrap--category--content.meeting-room .inner--block--wrap--category--content--box--info .texts .comment {
              font-size: clamp(13px, 3.3333333333vw, 16px);
              letter-spacing: 0;
              text-align: center; }
            .top article .container.container02 .inner--block--wrap--category--content.meeting-room .inner--block--wrap--category--content--box--info ul li {
              font-size: clamp(14px, 4.6153846154vw, 18px);
              line-height: 1.8; }
              .top article .container.container02 .inner--block--wrap--category--content.meeting-room .inner--block--wrap--category--content--box--info ul li span {
                font-size: clamp(22px, 7.1794871795vw, 28px);
                margin-top: .5em; }
          .top article .container.container02 .inner--block--wrap--category--content.meeting-room .inner--block--wrap--category--content--box .notice dl {
            width: 100%;
            margin-top: 3.5em; }
            .top article .container.container02 .inner--block--wrap--category--content.meeting-room .inner--block--wrap--category--content--box .notice dl dt {
              width: 100%;
              font-size: clamp(13px, 4.1025641026vw, 16px); }
            .top article .container.container02 .inner--block--wrap--category--content.meeting-room .inner--block--wrap--category--content--box .notice dl dd {
              width: 100%;
              margin-top: 1em; }
        .top article .container.container02 .inner--block--wrap.wrap03 .inner--block--wrap--pictures--category {
          width: 100%;
          margin-top: 3.5em; }
          .top article .container.container02 .inner--block--wrap.wrap03 .inner--block--wrap--pictures--category p {
            font-size: clamp(16px, 4.6153846154vw, 18px); }
      .top article .container.container02 .inner .notice dl {
        width: 100%; }
        .top article .container.container02 .inner .notice dl:nth-of-type(n+2) {
          margin-top: 3.5em; }
        .top article .container.container02 .inner .notice dl dt {
          width: 100%;
          font-size: clamp(13px, 4.1025641026vw, 16px); }
        .top article .container.container02 .inner .notice dl dd {
          width: 100%;
          margin-top: 1em; }
    .top article .container.container03 {
      border-top-left-radius: 5em;
      border-top-right-radius: 5em;
      padding: 0 0 10em;
      margin-top: -5em; }
      .top article .container.container03 .inner--block--wrap {
        color: #135233;
        margin-top: 5em; }
        .top article .container.container03 .inner--block--wrap--title h2 {
          font-size: clamp(24px, 7.6923076923vw, 32px); }
        .top article .container.container03 .inner--block--wrap--title p {
          font-size: clamp(34px, 10.7692307692vw, 64px); }
        .top article .container.container03 .inner--block--wrap--category--content {
          flex-direction: column !important;
          margin-top: 4em; }
          .top article .container.container03 .inner--block--wrap--category--content .image {
            width: 100%; }
          .top article .container.container03 .inner--block--wrap--category--content--texts {
            width: 100%; }
            .top article .container.container03 .inner--block--wrap--category--content--texts h3 {
              font-size: clamp(24px, 7.6923076923vw, 48px);
              letter-spacing: .3em;
              text-align: center;
              margin-top: 1em; }
            .top article .container.container03 .inner--block--wrap--category--content--texts p {
              margin-top: 2.5em; }
    .top article .container.container04 {
      border-top-left-radius: 5em;
      border-top-right-radius: 5em;
      padding: 0 0 5em;
      margin-top: -5em; }
      .top article .container.container04 .inner--block--wrap {
        margin-top: 5em; }
        .top article .container.container04 .inner--block--wrap--title h2 {
          font-size: clamp(24px, 7.6923076923vw, 32px); }
        .top article .container.container04 .inner--block--wrap--title p {
          font-size: clamp(34px, 10.7692307692vw, 64px); }
          .top article .container.container04 .inner--block--wrap--title p.lead {
            font-size: clamp(18px, 5.641025641vw, 30px);
            margin-top: 2em; }
        .top article .container.container04 .inner--block--wrap--lead h3 {
          font-size: clamp(22px, 7.1794871795vw, 28px);
          margin-top: 2em; }
        .top article .container.container04 .inner--block--wrap--lead p {
          font-size: clamp(14px, 4.1025641026vw, 18px);
          line-height: 1.8;
          margin-top: 1em; }
        .top article .container.container04 .inner--block--wrap--category .image {
          margin-top: 3.5em; }
        .top article .container.container04 .inner--block--wrap--category h4 {
          font-size: clamp(14px, 4.6153846154vw, 22px);
          line-height: 1.8;
          text-align: justify;
          margin-top: 2em; } }
