@charset "UTF-8";

/* ============================================================
	ビジュアル
============================================================ */
#visual {
	position: relative;
	height: 640px;
}
#visual .photo {
	width: 100%;
	height: 640px;
	background: no-repeat center / cover;
}
#visual .gallery {
	width: 100%;
}
#visual .gallery-carousel {
	width: 1020px;
	height: 640px;
	margin: 0 auto;
	overflow: visible!important;
}
#visual .gallery-carousel .swiper-slide {
	width: 1020px;
	text-align: center;
}
#visual .gallery-carousel .swiper-slide img {
	width: 1020px;
	height: 640px;
}
#visual .gallery .swiper-wrapper {
	transform: translate3d(-2044px, 0px, 0px);
}


/* ============================================================
	固定バナー
============================================================ */
#fixed-rb {
	position: fixed;
	width: 280px;
	right: 30px;
	bottom: 30px;
	z-index: 40;
	padding-bottom: constant(safe-area-inset-bottom);
	padding-bottom: env(safe-area-inset-bottom);
}
#fixed-rb .campaign-banner {
	text-align: right;
	cursor: pointer;
}
#fixed-rb .campaign-banner-img {
	width: 280px;
	height: 280px;
	box-shadow: 0 10px 20px rgba(0, 0, 0, .3);
}


/* ============================================================
	プロフィール
============================================================ */
#profile {
	padding: 120px 0 0;
}
#profile .headline {
	text-align: center;
}
#profile .headline-sub {
	font-size: 20px;
	color: #9b8a74;
	letter-spacing: .2em;
	text-indent: .2em;
}
#profile .headline-main {
	margin-top: 20px;
	font-size: 36px;
	letter-spacing: .2em;
	line-height: 1.5;
}
#profile .headline-desc {
	margin-top: 10px;
	font-size: 24px;
	letter-spacing: .1em;
	line-height: 1.5;
}
#profile .news {
	margin-top: 50px;
}
#profile .news-text {
	text-align: center;
	letter-spacing: .1em;
	line-height: 2;
}
#profile .news-text-label {
	display: inline-block;
	background: #9b8a74;
	padding: 0 10px 0 16px;
	color: #fff;
}
#profile .message {
	margin-top: 50px;
}
#profile .message-text {
	text-align: center;
	letter-spacing: .1em;
	line-height: 2;
}
#profile .campaign {
	position: relative;
	margin-top: 90px;
}
#profile .campaign-inner {
	display: flex;
	justify-content: space-between;
	width: 1120px;
	margin: 0 auto;
}
#profile .campaign .swiper {
	width: 100%;
	max-width: 1120px!important;
	height: 460px;
	margin: 0 auto!important;
}
#profile .campaign .swiper-slide {
	width: 340px;
	overflow: hidden;
	text-align: center;
}
#profile .campaign .swiper-pagination {
	bottom: 0;
}
#profile .campaign .swiper-pagination-bullet {
	width: 10px;
	height: 10px;
	margin: 0 10px;
	background: #ccc;
	opacity: 1;
	border: none;
	border-radius: 50%;
}
#profile .campaign .swiper-pagination-bullet-active {
	background: #9b8a74;
}
#profile .campaign .swiper-pagination-bullet:hover {
	background: #808080;
}
#profile .campaign-banner {
	text-align: center;
}
#profile .campaign-banner-img {
	width: 340px;
	height: 425px;
	cursor: pointer;
}
#profile .access {
	display: flex;
	justify-content: space-between;
	width: 1200px;
	margin: 90px auto 0;
}
#profile .access-inner {
	width: 560px;
}
#profile .map {
	height: 350px;
	text-align: center;
}
#profile .map-iframe {
	width: 560px;
	height: 350px;
}
#profile .gallery {
	width: 560px;
	margin: 8px auto 0;
}
#profile .gallery-photo {
	float: left;
	width: 276px;
}
#profile .gallery-photo:nth-of-type(2n) {
	margin-left: 8px;
}
#profile .gallery-photo-img {
	width: 276px;
	height: 202px;
}
#profile .data {
	width: 560px;
}
#profile .data-table {
	width: 100%;
}
#profile .data-tr {
	border-bottom: solid 1px #ccc;
}
#profile .data-th {
	width: 160px;
	padding: 20px 20px;
	text-align: left;
	letter-spacing: .1em;
	line-height: 2.25;
	vertical-align: top;
}
#profile .data-th::before {
	content: '■';
	color: #9b8a74;
}
#profile .data-td {
	padding: 20px 0;
	text-align: left;
	letter-spacing: .1em;
	line-height: 2.25;
	vertical-align: top;
}
#profile .data-td a {
	text-decoration: underline;
}
#profile .link {
	margin-top: 40px;
	display: flex;
	justify-content: center;
}
#profile .link-icon {
	margin: 0 20px;
}
#profile .link-icon-img {
	width: 50px;
	height: 50px;
}


