@charset "UTF-8";
/* CSS Document */




#contents {
	width: 90%;
	max-width: 1020px;
	margin-right: auto;
	margin-left: auto;
	padding-bottom: 70px;
}

.MainImageText {
	width: 80%;
	max-width: 1020px;
	margin: 0 auto;
	padding: 30px 0;
	font-size: 16px;
}


.tabpanel {
	position: relative;
}

.tabpanel ul {
	display: table;
	list-style: none;
	margin: 0;
	padding: 0;
	width: 100%;
}

.tabpanel li {
	display: table-cell;
	background: EFEFEF;
}

.tabpanel li.is-active {
	background: #EFEFEF;
	text-shadow: 0 1px 0 rgba(0, 0, 0, 0.5);
	padding: 15px 0;
}

.tabpanel li.is-active a {
	color: #49423e;
}

.tabpanel>div {
	position: relative;
	-moz-transition: all 1s ease;
	-o-transition: all 1s ease;
	-webkit-transition: all 1s ease;
	transition: all 1s ease;
}

.tabpanel>div:nth-of-type(n+2) {
	position: absolute;
	top: 70px;
	left: 0;
	opacity: 0;
	-moz-transform: translateX(-20px);
	-ms-transform: translateX(-20px);
	-webkit-transform: translateX(-20px);
	transform: translateX(-20px);
}

.tabpanel>div.animation-out {
	opacity: 0;
	-moz-transform: translateX(-20px);
	-ms-transform: translateX(-20px);
	-webkit-transform: translateX(-20px);
	transform: translateX(-20px);
}

.tabpanel>div.animation-in {
	opacity: 1;
	-moz-transition-delay: 0.8s;
	-o-transition-delay: 0.8s;
	-webkit-transition-delay: 0.8s;
	transition-delay: 0.8s;
	-moz-transform: translateX(0);
	-ms-transform: translateX(0);
	-webkit-transform: translateX(0);
	transform: translateX(0);
}


.theme-tabpanel {
	margin: 10px;
}

.theme-tabpanel li {
	text-align: center;
}

.theme-tabpanel li+li {
	border-left: solid 1px #e0e0e0;
}

.theme-tabpanel li a {
	display: block;
	color: #999;
	padding: 10px;
	text-decoration: none;
}

.theme-tabpanel div {
	line-height: 1.5;
	background: #eceff1;
	overflow: hidden;
}

#tab1,
#tab2,
#tab3 {
	width: 100%;
}

.tab_box {
	width: 90%;
	margin: 0 auto;
	padding: 30px 0;
}


.theme-tabpanel div img {
	padding-bottom: 0.5rem;
}

.theme-tabpanel div p {
	padding-left: 10px;
	overflow: hidden;
}

/*********************************/
/**  文字折り返し位置指定 <wbr> **/
/*********************************/
/* 日本語の場合class="wsnw"を指定する */
.wsnw span {
	white-space: nowrap;
	/* chrome・safari */
	display: inline-block;
}


