@charset "UTF-8";
@import url(reset.css);
@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@300&family=Noto+Sans+JP:wght@300;400&family=Noto+Serif+JP:wght@300;400&display=swap");
/*-----------------*/
/* body */
html { font-size: 10px; }
@media screen and (max-width: 600px) { html { font-size: 9px; } }
@media screen and (max-width: 320px) { html { font-size: 8px; } }

body { font-family: "Times New Roman", 'Noto Serif JP', "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif; font-weight: normal; font-feature-settings: "palt"; line-height: 1.6; color: #323232; 	/*@media screen and (max-width:$bp01){ padding-top: 160px;
	}*/ }
body *, body *:before, body *:after { -webkit-box-sizing: border-box; box-sizing: border-box; }
@media screen and (max-width: 600px) { body { padding-top: 3.75rem; } }

h1 { width: 98%; padding: 0.25rem 0 0.5rem; font-size: 0.5625em; max-width: 1400px; margin: 0 auto; font-size: 1rem; color: #616161; font-family: "Helvetica Neue", "Helvetica","Yu Gothic",  'Noto Sans JP', "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Meiryo", sans-serif; font-weight: normal; }
@media screen and (max-width: 864px) { h1 { padding: 0.25rem 0 0.5rem; } }
@media screen and (max-width: 768px) { h1 { display: none; } }

h2, h3, h4, h5 { font-weight: normal; }

a { text-decoration: none; color: #000; }

img { vertical-align: bottom; }

sup { vertical-align: text-top; font-size: small; }

.aw { display: inline-block; }

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

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

.cap { font-size: .625rem; line-height: 1; }

.flexBox { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -webkit-box-align: start; -ms-flex-align: start; align-items: flex-start; }
.flexBox div, .flexBox li { min-height: 0%; }
.flexBox.box2 > li, .flexBox.box2 > div, .flexBox.box2 > p, .flexBox.box2 > span { width: 47%; }
.flexBox.box3 > li, .flexBox.box3 > div, .flexBox.box3 > p, .flexBox.box3 > span { width: 31%; }
.flexBox.box4 > li, .flexBox.box4 > div, .flexBox.box4 > p, .flexBox.box4 > span { width: 23%; }
.flexBox > li.w100, .flexBox > div.w100, .flexBox > p.w100, .flexBox > span.w100 { width: 100% !important; }
@media screen and (max-width: 639px) { .flexBox.box2 > li, .flexBox.box2 > div, .flexBox.box2 > p, .flexBox.box2 > span { width: 100%; margin-bottom: 3rem; }
  .flexBox.box2 > li:last-child, .flexBox.box2 > div:last-child, .flexBox.box2 > p:last-child, .flexBox.box2 > span:last-child { margin-bottom: 0; }
  .flexBox.box3 > li, .flexBox.box3 > div, .flexBox.box3 > p, .flexBox.box3 > span { width: 100%; margin-bottom: 3rem; }
  .flexBox.box3 > li:last-child, .flexBox.box3 > div:last-child, .flexBox.box3 > p:last-child, .flexBox.box3 > span:last-child { margin-bottom: 0; }
  .flexBox.box4 > li, .flexBox.box4 > div, .flexBox.box4 > p, .flexBox.box4 > span { width: 100%; margin-bottom: 3rem; }
  .flexBox.box4 > li:last-child, .flexBox.box4 > div:last-child, .flexBox.box4 > p:last-child, .flexBox.box4 > span:last-child { margin-bottom: 0; } }

section > .inner { max-width: 1080px; width: 90%; margin: auto; }

.sec_ttl_en { text-align: center; margin-bottom: 2rem; position: relative; }
.sec_ttl_en::before, .sec_ttl_en::after { content: ""; display: block; width: calc(50% - 160px); height: 1px; background: #88949D; position: absolute; top: 50%; }
.sec_ttl_en::before { left: 0; }
.sec_ttl_en::after { right: 0; }
.sec_ttl_en img { height: 4.6rem; width: auto; margin: auto; }
@media screen and (max-width: 600px) { .sec_ttl_en::before, .sec_ttl_en::after { width: calc(50% - 100px); }
  .sec_ttl_en img { height: 3.6rem; } }

.sec_ttl_icon { text-align: center; margin-bottom: 5rem; }
.sec_ttl_icon img { height: 7rem; width: auto; }

.mainvisual { width: 100%; margin: 0 auto; max-width: 1408px; position: relative; }
.mainvisual img { width: 100%; height: auto; }
.mainvisual .cap { bottom: 2rem; right: 2rem; }

#main { position: relative; }
#main img { width: 100%; height: auto; line-height: 0; vertical-align: middle; }
#main .mv-inner { width: 84%; max-width: 960px; margin: auto; position: relative; }
#main .page-title { width: calc((66/960)*100%); position: absolute; left: 0; top: 4rem; }
#main .image-container { width: calc((480/960)*100%); padding-top: 8rem; margin: 0 8% 0 auto; }
#main .image-container .mv-head { margin-bottom: 2.4rem; }
@media screen and (max-width: 600px) { #main .page-title { width: calc((66/624)*100%); top: 16px; }
  #main .image-container { width: calc((400/624)*100%); margin-top: 6%; }
  #main .image-container .mv-head { margin-bottom: 12px; } }

#anchor { display: block; height: 170px; position: absolute; top: 0; }
@media screen and (max-width: 600px) { #anchor { height: 0; } }

.contents-wrap { width: 100%; margin: auto; padding: 0; }
.contents-wrap img { width: 100%; height: auto; line-height: 0; vertical-align: middle; }

.cont-inner { width: 86%; max-width: 1056px; margin: auto; padding: 0; }
.cont-inner .note-area { width: 100%; }

.maincopy { font-size: min(3vw, 3.2rem); color: #212121; text-align: left; line-height: 1.44; letter-spacing: 0.1em; font-weight: 500; margin: 0 auto 2rem; }
@media screen and (max-width: 600px) { .maincopy { font-size: min(4.75vw, 22px); } }

.lead { font-size: min(2.125vw, 1.6rem); color: #323232; line-height: 1.68; font-feature-settings: 'palt'; margin: 0 auto; }
.lead .acc { color: #39baae; }
@media screen and (max-width: 600px) { .lead { font-size: min(3.5vw, 13px); } }

/* contents common parts */
.pankuzu { width: 100%; background-color: #F4F4F4; color: #787878; }
.pankuzu ul { display: flex; justify-content: flex-start; align-items: center; font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif"; max-width: 1400px; margin: 0 auto; padding: 0.5rem 0; }
.pankuzu .arrow { margin: 0 1rem; }
.pankuzu a { text-decoration: underline; color: #787878; }
@media screen and (max-width: 1430px) { .pankuzu ul { margin-left: 1rem; } }
@media screen and (max-width: 768px) { .pankuzu { display: none; } }

.intro { width: 100%; margin: 0 auto 4.5rem; }

.contents-box { width: 100%; margin: 0 auto 5rem; }

.contents-ttl { color: #002f7b; text-align: center; font-weight: 300; line-height: 1.44; margin: 3.5rem  auto 1.5rem; }
.contents-ttl.en { font-size: 2rem; letter-spacing: 0.1em; font-family: "Helvetica Neue", "Helvetica","Yu Gothic",  'Noto Sans JP', "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Meiryo", sans-serif; font-weight: normal; /*@include en1;*/ }
.contents-ttl.ja { font-size: 1em; }

@media screen and (max-width: 600px) { .object-scroll-wrapper { overflow-x: scroll; margin-inline: calc(50% - 50vw); }
  .object-scroll-wrapper > .scroll-inner { padding: 0.8rem 1rem 2.8rem; }
  .object-scroll-wrapper > .scroll-inner > img { width: 160%; height: auto; object-fit: cover; }
  .object-scroll-wrapper + .cap { margin-inline: calc(50% - 50vw); }
  .object-scroll-wrapper + .cap.in { padding-right: 1rem; }
  .object-scroll-wrapper > ul { padding: 0 1rem 0.8rem; gap: 1rem; /*    & > li{ width: 188px; } */ } }

.slide-notice { margin-top: 1rem; display: flex; justify-content: center; flex-wrap: wrap; align-items: center; gap: 0 1rem; }
.slide-notice .icon { max-width: 32px; }
.slide-notice .text { font-size: 12px; }
.slide-notice .arrow { width: 100%; }
.slide-notice .arrow img { width: 100%; height: auto; }

.img { position: relative; }
.img img { width: 100%; height: auto; }
.img .cap { font-size: 1.1rem; font-family: "Helvetica Neue", "Helvetica","Yu Gothic",  'Noto Sans JP', "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Meiryo", sans-serif; font-weight: normal; }
.img .cap.in { position: absolute; display: inline-block; bottom: 5px; right: 5px; color: #fff; text-shadow: #222 0 0 2px, #222 0 0 3px, #222 0 0 4px, #222 0 0 5px; text-align: right; line-height: 1.2; }
.img .cap.in.left { right: auto; left: 5px; }
.img .cap.out { display: block; text-align: right; margin-top: 0.25rem; color: #333; }
.img .cap.out.left { text-align: left; }
.img .cap.bk { color: #333; text-shadow: none; }

.note-area { width: 100%; background: #fff; padding: 1.5rem 0; margin: 2rem auto 0; }
.note-area .note { width: 100%; max-width: 1056px; margin: auto; text-align: left; color: #424242; line-height: 1.6; }
.note-area.tal-right .note { text-align: right; }
@media screen and (max-width: 1024px) { .note-area { width: 96%; } }

.note { font-size: 1.1rem; font-family: "Helvetica Neue", "Helvetica","Yu Gothic",  'Noto Sans JP', "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Meiryo", sans-serif; font-weight: normal; }

/*-----------------------------
 pickup

------------------------------*/
.pickup_icon { -webkit-mask-image: url("../images/share/pickup_e.webp"); -webkit-mask-size: cover; width: 40%; max-width: 260px; margin: 5rem auto 0rem; }
.pickup_icon .pickup-color { display: block; width: 100%; padding-bottom: calc(80 / 360 * 100%); }

.pickup_txt { font-family: "Helvetica Neue", "Helvetica","Yu Gothic",  'Noto Sans JP', "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Meiryo", sans-serif; font-weight: normal; }

/*-----------------------------
 header 

------------------------------*/
header { background: #fff; width: 100%; position: fixed; z-index: 101; left: 0; top: 0; border-bottom: 1px solid #ddd; }
header .sp_gnav_sub { display: none; }

.headerbody { width: 100%; margin: auto; }
.headerbody .inner { position: relative; width: 96%; max-width: 1400px; padding: 0 1rem 0rem 0; margin: auto; height: 64px; }
@media screen and (max-width: 768px) { .headerbody .inner { height: 55px; width: 100%; } }
.headerbody .menu { position: absolute; top: 10px; width: 70px; right: 0px; display: none; }
.headerbody .menu img { width: 100%; height: auto; }
@media screen and (max-width: 768px) { .headerbody .menu { display: block; } }
.headerbody h2 { display: inline-block; line-height: 1; width: 72%; max-width: 292px; margin-top: 0.5rem; margin-bottom: 0; }
.headerbody h2 img { width: 100%; height: auto; display: block; }
@media screen and (max-width: 768px) { .headerbody h2 { margin-left: 5%; } }
.headerbody .snav { position: absolute; top: 40%; -webkit-transform: translateY(-50%); transform: translateY(-50%); right: 0; width: 70%; max-width: 1000px; /*padding-right: 1rem;*/ }
.headerbody .snav ul { text-align: right; padding: 0; display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; -webkit-box-pack: end; -ms-flex-pack: end; justify-content: flex-end; -webkit-box-align: center; -ms-flex-align: center; align-items: center; }
.headerbody .snav ul div, .headerbody .snav ul li { min-height: 0%; }
.headerbody .snav ul li { display: inline-block; margin: 0; font-size: 1.4rem; letter-spacing: 0.1rem; text-align: center; -webkit-transition: 0.3s ease 0s opacity; transition: 0.3s ease 0s opacity; }
.headerbody .snav ul li + li { margin-left: 2rem; }
.headerbody .snav ul li a { display: block; vertical-align: middle; }
.headerbody .snav ul li.index a, .headerbody .snav ul li.access a, .headerbody .snav ul li.map a, .headerbody .snav ul li.outline a { position: relative; }
.headerbody .snav ul li.index a::before, .headerbody .snav ul li.access a::before, .headerbody .snav ul li.map a::before, .headerbody .snav ul li.outline a::before { content: ""; display: inline-block; margin-right: 0.8rem; vertical-align: text-top; width: 1.2rem; height: 1.2rem; background: url("../images/share/arrow01.png") center center no-repeat; background-size: cover; }
.headerbody .snav ul li.index a::after, .headerbody .snav ul li.access a::after, .headerbody .snav ul li.map a::after, .headerbody .snav ul li.outline a::after { position: absolute; bottom: -2px; left: 0; content: ''; width: 100%; height: 2px; background: #002f7b; transform: scale(0, 1); transform-origin: left top; transition: transform .3s; }
.headerbody .snav ul li.index a:hover::after, .headerbody .snav ul li.access a:hover::after, .headerbody .snav ul li.map a:hover::after, .headerbody .snav ul li.outline a:hover::after { transform: scale(1, 1); }
.headerbody .snav ul li.request, .headerbody .snav ul li.reserved { margin-left: 3rem; }
.headerbody .snav ul li.request a, .headerbody .snav ul li.reserved a { width: 18rem; height: 4rem; display: block; position: relative; transition: .3s; }
.headerbody .snav ul li.request a .txt, .headerbody .snav ul li.reserved a .txt { position: absolute; font-size: 1.6rem; line-height: 1.5; white-space: nowrap; transform: translateX(-50%) translateY(-50%); top: 50%; height: 50%; }
.headerbody .snav ul li.request { margin-left: 3.2rem; }
.headerbody .snav ul li.request a { background-color: #002f7b; color: #fff; }
.headerbody .snav ul li.request a:hover { filter: brightness(120%); }
@media screen and (max-width: 864px) { .headerbody .inner { padding: 0 0 0.5rem; }
  .headerbody h2 { max-width: 240px; } }
@media screen and (max-width: 768px) { .headerbody h2 { max-width: 200px; margin-top: 10px; }
  .headerbody .snav { display: none; } }

/*-----------------------------
 nav 

------------------------------*/
.gnav_container { width: 100%; background-color: #fff; }
@media screen and (max-width: 600px) { .gnav_container { display: none; } }

.gnav_inner { width: 100%; margin: 0 auto; }

.gnav { width: 100%; margin: 0 auto; }
.gnav li { text-align: center; position: relative; z-index: 1; }
.gnav li a .new, .gnav li .soon .new { width: 3rem; background: #e3351e; position: absolute; top: 0; right: 0; color: #fff; font-size: 0.8; line-height: 1; padding: 0.1rem; }
@media screen and (max-width: 600px) { .gnav li { width: 50%; } }

/* header grobalnav */
.hnav::after { content: ""; position: absolute; width: 100%; height: 0.375rem; bottom: 0; left: 0; background-color: #eceff1; }
.hnav .gnav { max-width: 1408px; display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: stretch; -ms-flex-align: stretch; align-items: stretch; }
.hnav .gnav div, .hnav .gnav li { min-height: 0%; }
.hnav .gnav li { width: 12%; border-right: 1px solid #eee; 			/*&.concept{ a { &::after { background: $con01; } }
			}
			&.access{ a { &::after { background: $con02; } }
			}
			&.location{ a { &::after { background: $con03; } }
			}
			&.plan{ a { &::after { background: $con04; } }
			}
			&.design{ a { &::after { background: $con05; } }
			}
			&.brand{ a { &::after { background: $con06; } }
			}
			&.quality{ a { &::after { background: $con07; } }
			}
			&.select{ a { &::after { background: $con08; } }
			}
			&.modelroom{ a { &::after { background: $con09; } }
			}*/ }
.hnav .gnav li.index { border-left: 1px solid #eee; /*a { &::after { background: $color1; }
}*/ }
.hnav .gnav li.map, .hnav .gnav li.outline, .hnav .gnav li.entry { display: none; }
.hnav .gnav li a, .hnav .gnav li .soon { display: block; width: 100%; text-align: center; position: relative; height: 40px; }
.hnav .gnav li a .txt, .hnav .gnav li .soon .txt { color: #707070; text-align: center; position: absolute; top: 50%; left: 50%; transform: translateX(-50%) translateY(-50%); line-height: 1; }
.hnav .gnav li a .txt .en, .hnav .gnav li .soon .txt .en { font-family: "Cormorant Garamond", serif; font-optical-sizing: auto; font-weight: normal; font-style: normal; white-space: nowrap; display: block; font-size: 1rem; margin-top: 0.2rem; }
.hnav .gnav li a .txt .kana, .hnav .gnav li .soon .txt .kana { white-space: nowrap; display: block; font-size: 1.4rem; }
.hnav .gnav li a { position: relative; }
.hnav .gnav li a:after { content: ""; position: absolute; bottom: 0; left: 0; width: 100%; height: 3px; transition: 0.5s; opacity: 0.88; background: #808080; }
.hnav .gnav li a:hover .txt { color: #1d2088; }
.hnav .gnav li a:hover:after { opacity: 1; background-color: #002f7b; }
.hnav .gnav li .soon .txt { opacity: 0.3; }
.hnav .gnav li.current a .txt { color: #1d2088; }
.hnav .gnav li.current a:after { background-color: #002f7b; opacity: 1; }
@media screen and (max-width: 768px) { .hnav { display: none; } }

/*----------------*/
/* txtNav */
.txtNav { border-top: 1px solid #ddd; width: 100%; background: #fff; padding-bottom: 1.5rem; margin: auto; }
.txtNav .txtNav_inner { text-align: center; }
.txtNav .txtNav_inner .gnav { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: stretch; -ms-flex-align: stretch; align-items: stretch; width: 100%; max-width: 1040px; margin: 0 auto; padding: 0; padding-top: 2.5rem; padding-bottom: 1rem; }
.txtNav .txtNav_inner .gnav div, .txtNav .txtNav_inner .gnav li { min-height: 0%; }
.txtNav .txtNav_inner .gnav li { width: auto; background: none; padding: 0 1.3rem; margin: 0.25rem 0; font-family: "Helvetica Neue", "Helvetica","Yu Gothic",  'Noto Sans JP', "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Meiryo", sans-serif; font-weight: normal; letter-spacing: 0.01em; overflow: visible; }
.txtNav .txtNav_inner .gnav li a, .txtNav .txtNav_inner .gnav li .soon { padding: 0; font-weight: 300; color: #212121; text-align: center; }
.txtNav .txtNav_inner .gnav li a .txt, .txtNav .txtNav_inner .gnav li .soon .txt { position: static; width: auto; display: inline; font-size: 1.2rem; }
.txtNav .txtNav_inner .gnav li a .txt .en, .txtNav .txtNav_inner .gnav li .soon .txt .en { display: none; }
.txtNav .txtNav_inner .gnav li a { position: relative; transition: transform 0.3s ease; }
.txtNav .txtNav_inner .gnav li a::after { content: ""; display: block; width: 100%; height: 0.25rem; position: absolute; bottom: -0.5rem; left: 0; opacity: 0; }
.txtNav .txtNav_inner .gnav li a:hover { color: #002f7b; }
.txtNav .txtNav_inner .gnav li .soon .txt { opacity: 0.3; }
.txtNav .txtNav_inner .gnav li.current a { font-weight: bold; color: #002f7b; }
.txtNav .txtNav_inner .new { display: none; }
.txtNav .sp_gnav_sub { display: none; }
@media screen and (max-width: 1024px) { .txtNav .txtNav_inner .gnav li { padding: 0 1rem; } }
@media screen and (max-width: 768px) { .txtNav { padding-bottom: 0rem; border-top: none; }
  .txtNav .txtNav_inner .gnav { width: 100%; display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -webkit-box-align: stretch; -ms-flex-align: stretch; align-items: stretch; border-bottom: solid thin #e0e0e0; border-right: none; padding-top: 0; margin-top: 0; margin-bottom: 0; padding-bottom: 0rem; }
  .txtNav .txtNav_inner .gnav div, .txtNav .txtNav_inner .gnav li { min-height: 0%; }
  .txtNav .txtNav_inner .gnav li { width: 50%; padding: 0; margin: 0; border-top: solid thin #e0e0e0; border-right: solid thin #e0e0e0; font-size: 1em; }
  .txtNav .txtNav_inner .gnav li.entry { width: 100%; border-right: none; }
  .txtNav .txtNav_inner .gnav li.entry a { background-color: #002f7b; color: #fff; }
  .txtNav .txtNav_inner .gnav li.entry a:hover { filter: brightness(120%); }
  .txtNav .txtNav_inner .gnav li a, .txtNav .txtNav_inner .gnav li .soon { width: 100%; padding: 1.5rem 0; display: block; }
  .txtNav .txtNav_inner .gnav li a::after, .txtNav .txtNav_inner .gnav li .soon::after { content: ""; display: block; width: 100%; height: 2px; position: absolute; bottom: 0; left: 0; opacity: 0; }
  .txtNav .txtNav_inner .gnav li a { position: relative; }
  .txtNav .txtNav_inner .gnav li a:hover { border-bottom: none; } }

/*-------------*/
/* spnav */
#spnavArea { width: 100%; position: fixed; top: 55px; left: 0; z-index: 100; display: none; }
@media screen and (max-width: 768px) { #spnavArea { display: block; } }
#spnavArea .spnav_list { width: 100%; height: 100vh; position: absolute; top: 0; left: 0; background-color: #fff; z-index: 100; }
#spnavArea .spnav_list .gnav { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -webkit-box-align: stretch; -ms-flex-align: stretch; align-items: stretch; }
#spnavArea .spnav_list .gnav div, #spnavArea .spnav_list .gnav li { min-height: 0%; }
#spnavArea .spnav_list .gnav li { width: 50%; border-right: 1px solid #ddd; border-top: 1px solid #ddd; /*a{
	position:relative;
	&:after{
		content: "";
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 3px;
		transition: 0.5s;
		background: #efece4;
	}
	&:hover{
		&:after{
			background: $color1;
		}
	}
}*/ }
#spnavArea .spnav_list .gnav li a, #spnavArea .spnav_list .gnav li .soon { display: block; width: 100%; text-align: center; position: relative; height: 58px; background-color: #fff; }
#spnavArea .spnav_list .gnav li a::after, #spnavArea .spnav_list .gnav li .soon::after { content: none; }
#spnavArea .spnav_list .gnav li a .txt, #spnavArea .spnav_list .gnav li .soon .txt { text-align: center; position: absolute; top: 50%; left: 50%; transform: translateX(-50%) translateY(-50%); line-height: 1; }
#spnavArea .spnav_list .gnav li a .txt .en, #spnavArea .spnav_list .gnav li .soon .txt .en { font-family: "Cormorant Garamond", serif; font-optical-sizing: auto; font-weight: normal; font-style: normal; white-space: nowrap; display: none; font-size: 2rem; font-weight: normal; margin-top: 0.2rem; color: #a38a78; }
#spnavArea .spnav_list .gnav li a .txt .kana, #spnavArea .spnav_list .gnav li .soon .txt .kana { white-space: nowrap; /*display: none;*/ font-size: 1.4rem; }
#spnavArea .spnav_list .gnav li .soon { background: #f9f9f9; opacity: 0.5; }
#spnavArea .spnav_list .gnav li.current a { color: #002f7b; background: #ecf2f8; }
#spnavArea .spnav_list .gnav li.map, #spnavArea .spnav_list .gnav li.outline, #spnavArea .spnav_list .gnav li.entry { display: none !important; }
#spnavArea .sp_gnav_sub { text-align: center; max-width: 400px; width: 90%; margin: 2rem auto 0; }
#spnavArea .sp_gnav_sub li { display: inline-block; font-size: 1.5rem; }
#spnavArea .sp_gnav_sub li.out, #spnavArea .sp_gnav_sub li.map { margin: 0 10px; }
#spnavArea .sp_gnav_sub li.out a, #spnavArea .sp_gnav_sub li.map a { position: relative; }
#spnavArea .sp_gnav_sub li.out a::before, #spnavArea .sp_gnav_sub li.map a::before { content: ""; display: inline-block; box-sizing: border-box; width: 5px; height: 5px; border: 5px solid transparent; border-left: 5px solid #000; }
#spnavArea .sp_gnav_sub li.entry, #spnavArea .sp_gnav_sub li.reserved { width: 100%; margin-top: 2rem; }
#spnavArea .sp_gnav_sub li.entry a, #spnavArea .sp_gnav_sub li.reserved a { display: block; width: 100%; padding: 13px 0; background-color: #002f7b; color: #fff; color: #fff; font-size: 2.0rem; }

.spnav_container { width: 100%; z-index: 10000; position: fixed; font-size: 1rem; bottom: 0; background-color: #fff; border-top: thin solid #e0e0e0; display: none; }
@media screen and (max-width: 768px) { .spnav_container { display: block; } }

/*-----------------------------

wrap

------------------------------*/
.wrap { width: 96%; max-width: 1200px; margin: 0 auto; }

@media screen and (max-width: 600px) { h3 img { height: 16px; width: auto; } }

.copytext { text-align: center; line-height: 1.6; margin: 48px auto; }
.copytext img { margin-bottom: 5px; padding-left: 8px; }
@media screen and (max-width: 600px) { .copytext { margin: 32px auto; }
  .copytext img { height: 21px; width: auto; } }

/*-----------------------------

footer

------------------------------*/
footer { display: block; width: 100%; position: relative; border-top: 3px solid #002f7b; }

.freedial { width: 100%; background: #eee; }
.freedial ul { width: 100%; margin: 0 auto; max-width: none; padding: 3rem 0 3rem; text-align: center; }
.freedial ul li { text-align: left; display: inline-block; vertical-align: middle; color: #212121; font-size: 1rem; font-family: "Helvetica Neue", "Helvetica","Yu Gothic",  'Noto Sans JP', "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Meiryo", sans-serif; font-weight: normal; font-feature-settings: normal; }
.freedial ul li:nth-child(2) { width: 76%; max-width: 312px; margin: 0 2rem; }
.freedial ul li:nth-child(2) img { width: 100%; height: auto; }
.freedial ul li .note { font-size: 1rem; }

.company { width: 100%; text-align: center; }
.company ul { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; justify-content: center; align-items: flex-start; padding: 2rem 0; }
.company ul div, .company ul li { min-height: 0%; }
.company li { width: auto; margin-top: 2rem; margin-bottom: 2rem; font-family: "Helvetica Neue", "Helvetica","Yu Gothic",  'Noto Sans JP', "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Meiryo", sans-serif; font-weight: normal; font-size: 1rem; line-height: 1.6; text-align: left; }
.company li + li { margin-left: 4.5rem; }
.company li img { width: auto; height: 5rem; }

.copyright { width: 100%; padding: 0 0 2rem; margin: 0 auto; text-align: center; font-family: "Helvetica Neue", "Helvetica","Yu Gothic",  'Noto Sans JP', "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Meiryo", sans-serif; font-weight: normal; }
.copyright .note { text-align: center; margin: 0 auto; letter-spacing: 0.1em; }

@media screen and (max-width: 1024px) { .freedial ul li:nth-child(2) { margin: 0 1rem; } }
@media screen and (max-width: 864px) { .freedial ul { padding-top: 1.75rem; }
  .freedial ul li:nth-child(2) { width: 32%; margin: 0 1rem; } }
@media screen and (max-width: 768px) { .freedial ul li:nth-child(1) { width: 32%; }
  .freedial ul li:nth-child(2) { margin-left: 0; } }
@media screen and (max-width: 768px) { footer { padding-bottom: 10rem; }
  footer::after { height: 2vh; }
  .freedial ul { padding: 3rem 0; }
  .freedial ul li { text-align: center; width: 100%; }
  .freedial ul li:nth-child(1) { width: 100%; }
  .freedial ul li:nth-child(2) { width: 76%; margin: 1.5rem 0; }
  .company { padding: 1.25rem 0.5rem; }
  .company ul { flex-direction: column; }
  .company li { text-align: center; margin: auto auto 3rem; }
  .company li + li { margin-left: auto; }
  .copyright { padding-bottom: 2rem; } }
/*-----------------------------

CLOSE / PRINT Button

-------------------------------*/
.btn_container { width: 90%; max-width: 900px; padding: 3rem 0 0; margin: 0 auto; text-align: center; }
.btn_container ul { display: flex; flex-wrap: wrap; justify-content: center; /*justify-content: space-between;*/ align-items: flex-start; }
.btn_container .btn_cls { display: inline-block; width: 48%; /*width: 100%;*/ max-width: 400px; font-size: 1.4rem; background-color: #847758; margin: 0 1%; }
.btn_container .btn_cls a { -webkit-transition: all .2s linear; box-sizing: border-box; display: block; width: 100%; padding: 12px 0; border: 1px solid rgba(0, 0, 0, 0.15); background: #fff; color: #000 !important; text-align: center; text-decoration: none; }
.btn_container .btn_cls a:hover { background: #eee; }
@media screen and (max-width: 600px) { .btn_container { width: 80%; }
  .btn_container .btn_cls { width: 100%; }
  .btn_container .btn_pr { display: none; } }

/*-----------------------------

print

------------------------------*/
@media print { .snav, .subwin .btn_container, .btn_container, .conversion, .txtNav { display: none; }
  #outline .data caption { font-size: 10px !important; }
  #outline .data th, #outline .data td { font-size: 9px !important; padding: 5px !important; }
  body { padding-top: 0 !important; }
  header { display: none !important; } }
.conversion { margin: 4rem auto 6rem; }
.conversion ul { width: 100%; max-width: 1000px; margin: 0 auto; display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; }
.conversion ul div, .conversion ul li { min-height: 0%; }
.conversion ul li { width: 45%; max-width: 384px; }
.conversion ul li a { display: block; color: #fff; font-weight: bold; text-align: center; height: 6.5rem; width: 100%; position: relative; transition: .3s;   /*&:before{
	  content: "";
	  position: absolute;
	  z-index: 0;
	  top: 50%;
	  right: 1.5rem;
	  transform: translateY(-50%);
	  width: 2.2rem;
	  height: 2.2rem;
	  border-radius: 50%;
	  background: rgba(0,0,0,0.4); } &:after{
	  content: "▲";
	  position: absolute;
	  z-index: 1;
	  top: 50%;
	  right: 1.5rem;
	  transform: translateX(-50%) translateY(-50%) rotate(90deg);
	  color: #fff; }*/ }
.conversion ul li a .txt { position: absolute; top: 50%; left: 50%; transform: translateX(-50%) translateY(-50%); font-size: 2rem; white-space: nowrap; }
.conversion ul li + li { margin-left: 1rem; }
.conversion ul li.request a { background-color: #002f7b; color: #fff; padding: 1.5rem 0; }
.conversion ul li.request a img { width: 100%; max-width: 160px; height: auto; }
.conversion ul li.request a:hover { filter: brightness(120%); }
@media screen and (max-width: 600px) { .conversion ul li { width: 88%; }
  .conversion ul li a { font-size: 1em; }
  .conversion ul li + li { margin-left: 0; margin-top: 1rem; }
  .conversion ul li.request a, .conversion ul li.reserve a { padding: 1.25rem 0; }
  .conversion ul li.request a img, .conversion ul li.reserve a img { max-width: 136px; } }

.holiday { display: inline-block; color: #D50000; line-height: 1.6; }

.spnav_inner ul { display: flex; }
.spnav_inner ul li { width: calc(100% / 4); box-sizing: border-box; border-left: 1px solid #ddd; }
.spnav_inner ul li a { display: block; width: 100%; height: 45px; position: relative; background: #f9f9f9; }
.spnav_inner ul li a img { position: absolute; top: 50%; left: 50%; transform: translateX(-50%) translateY(-50%); width: 7rem; height: auto; }
.spnav_inner ul li.request a { background-color: #002f7b; color: #fff; }

/* pagetop
-----------------------------*/
#pagetop { position: fixed; right: 10px; bottom: 10px; z-index: 100; }

@media (max-width: 600px) { #pagetop { bottom: 75px; } }
.bnr_root { margin: 3rem auto 2rem; text-align: center; }
.bnr_root a:hover { opacity: 0.7; }
.bnr_root img { width: 100%; height: auto; max-width: 640px; }
