@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=EB+Garamond:ital,wght@0,400..800;1,400..800&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Shippori+Mincho+B1:wght@400;500;600;700;800&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: 80vw;
    max-width: 1152px;
    margin: 0 auto; }
  main .parallax {
    position: relative;
    width: 100%;
    height: 100%;
    clip-path: inset(0 0 0 0); }
    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: fixed;
    z-index: 99;
    width: 100%;
    transition: all .3s ease; }
    main .header .inner {
      width: 92.5%;
      max-width: inherit;
      padding: 2em 0;
      margin: 0 auto;
      display: flex;
      justify-content: space-between;
      align-items: center; }
      main .header .inner--logo h1 {
        width: 9.375vw;
        max-width: 135px; }
  main .footer--block {
    background-color: #5F5935;
    padding: 2em 0; }
    main .footer--block .inner {
      display: flex;
      justify-content: space-between;
      align-items: center; }
      main .footer--block .inner .logo {
        width: fit-content; }
        main .footer--block .inner .logo .symbol {
          width: 3.8194444444vw;
          max-width: 55px;
          margin: 0 auto; }
        main .footer--block .inner .logo p {
          font-size: clamp(26px, 2.2222222222vw, 32px);
          text-align: center;
          margin-top: .3em; }
          main .footer--block .inner .logo p em {
            display: block;
            font-size: clamp(12px, 1.0416666667vw, 15px); }
      main .footer--block .inner--category {
        width: 85%; }
        main .footer--block .inner--category ul {
          display: flex;
          font-size: clamp(11px, 0.9027777778vw, 13px); }
          main .footer--block .inner--category ul li:nth-of-type(n+2) {
            margin-left: 5em; }
        main .footer--block .inner--category .copyright {
          font-size: clamp(12px, 0.9722222222vw, 14px);
          color: #fff;
          margin-top: 2.5em; }

#pagetop {
  width: 3.8194444444vw;
  height: 3.8194444444vw;
  max-width: 55px;
  max-height: 55px;
  position: fixed;
  right: 0;
  bottom: 0;
  z-index: 200; }
  #pagetop a {
    line-height: 1;
    letter-spacing: 0;
    text-align: center;
    color: #fff;
    background-color: #9D4332;
    transition: all .3s ease;
    padding: 0; }
    #pagetop a p {
      white-space: nowrap;
      padding-bottom: .25em;
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%); }
    #pagetop a:hover {
      opacity: 1;
      transform: scale(1.04); }
  #pagetop.is-inview {
    position: absolute; }

@media screen and (max-width: 767px) {
  html {
    scroll-padding-top: 4em; }

  section {
    scroll-margin-top: 4em; }

  main .inner {
    width: 100vw; }
  main .header .inner {
    width: 95vw;
    padding: 1em 0; }
    main .header .inner--logo h1 {
      width: 30.7692307692vw;
      max-width: 120px; }
  main .footer--block {
    padding: 2em 0; }
    main .footer--block .inner {
      width: 92.5vw;
      flex-direction: column; }
      main .footer--block .inner .logo {
        width: fit-content;
        margin: 3em auto 0;
        padding-right: 0; }
        main .footer--block .inner .logo .symbol {
          width: 18.4615384615vw;
          max-width: 72px; }
        main .footer--block .inner .logo p {
          font-size: clamp(26px, 10.5128205128vw, 41px); }
          main .footer--block .inner .logo p em {
            font-size: clamp(12px, 5.1282051282vw, 20px); }
      main .footer--block .inner--category {
        width: 95%; }
        main .footer--block .inner--category ul {
          justify-content: center;
          flex-direction: column;
          font-size: clamp(11px, 3.8461538462vw, 15px); }
          main .footer--block .inner--category ul li {
            text-align: center;
            margin-top: 3em; }
            main .footer--block .inner--category ul li a {
              display: inline-block;
              width: fit-content; }
            main .footer--block .inner--category ul li:nth-of-type(n+2) {
              margin-left: 0; }
        main .footer--block .inner--category .copyright {
          font-size: clamp(10px, 3.0769230769vw, 14px);
          letter-spacing: -.02em;
          text-align: center;
          margin-top: 3.5em; }

  #pagetop {
    width: 14.1025641026vw;
    height: 14.1025641026vw; } }
/* =========================================================
 * 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: normal; }

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: #AA9F5E;
      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(14px, 1.1111111111vw, 16px);
  font-family: "Shippori Mincho B1", "Noto Serif JP", serif, YuGothic, "Yu Gothic medium", "Yu Gothic", "Hiragino Sans", Meiryo, "sans-serif";
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: .05em;
  font-feature-settings: "palt";
  /*日本語フォントの文字間隔（カーニング）全角スペースを詰める調整、句読点や括弧などの約物を含めた文字間をしっかり詰めてくれます。*/
  color: #fff;
  background: #fff; }

main {
  display: block; }

/*リンクテキスト全般の設定*/
a {
  width: 100%;
  height: 100%;
  display: block;
  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, 16px);
    -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
========================================================= */
/*EB Garamond*/
/*CShippori Mincho B1*/
/*Roboto Condensed & Roboto*/
/*Noto Sans Japanese*/
.eb-garamond {
  font-family: "EB Garamond", serif;
  font-optical-sizing: auto;
  font-style: normal; }

.shippori-mincho-b1 {
  font-family: "Shippori Mincho B1", serif;
  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; }

/* =========================================================
 * scrollbar　　   /*フスクロールバー
========================================================= */
::-webkit-scrollbar {
  /* Chrome, Safari 対応 */
  display: none;
  -webkit-appearance: none;
  -ms-overflow-style: none;
  /* IE, Edge 対応 */
  scrollbar-width: none;
  /* Firefox 対応 */ }

