@charset "UTF-8";

/*
Theme Name: まゆりなクリニック
Author: Catwork Catwork Co., Ltd.
*/

/* Reset
----------------------------------------------------------- */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header,
menu, nav, output, ruby, section, summary,
time, mark, audio, video{
	zoom:1;	/* hasLayout in IE */
	margin:0;
	padding:0;
	border:0;
	outline:0;
	font:inherit;
	font-size:100%;
	font-weight:normal;
	font-style:normal;
	vertical-align:baseline;
	background:transparent;
	-webkit-text-size-adjust: 100%;
	word-break: break-all;
}
	p{max-height:100%;}
	header, menu, nav, footer,
	section,article, aside,
	details, summary,
	figure, figcaption{display:block;}
	table{
	border-collapse:collapse;
	border-spacing:0;
}
q, blockquote{quotes:none;}
q:before, q:after, blockquote:before, blockquote:after{
	content:"";
	content:none;
}
img{
	font-size:0;
	line-height:0;
	vertical-align: bottom;
	height:auto;
}
a{
	margin:0;
	padding:0;
	font-size:100%;
	vertical-align:baseline;
	background:transparent;
	color:#333;
}
a:focus{outline:none;}
a img{
	border:none;
	vertical-align:middle;
}
/* iOSでのデフォルトスタイルをリセット */
input[type="submit"],
input[type="button"] {
	border-radius: 0;
	-webkit-box-sizing: content-box;
	-webkit-appearance: button;
	appearance: button;
	border: none;
	box-sizing: border-box;
	cursor: pointer;
}
input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
	display: none;
}
input[type="submit"]:focus,
input[type="button"]:focus {
	outline-offset: -2px;
}
textarea{overflow:auto;}
label{cursor:pointer;}
.clearfix:after{
	display:block;
	visibility:hidden;
	content:".";
	clear:both;
	height:0;
	font-size:0;
	line-height:0;
}
* html .clearfix{zoom:1;}
*:first-child + html .clearfix{zoom:1;}
a{
	text-decoration: none;
}
strong{
	font-weight: normal;
}
ul,ol{
	list-style-type: none;
}
body{
	background: #f5f4ea;
	font-family: '游明朝体', YuMincho, '游明朝', 'Yu Mincho', 'Hiragino Mincho ProN', 'Hiragino Mincho Pro', 'HGS明朝E', 'ＭＳ Ｐ明朝', 'ＭＳ 明朝', serif;
	font-size: 16px;
	line-height: 2;
	color: #333;
}
.wrap{
	width:100%;
}

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

.inner{
	margin:0 auto;
	width: 1200px;
}
img{
	max-width:100%;
}
span, strong {
	font-weight: inherit;
}

.f-gothic {
	font-family: '游ゴシック体', YuGothic, '游ゴシック Medium', 'Yu Gothic Medium', '游ゴシック', 'Yu Gothic', 'Hiragino Kaku Gothic ProN', 'Hiragino Sans', 'ヒラギノ角ゴ ProN W3', 'メイリオ', Meiryo, sans-serif;
}


/*===============================================
横幅1240px以下
===============================================*/
@media screen and (max-width: 1240px) and (min-width: 431px){
	html,
	body,
	.wrap{
		width: 1240px;
	}
}