/* ============================================================
	営業日カレンダー
============================================================ */
#calendar {
	padding: 120px 0;
}
#calendar .headline {
	text-align: center;
}
#calendar .headline-sub {
	font-size: 20px;
	color: #9b8a74;
	letter-spacing: .2em;
	text-indent: .2em;
}
#calendar .headline-main {
	margin-top: 20px;
	font-size: 36px;
	letter-spacing: .2em;
	line-height: 1.5;
}
#calendar .headline-desc {
	margin-top: 30px;
	letter-spacing: .1em;
	line-height: 2;
}
#calendar .headline-desc-a {
	text-decoration: underline;
}
#calendar .calendar-wrap {
	margin-top: 40px;
}
#calendar .calendar-note {
	width: 1020px;
	margin: 0 auto;
}
#calendar .calendar-note-text {
	position: relative;
	text-align: right;
	letter-spacing: .1em;
	line-height: 2;
}
#calendar .calendar-note-text::before {
	content: '●';
	color: rgba(204, 51, 51, .3);
	margin-right: 4px;
}
#calendar .calendar-ul {
	display: flex;
	justify-content: space-between;
	width: 1020px;
	margin: 0 auto;
}
#calendar .calendar-li {
	position: relative;
	width: 470px;
}
#calendar .calendar-li:not(:last-child) {
	margin-bottom: 60px;
}
#calendar .calendar-month {
	width: 100%;
	padding: 15px 0;
	border-top: solid 1px #b3b3b3;
	border-bottom: solid 1px #b3b3b3;
	font-size: 20px;
	letter-spacing: .1em;
	text-align: center;
}
#calendar .calendar-table {
	width: 100%;
	margin: 14px 0;
}
#calendar .calendar-tr {
	line-height: 54px;
}
#calendar .calendar-week {
	position: relative;
	text-align: center;
	letter-spacing: .05em;
	text-indent: .05em;
}
#calendar .calendar-week:nth-of-type(6) {
	color: #336699;
}
#calendar .calendar-week:nth-of-type(7) {
	color: #cc6666;
}
#calendar .calendar-day {
	position: relative;
	font-size: 18px;
	color: #333;
	text-align: center;
	letter-spacing: .05em;
	text-indent: .05em;
}
#calendar .calendar-day.close {
	color: #fff;
	text-decoration: line-through;
}
#calendar .calendar-day.close::before {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	right: 0;
	left: 0;
	transform: translateY(-50%);
	margin: 0 auto;
	width: 30px;
	height: 30px;
	border-radius: 50%;
	background: rgba(204, 51, 51, .3);
	z-index: -1;
}
#calendar .calendar-day:nth-of-type(6) {
	color: #336699;
}
#calendar .calendar-day:nth-of-type(7) {
	color: #cc6666;
}
#calendar .calendar-button {
	margin-top: 50px;
	text-align: center;
}
#calendar .calendar-button-more {
	letter-spacing: .1em;
	cursor: pointer;
}
#calendar .calendar-button-more span {
	margin-left: 4px;
	text-decoration: underline;
}