/******************/
/** tab Contents **/
/******************/
.TabTitleContents {
	padding-bottom: 2%;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.TabTitleContents h3 {
	font-size: clamp(1.375rem, -0.396rem + 3.7vw, 2.375rem);
	font-weight: bold;
}

.TabTitleContents h3 ruby rt {
	font-size: 0.6em;
}

.TabTitleContents p {
	width: 70%;
}

.PhotoContents,
.PhotoContents3 {
	display: flex;
	justify-content: space-between;
}


.PhotoContents .Content01,
.PhotoContents .Content02 {
	width: 48%;
	margin: 0;
	padding: 0px;
}

.PhotoContents3 .Content3_01,
.PhotoContents3 .Content3_02,
.PhotoContents3 .Content3_03 {
	width: 30%;
}

.tab3 .Content3_01 img {
	width: 100%;
}


.Title {
	font-size: 18px;
	font-weight: bold;
	color: #fff;
	background-color: #2CA6E0;
	margin-top: 15px;
}

.SekouJirei {
	padding-bottom: 2%;
}

.SekouJirei .Befor {
	float: left;
	margin-top: 0px;
	margin-right: 2%;
	margin-bottom: 0px;
	margin-left: 0px;
	width: 25%;
	display: inline-block;
}

.SekouJirei .Befor p {
	text-align: center;
}

.SekouJirei .After {
	float: left;
	width: 25%;
	margin-right: 2%;
	display: inline-block;
}

.SekouJirei .After p {
	text-align: center;
}

.SekouJirei dl {
	float: left;
	list-style-type: none;
	display: inline-block;
	width: 45%;
}

.SekouJirei dl dt {
	float: left;
	padding: 3%;
	border: medium solid #CCC;
	text-align: center;
	width: 6em;
	margin-top: 3%;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	font-weight: bold;
	color: #333;
	font-size: 1em;
	background-color: #FFF;
}

.SekouJirei dl dd {
	padding: 3%;
	border: medium solid #CCC;
	text-align: center;
	margin-top: 3%;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	background-color: #FFF;
}



/*===============================================
●tablet.css 画面の横幅が768pxまで
===============================================*/
@media screen and (max-width: 768px) {

	#contents {
		width: 90%;
		margin-right: auto;
		margin-left: auto;
	}

	.MainImageText {
		width: 80%;
		margin-right: auto;
		margin-left: auto;
		font-size: 1.2em;
	}



	/****************/
	/** タブパネル **/
	/****************/

	.tabpanel {
		position: relative;
	}

	.tabpanel ul {
		display: table;
		list-style: none;
		margin: 0;
		padding: 0;
		width: 100%;
	}

	.tabpanel li {
		display: table-cell;
		background: EFEFEF;
	}

	.tabpanel li.is-active {
		background: #EFEFEF;
		text-shadow: 0 1px 0 rgba(0, 0, 0, 0.5);
	}

	.tabpanel li.is-active a {
		color: #49423e;
	}

	.tabpanel>div {
		position: relative;
		-moz-transition: all 1s ease;
		-o-transition: all 1s ease;
		-webkit-transition: all 1s ease;
		transition: all 1s ease;
	}

	.tabpanel>div:nth-of-type(n+2) {
		position: absolute;
		top: 70px;
		left: 0;
		opacity: 0;
		-moz-transform: translateX(-20px);
		-ms-transform: translateX(-20px);
		-webkit-transform: translateX(-20px);
		transform: translateX(-20px);
	}

	.tabpanel>div.animation-out {
		opacity: 0;
		-moz-transform: translateX(-20px);
		-ms-transform: translateX(-20px);
		-webkit-transform: translateX(-20px);
		transform: translateX(-20px);
	}

	.tabpanel>div.animation-in {
		opacity: 1;
		-moz-transition-delay: 0.8s;
		-o-transition-delay: 0.8s;
		-webkit-transition-delay: 0.8s;
		transition-delay: 0.8s;
		-moz-transform: translateX(0);
		-ms-transform: translateX(0);
		-webkit-transform: translateX(0);
		transform: translateX(0);
	}


	.theme-tabpanel {
		margin: 10px;
	}

	.theme-tabpanel li {
		text-align: center;
	}

	.theme-tabpanel li+li {
		border-left: solid 1px #e0e0e0;
	}

	.theme-tabpanel li a {
		display: block;
		color: #999;
		padding: 10px;
		text-decoration: none;
	}

	.theme-tabpanel div {
		line-height: 1.5;
		background: #eceff1;
		overflow: hidden;
	}

	.theme-tabpanel div img {
		float: left;
	}


	/******************/
	/** tab Contents **/
	/******************/
	.TabTitleContents {
		padding-bottom: 2%;
	}

	.TabTitleContents h3 ruby rt {
		font-size: 0.6em;
	}

	.TabTitleContents p {
		width: 70%;
	}




	/** PhotoContents **/
	.PhotoContents {
		margin: 0px;
		padding-bottom: 5%;
	}

	.PhotoContents dl {
		clear: left;
	}

	.PhotoContents .Content01 {
		float: left;
		width: 48%;
		margin-right: 2%;
		padding: 0px;
	}

	.PhotoContents .Content02 {
		margin: 0px;
		float: left;
		width: 48%;
		padding: 0px;
	}

	.PhotoContents3 .Content3_01,
	.PhotoContents3 .Content3_02,
	.PhotoContents3 .Content3_03 {
		width: 32%;
	}


	/** Befor **/
	.SekouJirei .Befor {
		float: left;
		margin-top: 0px;
		margin-right: 2%;
		margin-bottom: 0px;
		margin-left: 0px;
		width: 48%;
	}

	/** After **/
	.SekouJirei .After {
		float: left;
		width: 48%;
		margin-right: 2%;
	}

	/** Befor After 詳細 **/
	.SekouJirei dl {
		float: left;
		list-style-type: none;
		display: inline-block;
		width: 100%;
	}

	.SekouJirei dl dt {
		background: #FFF;
		float: left;
		padding: 1%;
		border: medium solid #CCC;
		text-align: center;
		width: 45%;
		margin-top: 3%;
		margin-right: 0px;
		margin-bottom: 0px;
		margin-left: 0px;
		font-weight: bold;
		color: #333;
		font-size: 1em;
	}

	.SekouJirei dl dd {
		background: #FFF;
		padding: 1%;
		border: medium solid #CCC;
		text-align: center;
		margin-top: 3%;
		margin-right: 0px;
		margin-bottom: 0px;
		margin-left: 0px;
	}


	.PhotoContents3 {
		flex-direction: column;
	}

	.PhotoContents3 .Content3_01,
	.PhotoContents3 .Content3_02,
	.PhotoContents3 .Content3_03 {
		width: 100%;
		display: flex;
		align-items: center;
	}

	.PhotoContents3 .Content3_01 img,
	.PhotoContents3 .Content3_02 img,
	.PhotoContents3 .Content3_03 img {
		width: 25%;
	}

	.PhotoContents3 .Content3_01 dl,
	.PhotoContents3 .Content3_02 dl,
	.PhotoContents3 .Content3_03 dl {
		padding: 0 0 0 0.5rem ;
	}

	.PhotoContents3 .Content3_01 dt,
	.PhotoContents3 .Content3_02 dt,
	.PhotoContents3 .Content3_03 dt {
		font-weight: 600;
		padding-bottom: 1rem;
	}




}