/*===============================================
横幅431px以上
===============================================*/
@media screen and (min-width: 431px) {
	a {
		transition: all .5s;
	}

	a:hover {
		opacity: 0.8;
		filter: alpha(opacity=80);
		-moz-opacity: 0.8;
	}

	.sp {
		display: none !important;
	}

	/* common
	------------------------------------------------------------------------*/
	/*	tit
	------------------------------------------*/
	.common_tit01 {
		padding: 45px 0 0;
		font-size: 36px;
		text-align: center;
		position: relative;
		z-index: 1;
	}
	.common_tit01::after {
		content: "";
		display: block;
		width: 100%;
		height: 120px;
		background: no-repeat center bottom;
		position: absolute;
		left: 0;
		bottom: 10px;
		z-index: -1;
		pointer-events: none;
	}
	.common_tit01 span {
		display: block;
		margin-bottom: 5px;
		font-size: 14px;
	}
	.common_tit01.is-small {
		font-size: 30px;
	}
	.common_tit01.is-small::after {
		height: 100px;
	}

	/*	.common_cv01
	------------------------------------------*/
	.common_cv01 {
		padding: 25px 0 40px;
		background: #ece9db;
	}
	.common_cv01 .inner {
		width: 1120px;
		display: grid;
		grid-template-columns: auto 1fr;
		align-items: center;
		grid-gap: 30px 40px;
	}
	.common_cv01 h2 {
		padding: 20px 0 0 95px;
		font-size: 32px;
		text-shadow: 15px 12px 5px rgba(0, 0, 0, 0.1);
		letter-spacing: .17em;
		position: relative;
		z-index: 1;
	}
	.common_cv01 h2::after {
		content: "";
		display: block;
		width: 191px;
		height: 74px;
		background: url("img/common_cv_txt01.png") no-repeat center/contain;
		position: absolute;
		top: 0;
		left: 0;
		z-index: -1;
	}
	.common_cv01 .lead {
		align-self: flex-end;
		line-height: 1.8;
	}
	.common_cv01 .btns {
		grid-area: 2 / 1 / 3 / 3;
		display: grid;
		grid-template-columns: 530px 1fr 1fr;
		grid-gap: 10px;
	}
	.common_cv01 .btn {
		font-size: 20px;
		line-height: 1.5;
	}
	.common_cv01 .btn a {
		display: flex;
		justify-content: center;
		align-items: center;
		height: 80px;
		box-sizing: border-box;
	}
	.common_cv01 .btn a::before {
		content: "";
		display: inline-block;
		margin-right: 15px;
		background: no-repeat center / contain;
	}
	.common_cv01 .btn.is-tel {
		font-size: 32px;
		letter-spacing: .05em;
	}
	.common_cv01 .btn.is-tel a {
		background: #fff;
	}
	.common_cv01 .btn.is-tel a::before {
		width: 22px;
		height: 22px;
		background-image: url("img/common_ico_tel02.png");
	}
	.common_cv01 .btn.is-tel .time {
		margin-left: 20px;
		font-size: 14px;
		letter-spacing: 0;
	}
	.common_cv01 .btn.is-web a, .common_cv01 .btn.is-line a {
		overflow: hidden;
		position: relative;
		z-index: 1;
	}
	.common_cv01 .btn.is-web a::after, .common_cv01 .btn.is-line a::after {
		content: "";
		display: block;
		width: 100%;
		height: 100%;
		position: absolute;
		z-index: -1;
		bottom: 0;
		left: 0;
		transform: scaleX(0);
		transform-origin: right;
		transition: transform .5s;
		pointer-events: none;
	}
	.common_cv01 .btn.is-web a:hover, .common_cv01 .btn.is-line a:hover {
		opacity: 1;
	}
	.common_cv01 .btn.is-web a:hover::after, .common_cv01 .btn.is-line a:hover::after {
		transform: scaleX(1);
		transform-origin: left;
	}
	.common_cv01 .btn.is-web a {
		background: #ded0a8;
	}
	.common_cv01 .btn.is-web a::before {
		width: 21px;
		height: 19px;
		background-image: url("img/common_ico_calendar01.png");
	}
	.common_cv01 .btn.is-web a::after {
		background: #d0bc83;
	}
	.common_cv01 .btn.is-line a {
		background: #333;
		color: #fff;
	}
	.common_cv01 .btn.is-line a::before {
		width: 24px;
		height: 23px;
		background-image: url("img/common_ico_line01.png");
	}
	.common_cv01 .btn.is-line a::after {
		background: #1a1a1a;
	}

	/* header
	------------------------------------------------------------------------*/
	header {
		padding: 80px 0 0;
		position: relative;
		z-index: 9990;
	}
	header h1 {
		position: absolute;
		top: 100%;
		left: 0;
		width: 100%;
		padding: 10px 10px 0;
		box-sizing: border-box;
		font-size: 12px;
		text-align: right;
		font-family: '游ゴシック体', YuGothic, '游ゴシック Medium', 'Yu Gothic Medium', '游ゴシック', 'Yu Gothic', 'Hiragino Kaku Gothic ProN', 'Hiragino Sans', 'ヒラギノ角ゴ ProN W3', 'メイリオ', Meiryo, sans-serif;
		text-shadow: 0 0 0.5px rgba(255, 255, 255, 0.5), 0 0 0.5px rgba(255, 255, 255, 0.5), 0 0 0.5px rgba(255, 255, 255, 0.5), 0 0 0.5px rgba(255, 255, 255, 0.5);
	}
	header .headerTop {
		position: fixed;
		top: 0;
		left: 0;
		width: max(100%, 1240px);
		height: 80px;
		display: flex;
		justify-content: space-between;
		align-items: center;
		padding: 0 0 0 15px;
		box-sizing: border-box;
		background: #f5f4ea;
	}
	header .logo {
		margin-right: 10px;
		flex-shrink: 0;
	}
	header .tel {
		margin: 0 0 0 40px;
		font-size: 30px;
		letter-spacing: .03em;
		flex-shrink: 0;
	}
	header .tel a {
		display: flex;
		align-items: center;
		padding: 0 0 0 33px;
		background: url("img/common_ico_tel01.png") no-repeat left center;
	}
	header .tel a > span {
		display: contents;
	}
	header .tel .time {
		margin-left: 10px;
		font-size: 14px;
		line-height: 1.4;
		letter-spacing: 0;
	}
	header .headerCv {
		display: flex;
		margin-left: 20px;
		flex-shrink: 0;
	}
	header .headerCv__btn {
		width: 80px;
		font-size: 14px;
		text-align: center;
	}
	header .headerCv__btn a {
		display: flex;
		justify-content: center;
		align-items: flex-end;
		padding: 0 0 7px;
		box-sizing: border-box;
		height: 80px;
	}
	header .headerCv__btn.is-web a {
		background: #ded0a8 url("img/common_ico_calendar01.png") no-repeat center top 18px;
	}
	header .headerCv__btn.is-web a:hover {
		opacity: 1;
		background-color: #d0bc83;
	}
	header .headerCv__btn.is-line a {
		background: #333 url("img/common_ico_line01.png") no-repeat center top 15px;
		color: #fff;
	}
	header .headerCv__btn.is-line a:hover {
		opacity: 1;
		background-color: #1a1a1a;
	}

	/* nav
	------------------------------------------------------------------------*/
	nav {
		margin: 0 0 0 auto;
	}
	nav #nav {
		display: flex;
		justify-content: flex-end;
		align-items: center;
		flex-wrap: wrap;
		gap: 0 25px;
	}
	nav #nav li {
		font-size: 14px;
		line-height: 1.5;
		text-align: center;
	}
	nav #nav li a {
		display: block;
		padding: 5px 3px;
		position: relative;
	}
	nav #nav li a::after {
		content: "";
		display: block;
		width: 1px;
		height: 1px;
		background: #b4a173;
		position: absolute;
		left: 0;
		bottom: 0;
		right: 0;
		margin: auto;
		opacity: 0;
		transition: all .3s;
	}
	nav #nav li a:hover {
		opacity: 1;
		color: #b4a173;
	}
	nav #nav li a:hover::after {
		opacity: 1;
		width: 100%;
	}

	/* .home
	------------------------------------------------------------------------*/
	/*	.home .key
	------------------------------------------*/
	.home .key {
		margin-bottom: 135px;
		background: url("img/home_key_img01_pc.png") no-repeat right calc(50% - 270px) center/contain;
		position: relative;
	}
	.home .key::after {
		content: "";
		display: block;
		width: min(54%, 948px);
		height: 163px;
		background: url("img/home_key_txt01_pc.png") no-repeat center right/contain;
		position: absolute;
		top: 70px;
		left: max(20px, 50% - 860px);
	}
	.home .key .inner {
		padding: 145px 0 0;
		min-height: 820px;
		box-sizing: border-box;
		position: relative;
		z-index: 2;
	}
	.home .key .txtBox {
		width: 630px;
		margin: 0 auto 0 30px;
		position: relative;
	}
	.home .key .txt01 {
		position: absolute;
		top: 14px;
		right: 40px;
		padding: 2px 12px;
		border-top: 1px solid #b4a173;
		border-bottom: 1px solid #b4a173;
		font-size: 18px;
		z-index: 2;
	}
	.home .key .txt02 {
		width: 100%;
		margin-bottom: 20px;
		font-size: 48px;
		line-height: 1.4;
	}
	.home .key .txt03 {
		display: flex;
		align-items: flex-start;
	}
	.home .key .txt03 img:nth-of-type(1) {
		position: relative;
		z-index: 2;
	}
	.home .key .txt03 img:nth-of-type(2) {
		margin: -5px auto 0 -32px;
	}
	.home .key .campaign {
		display: flex;
		align-items: center;
		justify-content: space-between;
		width: calc(100% - 20px);
		padding: 12px;
		box-sizing: border-box;
		border-left: 5px solid #dc7693;
		background: rgba(255, 255, 255, 0.8);
		line-height: 1.5;
	}
	.home .key .campaign__txt_box {
		width: calc(100% - 210px);
	}
	.home .key .campaign__tit {
		margin-bottom: 15px;
		padding: 0 0 15px;
		color: #dc7693;
		font-size: 20px;
		position: relative;
	}
	.home .key .campaign__tit::after {
		content: "";
		display: block;
		width: calc(100% + 12px);
		height: 1px;
		background: #dc7693;
		position: absolute;
		right: 0;
		bottom: 0;
	}
	.home .key .campaign__txt {
		font-size: 28px;
		white-space: nowrap;
	}
	.home .key .campaign__txt span {
		display: block;
		color: #999;
		font-size: 16px;
	}
	.home .key .campaign-price {
		grid-area: 1 / 2 / 3 / 3;
		padding: 10px;
		background: rgba(220, 118, 147, 0.2);
		text-align: center;
		width: 210px;
		position: relative;
	}
		.home .key .campaign-price::before {
			content: url(img/home_key_icon01.png);
			position: absolute;
			bottom: 8px;
			left: -17px;
		}
		.home .key .campaign-price::after {
			content: url(img/home_key_icon01.png);
			position: absolute;
			bottom: 8px;
			right: -17px;
			transform: rotateY(180deg);
		}
	.home .key .campaign-price__txt01 {
		width: 145px;
		margin: 0 auto 5px;
		line-height: 1;
		padding: 5px 0;
		border-top: 1px solid #e61673;
		border-bottom: 1px solid #e61673;
	}
	.home .key .campaign-price__txt02 {
		display: flex;
		justify-content: center;
		align-items: flex-end;
		color: #e61673;
		font-size: 46px;
		line-height: 1;
	}
	.home .key .campaign-price__txt02 .yen {
		display: grid;
		margin: 0 0 5px 3px;
		font-size: 20px;
	}
	.home .key .campaign-price__txt02 .tax {
		order: -1;
		font-size: 12px;
	}
	.home .key .campaign-price__txt03 {
		font-size: 12px;
	}
	.home .key .campaign-price__txt04 {
		font-size: 14px;
		text-align: left;
		padding-left: 23px;
		background: url(img/common_ico_row.png) no-repeat center right 23px;
	}
	.home .key .campaign-price-right {
		display: flex;
		flex-direction: column-reverse;
	}
	.home .key .img {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: calc(100% + 155px);
		pointer-events: none;
		background: url("img/home_key_img02.png") no-repeat left calc(50% - 780px) top 51%, url("img/home_key_img03.png") no-repeat left calc(50% - 270px) bottom, url("img/home_key_img04.png") no-repeat right calc(50% - 550px) bottom 100px, url("img/home_key_img05.png") no-repeat right calc(50% - 750px) top 30%;
		filter: drop-shadow(15px 15px 20px rgba(0, 0, 0, 0.15));
	}

	/*	.home .cont01
	------------------------------------------*/
	.home .cont01 {
		padding: 0 0 60px;
		position: relative;
		z-index: 2;
	}
	.home .cont01::after {
		content: "";
		display: block;
		width: 100%;
		height: 480px;
		background: #f5f4ea url("img/home_cont01_bg01.png") no-repeat right calc(50% - 480px) bottom/contain;
		background-blend-mode: multiply;
		position: absolute;
		bottom: 0;
		left: 0;
		z-index: -1;
		pointer-events: none;
	}
	.home .cont01 .list {
		display: grid;
		grid-template-columns: repeat(4, 1fr);
		align-items: flex-start;
		grid-gap: 45px;
		counter-reset: number;
	}
	.home .cont01 .list li {
		padding: 45px 0 0;
		position: relative;
	}
	.home .cont01 .list li::before {
		counter-increment: number;
		content: counter(number,decimal-leading-zero);
		color: #b4a173;
		position: absolute;
		top: 0;
		left: 0;
	}
	.home .cont01 .list li::after {
		content: "";
		display: block;
		width: 100%;
		height: 2px;
		background: linear-gradient(to right, #c3b38e 90px, #ccc 90px);
		position: absolute;
		top: 30px;
		left: 0;
	}
	.home .cont01 .list li .tit {
		margin-bottom: 10px;
		font-size: 30px;
	}
	.home .cont01 .list li .txt {
		font-size: 18px;
		line-height: 1.7;
	}
	.home .cont01 .list li:nth-of-type(1) {
		margin-top: 120px;
	}
	.home .cont01 .list li:nth-of-type(2) {
		margin-top: 80px;
	}
	.home .cont01 .list li:nth-of-type(3) {
		margin-top: 40px;
	}
	.home .cont01 .campaign {
		display: flex;
		margin: 80px auto 0;
		align-items: center;
		justify-content: space-between;
		width: min(100%, 810px);
		padding: 15px 15px 15px 20px;
		box-sizing: border-box;
		border-left: 5px solid #dc7693;
		background: rgba(255, 255, 255, 0.8);
		line-height: 1.5;
		position: relative;
	}
		.home .cont01 .campaign::after {
			content: "";
			display: block;
			width: 268px;
			height: 93px;
			background: url(img/home_cont01_txt01.png) no-repeat center/contain;
			position: absolute;
			top: -55px;
			left: -100px;
		}
	.home .cont01 .campaign__txt_box {
		width: calc(100% - 300px);
	}
	.home .cont01 .campaign__tit {
		margin-bottom: 15px;
		padding: 0 0 15px;
		color: #dc7693;
		font-size: 24px;
		position: relative;
	}
		.home .cont01 .campaign__tit::after {
			content: "";
			display: block;
			width: calc(100% + 12px);
			height: 1px;
			background: #dc7693;
			position: absolute;
			right: 0;
			bottom: 0;
		}
	.home .cont01 .campaign__txt {
		font-size: 36px;
		white-space: nowrap;
	}
	.home .cont01 .campaign__txt span {
		display: block;
		color: #999;
		font-size: 16px;
	}
	.home .cont01 .campaign-price {
		grid-area: 1 / 2 / 3 / 3;
		padding: 10px;
		background: rgba(220, 118, 147, 0.2);
		text-align: center;
		width: 300px;
		position: relative;
	}
		.home .cont01 .campaign-price::before {
			content: url(img/home_key_icon01.png);
			position: absolute;
			bottom: 22px;
			left: 10px;
		}
		.home .cont01 .campaign-price::after {
			content: url(img/home_key_icon01.png);
			position: absolute;
			bottom: 22px;
			right: 10px;
			transform: rotateY(180deg);
		}
	.home .cont01 .campaign-price__txt01 {
		width: 190px;
		margin: 0 auto 5px;
		line-height: 1;
		padding: 5px 0;
		font-size: 20px;
		border-top: 1px solid #e61673;
		border-bottom: 1px solid #e61673;
	}
	.home .cont01 .campaign-price__txt02 {
		display: flex;
		justify-content: center;
		align-items: flex-end;
		color: #e61673;
		font-size: 62px;
		line-height: 1;
	}
	.home .cont01 .campaign-price__txt02 .yen {
		display: grid;
		margin: 0 0 5px 3px;
		font-size: 28px;
	}
	.home .cont01 .campaign-price__txt02 .tax {
		order: -1;
		font-size: 14px;
	}
	.home .cont01 .campaign-price__txt03 {
		font-size: 14px;
	}
	.home .cont01 .campaign-price__txt04 {
		font-size: 14px;
		display: inline-block;
		padding-right: 30px;
		margin: auto;
		background: url(img/common_ico_row.png) no-repeat center right;
	}
	.home .cont01 .campaign-price-right {
		display: flex;
		flex-direction: column-reverse;
	}
	.home .cont01 .campaign__note {
		margin: 5px auto 0;
		font-size: 18px;
		text-align: right;
		padding-right: 195px;
	}

	/*	.home .cont02
	------------------------------------------*/
	.home .cont02 {
		padding: 155px 0 100px;
		counter-reset: number;
	}
	.home .cont02 h2 {
		margin-bottom: 70px;
	}
	.home .cont02 h2::after {
		background-image: url("img/home_cont02_en01.png");
	}
	.home .cont02 .list01 {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		align-items: flex-start;
		grid-gap: 40px 80px;
		padding: 0 20px 0 40px;
	}
	.home .cont02 .list01 li {
		display: flex;
		flex-direction: column;
		position: relative;
	}
	.home .cont02 .list01 li:nth-of-type(odd) {
		margin-top: 60px;
	}
	.home .cont02 .list01 li::after {
		counter-increment: number;
		content: "POINT " counter(number,decimal-leading-zero);
		display: block;
		position: absolute;
		top: 170px;
		right: calc(100% - 10px);
		z-index: -1;
		color: #fff;
		font-size: 60px;
		line-height: 1;
		letter-spacing: .1em;
		white-space: nowrap;
		writing-mode: vertical-rl;
	}
	.home .cont02 .list01 h3, .home .cont02 .list01 .txt {
		width: calc(100% - 80px);
		margin: 0 auto;
	}
	.home .cont02 .list01 h3 {
		margin-bottom: 10px;
		font-size: 30px;
	}
	.home .cont02 .list01 .txt {
		font-size: 20px;
	}
	.home .cont02 .list01 .img {
		order: -1;
		margin-bottom: 30px;
		position: relative;
	}
	.home .cont02 .list01 .img::before, .home .cont02 .list01 .img::after {
		content: "";
		display: block;
		width: 100px;
		height: 1px;
		background: #b4a173;
		transform: rotate(-45deg);
		position: absolute;
		pointer-events: none;
	}
	.home .cont02 .list01 .img::before {
		top: 15px;
		left: -35px;
	}
	.home .cont02 .list01 .img::after {
		right: -35px;
		bottom: 15px;
	}
	.home .cont02 .list01 .img img {
		width: 100%;
		box-shadow: 20px 20px 30px rgba(0, 0, 0, 0.1);
	}
	.home .cont02 .list02 {
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		align-items: flex-start;
		grid-gap: 15px;
		margin: 60px auto 0;
	}
	.home .cont02 .list02 li {
		display: flex;
		align-items: center;
		min-height: 70px;
		padding: 10px 20px 10px 75px;
		box-sizing: border-box;
		background: #fff;
		box-shadow: 0 0 15px rgba(0, 0, 0, 0.1);
		position: relative;
	}
	.home .cont02 .list02 li::after {
		counter-increment: number;
		content: counter(number,decimal-leading-zero);
		display: block;
		position: absolute;
		height: 1em;
		top: 0;
		left: 20px;
		bottom: 0;
		margin: auto;
		padding: 0 15px 0 0;
		border-right: 1px solid;
		color: #b4a173;
		font-size: 24px;
		line-height: 1;
	}

	/*	.home .cont03
	------------------------------------------*/
	.home .cont03 {
		padding: 100px 0 90px;
		position: relative;
	}
	.home .cont03::before {
		content: "";
		display: block;
		width: 100%;
		height: 716px;
		background: url("img/home_cont03_bg01_pc.png") no-repeat right calc(50% - 435px) center/contain;
		position: absolute;
		top: -110px;
		left: 0;
		z-index: -1;
		pointer-events: none;
	}
	.home .cont03::after {
		content: "";
		display: block;
		width: calc(50% + 300px);
		height: 100%;
		background: #ece9db;
		position: absolute;
		top: 0;
		left: 0;
		z-index: -2;
		pointer-events: none;
	}
	.home .cont03 .topBox {
		display: grid;
		grid-template-columns: auto 1fr;
		align-items: end;
		grid-column-gap: 50px;
		margin-bottom: 105px;
		background: url("img/home_cont03_en01_pc.png") no-repeat 210px top;
	}
	.home .cont03 h2 {
		display: flex;
		flex-direction: column-reverse;
		padding: 0 40px 0 0;
		border-right: 1px solid #dc7693;
		color: #dc7693;
		font-size: 39px;
		writing-mode: vertical-rl;
		letter-spacing: .08em;
	}
	.home .cont03 h2 span {
		margin-right: 10px;
		color: #333;
		font-size: 16px;
		letter-spacing: .05em;
		line-height: 1.8;
	}
	.home .cont03 .lead {
		font-size: 20px;
		text-shadow: 2px 2px 2px rgba(236, 233, 219, 0.5), -2px 2px 2px rgba(236, 233, 219, 0.5), 2px -2px 2px rgba(236, 233, 219, 0.5), -2px -2px 2px rgba(236, 233, 219, 0.5), 2px 0 2px rgba(236, 233, 219, 0.5), 0 2px 2px rgba(236, 233, 219, 0.5), -2px 0 2px rgba(236, 233, 219, 0.5), 0 -2px 2px rgba(236, 233, 219, 0.5);
	}
	.home .cont03 .box {
		display: grid;
		align-items: center;
	}
	.home .cont03 .box::after {
		content: "";
		display: block;
		background: no-repeat center / contain;
	}
	.home .cont03 .box h3 {
		margin-bottom: 30px;
		padding: 25px 0 0;
		font-size: 24px;
		position: relative;
	}
	.home .cont03 .box h3::after {
		content: "";
		display: block;
		width: 20px;
		height: 3px;
		background: #dc7693;
		position: absolute;
		top: 0;
		left: 0;
	}
	.home .cont03 .box.is-double {
		grid-template-columns: 647px 1fr;
		grid-gap: 80px;
	}
	.home .cont03 .box.is-double::after {
		order: -1;
		height: 393px;
		background-image: url("img/home_cont03_img01.png");
	}
	.home .cont03 .box.is-double .txtBox {
		margin-top: 50px;
	}
	.home .cont03 .box.is-improve {
		margin-top: 80px;
		grid-template-columns: 1fr 710px;
		grid-gap: 20px;
	}
	.home .cont03 .box.is-improve::after {
		height: 593px;
		background-image: url("img/home_cont03_img02.png");
	}
	.home .cont03 .box.is-improve .img {
		margin: 70px auto 55px;
	}
	.home .cont03 .box.is-improve .effect {
		margin: 30px auto 0;
		counter-reset: number;
	}
	.home .cont03 .box.is-improve .effect li {
		padding: 0 0 0 90px;
		color: #e61673;
		font-size: 40px;
		line-height: 1.5;
		position: relative;
	}
	.home .cont03 .box.is-improve .effect li + li {
		margin-top: 8px;
	}
	.home .cont03 .box.is-improve .effect li::before {
		counter-increment: number;
		content: counter(number,decimal-leading-zero);
		position: absolute;
		top: 0;
		left: 28px;
		bottom: 0;
		height: 1em;
		margin: auto;
		color: #333;
		font-size: 42px;
		line-height: 1;
		z-index: 1;
	}
	.home .cont03 .box.is-improve .effect li::after {
		content: "Effect";
		position: absolute;
		top: 0;
		left: 0;
		bottom: 0;
		margin: auto;
		height: 1em;
		color: #333;
		font-size: 14px;
		line-height: 1;
		text-shadow: 1px 1px 0.5px #ece9db, -1px 1px 0.5px #ece9db, 1px -1px 0.5px #ece9db, -1px -1px 0.5px #ece9db, 1px 0 0.5px #ece9db, 0 1px 0.5px #ece9db, -1px 0 0.5px #ece9db, 0 -1px 0.5px #ece9db;
		z-index: 2;
	}

	/*	.home .cont04
	------------------------------------------*/
	.home .cont04 {
		padding: 125px 0 150px;
	}
	.home .cont04 h2 {
		margin-bottom: 40px;
	}
	.home .cont04 h2::after {
		background-image: url("img/home_cont04_en01.png");
	}
	.home .cont04 .lead {
		margin-bottom: 15px;
		font-size: 24px;
		text-align: center;
	}
	.home .cont04 .txt {
		margin-bottom: 60px;
		font-size: 18px;
		text-align: center;
	}
	.home .cont04 .img {
		display: flex;
		justify-content: space-between;
		align-items: flex-start;
	}

	/*	.home .cont05
	------------------------------------------*/
	.home .cont05 {
		overflow: hidden;
		padding: 135px 0 120px;
		background: #ece9db;
	}
	.home .cont05 h2 {
		margin-bottom: 30px;
	}
	.home .cont05 h2::after {
		background-image: url("img/home_cont05_en01.png");
	}
	.home .cont05 .lead {
		margin-bottom: 30px;
		font-size: 18px;
		text-align: center;
	}
	.home .cont05 .boxWrap {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		grid-gap: 40px;
	}
	.home .cont05 .box .titBox {
		min-height: 180px;
		display: grid;
		grid-template-columns: 1fr 145px;
		grid-auto-rows: 1fr auto;
		grid-gap: 0 20px;
		align-items: end;
		margin-bottom: 5px;
	}
	.home .cont05 .box h3 {
		grid-row: 1 / 2;
		margin-bottom: 10px;
		padding: 0 0 0 25px;
		font-size: 28px;
		position: relative;
	}
	.home .cont05 .box h3::after {
		content: "";
		display: block;
		width: 5px;
		height: 80%;
		background: #b4a173;
		position: absolute;
		top: 0;
		left: 0;
		bottom: 0;
		margin: auto;
	}
	.home .cont05 .box .tag {
		grid-row: 2 / 3;
		display: flex;
		flex-wrap: wrap;
		margin: 0 0 25px 25px;
	}
	.home .cont05 .box .tag li {
		margin: 3px;
		padding: 2px 12px;
		color: #fff;
		font-size: 18px;
		line-height: 1.5;
	}
	.home .cont05 .box .tag li:not([class]) {
		color: #333;
		padding: 0;
		font-size: 20px;
	}
	.home .cont05 .box .tag li.gold {
		background: #b4a173;
	}
	.home .cont05 .box .tag li.pink {
		background: #dc7693;
	}
	.home .cont05 .box .tag li.gray {
		background: #aaa;
	}
	.home .cont05 .box .img {
		grid-area: 1 / 2 / 3 / 3;
		text-align: center;
	}
	.home .cont05 .box .data {
		width: calc(100% + 10px);
		margin: 0 -5px;
		border-collapse: separate;
		border-spacing: 5px;
	}
	.home .cont05 .box .data th, .home .cont05 .box .data td {
		height: 60px;
		padding: 5px 20px;
		box-sizing: border-box;
		line-height: 1.5;
		vertical-align: middle;
	}
	.home .cont05 .box .data th {
		width: 190px;
		background: #d8cbab;
		font-size: 18px;
		text-align: left;
	}
	.home .cont05 .box .data th span {
		font-size: 24px;
	}
	.home .cont05 .box .data .through {
		text-decoration: line-through;
	}
	.home .cont05 .box .data .big {
		display: inline-block;
		margin-left: 10px;
		padding: 0 0 0 50px;
		color: #e61673;
		font-size: 30px;
		position: relative;
	}
	.home .cont05 .box .data .big::before, .home .cont05 .box .data .big::after {
		content: "";
		display: block;
		background: no-repeat center / contain;
		position: absolute;
		pointer-events: none;
	}
	.home .cont05 .box .data .big::before {
		width: 39px;
		height: 24px;
		background-image: url("img/home_cont05_ico01.png");
		top: 0;
		left: 0;
		bottom: 0;
		margin: auto;
	}
	.home .cont05 .box .data .big::after {
		width: 40px;
		height: 42px;
		background-image: url("img/home_cont05_ico02.png");
		top: -15px;
		right: -30px;
	}
	.home .cont05 .box .data .big img {
		margin-right: 5px;
	}
	.home .cont05 .box .data td {
		background: #fff;
		font-size: 20px;
		text-align: right;
		color: #e61673;
	}
	.home .cont05 .box .data td .note {
		display: grid;
		grid-template-columns: auto auto;
		justify-content: end;
		grid-gap: 3px;
		margin: 10px 0 0 auto;
		font-size: 16px;
		text-align: left;
	}
	.home .cont05 .box.is-body .titBox {
		grid-template-columns: 1fr;
	}
	.home .cont05 .box.is-body .data th, .home .cont05 .box.is-body .data td {
		height: 125px;
	}
	.home .cont05 .noticeBox {
		width: min(100%, 1100px);
		display: grid;
		grid-template-columns: auto 1fr;
		align-items: center;
		grid-column-gap: 50px;
		margin: 70px auto 0;
		padding: 30px 70px;
		box-sizing: border-box;
		border: 1px solid #d8cbab;
	}
	.home .cont05 .noticeBox__tit {
		color: #b4a173;
		font-size: 24px;
		letter-spacing: .1em;
	}
	.home .cont05 .typeBox {
		margin: 80px auto 0;
		padding: 55px 0 80px;
		position: relative;
		z-index: 1;
	}
	.home .cont05 .typeBox::after {
		content: "";
		display: block;
		width: max(910px, 50vw + 300px);
		height: 100%;
		background: #f5f4ea;
		position: absolute;
		top: 0;
		right: min(20px * -1, (50vw - 600px) * -1);
		z-index: -1;
		pointer-events: none;
	}
	.home .cont05 .typeBox__tit {
		margin-bottom: 20px;
		padding: 30px 0 0;
		font-size: 24px;
		text-align: center;
		position: relative;
	}
	.home .cont05 .typeBox__tit::after {
		content: "";
		display: block;
		width: 20px;
		height: 3px;
		background: #b4a173;
		position: absolute;
		top: 0;
		right: 0;
		left: 0;
		margin: auto;
	}
	.home .cont05 .typeBox__lead {
		margin-bottom: 40px;
		font-size: 18px;
		text-align: center;
	}
	.home .cont05 .typeBox-box {
		background: #fff;
		border: 1px solid #d8cbab;
		box-sizing: border-box;
	}
	.home .cont05 .typeBox-boxWrap {
		display: grid;
		grid-template-columns: auto auto;
		justify-content: center;
		grid-column-gap: 30px;
	}
	.home .cont05 .typeBox-box:nth-of-type(2) {
		border-color: #ccc;
	}
	.home .cont05 .typeBox-box:nth-of-type(2) .typeBox-box__tit {
		background: #ccc;
	}
	.home .cont05 .typeBox-box__tit {
		margin: 0 auto 15px;
		padding: 2px 10px;
		background: #d8cbab;
		font-size: 24px;
		text-align: center;
		letter-spacing: .1em;
	}
	.home .cont05 .typeBox-box__img {
		padding: 10px;
		text-align: center;
	}

	/*	.home .cont06
	------------------------------------------*/
	.home .cont06 {
		padding: 80px 0 120px;
	}
	.home .cont06 h2 {
		margin-bottom: 40px;
	}
	.home .cont06 h2::after {
		background-image: url("img/home_cont06_en01.png");
	}
	.home .cont06 .data {
		width: min(100%, 1000px);
		margin: 0 auto;
		border-top: 1px solid #b4a173;
	}
	.home .cont06 .data tr {
		border-bottom: 1px solid #b4a173;
	}
	.home .cont06 .data th, .home .cont06 .data td {
		box-sizing: border-box;
		text-align: left;
		vertical-align: middle;
	}
	.home .cont06 .data th {
		width: 190px;
		padding: 15px 15px 15px 30px;
		position: relative;
	}
	.home .cont06 .data th::before {
		content: "";
		display: block;
		width: .8em;
		height: .8em;
		background: #b4a173;
		position: absolute;
		top: 0;
		left: 10px;
		bottom: 0;
		margin: auto;
	}
	.home .cont06 .data td {
		padding: 15px 0;
	}

	/*	.home .cont07
	------------------------------------------*/
	.home .cont07 {
		padding: 125px 0 100px;
	}
	.home .cont07 h2 {
		margin-bottom: 50px;
	}
	.home .cont07 h2::after {
		background-image: url("img/home_cont07_en01.png");
	}
	.home .cont07 .list {
		display: grid;
		grid-template-columns: repeat(4, 280px);
		grid-gap: 60px 26px;
		margin: 0 auto 90px;
		counter-reset: number;
	}
	.home .cont07 .list li {
		display: flex;
		flex-direction: column;
		padding: 0 0 25px;
		background: #fff;
		box-shadow: 0 0 15px rgba(0, 0, 0, 0.1);
	}
	.home .cont07 .list li:nth-of-type(4n + 1) {
		transform: translateY(90px);
	}
	.home .cont07 .list li:nth-of-type(4n + 2) {
		transform: translateY(60px);
	}
	.home .cont07 .list li:nth-of-type(4n + 3) {
		transform: translateY(30px);
	}
	.home .cont07 .list h3, .home .cont07 .list .txt {
		width: calc(100% - 40px);
		margin: 0 auto;
	}
	.home .cont07 .list h3 {
		margin-bottom: 15px;
		padding: 0 0 18px;
		font-size: 18px;
		position: relative;
	}
	.home .cont07 .list h3::after {
		content: "";
		display: block;
		width: 20px;
		height: 2px;
		background: #b4a173;
		position: absolute;
		left: 0;
		bottom: 0;
	}
	.home .cont07 .list .txt {
		line-height: 1.8;
	}
	.home .cont07 .list .img {
		order: -1;
		margin-bottom: 40px;
		position: relative;
	}
	.home .cont07 .list .img::after {
		counter-increment: number;
		content: counter(number,decimal-leading-zero);
		display: flex;
		justify-content: center;
		align-items: center;
		position: absolute;
		left: 20px;
		bottom: -23px;
		width: 45px;
		height: 45px;
		background: #b4a173;
		color: #fff;
		font-size: 20px;
	}
	.home .cont07 .list .img img {
		width: 100%;
	}
	.home .cont07 .list .notice {
		display: block;
		padding: 38px 30px;
		background: none;
		box-shadow: none;
		border: 1px solid #b4a173;
		color: #b4a173;
	}
	.home .cont07 .list .notice h3, .home .cont07 .list .notice .txt {
		width: 100%;
	}
	.home .cont07 .list .notice h3 {
		padding: 0;
		font-size: 24px;
		letter-spacing: .1em;
	}
	.home .cont07 .list .notice h3::after {
		content: none;
	}
	.home .cont07 .list .notice .txt + .txt {
		margin-top: 10px;
	}

	/*	.home .cont08
	------------------------------------------*/
	.home .cont08 {
		padding: 90px 0 110px;
		background: #ece9db;
	}
	.home .cont08 h2 {
		margin-bottom: 50px;
	}
	.home .cont08 h2::after {
		background-image: url("img/home_cont08_en01.png");
		bottom: -10px;
	}
	.home .cont08 .list dt, .home .cont08 .list dd {
		background: #fff;
		box-sizing: border-box;
		position: relative;
	}
	.home .cont08 .list dt::after, .home .cont08 .list dd::after {
		display: block;
		position: absolute;
		left: 20px;
		font-size: 16px;
		line-height: 1;
	}
	.home .cont08 .list dt {
		cursor: pointer;
		min-height: 55px;
		display: flex;
		align-items: center;
		padding: 10px 100px 10px 65px;
	}
	.home .cont08 .list dt::after {
		content: "Q.";
		color: #b4a173;
		top: 19px;
	}
	.home .cont08 .list dt .btn {
		width: 35px;
		height: 35px;
		display: block;
		border-radius: 50%;
		background: #b4a173;
		position: absolute;
		top: 0;
		right: 30px;
		bottom: 0;
		margin: auto;
	}
	.home .cont08 .list dt .btn::before, .home .cont08 .list dt .btn::after {
		content: "";
		display: block;
		width: 7px;
		height: 7px;
		position: absolute;
		right: 0;
		left: 0;
		margin: auto;
		color: #fff;
		transform: rotate(45deg);
		transition: all .3s;
	}
	.home .cont08 .list dt .btn::before {
		top: calc(50% - 6px);
		border-bottom: 3px solid;
		border-right: 3px solid;
	}
	.home .cont08 .list dt .btn::after {
		bottom: calc(50% - 6px);
		border-top: 3px solid;
		border-left: 3px solid;
		opacity: 0;
	}
	.home .cont08 .list dt.is-open .btn::before {
		opacity: 0;
	}
	.home .cont08 .list dt.is-open .btn::after {
		opacity: 1;
	}
	.home .cont08 .list dd {
		display: none;
		padding: 0 100px 20px 65px;
		font-size: 14px;
	}
	.home .cont08 .list dd::after {
		content: "A.";
		color: #ccc;
		top: 6px;
	}
	.home .cont08 .list dd + dt {
		margin-top: 20px;
	}

	/*	.home .cont09
	------------------------------------------*/
	.home .cont09 {
		padding: 125px 0 100px;
	}
	.home .cont09 h2 {
		margin-bottom: 55px;
		padding: 50px 0 0;
		background: url("img/home_cont09_en01.png") no-repeat center top;
		font-size: 20px;
		text-align: center;
	}
	.home .cont09 .box01 {
		overflow: hidden;
		margin: 0 auto 60px;
		padding: 60px 0;
		position: relative;
	}
	.home .cont09 .box01::after {
		content: "";
		display: block;
		width: calc(50% + 330px);
		height: 100%;
		background: url("img/common_bg01.png");
		position: absolute;
		top: 0;
		right: 0;
		z-index: -1;
		pointer-events: none;
	}
	.home .cont09 .box01 .inner {
		display: grid;
		grid-template-columns: 540px 1fr;
		grid-column-gap: 50px;
		align-items: flex-start;
	}
	.home .cont09 .box01 .txtBox {
		order: 2;
	}
	.home .cont09 .box01 h3 {
		margin-bottom: 20px;
		font-size: 28px;
		text-shadow: 4px 4px 2px #f5f4ea, -4px 4px 2px #f5f4ea, 4px -4px 2px #f5f4ea, -4px -4px 2px #f5f4ea, 4px 0 2px #f5f4ea, 0 4px 2px #f5f4ea, -4px 0 2px #f5f4ea, 0 -4px 2px #f5f4ea;
	}
	.home .cont09 .box01 .txt {
		text-shadow: 3px 3px 2px #f5f4ea, -3px 3px 2px #f5f4ea, 3px -3px 2px #f5f4ea, -3px -3px 2px #f5f4ea, 3px 0 2px #f5f4ea, 0 3px 2px #f5f4ea, -3px 0 2px #f5f4ea, 0 -3px 2px #f5f4ea;
	}
	.home .cont09 .box01 .txt .tit::after {
		content: "\FF1A";
	}
	.home .cont09 .box01 .message {
		display: table;
		margin: 30px auto 0 0;
		padding: 10px 40px;
		box-sizing: border-box;
		background: #fff;
		color: #b4a173;
	}
	.home .cont09 .box01 .img {
		position: relative;
	}
	.home .cont09 .box01 .img::after {
		content: "";
		display: block;
		width: 100%;
		height: 100%;
		background: #b4a173;
		position: absolute;
		top: 10px;
		left: 10px;
		z-index: -1;
		pointer-events: none;
	}
	.home .cont09 .box02 {
		overflow: hidden;
		margin: 0 auto 70px;
		padding: 50px 0 85px;
		position: relative;
	}
	.home .cont09 .box02::after {
		content: "";
		display: block;
		width: calc(50% + 330px);
		height: 100%;
		background: url("img/common_bg01.png");
		position: absolute;
		top: 0;
		left: 0;
		z-index: -1;
		pointer-events: none;
	}
	.home .cont09 .box02 .inner {
		display: grid;
		grid-template-columns: 1fr 525px;
		grid-column-gap: 50px;
		align-items: end;
	}
	.home .cont09 .box02 h3 {
		margin: 0 auto 40px 35px;
		font-size: 26px;
		text-shadow: 4px 4px 2px #f5f4ea, -4px 4px 2px #f5f4ea, 4px -4px 2px #f5f4ea, -4px -4px 2px #f5f4ea, 4px 0 2px #f5f4ea, 0 4px 2px #f5f4ea, -4px 0 2px #f5f4ea, 0 -4px 2px #f5f4ea;
	}
	.home .cont09 .box02 h3 span {
		font-size: 20px;
	}
	.home .cont09 .box02 .subBox {
		padding: 35px 40px 30px;
		background: #fff;
		position: relative;
	}
	.home .cont09 .box02 .subBox::after {
		content: "";
		display: block;
		background: no-repeat center / contain;
		position: absolute;
		top: -25px;
		right: 40px;
	}
	.home .cont09 .box02 .subBox + .subBox {
		margin-top: 40px;
	}
	.home .cont09 .box02 .subBox.is-biography::after {
		width: 146px;
		height: 45px;
		background-image: url("img/home_cont09_en02.png");
	}
	.home .cont09 .box02 .subBox.is-qualification::after {
		width: 172px;
		height: 46px;
		background-image: url("img/home_cont09_en03.png");
	}
	.home .cont09 .box02 .subBox__tit {
		position: absolute;
		top: -15px;
		left: 40px;
		color: #b4a173;
		font-size: 20px;
		text-shadow: 3px 3px 2px white, -3px 3px 2px white, 3px -3px 2px white, -3px -3px 2px white, 3px 0 2px white, 0 3px 2px white, -3px 0 2px white, 0 -3px 2px white;
	}
	.home .cont09 .box02 .subBox-data {
		width: 100%;
	}
	.home .cont09 .box02 .subBox-data th, .home .cont09 .box02 .subBox-data td {
		padding: 10px 0;
		box-sizing: border-box;
		text-align: left;
		vertical-align: top;
	}
	.home .cont09 .box02 .subBox-data th {
		width: 110px;
		padding-right: 10px;
	}
	.home .cont09 .box02 .img {
		margin-bottom: 10px;
		position: relative;
	}
	.home .cont09 .box02 .img::after {
		content: "";
		display: block;
		width: 100%;
		height: 100%;
		background: #b4a173;
		position: absolute;
		top: 10px;
		left: -10px;
		z-index: -1;
		pointer-events: none;
	}
	.home .cont09 .box02 .img span {
		position: absolute;
		right: 20px;
		bottom: 10px;
		color: #b4a173;
		font-size: 20px;
	}
	.home .cont09 .loop {
		margin: 0 auto 70px;
		height: 325px;
		background: url("img/home_cont09_bg01_pc.png") repeat-x 0 0/auto 100%;
		animation: loop_pc 50s linear infinite;
	}

	@keyframes loop_pc {
		0% {
			background-position: 0 0;
		}
		100% {
			background-position: -1818px 0;
		}
	}
	.home .cont09 .mapBox {
		height: 580px;
	}
	.home .cont09 .mapBox iframe {
		width: 100%;
		height: 100%;
	}

	/* footer
	------------------------------------------------------------------------*/
	footer {
		padding: 90px 0;
		box-sizing: border-box;
	}
	footer .copy {
		font-size: 14px;
		text-align: center;
	}

	/*	.to_top
	------------------------------------------*/
	.to_top {
		display: none;
		position: fixed;
		z-index: 9000;
		right: 30px;
		bottom: 30px;
		width: 70px;
		height: 70px;
		box-shadow: 0 0 15px rgba(0, 0, 0, 0.1);
	}
	.to_top a {
		display: flex;
		justify-content: center;
		align-items: center;
		height: 100%;
		background: #baa97f;
	}
}
/*===============================================
横幅430px以下
===============================================*/
@media screen and (max-width: 431px) {
	body {
		padding-top: 50px;
		line-height: 1.8;
	}

	html,
	body,
	.wrap {
		width: 430px;
		position: relative;
		font-size: 14px;
	}

	.inner {
		width: auto;
		padding-right: 20px;
		padding-left: 20px;
	}

	.pc {
		display: none !important;
	}

	/* common
	------------------------------------------------------------------------*/
	/*	tit
	------------------------------------------*/
	.common_tit01 {
		padding: 30px 0 0;
		font-size: 26px;
		text-align: center;
		position: relative;
		z-index: 1;
	}
	.common_tit01::after {
		content: "";
		display: block;
		width: 100%;
		height: 80px;
		background: no-repeat center bottom / contain;
		position: absolute;
		left: 0;
		bottom: 10px;
		z-index: -1;
		pointer-events: none;
	}
	.common_tit01 span {
		display: block;
		margin-bottom: 5px;
		font-size: 12px;
	}
	.common_tit01.is-small {
		font-size: 22px;
	}

	/*	.common_cv01
	------------------------------------------*/
	.common_cv01 {
		padding: 40px 0;
		background: #ece9db;
	}
	.common_cv01 h2 {
		margin: 0 auto 20px;
		padding: 35px 0 0 20px;
		font-size: 30px;
		text-shadow: 15px 12px 5px rgba(0, 0, 0, 0.1);
		letter-spacing: .17em;
		text-align: center;
		position: relative;
		z-index: 1;
	}
	.common_cv01 h2::after {
		content: "";
		display: block;
		width: 180px;
		height: 70px;
		background: url("img/common_cv_txt01.png") no-repeat center/contain;
		position: absolute;
		top: 0;
		left: 0;
		z-index: -1;
	}
	.common_cv01 .lead {
		margin-bottom: 30px;
		text-align: center;
	}
	.common_cv01 .btns {
		display: grid;
		grid-template-columns: 1fr 1fr;
		grid-gap: 20px;
	}
	.common_cv01 .btn {
		font-size: 18px;
		line-height: 1.5;
	}
	.common_cv01 .btn a {
		display: flex;
		justify-content: center;
		align-items: center;
		box-sizing: border-box;
	}
	.common_cv01 .btn a::before {
		content: "";
		display: inline-block;
		margin-right: 10px;
		background: no-repeat center / contain;
	}
	.common_cv01 .btn.is-tel {
		grid-area: 1 / 1 / 2 / 3;
		font-size: 24px;
	}
	.common_cv01 .btn.is-tel a {
		justify-content: flex-start;
		padding: 10px 5px 10px 10px;
		height: 80px;
		background: #fff;
	}
	.common_cv01 .btn.is-tel a::before {
		width: 20px;
		height: 20px;
		background-image: url("img/common_ico_tel02.png");
	}
	.common_cv01 .btn.is-tel .time {
		margin: 0 auto 0 10px;
		font-size: 12px;
		line-height: 1.8;
		letter-spacing: 0;
	}
	.common_cv01 .btn.is-web a, .common_cv01 .btn.is-line a {
		height: 70px;
	}
	.common_cv01 .btn.is-web a {
		background: #ded0a8;
	}
	.common_cv01 .btn.is-web a::before {
		width: 21px;
		height: 19px;
		background-image: url("img/common_ico_calendar01.png");
	}
	.common_cv01 .btn.is-line a {
		background: #333;
		color: #fff;
	}
	.common_cv01 .btn.is-line a::before {
		width: 24px;
		height: 23px;
		background-image: url("img/common_ico_line01.png");
	}

	/* header
	------------------------------------------------------------------------*/
	header {
		position: fixed;
		z-index: 9990;
		top: 0;
		left: 0;
		width: 100%;
		height: 50px;
	}
	header h1 {
		position: absolute;
		z-index: 2;
		top: 0;
		left: 130px;
		max-width: calc(100% - 230px);
		height: 100%;
		display: flex;
		align-items: center;
		box-sizing: border-box;
		font-size: 10px;
		line-height: 1.4;
		font-family: '游ゴシック体', YuGothic, '游ゴシック Medium', 'Yu Gothic Medium', '游ゴシック', 'Yu Gothic', 'Hiragino Kaku Gothic ProN', 'Hiragino Sans', 'ヒラギノ角ゴ ProN W3', 'メイリオ', Meiryo, sans-serif;
	}
	header .headerTop {
		position: absolute;
		top: 0;
		left: 0 !important;
		width: 100%;
		height: 100%;
		display: flex;
		justify-content: space-between;
		align-items: center;
		padding: 0 50px 0 10px;
		box-sizing: border-box;
		background: #f5f4ea;
	}
	header .logo {
		width: 105px;
	}
	header .tel {
		width: 50px;
		height: 50px;
	}
	header .tel a {
		display: block;
		height: 100%;
		background: url("img/common_ico_tel01.png") no-repeat center;
	}
	header .headerCv {
		position: fixed;
		left: 0;
		bottom: 0;
		width: 100%;
		display: flex;
	}
	header .headerCv__btn {
		width: 50%;
	}
	header .headerCv__btn a {
		height: 50px;
		display: flex;
		justify-content: center;
		align-items: center;
	}
	header .headerCv__btn a::before {
		content: "";
		display: inline-block;
		width: 21px;
		height: 21px;
		margin-right: 10px;
		background: no-repeat center / contain;
	}
	header .headerCv__btn.is-web a {
		background: #ded0a8;
	}
	header .headerCv__btn.is-web a::before {
		background-image: url("img/common_ico_calendar01.png");
	}
	header .headerCv__btn.is-line a {
		background: #333;
		color: #fff;
	}
	header .headerCv__btn.is-line a::before {
		background-image: url("img/common_ico_line01.png");
	}

	/* nav
	------------------------------------------------------------------------*/
	nav {
		position: fixed;
		top: 0;
		right: 0;
		z-index: 10000;
	}

	#nav-btn {
		width: 50px;
		height: 50px;
		position: absolute;
		top: 0;
		right: 0;
		z-index: 10010;
		transition: all .5s;
		background: #ded0a8;
	}

	.menu-btn,
	.menu-btn span {
		display: inline-block;
		transition: all .4s;
		box-sizing: border-box;
	}

	.menu-btn {
		position: absolute;
		width: 15px;
		height: 14px;
		top: 0;
		bottom: 0;
		right: 0;
		left: 0;
		margin: auto;
	}
	.menu-btn span {
		position: absolute;
		left: 0;
		width: 100%;
		height: 2px;
		background: #333;
	}
	.menu-btn span:nth-of-type(1) {
		top: 0;
	}
	.menu-btn span:nth-of-type(2) {
		top: 0;
		bottom: 0;
		margin: auto;
	}
	.menu-btn span:nth-of-type(3) {
		bottom: 0;
	}

	#nav-btn.active .menu-btn span:nth-of-type(1) {
		-webkit-transform: translateY(6px) rotate(-45deg);
		transform: translateY(6px) rotate(-45deg);
	}
	#nav-btn.active .menu-btn span:nth-of-type(2) {
		opacity: 0;
	}
	#nav-btn.active .menu-btn span:nth-of-type(3) {
		-webkit-transform: translateY(-6px) rotate(45deg);
		transform: translateY(-6px) rotate(45deg);
	}

	#nav {
		display: none;
		padding: 10px 20px 70px;
		background: rgba(245, 244, 234, 0.95);
		box-sizing: border-box;
	}
	#nav li {
		border-bottom: 1px solid #b4a173;
		font-size: 16px;
		line-height: 1.4;
	}
	#nav li a {
		padding: 15px 0;
		min-height: 60px;
		display: flex;
		align-items: center;
		box-sizing: border-box;
	}

	#nav-btn.active + #nav {
		display: block;
		overflow: auto;
		position: absolute;
		z-index: 1001;
		top: 49px;
		left: -430px;
		z-index: 10000;
		width: 430px;
		height: calc(100vh - 100px);
		max-height: 90vh;
	}

	/* .home
	------------------------------------------------------------------------*/
	/*	.home .key
	------------------------------------------*/
	.home .key {
		margin-bottom: 30px;
		background: url("img/home_key_img01_sp.png") no-repeat center top/contain;
		position: relative;
	}
	.home .key::after {
		content: "";
		display: block;
		width: 49px;
		height: 278px;
		background: url("img/home_key_txt01_sp.png") no-repeat left top/contain;
		position: absolute;
		top: 0;
		left: 0;
	}
	.home .key .inner {
		width: 100%;
		height: 640px;
		display: flex;
		align-items: flex-end;
		padding: 0 20px;
		box-sizing: border-box;
		position: relative;
		z-index: 2;
	}
	.home .key .txtBox {
		width: 100%;
	}
	.home .key .txt01 {
		display: table;
		margin: 0 auto 13px 0;
		padding: 4px 0;
		border-top: 1px solid #b4a173;
		border-bottom: 1px solid #b4a173;
		font-size: 14px;
	}
	.home .key .txt02 {
		margin-bottom: 10px;
		font-size: 26px;
		line-height: 1.4;
	}
	.home .key .txt03 {
		position: relative;
		display: table;
		margin-bottom: 20px;
	}
	.home .key .txt03 img:nth-of-type(1) {
		width: 213px;
		position: relative;
		z-index: 2;
	}
	.home .key .txt03 img:nth-of-type(2) {
		width: 166px;
		position: absolute;
		top: -35px;
		right: -125px;
	}
	.home .key .campaign {
		width: 390px;
		padding: 12px 12px 12px 15px;
		box-sizing: border-box;
		border-left: 5px solid #dc7693;
		background: rgba(255, 255, 255, 0.8);
		line-height: 1.5;
	}
	.home .key .campaign__txt_box {
		display: flex;
		align-items: flex-end;
		gap: 0 10px;
		justify-content: center;
	}
	.home .key .campaign__tit {
		color: #dc7693;
		font-size: 16px;
		position: relative;
		text-align: center;
		display: flex;
		flex-direction: column;
		align-items: center;
		gap: 3px 0;
		line-height: 1;
	}
	.home .key .campaign__tit .campaign__tit_spacing01 {
		width: 100%;
		display: flex;
		justify-content: space-around;
	}
	.home .key .campaign__txt {
		font-size: 20px;
		line-height: 1;
	}
	.home .key .campaign__txt span {
		display: block;
		color: #999;
		font-size: 12px;
		margin-bottom: 5px;
	}
	.home .key .campaign-price {
		margin-top: 10px;
		display: flex;
		align-items: flex-start;
		justify-content: center;
		gap: 0 15px;
		padding: 15px 0 8px;
		background: rgba(220, 118, 147, 0.2);
		text-align: center;
	}
	.home .key .campaign-price__txt01 {
		line-height: 1;
		font-size: 18px;
		padding: 7px 0 5px;
		border-top: 1px solid #e61673;
		border-bottom: 1px solid #e61673;
	}
	.home .key .campaign-price__txt04 {
		width: 100%;
		font-size: 14px;
		text-align: left;
		padding-right: 15px;
		background: url(img/common_ico_row.png) no-repeat center right 6px;
		margin-top: 7px;
		line-height: 1;
	}
	.home .key .campaign-price__txt02 {
		display: flex;
		justify-content: center;
		align-items: flex-end;
		color: #e61673;
		font-size: 48px;
		line-height: 1;
		position: relative;
	}
		.home .key .campaign-price__txt02::before {
			content: "";
			position: absolute;
			top: -25px;
			left: -8px;
			width: 34px;
			height: 27px;
			background: url(img/home_key_icon_sp01.png) no-repeat center / 100%;
		}
		.home .key .campaign-price__txt02::after {
			content: "";
			position: absolute;
			bottom: -25px;
			right: -27px;
			width: 48px;
			height: 47px;
			background: url(img/home_key_icon_sp02.png) no-repeat center / 100%;
		}
	.home .key .campaign-price__txt02 .yen {
		display: grid;
		margin: 0 0 5px 3px;
		font-size: 20px;
	}
	.home .key .campaign-price__txt02 .tax {
		order: -1;
		font-size: 12px;
	}
	.home .key .campaign-price__txt03 {
		font-size: 12px;
		text-align: right;
		line-height: 1;
		margin-bottom: 2px;
	}
	/* .home .key .img {
		position: absolute;
		bottom: -128px;
		left: 65px;
		width: 240px;
		height: 140px;
		pointer-events: none;
		background: url("img/home_key_img05.png") no-repeat top left / 120px, 
		url("img/home_key_img04.png") no-repeat top 30px right / 80px;
		filter: drop-shadow(15px 15px 20px rgba(0, 0, 0, 0.15));
	} */

	/*	.home .cont01
	------------------------------------------*/
	.home .cont01 {
		padding: 0 0 80px;
		overflow: hidden;
	}
	.home .cont01 .list {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		align-items: flex-start;
		grid-gap: 25px 15px;
		position: relative;
		z-index: 2;
		counter-reset: number;
	}
	.home .cont01 .list li {
		padding: 40px 0 0;
		position: relative;
	}
		.home .cont01 .list li::before {
			counter-increment: number;
			content: counter(number,decimal-leading-zero);
			color: #b4a173;
			position: absolute;
			top: 0;
			left: 0;
		}
		.home .cont01 .list li::after {
			content: "";
			display: block;
			width: 100%;
			height: 1px;
			background: linear-gradient(to right, #c3b38e 90px, #ccc 90px);
			position: absolute;
			top: 30px;
			left: 0;
		}
	.home .cont01 .list li .tit {
		margin-bottom: 10px;
		font-size: 18px;
		position: relative;
	}
		.home .cont01 .list li .tit::before {
			content: url(img/home_cont01_icon_sp01.png);
			position: absolute;
			top: -40px;
			right: 8px;
			z-index: 1;
		}
		.home .cont01 .list li:nth-of-type(2) .tit::before {
			content: url(img/home_cont01_icon_sp02.png);
			position: absolute;
			top: -36px;
			right: 8px;
			z-index: 1;
		}
		.home .cont01 .list li:nth-of-type(3) .tit::before {
			content: url(img/home_cont01_icon_sp03.png);
			position: absolute;
			top: -70px;
			right: -3px;
			z-index: 1;
		}
		.home .cont01 .list li:nth-of-type(4) .tit::before {
			content: url(img/home_cont01_icon_sp04.png);
			position: absolute;
			top: -40px;
			right: 8px;
			z-index: 1;
		}
	.home .cont01 .list li .txt {
		font-size: 12px;
	}
	.home .cont01 .list li:nth-of-type(1) {
		margin-top: 40px;
	}
	.home .cont01 .list li:nth-of-type(4) {
		margin-top: -40px;
	}
	.home .cont01 .campaign {
		margin-top: 90px;
		width: 390px;
		padding: 12px 12px 12px 15px;
		box-sizing: border-box;
		border-left: 5px solid #dc7693;
		background: rgba(255, 255, 255, 0.8);
		line-height: 1.5;
		position: relative;
	}
		.home .cont01 .campaign::before {
			content: "";
			display: block;
			width: calc(100% + 40px);
			height: 210px;
			background: #f5f4ea url(img/home_cont01_bg01.png) no-repeat right -20px bottom/contain;
			background-blend-mode: multiply;
			position: absolute;
			bottom: 60px;
			left: -20px;
			z-index: -1;
			pointer-events: none;
		}
		.home .cont01 .campaign::after {
			content: "";
			display: block;
			width: 200px;
			height: 70px;
			background: url(img/home_cont01_txt01.png) no-repeat center/contain;
			position: absolute;
			top: -75px;
			left: -10px;
			right: 0;
			margin: auto;
		}
	.home .cont01 .campaign__txt_box {
		display: flex;
		align-items: flex-end;
		gap: 0 10px;
		justify-content: center;
	}
	.home .cont01 .campaign__tit {
		color: #dc7693;
		font-size: 16px;
		position: relative;
		text-align: center;
		display: flex;
		flex-direction: column;
		align-items: center;
		gap: 3px 0;
		line-height: 1;
	}
	.home .cont01 .campaign__tit .campaign__tit_spacing01 {
		width: 100%;
		display: flex;
		justify-content: space-around;
	}
	.home .cont01 .campaign__txt {
		font-size: 20px;
		line-height: 1;
	}
	.home .cont01 .campaign__txt span {
		display: block;
		color: #999;
		font-size: 12px;
		margin-bottom: 5px;
	}
	.home .cont01 .campaign-price {
		margin-top: 10px;
		display: flex;
		align-items: flex-start;
		justify-content: center;
		gap: 0 15px;
		padding: 15px 0 8px;
		background: rgba(220, 118, 147, 0.2);
		text-align: center;
	}
	.home .cont01 .campaign-price__txt01 {
		line-height: 1;
		font-size: 18px;
		padding: 7px 0 5px;
		border-top: 1px solid #e61673;
		border-bottom: 1px solid #e61673;
	}
	.home .cont01 .campaign-price__txt04 {
		width: 100%;
		font-size: 14px;
		text-align: left;
		padding-right: 15px;
		background: url(img/common_ico_row.png) no-repeat center right 6px;
		margin-top: 7px;
		line-height: 1;
	}
	.home .cont01 .campaign-price__txt02 {
		display: flex;
		justify-content: center;
		align-items: flex-end;
		color: #e61673;
		font-size: 48px;
		line-height: 1;
		position: relative;
	}
		.home .cont01 .campaign-price__txt02::before {
			content: "";
			position: absolute;
			top: -25px;
			left: -8px;
			width: 34px;
			height: 27px;
			background: url(img/home_key_icon_sp01.png) no-repeat center / 100%;
		}
		.home .cont01 .campaign-price__txt02::after {
			content: "";
			position: absolute;
			bottom: -25px;
			right: -27px;
			width: 48px;
			height: 47px;
			background: url(img/home_key_icon_sp02.png) no-repeat center / 100%;
		}
	.home .cont01 .campaign-price__txt02 .yen {
		display: grid;
		margin: 0 0 5px 3px;
		font-size: 20px;
	}
	.home .cont01 .campaign-price__txt02 .tax {
		order: -1;
		font-size: 12px;
	}
	.home .cont01 .campaign-price__txt03 {
		font-size: 12px;
		text-align: right;
		line-height: 1;
		margin-bottom: 2px;
	}
	.home .cont01 .campaign__note {
		margin: 10px auto 0;
		text-align: center;
	}

	/*	.home .cont02
	------------------------------------------*/
	.home .cont02 {
		padding: 60px 0;
		counter-reset: number;
	}
	.home .cont02 h2 {
		margin-bottom: 50px;
	}
	.home .cont02 h2::after {
		background-image: url("img/home_cont02_en01.png");
	}
	.home .cont02 .list01 {
		padding: 0 30px;
	}
	.home .cont02 .list01 li {
		display: flex;
		flex-direction: column;
		position: relative;
	}
	.home .cont02 .list01 li + li {
		margin-top: 60px;
	}
	.home .cont02 .list01 li::after {
		counter-increment: number;
		content: "POINT " counter(number,decimal-leading-zero);
		display: block;
		position: absolute;
		top: 60px;
		right: calc(100% - 5px);
		z-index: -1;
		color: #fff;
		font-size: 38px;
		line-height: 1;
		letter-spacing: .1em;
		white-space: nowrap;
		writing-mode: vertical-rl;
	}
	.home .cont02 .list01 h3, .home .cont02 .list01 .txt {
		width: calc(100% - 20px);
		margin: 0 auto;
	}
	.home .cont02 .list01 h3 {
		margin-bottom: 10px;
		font-size: 20px;
	}
	.home .cont02 .list01 .img {
		order: -1;
		margin-bottom: 20px;
		position: relative;
	}
	.home .cont02 .list01 .img::before, .home .cont02 .list01 .img::after {
		content: "";
		display: block;
		width: 80px;
		height: 1px;
		background: #b4a173;
		transform: rotate(-45deg);
		position: absolute;
		pointer-events: none;
	}
	.home .cont02 .list01 .img::before {
		top: 13px;
		left: -25px;
	}
	.home .cont02 .list01 .img::after {
		right: -25px;
		bottom: 13px;
	}
	.home .cont02 .list01 .img img {
		width: 100%;
		box-shadow: 10px 10px 15px rgba(0, 0, 0, 0.05);
	}
	.home .cont02 .list02 {
		margin: 50px auto 0;
	}
	.home .cont02 .list02 li {
		padding: 15px 15px 15px 60px;
		box-sizing: border-box;
		background: #fff;
		box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
		position: relative;
	}
	.home .cont02 .list02 li + li {
		margin-top: 15px;
	}
	.home .cont02 .list02 li::after {
		counter-increment: number;
		content: counter(number,decimal-leading-zero);
		display: block;
		position: absolute;
		height: 1em;
		top: 0;
		left: 15px;
		bottom: 0;
		margin: auto;
		padding: 0 12px 0 0;
		border-right: 1px solid;
		color: #b4a173;
		font-size: 20px;
		line-height: 1;
	}

	/*	.home .cont03
	------------------------------------------*/
	.home .cont03 {
		margin-top: 50px;
		padding: 60px 20px 60px 0;
		position: relative;
	}
	.home .cont03::before {
		content: "";
		display: block;
		width: 100%;
		height: 240px;
		background: url("img/home_cont03_bg01_sp.png") no-repeat right center/contain;
		position: absolute;
		top: -50px;
		left: 0;
		z-index: -1;
		pointer-events: none;
	}
	.home .cont03::after {
		content: "";
		display: block;
		width: calc(100% - 20px);
		height: 100%;
		background: #ece9db;
		position: absolute;
		top: 0;
		left: 0;
		z-index: -2;
		pointer-events: none;
	}
	.home .cont03 .topBox {
		margin-bottom: 70px;
		background: url("img/home_cont03_en01_sp.png") no-repeat center top 105px/contain;
	}
	.home .cont03 .topBox .lead {
		padding: 0 10px;
	}
	.home .cont03 h2 {
		display: flex;
		flex-direction: column-reverse;
		margin-bottom: 40px;
		padding: 0 20px 0 0;
		border-right: 1px solid #dc7693;
		color: #dc7693;
		font-size: 30px;
		writing-mode: vertical-rl;
		letter-spacing: .08em;
	}
	.home .cont03 h2 span {
		margin-right: 10px;
		color: #333;
		font-size: 12px;
		letter-spacing: .05em;
		line-height: 1.8;
	}
	.home .cont03 .box::after {
		content: "";
		display: block;
		margin: 20px auto 0;
		width: calc(100% - 40px);
		background: no-repeat center / contain;
	}
	.home .cont03 .box h3 {
		margin-bottom: 30px;
		padding: 20px 0 0;
		font-size: 22px;
		text-align: center;
		position: relative;
	}
	.home .cont03 .box h3::after {
		content: "";
		display: block;
		width: 20px;
		height: 3px;
		background: #dc7693;
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		margin: auto;
	}
	.home .cont03 .box.is-double::after {
		height: 200px;
		background-image: url("img/home_cont03_img01.png");
	}
	.home .cont03 .box.is-improve {
		margin-top: 70px;
	}
	.home .cont03 .box.is-improve::after {
		height: 280px;
		background-image: url("img/home_cont03_img02.png");
	}
	.home .cont03 .box.is-improve .img {
		margin: 35px auto 45px;
		text-align: center;
	}
	.home .cont03 .box.is-improve .img img {
		width: 270px;
	}
	.home .cont03 .box.is-improve .effect {
		display: table;
		margin: 0 auto;
		counter-reset: number;
	}
	.home .cont03 .box.is-improve .effect li {
		padding: 0 0 0 80px;
		color: #e61673;
		font-size: 24px;
		line-height: 1.5;
		position: relative;
	}
	.home .cont03 .box.is-improve .effect li + li {
		margin-top: 20px;
	}
	.home .cont03 .box.is-improve .effect li::before {
		counter-increment: number;
		content: counter(number,decimal-leading-zero);
		position: absolute;
		top: 0;
		left: 28px;
		bottom: 0;
		height: 1em;
		margin: auto;
		color: #333;
		font-size: 38px;
		line-height: 1;
		z-index: 1;
	}
	.home .cont03 .box.is-improve .effect li::after {
		content: "Effect";
		position: absolute;
		top: 0;
		left: 0;
		bottom: 0;
		margin: auto;
		height: 1em;
		color: #333;
		font-size: 14px;
		line-height: 1;
		text-shadow: 1px 1px 0.5px #ece9db, -1px 1px 0.5px #ece9db, 1px -1px 0.5px #ece9db, -1px -1px 0.5px #ece9db, 1px 0 0.5px #ece9db, 0 1px 0.5px #ece9db, -1px 0 0.5px #ece9db, 0 -1px 0.5px #ece9db;
		z-index: 2;
	}

	/*	.home .cont04
	------------------------------------------*/
	.home .cont04 {
		padding: 60px 0;
	}
	.home .cont04 h2 {
		margin-bottom: 30px;
	}
	.home .cont04 h2::after {
		background-image: url("img/home_cont04_en01.png");
	}
	.home .cont04 .lead {
		margin-bottom: 20px;
		font-size: 16px;
		text-align: center;
	}
	.home .cont04 .txt {
		margin-bottom: 40px;
	}
	.home .cont04 .img img {
		display: block;
		margin: 0 auto;
	}
	.home .cont04 .img img + img {
		margin-top: 40px;
	}

	/*	.home .cont05
	------------------------------------------*/
	.home .cont05 {
		overflow: hidden;
		padding: 60px 0;
		background: #ece9db;
	}
	.home .cont05 h2 {
		margin-bottom: 30px;
	}
	.home .cont05 h2::after {
		background-image: url("img/home_cont05_en01.png");
	}
	.home .cont05 .lead {
		margin-bottom: 30px;
		font-size: 16px;
		text-align: center;
	}
	.home .cont05 .box + .box {
		margin-top: 50px;
	}
	.home .cont05 .box .titBox {
		display: grid;
		grid-template-columns: 1fr 80px;
		grid-auto-rows: 1fr auto;
		grid-gap: 0 10px;
		align-items: end;
		margin-bottom: 5px;
	}
	.home .cont05 .box h3 {
		grid-row: 1 / 2;
		margin-bottom: 10px;
		padding: 0 0 0 15px;
		font-size: 20px;
		position: relative;
	}
	.home .cont05 .box h3::after {
		content: "";
		display: block;
		width: 3px;
		height: 80%;
		background: #b4a173;
		position: absolute;
		top: 0;
		left: 0;
		bottom: 0;
		margin: auto;
	}
	.home .cont05 .box .tag {
		grid-row: 2 / 3;
		display: flex;
		flex-wrap: wrap;
		margin: 0 0 10px 12px;
	}
	.home .cont05 .box .tag li {
		margin: 3px;
		padding: 2px 10px;
		color: #fff;
		line-height: 1.5;
		font-size: 12px;
	}
	.home .cont05 .box .tag li:not([class]) {
		color: #333;
		padding: 0;
	}
	.home .cont05 .box .tag li.gold {
		background: #b4a173;
	}
	.home .cont05 .box .tag li.pink {
		background: #dc7693;
	}
	.home .cont05 .box .tag li.gray {
		background: #aaa;
	}
	.home .cont05 .box .img {
		grid-area: 1 / 2 / 3 / 3;
		text-align: center;
	}
	.home .cont05 .box .data {
		width: calc(100% + 10px);
		margin: 0 -5px;
		border-collapse: separate;
		border-spacing: 5px;
	}
	.home .cont05 .box .data th, .home .cont05 .box .data td {
		padding: 12px 10px;
		box-sizing: border-box;
		line-height: 1.5;
		vertical-align: middle;
	}
	.home .cont05 .box .data th {
		width: auto;
		background: #d8cbab;
		font-size: 16px;
		text-align: left;
	}
	.home .cont05 .box .data th span {
		font-size: 20px;
	}
	.home .cont05 .box .data .through {
		text-decoration: line-through;
	}
	.home .cont05 .box .data .big {
		display: inline-block;
		margin-left: 10px;
		padding: 0 0 0 35px;
		color: #e61673;
		font-size: 24px;
		position: relative;
	}
	.home .cont05 .box .data .big::before, .home .cont05 .box .data .big::after {
		content: "";
		display: block;
		background: no-repeat center / contain;
		position: absolute;
		pointer-events: none;
	}
	.home .cont05 .box .data .big::before {
		width: 25px;
		height: 15px;
		background-image: url("img/home_cont05_ico01.png");
		top: 0;
		left: 0;
		bottom: 0;
		margin: auto;
	}
	.home .cont05 .box .data .big::after {
		width: 30px;
		height: 35px;
		background-image: url("img/home_cont05_ico02.png");
		top: -15px;
		right: -20px;
	}
	.home .cont05 .box .data .big img {
		width: 40px;
		margin-right: 3px;
		vertical-align: -7px;
	}
	.home .cont05 .box .data td {
		background: #fff;
		font-size: 18px;
		text-align: right;
		color: #e61673;
	}
	.home .cont05 .box .data td .note {
		display: grid;
		grid-template-columns: auto auto;
		justify-content: end;
		grid-gap: 3px;
		margin: 10px 0 0 auto;
		font-size: 12px;
		text-align: left;
	}
	.home .cont05 .box.is-body .titBox {
		grid-template-columns: 1fr;
	}
	.home .cont05 .noticeBox {
		margin: 50px auto 0;
		padding: 20px;
		box-sizing: border-box;
		border: 1px solid #d8cbab;
	}
	.home .cont05 .noticeBox__tit {
		margin-bottom: 10px;
		color: #b4a173;
		font-size: 24px;
		text-align: center;
		letter-spacing: .1em;
	}
	.home .cont05 .typeBox {
		margin: 50px auto 0;
		padding: 30px 20px 20px;
		position: relative;
		z-index: 1;
	}
	.home .cont05 .typeBox::after {
		content: "";
		display: block;
		width: calc(100% + 20px);
		height: 100%;
		background: #f5f4ea;
		position: absolute;
		top: 0;
		right: -20px;
		z-index: -1;
		pointer-events: none;
	}
	.home .cont05 .typeBox__tit {
		margin-bottom: 20px;
		padding: 20px 0 0;
		font-size: 22px;
		text-align: center;
		position: relative;
	}
	.home .cont05 .typeBox__tit::after {
		content: "";
		display: block;
		width: 20px;
		height: 3px;
		background: #b4a173;
		position: absolute;
		top: 0;
		right: 0;
		left: 0;
		margin: auto;
	}
	.home .cont05 .typeBox__lead {
		margin-bottom: 30px;
		text-align: center;
	}
	.home .cont05 .typeBox-box {
		background: #fff;
		border: 1px solid #d8cbab;
		box-sizing: border-box;
	}
	.home .cont05 .typeBox-box:nth-of-type(2) {
		margin-top: 20px;
		border-color: #ccc;
	}
	.home .cont05 .typeBox-box:nth-of-type(2) .typeBox-box__tit {
		background: #ccc;
	}
	.home .cont05 .typeBox-box__tit {
		margin: 0 auto 15px;
		padding: 2px 10px;
		background: #d8cbab;
		font-size: 20px;
		text-align: center;
		letter-spacing: .1em;
	}
	.home .cont05 .typeBox-box__img {
		padding: 10px;
		text-align: center;
	}

	/*	.home .cont06
	------------------------------------------*/
	.home .cont06 {
		padding: 60px 0;
	}
	.home .cont06 h2 {
		margin-bottom: 40px;
	}
	.home .cont06 h2::after {
		background-image: url("img/home_cont06_en01.png");
	}
	.home .cont06 .data {
		border-top: 1px solid #b4a173;
	}
	.home .cont06 .data tr {
		border-bottom: 1px solid #b4a173;
	}
	.home .cont06 .data th, .home .cont06 .data td {
		box-sizing: border-box;
		text-align: left;
		vertical-align: middle;
	}
	.home .cont06 .data th {
		width: 135px;
		padding: 15px 10px 15px 20px;
		position: relative;
	}
	.home .cont06 .data th::before {
		content: "";
		display: block;
		width: .8em;
		height: .8em;
		background: #b4a173;
		position: absolute;
		top: 0;
		left: 2px;
		bottom: 0;
		margin: auto;
	}
	.home .cont06 .data td {
		padding: 15px 0;
		font-size: 12px;
	}

	/*	.home .cont07
	------------------------------------------*/
	.home .cont07 {
		padding: 50px 0;
	}
	.home .cont07 h2 {
		margin-bottom: 40px;
	}
	.home .cont07 h2::after {
		background-image: url("img/home_cont07_en01.png");
	}
	.home .cont07 .list {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		grid-gap: 40px 20px;
		margin: 0 auto 30px;
		counter-reset: number;
	}
	.home .cont07 .list li {
		display: flex;
		flex-direction: column;
		padding: 0 0 15px;
		background: #fff;
		box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
	}
	.home .cont07 .list li:nth-of-type(odd) {
		transform: translateY(30px);
	}
	.home .cont07 .list h3, .home .cont07 .list .txt {
		width: calc(100% - 30px);
		margin: 0 auto;
	}
	.home .cont07 .list h3 {
		margin-bottom: 12px;
		padding: 0 0 10px;
		font-size: 16px;
		position: relative;
	}
	.home .cont07 .list h3::after {
		content: "";
		display: block;
		width: 20px;
		height: 2px;
		background: #b4a173;
		position: absolute;
		left: 0;
		bottom: 0;
	}
	.home .cont07 .list .txt {
		font-size: 12px;
	}
	.home .cont07 .list .img {
		order: -1;
		margin-bottom: 30px;
		position: relative;
	}
	.home .cont07 .list .img::after {
		counter-increment: number;
		content: counter(number,decimal-leading-zero);
		display: flex;
		justify-content: center;
		align-items: center;
		position: absolute;
		left: 15px;
		bottom: -18px;
		width: 35px;
		height: 35px;
		background: #b4a173;
		color: #fff;
		font-size: 18px;
	}
	.home .cont07 .list .img img {
		width: 100%;
	}
	.home .cont07 .list .notice {
		padding: 15px;
		background: none;
		box-shadow: none;
		border: 1px solid #b4a173;
		color: #b4a173;
	}
	.home .cont07 .list .notice h3, .home .cont07 .list .notice .txt {
		width: 100%;
	}
	.home .cont07 .list .notice h3 {
		padding: 0;
		font-size: 18px;
		letter-spacing: .1em;
	}
	.home .cont07 .list .notice h3::after {
		content: none;
	}
	.home .cont07 .list .notice .txt + .txt {
		margin-top: 10px;
	}

	/*	.home .cont08
	------------------------------------------*/
	.home .cont08 {
		padding: 60px 0;
		background: #ece9db;
	}
	.home .cont08 h2 {
		margin-bottom: 30px;
	}
	.home .cont08 h2::after {
		background-image: url("img/home_cont08_en01.png");
		bottom: 0;
	}
	.home .cont08 .list dt, .home .cont08 .list dd {
		background: #fff;
		box-sizing: border-box;
		position: relative;
	}
	.home .cont08 .list dt::after, .home .cont08 .list dd::after {
		display: block;
		position: absolute;
		left: 15px;
		font-size: 16px;
		line-height: 1;
	}
	.home .cont08 .list dt {
		cursor: pointer;
		min-height: 55px;
		display: flex;
		align-items: center;
		padding: 12px 60px 12px 50px;
		font-size: 16px;
	}
	.home .cont08 .list dt::after {
		content: "Q.";
		color: #b4a173;
		top: 18px;
	}
	.home .cont08 .list dt .btn {
		width: 30px;
		height: 30px;
		display: block;
		border-radius: 50%;
		background: #b4a173;
		position: absolute;
		top: 0;
		right: 15px;
		bottom: 0;
		margin: auto;
	}
	.home .cont08 .list dt .btn::before, .home .cont08 .list dt .btn::after {
		content: "";
		display: block;
		width: 7px;
		height: 7px;
		position: absolute;
		right: 0;
		left: 0;
		margin: auto;
		color: #fff;
		transform: rotate(45deg);
		transition: all .3s;
	}
	.home .cont08 .list dt .btn::before {
		top: calc(50% - 6px);
		border-bottom: 2px solid;
		border-right: 2px solid;
	}
	.home .cont08 .list dt .btn::after {
		bottom: calc(50% - 6px);
		border-top: 2px solid;
		border-left: 2px solid;
		opacity: 0;
	}
	.home .cont08 .list dt.is-open .btn::before {
		opacity: 0;
	}
	.home .cont08 .list dt.is-open .btn::after {
		opacity: 1;
	}
	.home .cont08 .list dd {
		display: none;
		padding: 0 20px 15px 50px;
	}
	.home .cont08 .list dd::after {
		content: "A.";
		color: #ccc;
		top: 4px;
	}
	.home .cont08 .list dd + dt {
		margin-top: 10px;
	}

	/*	.home .cont09
	------------------------------------------*/
	.home .cont09 {
		padding: 60px 0;
	}
	.home .cont09 h2 {
		margin-bottom: 30px;
		padding: 50px 0 0;
		background: url("img/home_cont09_en01.png") no-repeat center top;
		font-size: 20px;
		text-align: center;
	}
	.home .cont09 .box01 {
		overflow: hidden;
		margin: 0 auto 50px;
		padding: 30px 0 30px 20px;
		position: relative;
	}
	.home .cont09 .box01::after {
		content: "";
		display: block;
		width: calc(100% - 20px);
		height: 100%;
		background: url("img/common_bg01.png") repeat left top/7px;
		position: absolute;
		top: 0;
		right: 0;
		z-index: -1;
		pointer-events: none;
	}
	.home .cont09 .box01 .txtBox {
		margin: 0 auto 30px;
	}
	.home .cont09 .box01 h3 {
		margin-bottom: 25px;
		font-size: 20px;
		text-align: center;
		text-shadow: 4px 4px 2px #f5f4ea, -4px 4px 2px #f5f4ea, 4px -4px 2px #f5f4ea, -4px -4px 2px #f5f4ea, 4px 0 2px #f5f4ea, 0 4px 2px #f5f4ea, -4px 0 2px #f5f4ea, 0 -4px 2px #f5f4ea;
	}
	.home .cont09 .box01 .txt {
		display: grid;
		grid-template-columns: auto 1fr;
		grid-gap: 5px;
		text-shadow: 3px 3px 2px #f5f4ea, -3px 3px 2px #f5f4ea, 3px -3px 2px #f5f4ea, -3px -3px 2px #f5f4ea, 3px 0 2px #f5f4ea, 0 3px 2px #f5f4ea, -3px 0 2px #f5f4ea, 0 -3px 2px #f5f4ea;
	}
	.home .cont09 .box01 .txt .tit {
		padding: 0 25px 0 0;
		position: relative;
	}
	.home .cont09 .box01 .txt .tit::after {
		content: "\FF1A";
		position: absolute;
		top: 0;
		right: 0;
	}
	.home .cont09 .box01 .message {
		margin: 25px auto 0;
		padding: 10px 15px;
		background: #fff;
		color: #b4a173;
		text-align: center;
	}
	.home .cont09 .box01 .img {
		position: relative;
	}
	.home .cont09 .box01 .img::after {
		content: "";
		display: block;
		width: 100%;
		height: 100%;
		background: #b4a173;
		position: absolute;
		top: 10px;
		left: 10px;
		z-index: -1;
		pointer-events: none;
	}
	.home .cont09 .box02 {
		overflow: hidden;
		margin: 0 auto 50px;
		padding: 30px 20px 30px 0;
		position: relative;
	}
	.home .cont09 .box02::after {
		content: "";
		display: block;
		width: calc(100% - 20px);
		height: 100%;
		background: url("img/common_bg01.png") repeat left top/7px;
		position: absolute;
		top: 0;
		left: 0;
		z-index: -1;
		pointer-events: none;
	}
	.home .cont09 .box02 .txtBox {
		margin: 0 auto 30px;
	}
	.home .cont09 .box02 h3 {
		margin-bottom: 40px;
		font-size: 20px;
		text-align: center;
		line-height: 1.8;
		text-shadow: 4px 4px 2px #f5f4ea, -4px 4px 2px #f5f4ea, 4px -4px 2px #f5f4ea, -4px -4px 2px #f5f4ea, 4px 0 2px #f5f4ea, 0 4px 2px #f5f4ea, -4px 0 2px #f5f4ea, 0 -4px 2px #f5f4ea;
	}
	.home .cont09 .box02 h3 span {
		font-size: 16px;
	}
	.home .cont09 .box02 .subBox {
		padding: 25px 20px 20px;
		background: #fff;
		position: relative;
	}
	.home .cont09 .box02 .subBox::after {
		content: "";
		display: block;
		height: 35px;
		background: no-repeat center / contain;
		position: absolute;
		top: -20px;
		right: 20px;
	}
	.home .cont09 .box02 .subBox + .subBox {
		margin-top: 40px;
	}
	.home .cont09 .box02 .subBox.is-biography::after {
		width: 110px;
		background-image: url("img/home_cont09_en02.png");
	}
	.home .cont09 .box02 .subBox.is-qualification::after {
		width: 130px;
		background-image: url("img/home_cont09_en03.png");
	}
	.home .cont09 .box02 .subBox__tit {
		position: absolute;
		top: -15px;
		left: 20px;
		color: #b4a173;
		font-size: 20px;
		text-shadow: 3px 3px 2px white, -3px 3px 2px white, 3px -3px 2px white, -3px -3px 2px white, 3px 0 2px white, 0 3px 2px white, -3px 0 2px white, 0 -3px 2px white;
	}
	.home .cont09 .box02 .subBox-data {
		width: 100%;
	}
	.home .cont09 .box02 .subBox-data th, .home .cont09 .box02 .subBox-data td {
		box-sizing: border-box;
		text-align: left;
		vertical-align: top;
	}
	.home .cont09 .box02 .subBox-data th {
		width: 100px;
		padding: 5px 10px 5px 0;
	}
	.home .cont09 .box02 .subBox-data td {
		padding: 7px 0;
		font-size: 12px;
	}
	.home .cont09 .box02 .subBox__txt {
		font-size: 13px;
	}
	.home .cont09 .box02 .img {
		position: relative;
	}
	.home .cont09 .box02 .img::after {
		content: "";
		display: block;
		width: 100%;
		height: 100%;
		background: #b4a173;
		position: absolute;
		top: 10px;
		left: -10px;
		z-index: -1;
		pointer-events: none;
	}
	.home .cont09 .box02 .img span {
		position: absolute;
		right: 20px;
		bottom: 10px;
		color: #b4a173;
		font-size: 18px;
	}
	.home .cont09 .loop {
		margin: 0 auto 50px;
		height: 163px;
		background: url("img/home_cont09_bg01_sp.png") repeat-x 0 0/auto 100%;
		animation: loop_sp 50s linear infinite;
	}

	@keyframes loop_sp {
		0% {
			background-position: 0 0;
		}
		100% {
			background-position: -909px 0;
		}
	}
	.home .cont09 .mapBox {
		height: 300px;
	}
	.home .cont09 .mapBox iframe {
		width: 100%;
		height: 100%;
	}

	/* footer
	------------------------------------------------------------------------*/
	footer {
		padding: 30px 0 80px;
		box-sizing: border-box;
	}
	footer .copy {
		font-size: 12px;
		text-align: center;
	}
}