/* ============================================================
	キャンペーン
============================================================ */
#topics {
	padding: 0 0 120px;
}
#topics .banner {
	position: relative;
	width: 1120px;
	margin: 0 auto;
}
#topics .banner-photo {
	text-align: center;
}
#topics .banner-photo-img {
	width: 1120px;
	height: 308px;
}


/* ============================================================
	予約
============================================================ */
#appoint {
	padding: 120px 0;
	background: url(../images-common/background-pattern.jpg) center;
	background-size: 200px 200px;
}
#appoint .headline {
	text-align: center;
}
#appoint .headline-sub {
	font-size: 20px;
	color: #9b8a74;
	letter-spacing: .2em;
	text-indent: .2em;
}
#appoint .headline-main {
	margin-top: 20px;
	font-size: 36px;
	letter-spacing: .2em;
	line-height: 1.5;
}
#appoint .headline-desc {
	margin-top: 40px;
	letter-spacing: .1em;
	line-height: 2;
}
#appoint .button {
	margin: 50px auto 0;
	width: 840px;
}
#appoint .button-ul {
	width: 840px;
}
#appoint .button-li:not(:first-of-type) {
	margin-left: 20px;
}
#appoint .button-li {
	float: left;
	width: 400px;
}
#appoint .button-li-a {
	display: block;
	width: 400px;
	height: 70px;
	line-height: 70px;
	background: #f2e982;
	text-align: center;
	font-size: 26px;
	letter-spacing: .1em;
	text-indent: .1em;
	border-radius: 50px;
}


/* ============================================================
	スタジオ紹介
============================================================ */
#studio {
	padding: 120px 0 160px;
}
#studio .headline {
	text-align: center;
}
#studio .headline-sub {
	font-size: 20px;
	color: #9b8a74;
	letter-spacing: .2em;
	text-indent: .2em;
}
#studio .headline-main {
	margin-top: 20px;
	font-size: 36px;
	letter-spacing: .2em;
	line-height: 1.5;
}
#studio .spot {
	margin-top: 80px;
}
#studio .spot-ul {
}
#studio .spot-li {
	position: relative;
}
#studio .spot-li:not(:first-of-type) {
	margin-top: 150px;
}
#studio .spot-headline {
	text-align: center;
}
#studio .spot-headline-name {
	position: relative;
	display: inline-block;
	font-family: "Petit Formal Script", cursive;
	font-size: 40px;
}
#studio .spot-headline-name::before {
	content: '';
	display: inline-block;
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	padding: 0 20px;
	background: #f2f0e9;
	width: 100%;
	height: 20px;
	z-index: -1;
}
#studio .spot-headline-desc {
	margin-top: 40px;
	color: #666;
	text-align: center;
	letter-spacing: .1em;
	line-height: 2;
}
#studio .spot-news {
	margin-top: 50px;
}
#studio .spot-news-text {
	text-align: center;
	letter-spacing: .1em;
	line-height: 2;
}
#studio .spot-news-text-label {
	display: inline-block;
	background: #9b8a74;
	padding: 0 10px 0 16px;
	color: #fff;
}
#studio .spot-point {
	margin-top: 100px;
	text-align: left;
}
#studio .spot-point-ul {
	width: 1080px;
	margin: 0 auto;
	counter-reset: number 0;
}
#studio .spot-point-li {
	position: relative;
	display: flex;
	justify-content: space-between;
	align-items: center;
}
#studio .spot-point-li:not(:first-of-type) {
	margin-top: 100px;
}
#studio .spot-point-badge {
	position: absolute;
	top: -50px;
	left: -50px;
	width: 110px;
	padding: 24px 0 18px;
	background: #fff;
	text-align: center;
}
#studio .spot-point-badge-num {
	position: relative;
}
#studio .spot-point-badge-num::after {
	counter-increment: number 1;
	content: counter(number, decimal-leading-zero) " ";
	display: block;
	margin-top: 6px;
	font-size: 46px;
}
#studio .spot-point-photo {
	width: 500px;
}
#studio .spot-point-photo-img {
	width: 500px;
	height: 320px;
}
#studio .spot-point-headline {
	width: 500px;
}
#studio .spot-point-headline-main {
	font-size: 26px;
	letter-spacing: .1em;
	line-height: 2;
}
#studio .spot-point-headline-desc {
	margin-top: 15px;
	color: #666;
	letter-spacing: .1em;
	line-height: 2;
}
#studio .spot-gallery {
	max-width: 1580px;
	margin: 50px auto 0;
	overflow: hidden;
}
#studio .spot-gallery-carousel {
	position: relative;
	width: 100%;
	max-width: 520px!important;
	height: 560px;
	margin: 0 auto!important;
	overflow: visible!important;
}
#studio .spot-gallery-carousel .swiper-slide {
	width: 520px;
	overflow: hidden;
	text-align: center;
}
#studio .spot-gallery-carousel .swiper-slide img {
	width: 520px;
	height: 520px;
}
#studio .spot-gallery-carousel .swiper-pagination {
	bottom: 0;
}
#studio .spot-gallery-carousel .swiper-pagination-bullet {
	width: 10px;
	height: 10px;
	margin: 0 10px;
	background: #ccc;
	opacity: 1;
	border: none;
	border-radius: 50%;
}
#studio .spot-gallery-carousel .swiper-pagination-bullet-active {
	background: #9b8a74;
}
#studio .spot-gallery-carousel .swiper-pagination-bullet:hover {
	background: #808080;
}