/*===============================================
●smart.css  画面の横幅が640pxまで
===============================================*/
@media screen and (max-width: 640px) {

	#contents {
		width: 100%;
		margin: 0 auto;
		padding-bottom: 0;
	}

	.theme-tabpanel div p {
		padding-left: 0.5rem;
	}


	/******************/
	/** tab Contents **/
	/******************/
	.TabTitleContents {
		padding-bottom: 2%;
		flex-direction: column;
	}

	.TabTitleContents h3 {
		margin-bottom: 1em;
	}


	.TabTitleContents dl {
		width: 100%;
	}

	.TabTitleContents dl dt {
		font-size: 1.2em;
		text-decoration: none;
	}

	.TabTitleContents p {
		width: 100%;
		padding-left: 0;
	}



	/** PhotoContents **/
	.PhotoContents {
		flex-direction: column;
	}


	.PhotoContents dl {
		clear: left;
	}

	.PhotoContents .Content01 {
		width: 100%;
		margin-right: 2%;
		padding: 0px;
	}

	.PhotoContents .Content02 {
		margin: 0px;
		width: 100%;
		padding: 0px;
	}

	.PhotoContents3 .Content3_01,
	.PhotoContents3 .Content3_02,
	.PhotoContents3 .Content3_03 {
		margin-bottom: 15px;
	}



	.PhotoContents3 .Content3_01 img,
	.PhotoContents3 .Content3_02 img,
	.PhotoContents3 .Content3_03 img {
		width: 45%;
		height: 200px;
		object-fit: cover;
		padding-bottom: 0;
	}




	/** Befor **/
	.SekouJirei .Befor {
		float: left;
		margin-top: 0px;
		margin-right: 2%;
		margin-bottom: 0px;
		margin-left: 0px;
		width: 48%;
	}

	/** After **/
	.SekouJirei .After {
		float: right;
		width: 48%;
		margin-right: 0;
	}

	/** Befor After 詳細 **/
	.SekouJirei dl {
		float: left;
		list-style-type: none;
		display: inline-block;
		width: 100%;
	}

	.SekouJirei dl dt {
		background: #FFF;
		float: left;
		padding: 1%;
		border: medium solid #CCC;
		text-align: center;
		width: 40%;
		margin-top: 3%;
		margin-right: 0px;
		margin-bottom: 0px;
		margin-left: 0px;
		font-weight: bold;
		color: #333;
		font-size: 1em;
	}

	.SekouJirei dl dd {
		background: #FFF;
		padding: 1%;
		border: medium solid #CCC;
		text-align: center;
		margin-top: 3%;
		margin-right: 0px;
		margin-bottom: 0px;
		margin-left: 0px;
	}
}