@charset "UTF-8";
.con-pageoutline.noimg { max-width: 1280px; margin-inline: auto; width: calc(100% - 160px); }
@media (max-width: 1439px) { .con-pageoutline.noimg { width: 96%; } }
@media (min-width: 768px) and (max-width: 1024px) { .con-pageoutline.noimg { width: 92%; } }
@media (max-width: 767px) { .con-pageoutline.noimg { width: 89.6%; } }

/*Animate */
/* -----------------------------------------------------------
	基本設定、リンクカラーなど
----------------------------------------------------------- */
html { font-size: 62.5%; line-height: 1.75; scroll-behavior: smooth; }

body { background: url(../images/common/body-background.webp) 0 0 repeat; color: #2B2B2B; -webkit-text-size-adjust: none; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; font-size: 1.6rem; }
@media (max-width: 767px) { body { font-size: 1.4rem; } }
body a { color: inherit; line-height: 1; text-decoration: none; }
body a:visited { color: inherit; }
body img { max-width: 100%; -webkit-touch-callout: none; image-rendering: -webkit-optimize-contrast; }

body, pre, input, textarea, select { font-family: "Zen Kaku Gothic New", sans-serif; font-weight: 400; font-style: normal; }

input, select, textarea { font-size: 100%; }

@media (min-width: 1025px) { body .view_tab-sp, body .view_tab { display: none !important; } }
@media (min-width: 768px) { body .view_sp { display: none !important; } }
@media (max-width: 1024px) { body .view_pc { display: none !important; } }
@media (max-width: 767px) { body .view_pc-tab, body .view_tab { display: none !important; } }

* { -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; }

.visually-hidden { position: absolute !important; clip: rect(1px, 1px, 1px, 1px); padding: 0 !important; border: 0 !important; height: 1px !important; width: 1px !important; overflow: hidden; }

/* -----------------------------------------------------------
	#page
----------------------------------------------------------- */
#page { position: relative; }

/* -----------------------------------------------------------
	header
----------------------------------------------------------- */
header { padding: 16px 0 0 21px; display: flex; justify-content: space-between; position: absolute; width: 100%; top: 0; left: 0; z-index: 10; }
header .logo { width: 35px; opacity: 0; }
header .logo.js-inview-in { -webkit-animation-duration: 0.8s; animation-duration: 0.8s; -webkit-animation-fill-mode: both; animation-fill-mode: both; -webkit-animation-name: fade-top; animation-name: fade-top; transition-timing-function: cubic-bezier(0.23, 1, 0.32, 1); }
@keyframes fade-top { from { opacity: 0; -webkit-transform: translate3d(0, -60px, 0); transform: translate3d(0, -60px, 0); }
  to { opacity: 1; -webkit-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); } }
@media (hover: hover) { header .logo { -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; }
  header .logo:hover { opacity: 0.7; } }
header .gnav { display: flex; justify-content: flex-end; align-items: flex-start; gap: 0 48px; padding-right: 32px; opacity: 0; }
header .gnav.js-inview-in { -webkit-animation-duration: 0.8s; animation-duration: 0.8s; -webkit-animation-fill-mode: both; animation-fill-mode: both; -webkit-animation-name: fade-top; animation-name: fade-top; transition-timing-function: cubic-bezier(0.23, 1, 0.32, 1); }
@keyframes fade-top { from { opacity: 0; -webkit-transform: translate3d(0, -60px, 0); transform: translate3d(0, -60px, 0); }
  to { opacity: 1; -webkit-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); } }