/* ============================================================
	よくあるご質問
============================================================ */
#faq {
	padding: 160px 0 120px;
}
#faq .headline {
	text-align: center;
}
#faq .headline-sub {
	font-size: 20px;
	color: #9b8a74;
	letter-spacing: .2em;
	text-indent: .2em;
}
#faq .headline-main {
	margin-top: 20px;
	font-size: 36px;
	letter-spacing: .2em;
	line-height: 1.5;
}
#faq .headline-desc {
	margin-top: 50px;
	text-align: center;
	letter-spacing: .1em;
	line-height: 2;
}
#faq .list {
	margin-top: 50px;
}
#faq .list-ul {
	width: 900px;
	margin: 0 auto;
}
#faq .list-li {
	position: relative;
}
#faq .list-li:not(:first-of-type) {
	margin-top: 40px;
}
#faq .list-question,
#faq .list-answer {
	position: relative;
	text-align: left;
	letter-spacing: .1em;
	line-height: 2;
}
#faq .list-question {
	background: #f2f0e9;
	padding: 24px 40px 24px 110px;
	text-decoration: underline;
	cursor: pointer;
}
#faq .list-answer {
	display: none;
	padding: 0 40px 24px 110px;
	margin-top: 20px;
}
#faq .list-answer a {
	text-decoration: underline;
}
#faq .list-question::before,
#faq .list-answer::before {
	content: '';
	position: absolute;
	left: 20px;
	width: 50px;
	height: 50px;
	line-height: 1.4;
	border-radius: 50%;
	font-family: 'Noto Serif JP', serif;
	font-size: 30px;
	color: #fff;
	text-align: center;
}
#faq .list-question::before {
	content: 'Q';
	top: 16px;
	background: #9b8a74;
}
#faq .list-answer::before {
	content: 'A';
	top: 0;
	background: #333;
}
#faq .list-hidden {
	display: none;
	margin-top: 40px;
}
#faq .list-button {
	margin-top: 60px;
	text-align: center;
}
#faq .list-button-more {
	letter-spacing: .1em;
	cursor: pointer;
}
#faq .list-button-more span {
	margin-left: 4px;
	text-decoration: underline;
}