/*垂直方向のスクロールバーに適用*/
/*::-webkit-scrollbar:horizontal {
    display: none;
    -webkit-appearance: none;
}*/
/*水平方向のスクロールバーに適用*/
/*::-webkit-scrollbar:vertical {
    display: none;
    -webkit-appearance: none;
}*/
/* =========================================================
 * 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); } }
/* =========================================================
 * js Animation　　   /*jS アニメーション
========================================================= */
/*1文字ずつ出現させるためのCSS*/
.eachTextAnime {
  display: inline-flex;
  opacity: 0; }
  .eachTextAnime span {
    opacity: 0; }
  .eachTextAnime.appeartext {
    animation: text_anime_on 2s ease-in-out forwards; }
    .eachTextAnime.appeartext span {
      animation: text_anime_on 2s ease-in-out forwards; }

@keyframes text_anime_on {
  0% {
    opacity: 0;
    transform: translate3d(0, 0, 0); }
  50% {
    opacity: 0;
    transform: translate3d(0, 0, 0); }
  70% {
    opacity: 0.5;
    transform: translate3d(0, -10px, 0); }
  100% {
    opacity: 1;
    transform: translate3d(0, 0, 0); } }
.top .bnr-entry {
  position: fixed;
  top: 0;
  bottom: inherit;
  right: 0;
  z-index: 999; }
  .top .bnr-entry a {
    background-color: #067569;
    padding: 1em 1.5em; }
    .top .bnr-entry a dl {
      text-align: center; }
      .top .bnr-entry a dl dt {
        font-size: clamp(13px, 1.25vw, 18px);
        letter-spacing: .3em;
        color: #AA9F5E; }
      .top .bnr-entry a dl dd {
        font-size: clamp(16px, 1.3888888889vw, 20px);
        margin-top: .5em; }
  .top .bnr-entry.page-bnr {
    opacity: 1;
    transition: all .3s ease; }
    .top .bnr-entry.page-bnr.is-inview {
      display: none;
      opacity: 0; }
  .top .bnr-entry.main-bnr {
    position: absolute;
    top: inherit;
    bottom: 0; }
    .top .bnr-entry.main-bnr a {
      padding: 2em; }
      .top .bnr-entry.main-bnr a dl {
        text-align: center; }
        .top .bnr-entry.main-bnr a dl dt {
          font-size: clamp(40px, 3.125vw, 45px);
          letter-spacing: .05em;
          color: #AA9F5E; }
          .top .bnr-entry.main-bnr a dl dt em {
            display: block;
            font-size: clamp(19px, 1.5277777778vw, 22px); }
        .top .bnr-entry.main-bnr a dl dd {
          font-size: clamp(24px, 1.875vw, 27px);
          margin-top: .5em; }
.top article {
  position: relative; }
  .top article .parallax-bg {
    background: #23573D url("../images/top/img_bg01.jpg") no-repeat center center/cover; }
  .top article .en {
    font-family: "EB Garamond", serif; }
  .top article .uppercase {
    text-transform: uppercase; }
  .top article .bnr-container {
    background: #23573D url("../images/top/img_bg03.jpg") no-repeat center 30%/cover;
    /*.parallax-bg{
        background: $maincolor url("../images/top/img_bg03.jpg")no-repeat center center/cover;
    }*/ }
  .top article .btn {
    padding: 3em 0;
    font-size: clamp(19px, 1.6666666667vw, 24px);
    line-height: 1;
    letter-spacing: .2em;
    text-align: center; }
    .top article .btn a {
      display: inline-block;
      width: fit-content;
      background-color: #1C4348;
      padding: 1em 5em;
      transition: all .3s ease; }
      .top article .btn a:hover {
        color: #fff;
        background-color: #067569 !important; }
    .top article .btn.more a {
      position: relative; }
      .top article .btn.more a:before, .top article .btn.more a:after {
        content: '';
        display: block;
        position: absolute;
        background-color: #23573D;
        top: 50%;
        right: 3.5em;
        transform: translateY(-50%);
        transition: all .3s ease; }
      .top article .btn.more a:before {
        width: 1em;
        height: 1px;
        margin-right: 3px; }
      .top article .btn.more a:after {
        width: 5px;
        height: 5px;
        clip-path: polygon(0 0, 0% 100%, 100% 50%); }
      .top article .btn.more a:hover {
        color: #fff !important; }
        .top article .btn.more a:hover:before, .top article .btn.more a:hover:after {
          background-color: #fff; }
  .top article .main {
    width: 100vw;
    height: 100vh;
    min-height: 900px;
    max-height: 900px;
    position: relative; }
    .top article .main .notice {
      position: absolute;
      bottom: 2.5vh;
      left: 56%;
      width: 24.6527777778vw;
      max-width: 355px; }
      .top article .main .notice dt {
        font-size: clamp(12px, 1.0416666667vw, 15px);
        line-height: 1;
        text-align: center;
        border: 1px solid #fff;
        padding: .3em; }
      .top article .main .notice dd {
        font-size: clamp(10px, 0.7638888889vw, 12px);
        letter-spacing: 0;
        text-align: justify;
        margin-top: .5em; }
    .top article .main .inner {
      width: 100%;
      max-width: 1440px;
      position: relative; }
      .top article .main .inner .splide {
        width: 77.0833333333vw;
        height: 78.3vh;
        max-width: 1110px;
        min-height: 705px;
        max-height: 705px;
        clip-path: polygon(0 0, 100% 0, 100% 100%, 41% 100%, 41% 90%, 0 90%);
        margin: 0 0 0 auto;
        position: relative; }
        .top article .main .inner .splide h4 {
          position: absolute;
          top: 54%;
          right: 15%;
          transform: translateY(-50%);
          z-index: 9; }
        .top article .main .inner .splide .splide__track {
          width: 100%;
          height: 100%; }
          .top article .main .inner .splide .splide__track .splide__list .splide__slide {
            position: relative;
            transition: opacity 4000ms cubic-bezier(0.25, 1, 0.5, 1) !important; }
            .top article .main .inner .splide .splide__track .splide__list .splide__slide:before, .top article .main .inner .splide .splide__track .splide__list .splide__slide:after {
              content: "";
              display: block;
              position: absolute;
              mix-blend-mode: multiply;
              opacity: .7;
              z-index: 1; }
            .top article .main .inner .splide .splide__track .splide__list .splide__slide:before {
              width: 40%;
              height: 100%;
              background-image: linear-gradient(90deg, #1B423E, transparent); }
            .top article .main .inner .splide .splide__track .splide__list .splide__slide:after {
              width: 100%;
              height: 10%;
              background-image: linear-gradient(0deg, #1B423E, transparent);
              bottom: 0;
              right: 0; }
            .top article .main .inner .splide .splide__track .splide__list .splide__slide img {
              max-width: inherit;
              height: 100%; }
            .top article .main .inner .splide .splide__track .splide__list .splide__slide p {
              width: 59%;
              font-size: clamp(11px, 0.9027777778vw, 13px);
              padding: 1.5em 3em;
              position: absolute;
              bottom: 0;
              right: 0;
              z-index: 2; }
      .top article .main .inner--title {
        position: absolute;
        top: 70%;
        left: 5%;
        transform: translateY(-50%); }
        .top article .main .inner--title h2 {
          font-size: clamp(40px, 5.1388888889vw, 74px);
          letter-spacing: 0; }
          .top article .main .inner--title h2 em {
            display: block;
            font-size: clamp(40px, 3.4722222222vw, 50px);
            margin-top: .5em; }
            .top article .main .inner--title h2 em span {
              font-size: clamp(48px, 4.1666666667vw, 60px); }
        .top article .main .inner--title h3 {
          font-size: clamp(38px, 3.3333333333vw, 48px);
          margin: -.5em 0 0 2.5em; }
          .top article .main .inner--title h3 .en {
            font-size: clamp(48px, 4.0277777778vw, 58px); }
        .top article .main .inner--title p {
          display: block;
          font-size: clamp(40px, 3.4722222222vw, 50px);
          margin-top: .5em; }
          .top article .main .inner--title p .en {
            font-size: clamp(48px, 4.1666666667vw, 60px); }
        .top article .main .inner--title .symbol {
          width: 5.9027777778vw;
          max-width: 85px;
          margin-top: 10.8em; }
      .top article .main .inner .scroll {
        position: absolute;
        top: 82.5%;
        right: 5%;
        transform: translateY(-50%);
        z-index: 9;
        font-size: clamp(16px, 1.3888888889vw, 20px);
        line-height: 1;
        letter-spacing: .1em;
        writing-mode: vertical-rl;
        /* 縦書きにする */
        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: 6em;
            overflow: hidden;
            position: absolute;
            top: -6.5em;
            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;
    max-width: 1440px;
    position: relative;
    margin: 5em auto 0; }
    .top article .container:before {
      content: '';
      display: block;
      position: absolute;
      width: 27.0833333333vw;
      max-width: 390px;
      height: 27.0833333333vw;
      max-height: 390px;
      z-index: -1; }
    .top article .container p {
      text-align: justify; }
    .top article .container .txt-right {
      text-align: right !important; }
    .top article .container .image {
      position: relative; }
      .top article .container .image p {
        position: absolute;
        font-size: clamp(88px, 7.6388888889vw, 110px);
        line-height: 1;
        color: #AA9F5E;
        top: 50%;
        left: -3.4em;
        transform: translateY(-50%); }
      .top article .container .image .comment {
        position: absolute;
        display: flex;
        align-items: center;
        bottom: -2em; }
        .top article .container .image .comment dt {
          font-size: clamp(11px, 0.9027777778vw, 13px);
          margin-right: 1.5em; }
        .top article .container .image .comment dd {
          font-size: clamp(10px, 0.8333333333vw, 12px); }
      .top article .container .image .links {
        margin-top: 1em; }
        .top article .container .image .links a {
          display: inline-block; }
          .top article .container .image .links a .comment {
            right: 1.5em;
            bottom: -.6em; }
      .top article .container .image.center {
        margin: 0 auto; }
      .top article .container .image.i02-1 .comment {
        left: 7em; }
      .top article .container .image.i02-2 {
        width: 71.8%;
        margin: 0 0 0 auto; }
        .top article .container .image.i02-2 .comment {
          right: 8em; }
      .top article .container .image.i02-3 {
        width: 64.1%;
        margin: 0 auto 0 0; }
        .top article .container .image.i02-3 .comment {
          bottom: 0;
          right: -11em; }
      .top article .container .image.i03-1-1:before, .top article .container .image.i03-2-1:before, .top article .container .image.i03-3-1:before {
        content: '';
        display: block;
        position: absolute;
        width: 22.2222222222vw;
        max-width: 320px;
        height: 22.2222222222vw;
        max-height: 320px;
        z-index: -1;
        background-color: #AA9F5E;
        opacity: .3; }
      .top article .container .image.i03-1-1:before {
        top: -11.1111111111vw;
        left: -11.1111111111vw; }
      .top article .container .image.i03-1-2 {
        left: 2em; }
      .top article .container .image.i03-2-1:before {
        bottom: -10.4166666667vw;
        right: -10.4166666667vw; }
      .top article .container .image.i03-2-2 {
        width: 53.1% !important;
        right: 5em; }
      .top article .container .image.i03-3-1:before {
        width: 18.8888888889vw;
        max-width: 272px;
        height: 18.8888888889vw;
        max-height: 272px;
        bottom: -9.4444444444vw;
        left: -9.4444444444vw; }
      .top article .container .image.i03-3-2 {
        width: 59.5% !important;
        left: 14em; }
        .top article .container .image.i03-3-2 .comment {
          right: 0; }
    .top article .container .inner--title {
      color: #AA9F5E;
      padding: 5em 0;
      position: relative; }
      .top article .container .inner--title:before {
        content: '';
        display: block;
        position: absolute;
        width: 0.4166666667vw;
        height: 14.4444444444vw;
        background: url("../images/common/img_treat.svg") no-repeat center center/cover;
        top: 50%;
        transform: translateY(-50%); }
      .top article .container .inner--title dt {
        font-size: clamp(56px, 4.8611111111vw, 70px);
        letter-spacing: .07em;
        white-space: nowrap; }
      .top article .container .inner--title dd {
        font-size: clamp(19px, 1.6666666667vw, 24px);
        letter-spacing: .4em;
        padding-top: 1em;
        margin-top: .5em;
        position: relative; }
        .top article .container .inner--title dd:before {
          content: '';
          display: block;
          position: absolute;
          width: 100vw;
          border: 0.5px solid #AA9F5E;
          top: 0; }
    .top article .container .inner--wrap--category {
      display: flex;
      justify-content: space-between;
      align-items: center;
      flex-wrap: wrap;
      margin-top: 7.5em; }
      .top article .container .inner--wrap--category .image {
        width: 47.5%; }
      .top article .container .inner--wrap--category--texts {
        width: 47.5%; }
        .top article .container .inner--wrap--category--texts h2 {
          font-size: clamp(40px, 3.4722222222vw, 50px);
          margin-bottom: 1em; }
        .top article .container .inner--wrap--category--texts h3 {
          font-size: clamp(26px, 2.2222222222vw, 32px);
          letter-spacing: 0; }
          .top article .container .inner--wrap--category--texts h3 em {
            font-size: clamp(106px, 9.1666666667vw, 132px);
            font-style: italic;
            letter-spacing: -.02em;
            display: inline-block;
            margin-top: -.7em; }
        .top article .container .inner--wrap--category--texts p {
          line-height: 2.2;
          margin-top: 1em; }
      .top article .container .inner--wrap--category:nth-of-type(even) {
        flex-direction: row-reverse; }
        .top article .container .inner--wrap--category:nth-of-type(even) .inner--wrap--category--texts {
          width: fit-content;
          margin: 0 auto; }
    .top article .container.container01:before {
      background-color: #AA9F5E;
      opacity: .3;
      bottom: 5em;
      right: -10.7638888889vw; }
    .top article .container.container01 .inner--title:before {
      left: -3em; }
    .top article .container.container01 .inner--title dd {
      left: 18em; }
      .top article .container.container01 .inner--title dd:before {
        left: 0; }
    .top article .container.container02:before {
      background-color: #067569;
      opacity: .5;
      top: 0;
      left: -6.25vw; }
    .top article .container.container02 .inner--title {
      text-align: right;
      margin-right: 30%; }
      .top article .container.container02 .inner--title:before {
        right: -3em; }
      .top article .container.container02 .inner--title dd {
        right: 11em; }
        .top article .container.container02 .inner--title dd:before {
          right: 0; }
    .top article .container.container02 .container--wrap--category {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-top: 2.5em; }
      .top article .container.container02 .container--wrap--category .image {
        width: 47.5%; }
      .top article .container.container02 .container--wrap--category--texts {
        width: 47.5%; }
        .top article .container.container02 .container--wrap--category--texts h3 {
          font-size: clamp(26px, 2.2222222222vw, 32px); }
          .top article .container.container02 .container--wrap--category--texts h3 em {
            font-size: clamp(107px, 9.3055555556vw, 134px);
            font-style: italic;
            display: inline-block;
            margin-top: -.7em; }
        .top article .container.container02 .container--wrap--category--texts p {
          line-height: 2;
          margin-top: 1em; }
      .top article .container.container02 .container--wrap--category:nth-of-type(even) {
        flex-direction: row-reverse; }
        .top article .container.container02 .container--wrap--category:nth-of-type(even) .inner--wrap--category--texts {
          width: fit-content;
          margin: 0 auto; }
    .top article .container.container03 {
      padding-bottom: 7.5em;
      margin-top: 7.5em; }
      .top article .container.container03 .inner--title {
        margin-left: 24.6%; }
        .top article .container.container03 .inner--title:before {
          left: -3em; }
        .top article .container.container03 .inner--title dd {
          left: 20em; }
          .top article .container.container03 .inner--title dd:before {
            left: 0; }
      .top article .container.container03 .inner--wrap--category:first-of-type {
        margin-top: 2.5em; }
      .top article .container.container03 .inner--wrap--category .image {
        width: 47.5%; }
    .top article .container.container04 {
      max-width: inherit;
      margin-top: 10em; }
      .top article .container.container04 .parallax-bg {
        background: url("../images/top/img_bg02.jpg") no-repeat center 85%/cover; }
      .top article .container.container04 .container04--block {
        padding: 10em 0; }
        .top article .container.container04 .container04--block .inner {
          width: 65.9722222222vw; }
          .top article .container.container04 .container04--block .inner .title {
            text-align: center; }
            .top article .container.container04 .container04--block .inner .title h2 {
              display: inline-block;
              font-size: clamp(54px, 3.75vw, 54px);
              padding-bottom: .8em;
              position: relative; }
              .top article .container.container04 .container04--block .inner .title h2:after {
                content: '';
                display: block;
                position: absolute;
                width: .1em;
                height: 1.7em;
                background: url("../images/common/img_treat.svg") no-repeat center center/cover;
                bottom: -.7em;
                left: 50%;
                transform: rotate(-90deg) translateX(-50%); }
            .top article .container.container04 .container04--block .inner .title h3 {
              font-size: clamp(26px, 2.2222222222vw, 32px);
              margin-top: 1.2em; }
            .top article .container.container04 .container04--block .inner .title p {
              line-height: 2.2;
              text-align: center;
              margin-top: 2em; }
            .top article .container.container04 .container04--block .inner .title .ttl {
              font-size: clamp(43px, 3.75vw, 54px);
              line-height: 1;
              text-align: center;
              margin-top: 0; }
              .top article .container.container04 .container04--block .inner .title .ttl em {
                display: block;
                font-size: clamp(56px, 4.8611111111vw, 70px);
                letter-spacing: .1em; }
          .top article .container.container04 .container04--block .inner--wrap {
            /* 既存の .js-floor-map（各マップブロック）に対して“ビューア化” */ }
            .top article .container.container04 .container04--block .inner--wrap h4 {
              font-size: clamp(24px, 2.0833333333vw, 30px);
              line-height: 1;
              text-align: center;
              margin-top: 2.5em; }
              .top article .container.container04 .container04--block .inner--wrap h4 span {
                display: inline-block;
                border: solid #fff;
                border-width: 1px 0;
                padding: .5em; }
            .top article .container.container04 .container04--block .inner--wrap .image {
              margin-top: 5em; }
            .top article .container.container04 .container04--block .inner--wrap .mapViewer {
              font-size: clamp(26px, 2.2222222222vw, 32px);
              margin-top: 2.5em;
              padding-bottom: 2.5em;
              position: relative;
              width: 100%;
              /* Panzoomのviewport（中央の白枠） */
              /* 下部コントローラ */ }
              .top article .container.container04 .container04--block .inner--wrap .mapViewer .map-container {
                position: relative;
                overflow: hidden;
                height: 63.5897435897vw;
                /*任意*/
                background-color: #fff;
                touch-action: none; }
                .top article .container.container04 .container04--block .inner--wrap .mapViewer .map-container.map01 {
                  height: 66.6666666667vw; }
                .top article .container.container04 .container04--block .inner--wrap .mapViewer .map-container--inner {
                  width: 100%;
                  height: 100%;
                  position: absolute;
                  top: 0;
                  left: 0;
                  transform-origin: 0 0; }
                  .top article .container.container04 .container04--block .inner--wrap .mapViewer .map-container--inner img,
                  .top article .container.container04 .container04--block .inner--wrap .mapViewer .map-container--inner canvas {
                    display: block;
                    position: absolute;
                    top: 0;
                    left: 0;
                    max-width: none;
                    /* img{max-width:100%}対策 */ }
              .top article .container.container04 .container04--block .inner--wrap .mapViewer .scale {
                display: flex;
                gap: 1.5em;
                position: absolute;
                bottom: 0;
                left: 50%;
                transform: translateX(-50%);
                z-index: 3;
                /* 丸ボタン（.mapBtn が無い場合でも既存ボタンに適用） */ }
                .top article .container.container04 .container04--block .inner--wrap .mapViewer .scale button {
                  cursor: pointer;
                  width: 2em;
                  height: 2em;
                  font-size: clamp(26px, 2.2222222222vw, 32px);
                  line-height: 1;
                  color: #fff;
                  border-radius: 50%;
                  background: rgba(0, 0, 0, 0.15);
                  border: 2px solid rgba(255, 255, 255, 0.85);
                  display: grid;
                  place-items: center;
                  -webkit-tap-highlight-color: transparent; }
                  .top article .container.container04 .container04--block .inner--wrap .mapViewer .scale button:disabled {
                    opacity: .35;
                    cursor: not-allowed; }
        .top article .container.container04 .container04--block.block01 {
          position: relative; }
          .top article .container.container04 .container04--block.block01 .parallax-bg {
            background: url("../images/top/img_bg02.jpg") no-repeat center 5%/cover; }
          .top article .container.container04 .container04--block.block01 .label {
            position: absolute;
            font-size: clamp(194px, 16.8055555556vw, 242px);
            writing-mode: vertical-rl;
            /* 縦書きにする */
            color: #AA9F5E;
            opacity: .4; }
            .top article .container.container04 .container04--block.block01 .label.label01 {
              top: 0;
              left: -.35em; }
            .top article .container.container04 .container04--block.block01 .label.label02 {
              bottom: .1em;
              right: -.5em; }
        .top article .container.container04 .container04--block.block02 {
          padding-bottom: 0; }
          .top article .container.container04 .container04--block.block02 .inner .ttl {
            font-size: clamp(147px, 12.7777777778vw, 184px); }
          .top article .container.container04 .container04--block.block02 .inner h3 {
            margin-top: .5em; }
        .top article .container.container04 .container04--block.block03 .inner .ttl {
          letter-spacing: .1em; }
        .top article .container.container04 .container04--block.block03 .inner h3 {
          margin-top: .5em; }
        .top article .container.container04 .container04--block.block03 .inner--wrap table {
          width: 100%;
          margin-top: 3em; }
          .top article .container.container04 .container04--block.block03 .inner--wrap table tr {
            border-top: 1px solid #fff; }
            .top article .container.container04 .container04--block.block03 .inner--wrap table tr:last-of-type {
              border-bottom: 1px solid #fff; }
            .top article .container.container04 .container04--block.block03 .inner--wrap table tr th,
            .top article .container.container04 .container04--block.block03 .inner--wrap table tr td {
              padding: 1em 2em; }
            .top article .container.container04 .container04--block.block03 .inner--wrap table tr td p {
              margin-top: .5em; }
              .top article .container.container04 .container04--block.block03 .inner--wrap table tr td p span {
                display: block;
                text-indent: -1em;
                padding-left: 1em;
                text-align: justify;
                font-size: clamp(11px, 0.8333333333vw, 12px); }
        .top article .container.container04 .container04--block.block03 .inner .btn {
          padding-bottom: 0; }
          .top article .container.container04 .container04--block.block03 .inner .btn a {
            color: #23573D;
            background-color: #F3F2EC; }
      .top article .container.container04 .pictures {
        display: flex;
        justify-content: center; }
        .top article .container.container04 .pictures .image {
          width: 33.333%; }
    .top article .container.container05 {
      margin: 10em auto; }
      .top article .container.container05 .inner {
        width: 65.9722222222vw; }
        .top article .container.container05 .inner--wrap {
          display: flex;
          justify-content: space-between; }
          .top article .container.container05 .inner--wrap--category {
            width: 50%;
            flex-direction: column;
            justify-content: flex-start;
            margin-top: 0; }
            .top article .container.container05 .inner--wrap--category:nth-of-type(2n) {
              border-left: 1px solid #fff; }
            .top article .container.container05 .inner--wrap--category .title h3 {
              display: block;
              font-size: clamp(26px, 2.2222222222vw, 32px);
              padding-bottom: 1.5em;
              position: relative; }
              .top article .container.container05 .inner--wrap--category .title h3:after {
                content: '';
                display: block;
                position: absolute;
                width: .2em;
                height: 5.3em;
                background: url("../images/common/img_treat.svg") no-repeat center center/cover;
                bottom: -2.3em;
                left: 50%;
                transform: rotate(-90deg) translateX(-50%); }
            .top article .container.container05 .inner--wrap--category .title h3,
            .top article .container.container05 .inner--wrap--category .title p {
              text-align: center; }
            .top article .container.container05 .inner--wrap--category .title p {
              line-height: 2.2;
              margin-top: 2.5em; }
            .top article .container.container05 .inner--wrap--category ul,
            .top article .container.container05 .inner--wrap--category .image {
              padding: 0 10%; }
            .top article .container.container05 .inner--wrap--category ul {
              display: flex;
              justify-content: center;
              align-items: center;
              flex-direction: column; }
              .top article .container.container05 .inner--wrap--category ul li {
                margin: 7.5em auto 0;
                /*&:nth-of-type(n+2){
                    margin-top: 5em;
                }*/ }
                .top article .container.container05 .inner--wrap--category ul li p {
                  text-align: center; }
                .top article .container.container05 .inner--wrap--category ul li a {
                  padding-right: 0;
                  margin-top: 1em; }
            .top article .container.container05 .inner--wrap--category .image {
              width: 100%;
              margin-top: 2.5em; }
            .top article .container.container05 .inner--wrap--category .btn {
              font-size: clamp(12px, 1.0416666667vw, 15px);
              padding-bottom: 0; }
              .top article .container.container05 .inner--wrap--category .btn a {
                color: #fff;
                background-color: transparent;
                border: 1px solid #fff; }
                .top article .container.container05 .inner--wrap--category .btn a:before, .top article .container.container05 .inner--wrap--category .btn a:after {
                  background-color: #fff; }

@media screen and (max-width: 767px) {
  .top .bnr-entry a {
    padding: .75em; }
    .top .bnr-entry a dl dt {
      font-size: clamp(9px, 2.8205128205vw, 11px);
      letter-spacing: .15em; }
    .top .bnr-entry a dl dd {
      font-size: clamp(10px, 3.0769230769vw, 12px);
      letter-spacing: 0;
      margin-top: .3em; }
  .top .bnr-entry.main-bnr a {
    padding: 1.5em; }
    .top .bnr-entry.main-bnr a dl dt {
      font-size: clamp(20px, 6.4102564103vw, 25px);
      line-height: 1; }
      .top .bnr-entry.main-bnr a dl dt em {
        font-size: clamp(10px, 3.0769230769vw, 12px);
        margin-top: .5em; }
    .top .bnr-entry.main-bnr a dl dd {
      font-size: clamp(12px, 3.5897435897vw, 14px);
      letter-spacing: 0; }
  .top article {
    padding-bottom: 5em;
    /*.parallax-bg{
        background: $maincolor url("../images/top/img_bg01.jpg")no-repeat center center/cover;
    }*/ }
    .top article .bnr-container {
      background: #23573D url("../images/top/img_bg03.jpg") no-repeat 55% top/cover;
      /*.parallax-bg{
          background: $maincolor url("../images/top/img_bg03.jpg")no-repeat 55% center/cover;
      }*/ }
    .top article .btn {
      font-size: clamp(19px, 6.1538461538vw, 24px); }
      .top article .btn a {
        padding: .8em 2.5em; }
      .top article .btn.more {
        font-size: clamp(12px, 3.8461538462vw, 24px);
        margin-top: 1.5em; }
        .top article .btn.more a {
          padding: 1em 5em; }
          .top article .btn.more a:before, .top article .btn.more a:after {
            right: 3.5em; }
    .top article .main {
      min-height: inherit;
      max-height: inherit; }
      .top article .main .notice {
        bottom: 1em;
        left: 3.5vw;
        transform: none;
        width: 56.4102564103vw;
        max-width: 220px;
        margin: 0 auto; }
        .top article .main .notice dt {
          font-size: clamp(10px, 2.8205128205vw, 15px); }
        .top article .main .notice dd {
          font-size: clamp(8px, 2.3076923077vw, 12px); }
      .top article .main .inner .splide {
        width: 79.4871794872vw;
        height: 76.5vh;
        max-width: inherit;
        min-height: inherit;
        max-height: inherit;
        clip-path: polygon(0 0, 100% 0, 100% 100%, 52.3% 100%, 52.3% 77.6%, 0 77.6%);
        padding-top: 8.5vh; }
        .top article .main .inner .splide h4 {
          width: auto;
          height: 63.7%;
          top: 51.5%;
          right: 11.3%; }
          .top article .main .inner .splide h4 img {
            height: 100%; }
        .top article .main .inner .splide .splide__track .splide__list .splide__slide:before {
          width: 52.3%; }
        .top article .main .inner .splide .splide__track .splide__list .splide__slide:after {
          width: 47.7%;
          height: 22.4%; }
        .top article .main .inner .splide .splide__track .splide__list .splide__slide p {
          width: 47.7%;
          font-size: clamp(8px, 2.3076923077vw, 13px);
          padding: 1em; }
      .top article .main .inner--title {
        top: 65.5%;
        left: 8vw; }
        .top article .main .inner--title h2 {
          font-size: clamp(29px, 9.2307692308vw, 74px);
          letter-spacing: 0; }
          .top article .main .inner--title h2 em {
            font-size: clamp(40px, 12.8205128205vw, 50px); }
            .top article .main .inner--title h2 em span {
              font-size: clamp(48px, 15.3846153846vw, 60px); }
        .top article .main .inner--title h3 {
          font-size: clamp(24px, 7.6923076923vw, 48px);
          margin: .8em 0 0; }
          .top article .main .inner--title h3 .en {
            font-size: clamp(34px, 10.2564102564vw, 58px); }
        .top article .main .inner--title p {
          font-size: clamp(18px, 8.2051282051vw, 50px); }
          .top article .main .inner--title p .en {
            font-size: clamp(21px, 8.7179487179vw, 60px); }
        .top article .main .inner--title .symbol {
          width: 14.1025641026vw;
          max-width: 55px;
          margin-top: 9.3vh; }
      .top article .main .inner .scroll {
        display: none;
        font-size: clamp(8px, 2.5641025641vw, 20px); }
    .top article .container {
      margin: 5em auto 0; }
      .top article .container:before {
        width: 34.6153846154vw;
        height: 34.6153846154vw; }
      .top article .container .txt-right {
        text-align: justify !important; }
      .top article .container .image p {
        font-size: clamp(52px, 16.6666666667vw, 110px);
        letter-spacing: .1em;
        left: -1.6em; }
      .top article .container .image .comment {
        position: absolute;
        display: flex;
        align-items: center;
        bottom: -2em; }
        .top article .container .image .comment dt {
          font-size: clamp(11px, 0.9027777778vw, 13px);
          margin-right: 1.5em; }
        .top article .container .image .comment dd {
          font-size: clamp(10px, 0.8333333333vw, 12px);
          letter-spacing: .3em; }
      .top article .container .image .links {
        margin-top: 1em; }
        .top article .container .image .links a {
          display: inline-block; }
          .top article .container .image .links a .comment {
            right: 1.8em;
            bottom: -.6em; }
      .top article .container .image.i02-1 .comment {
        left: inherit;
        right: 1.8em; }
      .top article .container .image.i02-2 {
        width: 68.7vw;
        margin: 5em 0 0 auto; }
        .top article .container .image.i02-2 .comment {
          right: 1.8em; }
      .top article .container .image.i02-3 {
        width: 100vw;
        margin: 7.5em auto 0; }
        .top article .container .image.i02-3 .comment {
          bottom: -2em;
          right: inherit;
          left: 1.8em; }
      .top article .container .image.i03-1-1:before, .top article .container .image.i03-2-1:before, .top article .container .image.i03-3-1:before {
        width: 46.1538461538vw;
        height: 46.1538461538vw; }
      .top article .container .image.i03-1-1:before {
        top: -32.0512820513vw;
        left: inherit;
        right: -14.1025641026vw; }
      .top article .container .image.i03-1-2 {
        width: 80.7692307692vw !important;
        height: 105.8974358974vw;
        margin: 5em auto 0 0;
        left: 0;
        overflow: hidden; }
        .top article .container .image.i03-1-2 img {
          width: auto;
          max-width: inherit;
          height: 100%;
          margin-left: -22.5%; }
      .top article .container .image.i03-2-1 {
        margin-top: 2.5em; }
        .top article .container .image.i03-2-1:before {
          top: -32.0512820513vw;
          bottom: inherit;
          right: -14.1025641026vw; }
      .top article .container .image.i03-2-2 {
        width: 100vw !important;
        right: inherit;
        height: 105.8974358974vw;
        margin: 3em auto 0 0;
        overflow: hidden; }
        .top article .container .image.i03-2-2 img {
          width: auto;
          max-width: inherit;
          height: 100%;
          margin-left: -35%; }
      .top article .container .image.i03-3-1 {
        margin-top: 3em; }
        .top article .container .image.i03-3-1:before {
          width: 46.1538461538vw;
          height: 46.1538461538vw;
          top: -20.5128205128vw;
          bottom: inherit;
          left: 0; }
      .top article .container .image.i03-3-2 {
        width: 100vw !important;
        left: inherit;
        margin-top: 3em; }
        .top article .container .image.i03-3-2 .links {
          padding-right: 1.8em;
          margin-top: 1.5em; }
        .top article .container .image.i03-3-2 .comment {
          flex-direction: column;
          align-items: flex-end;
          justify-content: flex-end;
          right: inherit; }
          .top article .container .image.i03-3-2 .comment dt {
            margin-right: -2.5em; }
          .top article .container .image.i03-3-2 .comment dd {
            margin-top: .5em; }
      .top article .container .inner--title {
        width: 82.5% !important;
        padding: 0;
        margin: 0 auto; }
        .top article .container .inner--title:before {
          width: 1.2820512821vw;
          height: 100%; }
        .top article .container .inner--title dt {
          font-size: clamp(46px, 14.8717948718vw, 70px);
          line-height: 1.1;
          letter-spacing: .05em; }
        .top article .container .inner--title dd {
          font-size: clamp(16px, 5.1282051282vw, 24px);
          margin-top: .8em; }
      .top article .container .inner--wrap--category {
        margin-top: 2.3em; }
        .top article .container .inner--wrap--category .image {
          width: 100%; }
        .top article .container .inner--wrap--category--texts {
          width: 85% !important;
          margin: 4em auto 0 !important; }
          .top article .container .inner--wrap--category--texts h2 {
            font-size: clamp(32px, 8.2051282051vw, 50px);
            margin-bottom: 1em; }
          .top article .container .inner--wrap--category--texts h3 {
            font-size: clamp(21px, 6.6666666667vw, 32px);
            line-height: 1.6; }
            .top article .container .inner--wrap--category--texts h3 em {
              font-size: clamp(85px, 27.1794871795vw, 132px);
              margin-top: -.3em; }
          .top article .container .inner--wrap--category--texts p {
            letter-spacing: 0;
            margin-top: 1em; }
        .top article .container .inner--wrap--category:nth-of-type(even) {
          flex-direction: row; }
      .top article .container.container01:before {
        bottom: 7.4em;
        right: 0; }
      .top article .container.container01 .inner--title {
        margin-right: 0; }
        .top article .container.container01 .inner--title:before {
          left: -2.8em; }
        .top article .container.container01 .inner--title dd {
          left: 0; }
      .top article .container.container02:before {
        width: 53.0769230769vw;
        height: 53.0769230769vw;
        top: 5.1282051282vw;
        left: -24.358974359vw; }
      .top article .container.container02 .inner--title {
        margin-right: auto;
        margin-left: 0; }
        .top article .container.container02 .inner--title:before {
          right: -2.8em; }
        .top article .container.container02 .inner--title dd {
          right: 0; }
      .top article .container.container02 .container--wrap--category {
        flex-wrap: wrap;
        margin-top: 2.5em; }
        .top article .container.container02 .container--wrap--category .image {
          width: 100%; }
        .top article .container.container02 .container--wrap--category--texts {
          width: 85% !important;
          margin: 0 auto; }
          .top article .container.container02 .container--wrap--category--texts h3 {
            font-size: clamp(21px, 6.6666666667vw, 32px);
            line-height: 1.6;
            margin-top: 2.5em; }
            .top article .container.container02 .container--wrap--category--texts h3 em {
              font-size: clamp(85px, 27.1794871795vw, 132px);
              margin-top: -.3em; }
          .top article .container.container02 .container--wrap--category--texts p {
            letter-spacing: 0;
            margin-top: 1em; }
        .top article .container.container02 .container--wrap--category:nth-of-type(even) {
          flex-direction: row; }
      .top article .container.container03 {
        padding-bottom: 7.5em;
        margin-top: 7.5em; }
        .top article .container.container03 .inner--title {
          margin-left: auto;
          margin-right: 0; }
          .top article .container.container03 .inner--title:before {
            left: -2.8em; }
          .top article .container.container03 .inner--title dd {
            left: 0; }
        .top article .container.container03 .inner--wrap--category:first-of-type {
          margin-top: 2.5em; }
        .top article .container.container03 .inner--wrap--category .image {
          width: 100%; }
      .top article .container.container04 {
        margin-top: 7.5em; }
        .top article .container.container04 .container04--block {
          padding: 5em 0; }
          .top article .container.container04 .container04--block .inner {
            width: 100vw; }
            .top article .container.container04 .container04--block .inner .title h2 {
              font-size: clamp(29px, 9.2307692308vw, 54px);
              padding-bottom: 1em; }
              .top article .container.container04 .container04--block .inner .title h2:after {
                width: .17em;
                height: 2.5em;
                bottom: -1em; }
            .top article .container.container04 .container04--block .inner .title h3 {
              font-size: clamp(24px, 7.6923076923vw, 32px); }
            .top article .container.container04 .container04--block .inner .title p {
              width: 80%;
              margin: 1em auto 0;
              font-size: clamp(14px, 4.6153846154vw, 18px);
              text-align: justify; }
            .top article .container.container04 .container04--block .inner .title .ttl {
              font-size: clamp(40px, 12.8205128205vw, 54px); }
              .top article .container.container04 .container04--block .inner .title .ttl em {
                font-size: clamp(40px, 12.8205128205vw, 70px);
                letter-spacing: .05em; }
            .top article .container.container04 .container04--block .inner--wrap h4 {
              font-size: clamp(24px, 7.6923076923vw, 30px); }
            .top article .container.container04 .container04--block .inner--wrap .image {
              margin-top: 5em; }
          .top article .container.container04 .container04--block.block01 .label {
            font-size: clamp(64px, 20.5128205128vw, 242px); }
            .top article .container.container04 .container04--block.block01 .label.label02 {
              bottom: 5.3em;
              right: -.4em; }
          .top article .container.container04 .container04--block.block02 {
            padding: 2.5em 0 0; }
            .top article .container.container04 .container04--block.block02 .inner .ttl {
              font-size: clamp(147px, 47.1794871795vw, 184px); }
            .top article .container.container04 .container04--block.block02 .inner h3 {
              margin-top: .5em; }
          .top article .container.container04 .container04--block.block03 .inner .ttl {
            letter-spacing: .1em; }
          .top article .container.container04 .container04--block.block03 .inner h3 {
            margin-top: .5em; }
          .top article .container.container04 .container04--block.block03 .inner--wrap table {
            width: 90%;
            margin: 3em auto 0; }
            .top article .container.container04 .container04--block.block03 .inner--wrap table tr th,
            .top article .container.container04 .container04--block.block03 .inner--wrap table tr td {
              width: 100%;
              display: block;
              text-align: center;
              padding: 1.5em 0; }
            .top article .container.container04 .container04--block.block03 .inner--wrap table tr th {
              font-weight: bold;
              padding-bottom: 1em; }
            .top article .container.container04 .container04--block.block03 .inner--wrap table tr td {
              line-height: 1.6;
              padding-top: 0; }
              .top article .container.container04 .container04--block.block03 .inner--wrap table tr td p {
                width: fit-content;
                margin: .5em auto 0; }
        .top article .container.container04 .pictures {
          flex-direction: column; }
          .top article .container.container04 .pictures .image {
            width: 100%; }
      .top article .container.container05 {
        margin: 5em auto; }
        .top article .container.container05 .inner {
          width: 85vw; }
          .top article .container.container05 .inner--wrap {
            flex-direction: column; }
            .top article .container.container05 .inner--wrap--category {
              width: 100%;
              padding: 0;
              flex-direction: column; }
              .top article .container.container05 .inner--wrap--category:nth-of-type(2n) {
                border-top: 1px solid #fff;
                border-left: none;
                padding-top: 5em;
                margin-top: 5em; }
              .top article .container.container05 .inner--wrap--category .title h3 {
                font-size: clamp(24px, 7.6923076923vw, 32px);
                padding-bottom: 1.5em; }
                .top article .container.container05 .inner--wrap--category .title h3:after {
                  width: .2em;
                  height: 4.5em;
                  bottom: -2em; }
              .top article .container.container05 .inner--wrap--category .title p {
                font-size: clamp(14px, 4.6153846154vw, 18px); }
                .top article .container.container05 .inner--wrap--category .title p.txt-justify {
                  text-align: justify; }
              .top article .container.container05 .inner--wrap--category ul,
              .top article .container.container05 .inner--wrap--category .image {
                padding: 0; }
              .top article .container.container05 .inner--wrap--category ul li {
                margin: 3.5em auto 0; }
              .top article .container.container05 .inner--wrap--category .image {
                width: 100%;
                margin-top: 2.5em; }
              .top article .container.container05 .inner--wrap--category .btn {
                font-size: clamp(12px, 1.0416666667vw, 15px);
                padding-bottom: 0; }
                .top article .container.container05 .inner--wrap--category .btn a {
                  color: #fff;
                  background-color: transparent;
                  border: 1px solid #fff; }
                  .top article .container.container05 .inner--wrap--category .btn a:before, .top article .container.container05 .inner--wrap--category .btn a:after {
                    background-color: #fff; } }