header .gnav .gnav-mainlist { display: flex; flex-wrap: wrap; gap: 0 48px; width: 20em; }
header .gnav .gnav-mainlist li { width: calc(50% - 24px); line-height: 2; }
header .gnav .gnav-mainlist li a { font-weight: 500; font-size: 1.3rem; letter-spacing: 0.08em; }
@media (hover: hover) { header .gnav .gnav-mainlist li a { -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; position: relative; }
  header .gnav .gnav-mainlist li a:after { content: ""; width: 0; height: 1px; background-color: #2E4282; position: absolute; bottom: -0.25em; left: 0; -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; }
  header .gnav .gnav-mainlist li a:hover { color: #2E4282; }
  header .gnav .gnav-mainlist li a:hover:after { width: 100%; } }
header .gnav .button-menu { display: block; width: 56px; height: 16px; position: relative; margin-top: 0.5em; cursor: pointer; overflow: hidden; }
@media (hover: hover) { header .gnav .button-menu { -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; }
  header .gnav .button-menu:hover { opacity: 0.6; }
  header .gnav .button-menu:hover span { transform: translate(calc(100% + 2rem)); } }
header .gnav .button-menu span { display: block; background-color: #2B2B2B; width: 100%; height: 1px; position: absolute; left: 0; right: 0; margin: 0 auto; transition: transform 0.46s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
@media (max-width: 767px) { header .gnav .button-menu span { background-color: #fff; -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; } }
header .gnav .button-menu span:nth-child(1) { top: 0; }
header .gnav .button-menu span:nth-child(2) { top: 50%; transition-delay: 0.15s; }
header .gnav .button-menu span:nth-child(3) { bottom: 0; transition-delay: 0.3s; }
header .gnav .button-menu span:before, header .gnav .button-menu span:after { content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-color: #2B2B2B; }
@media (max-width: 767px) { header .gnav .button-menu span:before, header .gnav .button-menu span:after { background-color: #fff; -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; } }
header .gnav .button-menu span:before { transform: translate(calc(-100% - 2rem)); }
@keyframes bar-animation { 0% { transform: scaleX(0); opacity: 0; }
  33% { transform: scaleX(1); opacity: 1; }
  66% { transform: scaleX(1); opacity: 1; }
  100% { transform: scaleX(1); opacity: 1; } }
header .button-houselab { position: absolute; top: calc(50vh - 90px); right: 0; opacity: 0; }
@media (max-width: 767px) { header .button-houselab { -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; } }
header .button-houselab.js-inview-in { -webkit-animation-duration: 0.8s; animation-duration: 0.8s; -webkit-animation-fill-mode: both; animation-fill-mode: both; -webkit-animation-name: fade-side; animation-name: fade-side; transition-timing-function: cubic-bezier(0.23, 1, 0.32, 1); }
@keyframes fade-side { from { opacity: 0; -webkit-transform: translate3d(40px, 0, 0); transform: translate3d(40px, 0, 0); }
  to { opacity: 1; -webkit-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); } }
header .button-houselab a { display: inline-block; background-color: #2B2B2B; color: #fff; -webkit-border-radius: 4px 0 0 4px; -moz-border-radius: 4px 0 0 4px; -ms-border-radius: 4px 0 0 4px; border-radius: 4px 0 0 4px; border-top: 1px solid #2B2B2B; border-left: 1px solid #2B2B2B; border-bottom: 1px solid #2B2B2B; padding: 16px 16px 12px; }
@media (hover: hover) { header .button-houselab a { -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; }
  header .button-houselab a:hover { background-color: #2E4282; } }
header .button-houselab a .txt { display: block; writing-mode: tb-rl; writing-mode: vertical-rl; -moz-writing-mode: vertical-rl; -o-writing-mode: vertical-rl; -webkit-writing-mode: vertical-rl; text-align: left; display: inline-block; letter-spacing: 0.1em; }
header .button-houselab a .icon { display: block; border-top: 1px dashed rgba(255, 255, 255, 0.5); text-align: center; margin: 0 auto; margin-top: 16px; padding-top: 12px; }
header .button-houselab a .icon svg { width: 8px; fill: #fff; }
header.hamburger-menu-on { position: fixed; }
header.hamburger-menu-on .gnav .gnav-mainlist { display: none; }
@media (max-width: 767px) { header.hamburger-menu-on .gnav .button-menu span { background-color: #2B2B2B; } }
@media (max-width: 767px) { header.hamburger-menu-on .gnav .button-menu span:before, header.hamburger-menu-on .gnav .button-menu span:after { background-color: #2B2B2B; } }
@media (max-width: 767px) { header.hamburger-menu-on .button-houselab { position: fixed; top: auto; bottom: 0; } }
@media (max-width: 767px) { header.hamburger-menu-on .button-houselab a { display: block; padding: 16px 10px 12px; min-width: 32px; } }
@media (max-width: 767px) { header.hamburger-menu-on .button-houselab a .icon { display: none; } }

@media (max-width: 767px) { body.nopageimg header .gnav .button-menu span { background-color: #2B2B2B; } }
@media (max-width: 767px) { body.nopageimg header .gnav .button-menu span:before, body.nopageimg header .gnav .button-menu span:after { display: none; } }

/* -----------------------------------------------------------
	.con-modalmenu
----------------------------------------------------------- */
.con-modalmenu { -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; opacity: 0; visibility: hidden; pointer-events: none; position: fixed; top: 0; right: 0; z-index: 100; width: 100%; height: 100vh; }
@media (max-width: 767px) { .con-modalmenu { height: 100%; } }
.con-modalmenu .box-modalmenu { clip-path: polygon(100% 0%, 100% 0%, 100% 100%, 100% 100%); position: absolute; bottom: 0; right: 0; background: url(../images/common/body-background.webp) 0 0 repeat; width: 100%; height: 100%; -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; overflow-y: auto; }
.con-modalmenu .box-modalmenu .button-close { position: absolute; top: 22px; right: 32px; width: 52px; height: 19px; cursor: pointer; }
@media (max-width: 767px) { .con-modalmenu .box-modalmenu .button-close { top: 43px; right: 24px; } }
.con-modalmenu .box-modalmenu .button-close span { display: block; background-color: #2B2B2B; width: 100%; height: 1px; position: absolute; top: 50%; left: 0; -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; }
.con-modalmenu .box-modalmenu .button-close span:nth-child(1) { transform: rotate(20deg); }
.con-modalmenu .box-modalmenu .button-close span:nth-child(2) { transform: rotate(-20deg); }
.con-modalmenu .box-modalmenu .inner-modalmenu { display: flex; }
@media (min-width: 768px) { .con-modalmenu .box-modalmenu .inner-modalmenu { justify-content: space-between; height: 100%; } }
@media (max-width: 767px) { .con-modalmenu .box-modalmenu .inner-modalmenu { padding: 1.6vh 8.2vw 24px; flex-direction: column; } }
.con-modalmenu .box-modalmenu .inner-modalmenu .title-en { font-family: "Outfit", serif; font-optical-sizing: auto; font-weight: 400; font-style: normal; color: #888; line-height: 1; }
@media (max-width: 767px) { .con-modalmenu .box-modalmenu .inner-modalmenu .title-en { font-size: 1.2rem; } }
@media (min-width: 768px) { .con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left { padding: 0 5.6%; display: flex; flex-direction: column; justify-content: center; } }
@media (min-width: 1025px) { .con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left { width: 33.3%; } }
@media (min-width: 768px) and (max-width: 1024px) { .con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left { width: 50%; } }
@media (max-width: 767px) { .con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left { display: contents; } }
.con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left .logo { max-width: 320px; margin-bottom: 8.5vh; }
@media (min-width: 768px) and (max-width: 1024px) { .con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left .logo { width: 85%; } }
@media (max-width: 767px) { .con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left .logo { order: 1; max-width: 100%; width: 51.4vw; margin-bottom: 4.7vh; } }
.con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left .box-access { margin-bottom: 6.3vh; }
@media (max-width: 767px) { .con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left .box-access { order: 4; margin-bottom: 4.7vh; } }
.con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left .box-access .title-en { margin-bottom: 1.6vh; }
.con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left .box-access address { letter-spacing: 0.08em; font-weight: 500; }
.con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left .box-access .txt-link-min a { display: inline-block; position: relative; font-family: "Outfit", serif; font-optical-sizing: auto; font-weight: 400; font-style: normal; font-size: 1.4rem; letter-spacing: 0.08em; }
@media (hover: hover) { .con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left .box-access .txt-link-min a:hover:after { width: 0; } }
.con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left .box-access .txt-link-min a:after { content: ""; width: 100%; height: 1px; background-color: #2B2B2B; position: absolute; bottom: -0.25em; right: 0; -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; }
.con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left .box-pickup-button { display: flex; flex-direction: column; gap: 1.6vh 0; margin-bottom: 6.3vh; }
@media (max-width: 767px) { .con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left .box-pickup-button { gap: 0.8vh 0; order: 3; margin-bottom: 4.7vh; } }
.con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left .box-pickup-button .button-line a .icon { width: 32px; }
@media (max-width: 767px) { .con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left .box-sns { order: 5; } }
.con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left .box-sns dt { margin-bottom: 16px; font-size: 1.4rem; }
@media (max-width: 767px) { .con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left .box-sns dt { margin-bottom: 0.8vh; font-size: 1.2rem; } }
.con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left .box-sns .list-sns { display: flex; gap: 0 32px; }
.con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left .box-sns .list-sns li a { display: flex; align-items: flex-end; gap: 0 9px; font-family: "Outfit", serif; font-optical-sizing: auto; font-weight: 500; font-style: normal; font-size: 1.5rem; line-height: 1; }
@media (hover: hover) { .con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left .box-sns .list-sns li a { -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; }
  .con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left .box-sns .list-sns li a:hover { opacity: 0.6; } }
.con-modalmenu .box-modalmenu .inner-modalmenu .wrap-left .box-sns .list-sns li a img { display: inline-block; width: 24px; margin-bottom: -4px; }
@media (min-width: 768px) { .con-modalmenu .box-modalmenu .inner-modalmenu .box-contentslist { border-left: 1px solid #EBEBEB; padding: 0 5.6%; display: flex; flex-direction: column; justify-content: center; } }
@media (min-width: 1025px) { .con-modalmenu .box-modalmenu .inner-modalmenu .box-contentslist { width: 34.7%; } }
@media (min-width: 768px) and (max-width: 1024px) { .con-modalmenu .box-modalmenu .inner-modalmenu .box-contentslist { width: 50%; } }
@media (max-width: 767px) { .con-modalmenu .box-modalmenu .inner-modalmenu .box-contentslist { order: 2; margin-bottom: 3.1vh; } }
.con-modalmenu .box-modalmenu .inner-modalmenu .box-contentslist ul { display: flex; flex-direction: column; margin-top: 64px; }
@media (max-width: 767px) { .con-modalmenu .box-modalmenu .inner-modalmenu .box-contentslist ul { margin-top: 1.6vh; } }
.con-modalmenu .box-modalmenu .inner-modalmenu .box-contentslist ul li { font-size: 1.8rem; font-family: "Shippori Mincho", serif; font-weight: 500; font-style: normal; letter-spacing: 0.08em; }
@media (max-width: 767px) { .con-modalmenu .box-modalmenu .inner-modalmenu .box-contentslist ul li { font-size: 1.6rem; } }
.con-modalmenu .box-modalmenu .inner-modalmenu .box-contentslist ul li a { display: flex; align-items: center; background-image: url(../images/common/icon-arrow-base.svg); background-position: calc(100% - 8px) center; background-repeat: no-repeat; background-size: auto 16px; position: relative; min-height: 72px; line-height: 1; font-weight: 500; padding-right: 40px; }
@media (hover: hover) { .con-modalmenu .box-modalmenu .inner-modalmenu .box-contentslist ul li a { -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; }
  .con-modalmenu .box-modalmenu .inner-modalmenu .box-contentslist ul li a:hover { background-position: right center; } }
@media (max-width: 767px) { .con-modalmenu .box-modalmenu .inner-modalmenu .box-contentslist ul li a { min-height: auto; padding-right: 29px; border-bottom: 1px solid #DEDEDE; padding: 2vh 0; } }
.con-modalmenu .box-modalmenu .inner-modalmenu .box-contentslist ul li a:after { content: ""; width: 1px; height: 16px; position: absolute; top: 50%; right: 24px; transform: translate(0, -50%); border-left: 1px dashed rgba(51, 51, 51, 0.5); }
@media (min-width: 768px) { .con-modalmenu .box-modalmenu .inner-modalmenu .box-contentslist ul li.sub { font-size: 1.5rem; } }
@media (min-width: 768px) { .con-modalmenu .box-modalmenu .inner-modalmenu .box-contentslist ul li.sub a { min-height: 64px; } }
.con-modalmenu .box-modalmenu .inner-modalmenu .box-pickup-event { padding: 0 5.6%; border-left: 1px solid #EBEBEB; }
@media (min-width: 1025px) { .con-modalmenu .box-modalmenu .inner-modalmenu .box-pickup-event { width: 31.9%; display: flex; flex-direction: column; justify-content: center; } }
.con-modalmenu .box-modalmenu .inner-modalmenu .box-pickup-event .item { margin-top: 6.3vh; }
.con-modalmenu .box-modalmenu .inner-modalmenu .box-pickup-event .item a { display: block; }
@media (hover: hover) { .con-modalmenu .box-modalmenu .inner-modalmenu .box-pickup-event .item a:hover .thumbnail { opacity: 0.6; }
  .con-modalmenu .box-modalmenu .inner-modalmenu .box-pickup-event .item a:hover .txt-caption { background-position: right center; } }
.con-modalmenu .box-modalmenu .inner-modalmenu .box-pickup-event .item a .thumbnail { margin-bottom: 2.3vh; -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; }
.con-modalmenu .box-modalmenu .inner-modalmenu .box-pickup-event .item a .txt-caption { font-family: "Shippori Mincho", serif; font-weight: 500; font-style: normal; background-image: url(../images/common/icon-arrow-base.svg); background-position: calc(100% - 8px) center; background-repeat: no-repeat; background-size: auto 16px; position: relative; line-height: 1; font-weight: 500; -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; padding-right: 40px; }
.con-modalmenu .box-modalmenu .inner-modalmenu .box-pickup-event .item a .txt-caption:after { content: ""; width: 1px; height: 16px; position: absolute; top: 50%; right: 24px; transform: translate(0, -50%); border-left: 1px dashed rgba(51, 51, 51, 0.5); }
.con-modalmenu .box-modalmenu .inner-modalmenu .box-pickup-event.noevent { padding: 0; }
.con-modalmenu .box-modalmenu .inner-modalmenu .box-pickup-event.noevent .img { overflow: hidden; width: 100%; height: 100%; opacity: 0.6; }
.con-modalmenu .box-modalmenu .inner-modalmenu .box-pickup-event.noevent .img img { width: 100%; height: 100%; object-fit: cover; }
.con-modalmenu.open { opacity: 1; visibility: inherit; pointer-events: all; }
.con-modalmenu.open .box-modalmenu { clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%); }

/* -----------------------------------------------------------
	footer Instagram
----------------------------------------------------------- */
.con-f-instagram { width: 100%; overflow: hidden; padding: 40px 0; margin-top: 160px; }
@media (max-width: 767px) { .con-f-instagram { margin-top: 0; } }
@media (hover: hover) { .con-f-instagram > a { -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; }
  .con-f-instagram > a:hover { opacity: 0.6; } }
.con-f-instagram .instagram-txt-slider { overflow: hidden; display: flex; width: 100vw; margin-inline: calc(50% - 50vw); }
.con-f-instagram .instagram-txt-slider .infiniteslide__item { flex-shrink: 0; font-family: "Shippori Mincho", serif; font-weight: 400; font-style: normal; line-height: 1; font-size: 4.8rem; letter-spacing: -0.08em; width: auto; height: auto; margin-right: 32px; }
@media (max-width: 767px) { .con-f-instagram .instagram-txt-slider .infiniteslide__item { font-size: 2.8rem; margin-right: 24px; } }
.con-f-instagram .instagram-txt-slider .infiniteslide__item .wrap { height: 100%; display: flex; flex-direction: column; justify-content: center; align-items: center; }
.con-f-instagram .instagram-txt-slider .infiniteslide__item img { -webkit-border-radius: 9999px; -moz-border-radius: 9999px; -ms-border-radius: 9999px; border-radius: 9999px; width: 80px; }
@media (max-width: 767px) { .con-f-instagram .instagram-txt-slider .infiniteslide__item img { width: 64px; } }
.con-f-instagram .instagram-txt-slider .infiniteslide__item.arrow img { width: 32px; }
@media (max-width: 767px) { .con-f-instagram .instagram-txt-slider .infiniteslide__item.arrow img { width: 24px; } }
.con-f-instagram .list-instagram { padding: 40px 0; display: flex; }
@media (max-width: 1024px) { .con-f-instagram .list-instagram { flex-wrap: wrap; } }
@media (max-width: 767px) { .con-f-instagram .list-instagram { padding: 16px 0; } }
.con-f-instagram .list-instagram .item-instagram { width: 16.66667%; }
@media (min-width: 768px) and (max-width: 1024px) { .con-f-instagram .list-instagram .item-instagram { width: 33.33333%; } }
@media (max-width: 767px) { .con-f-instagram .list-instagram .item-instagram { width: 50%; } }
.con-f-instagram .list-instagram .item-instagram a { display: block; aspect-ratio: 1/1; overflow: hidden; }
@media (hover: hover) { .con-f-instagram .list-instagram .item-instagram a { -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; }
  .con-f-instagram .list-instagram .item-instagram a:hover { opacity: 0.6; } }
.con-f-instagram .list-instagram .item-instagram a img { width: 100%; height: 100%; object-fit: cover; }

/* -----------------------------------------------------------
	footer
----------------------------------------------------------- */
footer .con-f-houselab { width: 100%; height: 688px; position: relative; background-color: #000; overflow: hidden; }
@media (max-width: 767px) { footer .con-f-houselab { height: 560px; } }
footer .con-f-houselab video { width: 100%; height: 100%; object-fit: cover; opacity: 0.6; position: absolute; top: 0; left: 0; }
footer .con-f-houselab .inner-f-houselab { position: relative; z-index: 1; color: #fff; padding: 120px 80px 64px; display: flex; flex-direction: column; height: 100%; }
@media (min-width: 768px) and (max-width: 1024px) { footer .con-f-houselab .inner-f-houselab { padding: 80px 40px 64px; } }
@media (max-width: 767px) { footer .con-f-houselab .inner-f-houselab { padding: 64px 32px 24px; } }
footer .con-f-houselab .inner-f-houselab .title-houselab { margin-bottom: 64px; }
@media (max-width: 767px) { footer .con-f-houselab .inner-f-houselab .title-houselab { margin-bottom: 32px; } }
footer .con-f-houselab .inner-f-houselab .title-houselab span { display: block; }
footer .con-f-houselab .inner-f-houselab .title-houselab span.en { font-family: "Marcellus", serif; font-weight: 400; font-style: normal; line-height: 1; font-size: 9.6rem; margin-bottom: 8px; }
@media (max-width: 767px) { footer .con-f-houselab .inner-f-houselab .title-houselab span.en { font-size: 6.4rem; margin-bottom: 6px; } }
footer .con-f-houselab .inner-f-houselab .title-houselab span.jp { font-family: "Shippori Mincho", serif; font-weight: 500; font-style: normal; line-height: 1.5; letter-spacing: 0.08em; font-size: 3.2rem; }
@media (max-width: 767px) { footer .con-f-houselab .inner-f-houselab .title-houselab span.jp { font-size: 2rem; } }
footer .con-f-houselab .inner-f-houselab .txt-lead { font-family: "Shippori Mincho", serif; font-weight: 500; font-style: normal; line-height: 1; letter-spacing: 0.08em; }
@media (max-width: 767px) { footer .con-f-houselab .inner-f-houselab .txt-lead { font-size: 1.3rem; } }
footer .con-f-houselab .inner-f-houselab .item-link { margin-top: auto; display: flex; justify-content: flex-end; align-items: center; gap: 0 40px; }
@media (max-width: 767px) { footer .con-f-houselab .inner-f-houselab .item-link { gap: 0 20px; align-items: flex-end; } }
footer .con-f-houselab .inner-f-houselab .item-link .txt { font-size: 1.4rem; }
@media (max-width: 767px) { footer .con-f-houselab .inner-f-houselab .item-link .txt { font-size: 1.2rem; width: calc(100% - 100px); }
  footer .con-f-houselab .inner-f-houselab .item-link .txt br { display: none; } }
footer .con-f-houselab .inner-f-houselab .item-link .arrow { width: 80px; height: 80px; }
footer .con-f-houselab .inner-f-houselab .item-link .arrow a { display: flex; flex-direction: column; justify-content: center; align-items: center; width: 100%; height: 100%; position: relative; }
@media (hover: hover) { footer .con-f-houselab .inner-f-houselab .item-link .arrow a:hover img { transform: scale(1.5); } }
footer .con-f-houselab .inner-f-houselab .item-link .arrow a img { -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; display: inline-block; }
footer .con-f-houselab .inner-f-houselab .item-link .arrow a svg { position: absolute; top: 0; left: 0; animation: rotateAnimation 5s linear infinite; width: 100%; height: 100%; }
@keyframes rotateAnimation { from { transform: rotate(0deg); }
  to { transform: rotate(360deg); } }
footer .con-footer { background-color: #2D2D2D; width: 100%; padding: 64px 40px 24px; color: #fff; }
@media (min-width: 768px) { footer .con-footer { display: grid; grid-template-columns: 1fr 300px; grid-template-rows: repeat(2, 1fr) repeat(2, auto); grid-column-gap: 0px; grid-row-gap: 0px; } }
@media (min-width: 768px) and (max-width: 1024px) { footer .con-footer { padding: 64px 24px 24px; } }
@media (max-width: 767px) { footer .con-footer { padding: 0; } }
footer .con-footer .box-sns { display: flex; align-items: flex-end; align-self: start; }
@media (min-width: 768px) { footer .con-footer .box-sns { grid-area: 1 / 1 / 2 / 2; gap: 0 29px; } }
@media (max-width: 767px) { footer .con-footer .box-sns { gap: 0 7.4vw; padding: 64px 6vw; border-bottom: 1px solid rgba(255, 255, 255, 0.2); } }
footer .con-footer .box-sns dt { font-family: "Outfit", serif; font-optical-sizing: auto; font-weight: 400; font-style: normal; line-height: 1; font-size: 1.2rem; opacity: 0.5; }
@media (max-width: 767px) { footer .con-footer .box-sns dt { padding-right: 2.6vw; } }
footer .con-footer .box-sns dd a { display: flex; align-items: flex-end; gap: 0 10px; color: #fff; font-family: "Outfit", serif; font-optical-sizing: auto; font-weight: 600; font-style: normal; font-size: 1.5rem; }
@media (hover: hover) { footer .con-footer .box-sns dd a { -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; }
  footer .con-footer .box-sns dd a:hover { opacity: 0.6; } }
footer .con-footer .box-sns dd a img { width: 24px; margin-bottom: -4px; }
@media (min-width: 768px) { footer .con-footer .box-contact-line { grid-area: 1 / 2 / 3 / 3; } }
@media (max-width: 767px) { footer .con-footer .box-contact-line { width: 83.6%; margin: 64px auto 0; } }
footer .con-footer .box-contact-line .title { margin-bottom: 16px; display: flex; justify-content: space-between; align-items: flex-end; }
footer .con-footer .box-contact-line .title .en { font-family: "Outfit", serif; font-optical-sizing: auto; font-weight: 400; font-style: normal; font-size: 1.2rem; line-height: 1; opacity: 0.5; }
footer .con-footer .box-contact-line .title .jp { font-family: "Shippori Mincho", serif; font-weight: 500; font-style: normal; line-height: 1; font-size: 2.2rem; letter-spacing: 0.08em; }
footer .con-footer .box-contact-line .item a { color: #fff; display: block; background-color: rgba(32, 32, 32, 0.8); padding: 80px 20px 12px 32px; width: 100%; height: 100%; }
@media (hover: hover) { footer .con-footer .box-contact-line .item a { -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; }
  footer .con-footer .box-contact-line .item a:hover { background-color: #2E4282; } }
footer .con-footer .box-contact-line .item a .logo-line { width: 48px; }
footer .con-footer .box-contact-line .item a .txt { margin-top: 16px; line-height: 1; letter-spacing: 0.08em; font-weight: 500; font-size: 1.4rem; }
footer .con-footer .box-contact-line .item a .icon { margin-top: 45px; position: relative; }
footer .con-footer .box-contact-line .item a .icon:before { content: ""; border-left: 1px dotted rgba(255, 255, 255, 0.1); height: 25px; width: 1px; position: absolute; right: 28px; bottom: 0; }
footer .con-footer .box-contact-line .item a .icon img { width: 9px; display: block; margin-left: auto; padding-bottom: 8px; }
footer .con-footer .box-contact-line .txt-caption { margin-top: 32px; font-size: 1.3rem; }
@media (max-width: 767px) { footer .con-footer .box-contact-line .txt-caption { text-align: center; font-size: 1.2rem; margin-top: 16px; } }
footer .con-footer .box-information { font-size: 1.2rem; font-weight: 500; }
@media (min-width: 768px) { footer .con-footer .box-information { grid-area: 2 / 1 / 3 / 2; align-self: end; } }
@media (max-width: 767px) { footer .con-footer .box-information { margin-top: 64px; text-align: center; } }
@media (max-width: 767px) { footer .con-footer .box-information address { margin-bottom: 24px; } }
footer .con-footer .box-information address a { display: inline-block; position: relative; font-family: "Outfit", serif; font-optical-sizing: auto; font-weight: 600; font-style: normal; letter-spacing: 0.08em; margin-left: 16px; color: #fff; }
@media (hover: hover) { footer .con-footer .box-information address a:hover:after { width: 0; } }
@media (max-width: 767px) { footer .con-footer .box-information address a { margin-left: 0; } }
footer .con-footer .box-information address a:after { content: ""; display: block; background-color: #fff; width: 100%; height: 1px; right: 0; position: absolute; bottom: -0.5em; -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; }
footer .con-footer .logo-type { aspect-ratio: 1158/73; margin-top: 80px; }
@media (min-width: 768px) { footer .con-footer .logo-type { grid-area: 3 / 1 / 4 / 3; } }
@media (max-width: 767px) { footer .con-footer .logo-type { width: calc(100% - 10px); margin: 80px auto 0; } }
footer .con-footer .logo-type img { width: 100%; }
footer .con-footer .copyright { text-align: center; font-family: "Outfit", serif; font-optical-sizing: auto; font-weight: 200; font-style: normal; line-height: 1; font-size: 1.2rem; letter-spacing: 0.16em; opacity: 0.5; }
@media (min-width: 768px) { footer .con-footer .copyright { grid-area: 4 / 1 / 5 / 3; margin-top: 64px; } }
@media (max-width: 767px) { footer .con-footer .copyright { padding: 32px 0 24px; } }

/* -----------------------------------------------------------
	下層共通スタイル
----------------------------------------------------------- */
@media (min-width: 768px) { .con-pageoutline { display: flex; } }
@media (min-width: 768px) { .con-pageoutline .img { width: 50%; } }
@media (min-width: 1025px) { .con-pageoutline .img { aspect-ratio: 1/1.167; overflow: hidden; }
  .con-pageoutline .img video { width: 100%; height: 100%; object-fit: cover; } }
@media (min-width: 1025px) and (max-width: 1439px) { .con-pageoutline .img { width: 50%; aspect-ratio: 1/1.167; overflow: hidden; }
  .con-pageoutline .img img, .con-pageoutline .img video { width: 100%; height: 100%; object-fit: cover; } }
@media (min-width: 768px) and (max-width: 1024px) { .con-pageoutline .img { aspect-ratio: 1/1.67; overflow: hidden; }
  .con-pageoutline .img img, .con-pageoutline .img video { width: 100%; height: 100%; object-fit: cover; } }
@media (max-width: 767px) { .con-pageoutline .img { width: 100%; aspect-ratio: 6/7; overflow: hidden; position: relative; }
  .con-pageoutline .img:after { content: ""; background-color: rgba(0, 0, 0, 0.25); width: 100%; height: 100%; position: absolute; top: 0; left: 0; }
  .con-pageoutline .img img, .con-pageoutline .img video { width: 100%; height: 100%; object-fit: cover; } }
.con-pageoutline .box-pageoutline { text-align: center; }
@media (min-width: 768px) { .con-pageoutline .box-pageoutline { width: 50%; display: flex; flex-direction: column; justify-content: center; } }
@media (min-width: 1025px) { .con-pageoutline .box-pageoutline { align-self: flex-start; padding-top: 320px; } }
@media (min-width: 1025px) and (max-width: 1439px) { .con-pageoutline .box-pageoutline { align-self: center; padding-top: 0; } }
@media (max-width: 767px) { .con-pageoutline .box-pageoutline { display: contents; } }
@media (max-width: 767px) { .con-pageoutline .box-pageoutline .box-title { position: absolute; top: 0; left: 0; text-align: center; width: 100%; aspect-ratio: 6/7; display: flex; flex-direction: column; justify-content: center; z-index: 1; } }
.con-pageoutline .box-pageoutline .box-title .sub-en { font-family: "Outfit", serif; font-optical-sizing: auto; font-weight: 400; font-style: normal; line-height: 1; letter-spacing: 0.16em; color: #888; margin-bottom: 8px; }
@media (max-width: 767px) { .con-pageoutline .box-pageoutline .box-title .sub-en { color: #fff; font-weight: 200; opacity: 0.8; font-size: 1.2rem; } }
.con-pageoutline .box-pageoutline .box-title h1 { font-family: "Shippori Mincho", serif; font-weight: 500; font-style: normal; font-size: 4rem; letter-spacing: 0.08em; }
@media (min-width: 768px) and (max-width: 1024px) { .con-pageoutline .box-pageoutline .box-title h1 { font-size: 3.6rem; } }
@media (max-width: 767px) { .con-pageoutline .box-pageoutline .box-title h1 { color: #fff; font-size: 3.2rem; } }
.con-pageoutline .box-pageoutline .txt-lead { margin-top: 7.8vh; line-height: 2; letter-spacing: 0.08em; }
@media (min-width: 768px) and (max-width: 1024px) { .con-pageoutline .box-pageoutline .txt-lead { margin-top: 3vh; font-size: 1.4rem; } }
@media (max-width: 767px) { .con-pageoutline .box-pageoutline .txt-lead { width: 83.6%; margin-left: auto; margin-right: auto; } }
.con-pageoutline .box-pageoutline .title-primary { text-align: left; }
.con-pageoutline.noimg { padding: 240px 0 80px; }
@media (min-width: 768px) and (max-width: 1024px) { .con-pageoutline.noimg { padding: 160px 0 64px; } }
@media (max-width: 767px) { .con-pageoutline.noimg { padding: 80px 0 64px; } }
@media (min-width: 768px) { .con-pageoutline.noimg .box-pageoutline { width: 100%; padding-top: 0; } }

/* -----------------------------------------------------------
	パーツ
----------------------------------------------------------- */
.button-basic a { display: flex; align-items: center; gap: 16px; border: 1px solid #DEDEDE; -webkit-border-radius: 4px; -moz-border-radius: 4px; -ms-border-radius: 4px; border-radius: 4px; padding: 12px 24px; background-image: url(../images/common/icon-arrow-base.svg); background-position: calc(100% - 16px) center; background-repeat: no-repeat; background-size: auto 16px; position: relative; min-height: 56px; line-height: 1.1; font-weight: 500; -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; }
@media (hover: hover) { .button-basic a:hover { background-position: calc(100% - 8px) center; } }
.button-basic a:after { content: ""; width: 1px; height: calc(100% - 32px); position: absolute; top: 50%; right: 40px; transform: translate(0, -50%); border-left: 1px dashed #DEDEDE; }
.button-basic.blank a { background-image: url(../images/common/icon-blank.svg); background-size: auto 8px; }
.button-basic.black a { border: 1px solid #2B2B2B; background-color: #2B2B2B; background-image: url(../images/common/icon-arrow-base-wh.svg); color: #fff; }
.button-basic.black a:after { border-left: 1px dashed rgba(255, 255, 255, 0.5); }
.button-basic.black_blank a { border: 1px solid #2B2B2B; background-color: #2B2B2B; background-image: url(../images/common/icon-blank-wh.svg); background-size: auto 8px; color: #fff; }
.button-basic.black_blank a:after { border-left: 1px dashed rgba(255, 255, 255, 0.5); }
.button-basic.red a { border: 1px solid #7C2020; background-color: #7C2020; background-image: url(../images/common/icon-arrow-base-wh.svg); color: #fff; }
.button-basic.red a:after { border-left: 1px dashed rgba(255, 255, 255, 0.5); }

.button-secondary a { display: flex; align-items: center; gap: 16px; border-bottom: 1px solid #DEDEDE; padding: 12px 0; background-image: url(../images/common/icon-arrow-base.svg); background-position: calc(100% - 16px) center; background-repeat: no-repeat; background-size: auto 16px; position: relative; font-size: 1.8rem; line-height: 1.1; -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; }
@media (hover: hover) { .button-secondary a:before { content: ""; background-color: #2B2B2B; width: 0; height: 1px; position: absolute; bottom: 0; left: 0; -webkit-transition: 0.5s; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; transition: 0.5s; }
  .button-secondary a:hover { background-position: calc(100% - 8px) center; }
  .button-secondary a:hover:before { width: 100%; } }
@media (max-width: 767px) { .button-secondary a { font-size: 1.4rem; } }
.button-secondary a:after { content: ""; width: 1px; height: calc(100% - 32px); position: absolute; top: 50%; right: 40px; transform: translate(0, -50%); border-left: 1px dashed #DEDEDE; }
.button-secondary.blank a { background-image: url(../images/common/icon-blank.svg); background-size: auto 8px; }

.title-primary { line-height: 1; }
.title-primary span { display: block; }
.title-primary span.number { font-family: "Outfit", serif; font-optical-sizing: auto; font-weight: 300; font-style: normal; font-size: 1.5rem; letter-spacing: 0.08em; margin-bottom: 21px; }
@media (max-width: 767px) { .title-primary span.number { font-size: 1.2rem; margin-bottom: 24px; } }
.title-primary span.main { font-family: "Marcellus", serif; font-weight: 400; font-style: normal; font-size: 9.6rem; line-height: 1.25; }
@media (max-width: 767px) { .title-primary span.main { font-size: 6.4rem; } }
.title-primary span.jp { font-family: "Shippori Mincho", serif; font-weight: 500; font-style: normal; font-size: 2rem; line-height: 1.5; margin-top: 16px; letter-spacing: 0.08em; }
@media (max-width: 767px) { .title-primary span.jp { margin-top: 8px; } }

.title-secondary span { display: block; }
.title-secondary span.en { color: #888; font-family: "Outfit", serif; font-optical-sizing: auto; font-weight: 400; font-style: normal; line-height: 1; font-size: 1.4rem; letter-spacing: 0.08em; margin-bottom: 24px; }
@media (max-width: 767px) { .title-secondary span.en { font-size: 1.2rem; margin-bottom: 16px; } }
.title-secondary span.jp { font-family: "Shippori Mincho", serif; font-weight: 500; font-style: normal; line-height: 1; letter-spacing: 0.08em; font-size: 3.6rem; }
@media (max-width: 767px) { .title-secondary span.jp { font-size: 2.6rem; line-height: 1.4; } }

.bg-gray { background: rgba(0, 0, 0, 0.05); }

/* -----------------------------------------------------------
	inview
----------------------------------------------------------- */
.anime-fade-in { opacity: 0; mask-image: linear-gradient(to bottom, #ffffff, #ffffff 33%, rgba(0, 0, 0, 0) 66%, rgba(0, 0, 0, 0) 100%); -webkit-mask-image: linear-gradient(to bottom, #ffffff, #ffffff 33%, rgba(0, 0, 0, 0) 66%, rgba(0, 0, 0, 0) 100%); mask-size: 100% 300%; -webkit-mask-size: 100% 300%; mask-position: 0 100%; -webkit-mask-position: 0 100%; transition: all 1.2s ease-out; will-change: opacity, transform, mask-position; }
.anime-fade-in.js-inview-in { opacity: 1; -webkit-mask-position: 0 0; mask-position: 0 0; }

.anime-fade-out { opacity: 1; mask-image: linear-gradient(to bottom, #ffffff, #ffffff 33%, rgba(0, 0, 0, 0) 66%, rgba(0, 0, 0, 0) 100%); -webkit-mask-image: linear-gradient(to bottom, #ffffff, #ffffff 33%, rgba(0, 0, 0, 0) 66%, rgba(0, 0, 0, 0) 100%); mask-size: 100% 300%; -webkit-mask-size: 100% 300%; -webkit-mask-position: 0 0; mask-position: 0 0; transition: all 1.2s ease-out; will-change: opacity, transform, mask-position; }
.anime-fade-out.js-inview-out { opacity: 0; mask-position: 0 100%; -webkit-mask-position: 0 100%; transition-delay: 1s; }
