@charset "utf-8";


/* ================================
   Font
================================ */

/* Font Global Setting */
h2 {
	font-size: 42px;
	font-weight: bold;
	text-align: center;
	color: #1d1d1d;
}

h3 {
	font-size: 36px;
	font-weight: bold;
	padding-bottom: 40px;
	color: #1d1d1d;
}

h4 {
	color: #1d1d1d;
}

p {
	font-size: 18px;
	line-height: 220%;
}

@media screen and (max-width:991px) {

	h2 {
		font-size: 32px;
	}

	h3 {
		font-size: 26px;
		padding-bottom: 40px;
	}

	h4 {
		color: #1d1d1d;
	}

	p {
		font-size: 16px;
		line-height: 180%;
	}

}

/* ================================
   Base 
================================ */
body {
	padding-top: 75px;
}

.page-template h2 {
	margin-bottom: 25px;
}

.page-template .basic-padding {
	padding-top: 75px;
	padding-bottom: 75px;
}

.page-template .basic-padding-top {
	padding-top: 80px;
}

.page-template .basic-padding-bottom {
	padding-bottom: 80px;
}

.page-template .mid-padding-bottom {
	padding-bottom: 40px;
}

.page-template .min-padding-bottom {
	padding-bottom: 0;
}

.page-template .strong-padding {
	padding-top: 120px;
	padding-bottom: 120px;
}

.page-template .strong-padding-top {
	padding-top: 120px;
}

.page-template .strong-padding-bottom {
	padding-bottom: 120px;
}

@media screen and (min-width:992px) and (max-width:1299px) {
	.page-template {}
}

@media screen and (max-width:991px) {

	.page-template h2 {
		margin-bottom: 25px;
	}

	.page-template .basic-padding {
		padding-top: 40px;
		padding-bottom: 40px;
	}

	.page-template .basic-padding-top {
		padding-top: 40px;
	}

	.page-template .basic-padding-bottom {
		padding-bottom: 40px;
	}

	.page-template .mid-padding-bottom {
		padding-bottom: 20px;
	}

	.page-template .min-padding-bottom {
		padding-bottom: 0;
	}

	.page-template .strong-padding {
		padding-top: 60px;
		padding-bottom: 60px;
	}

	.page-template .strong-padding-top {
		padding-top: 60px;
	}

	.page-template .strong-padding-bottom {
		padding-bottom: 60px;
	}
}

/* ================================
   Page Navigation
================================ */

.pageNavi {
	margin-bottom: 100px;
}

.pageNavi ul {
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	margin-bottom: 0;
}

.pageNavi ul>li {
	list-style: none;
	margin: 0 4px;
}

.pageNavi ul>li a {
	font-family: "Shippori Mincho", serif;
	font-size: 16px;
	font-weight: bold;
	padding: 10px 17px 10px 10px;
	display: flex;
	align-items: center;
	margin-bottom: 10px;
}

.pageNavi ul>li a:after {
	content: '';
	width: 11px;
	height: 11px;
	background-repeat: no-repeat;
	background-size: contain;
	display: inline-block;
	margin-left: 10px;
}

@media screen and (max-width:991px) {
	.pageNavi {
		margin-top: 0;
		margin-bottom: 20px;
	}
}

/* ================================
   Service
================================ */
.service-fv {
	width: 100%;
	height: 359px;
	object-fit: cover;
}

@media screen and (max-width:991px) {
	.service-fv {
		height: 170px;
	}
}

#service h3 {
	padding-bottom: 0;
}

#service .box {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	background-color: #000000;
}

#service .box .image {
	height: 437px;
	flex: 1;
}

#service .box .text {
	flex: 1;
	font-size: 1rem;
	/* テキストサイズ調整 */
	line-height: 1.5;
	/* 行間を調整 */
}

#service .box .text p {
	width: 100%;
	color: white;
	margin: 0;
	line-height: 180%;
	padding-left: 50px;
	padding-right: 50px;
}

#service .box.box-1 .image {
	background: url("../images/product/bg_box1.jpg") no-repeat center;
	background-size: cover;
}

#service .box.box-2 .image {
	background: url("../images/product/bg_box2.jpg") no-repeat center;
	background-size: cover;
}

#service .box.box-3 .image {
	background: url("../images/product/bg_box3.jpg") no-repeat center;
	background-size: cover;
}

#service .box.box-4 .image {
	background: url("../images/product/bg_box4.jpg") no-repeat center;
	background-size: cover;
}

#service section {
	padding-top: 80px;
}

#service section h3 {
	font-family: "Shippori Mincho", serif;
	font-weight: 700;
}

#service section p {
	font-family: "Shippori Mincho", serif;
}

#s4 {
	margin-bottom: 80px;
}

@media screen and (min-width:992px) and (max-width:1299px) {
	#service .content {
		padding: 20px;
	}
}

@media screen and (max-width:991px) {

	#service .content {
		padding: 20px;
	}

	#service h3 {
		text-align: center;
	}

	#service section {
		padding-top: 40px;
	}

	#service section:last-child {
		margin-bottom: 0;
	}

	#service section>p {
		font-size: 16px;
	}

	#service .box {
		padding: 25px;
	}

	#service .box .image {
		flex: auto;
		width: 100%;
		height: 250px;
		margin-bottom: 25px;
	}

	#service .box .text {
		flex: auto;
	}

	#service .box .text p {
		padding: 0;
	}
}

/* ================================
   Company
================================ */

.company-philosophy {
	background-color: #090303;
	padding: 50px 0;
}

.company-philosophy .container-fluid {
	max-width: 1300px;
	margin: auto;
}

.company-philosophy-box {
	display: flex;
	position: relative;
}

.company-philosophy-l {
	width: 50%;
}

.company-philosophy-l img {
	width: 100%;
}

.company-philosophy-r {
	width: 50%;
	position: absolute;
	right: 0;
	top: 0;
}

.company-philosophy-r img {
	width: 100%;
}

.company-philosophy h3 {
	color: #fff;
	font-family: "Shippori Mincho", serif;
	padding-bottom: 0;
	font-size: 36px;
	margin-bottom: 20px;
}

.company-philosophy p {
	color: #fff;
	font-family: "Shippori Mincho", serif;
	font-size: 27px;
}

.googlemap iframe {
	vertical-align: bottom;
}

@media screen and (max-width:991px) {

	.company-philosophy {
		padding: 50px 0 200px 0;
	}

	.company-philosophy-box {
		display: block;
	}

	.company-philosophy-l {
		width: 100%;
	}

	.company-philosophy-r {
		width: 100%;
		bottom: -450px;
		top: auto;
	}

	.company-philosophy h3 {
		font-size: 26px;
	}

	.company-philosophy p {
		font-size: 18px;
	}
}

@media screen and (max-width:500px) {
	.company-philosophy-r {
		width: 100%;
		bottom: -250px;
		top: auto;
	}
}


#greetings h3 {
	font-family: "Shippori Mincho", serif;
}

#greetings p {
	font-family: "Shippori Mincho", serif;
}

#company .greetings {
	background-color: #121212;
}

#company .greetings>div {
	background-color: white;
}

#company .greetings h3 {
	font-size: 36px;
	margin-bottom: 25px;
}

#company .greetings .div1 {
	display: flex;
	justify-content: flex-end;
	width: 50%;
}

@media screen and (max-width:991px) {
	#company .greetings .div1 {
		width: 100%;
	}
}

#company .greetings .message {
	padding-top: 50px;
}

@media screen and (max-width:991px) {
	#company .greetings .message {
		padding-top: 0;
	}
}

#company .greetings .separate {
	justify-content: space-between;
	max-width: 1300px;
	margin: auto;
	padding: 0 15px;
}

#companydata .separate {
	justify-content: space-between;
	max-width: 1300px;
	margin: auto;
	padding: 0 15px;
}

@media screen and (min-width:991px) {
	#company .greetings .separate {
		flex-direction: row;
	}
}

@media screen and (min-width: 1300px) {
	#company .greetings .separate {
		padding: 0;
	}

}

#company .greetings .div2 {
	display: flex;
	justify-content: center;
	width: 34.38%;
}

@media screen and (max-width:991px) {
	#company .greetings .div2 {
		width: 100%;
	}

	#company .greetings h3 {
		padding-bottom: 0;
		font-size: 26px;
	}
}

#company .greetings .div2 img {
	width: 100%;
}

#company .greetings .box {
	height: auto;
	text-align: center;
}

#companydata {
	background-color: #fff;
}

#companydata p {
	color: white;
}

#companydata>div {
	background-color: #121212;
}

#companydata h3 {
	color: white;
	font-family: "Shippori Mincho", serif;
}

#companydata .div1 {
	display: flex;
	justify-content: right;
}

#companydata .div2 dl>dt {
	border-top: 1px solid #fff;
	padding-top: 1rem;
	padding-bottom: 5px;
	font-size: 20px;
	color: white;
	font-family: "Shippori Mincho", serif;
}

#companydata .div2 {}

#companydata .div2 dl>dd {
	padding-bottom: 10px;
	font-size: 17px;
	font-weight: normal !important;
	color: white;
	font-family: "Shippori Mincho", serif;
}

#companydata .div2 dl>dd:last-child {
	border-bottom: 1px solid #fff;
	padding-bottom: 18px;
}

#companydata .yearBox p {
	margin: 0;
	padding: 15px 30px 30px 30px;
	font-family: "Shippori Mincho", serif;
}

#companydata .yearBox .yimage {
	margin-top: -30px;
	margin-left: 30px;
}

#companydata .sep {
	width: 1px;
	height: 40px;
	background: #fff;
	margin: auto;
}

#companyaccess {
	background-color: #121212;
}

#companyaccess>div {
	background-color: #fff;
}

#companydata .image {
	margin-top: 92px;
	text-align: center;
}

.yearBox {
	border: 1px solid#fff !important;
}

@media screen and (max-width:991px) {
	#companydata .image {
		margin-top: 0;
	}
}

.offices {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.offices iframe {
	filter: grayscale(100%);
}

.offices .item {
	background-color: #090303;
	width: 630px;
	margin-top: 30px;
}

.offices .item .title {
	font-size: 28px;
	padding-bottom: 8px;
}

.offices .top {
	padding: 10px 40px;
}

.offices .top-name {
	color: #fff;
	font-family: "Shippori Mincho", serif;
	margin-bottom: 0;
}

.offices .top-txt {
	color: #fff;
	font-family: "Shippori Mincho", serif;
	border-top: 1px solid #fff;
	line-height: 1.4;
	padding-top: 10px;
	margin-bottom: 0;
}

.offices .top-txt a {
	color: #fff;
}

@media screen and (min-width:992px) and (max-width:1299px) {
	.offices .top {
		padding: 10px;
	}

	#company .greetings .div1 {
		padding-left: 0;

	}

	#company .greetings .div2 {
		padding-top: 120px;
	}

	#company .greetings .box {
		height: fit-content;
	}

	#company .greetings .message {
		max-width: 640px;
		width: 640px;
		padding: 25px;
	}

	.separate .basic-width {
		width: 100%;
	}

	#companydata .div1,
	#companydata .div2 {
		padding: 20px;
	}

	#companydata .div2 {
		paddingtop: 20px;
	}

	#companyaccess h3 {
		text-align: center;
	}

	#companyaccess .offices .item {
		width: 100%;
		margin-left: 20px;
		margin-right: 20px;
	}

	.offices {
		justify-content: center;
	}
}

#companydata .separate {
	flex-direction: row-reverse;
}

@media screen and (max-width:991px) {
	.offices .item:first-child {
		margin-top: 0;
	}

	#philosophy h3 {
		padding-bottom: 0;
	}

	#philosophy p {
		padding-left: 0;
		padding-right: 0;
		font-size: 18px;
	}

	#philosophy .image {
		width: 200px;
	}

	#greetings h3 {
		text-align: center;
	}

	#company .greetings .div1 {
		padding-top: 0;
	}

	#company .greetings .div1 {
		padding: 20px;
		padding-top: 0;
	}

	#company .greetings .div2 {
		padding: 0;
	}

	#companydata h3 {
		text-align: center;
	}

	#companydata .div1,
	#companydata .div2 {
		padding: 20px;
	}

	#companydata .div1 .image {
		display: flex;
		justify-content: center;
	}

	#companydata .yearBox .yimage {
		margin-top: -20px;
	}

	#companydata .yimage img {
		width: 120px;
	}

	#companydata .separate .basic-width {
		width: 100%;
	}

	#companyaccess h3 {
		text-align: center;
	}

	#companyaccess .offices {
		padding: 20px;
	}

	.offices {
		justify-content: center;
	}
}

#companydata .ttl02 {
	margin-top: 100px;
}

#companydata .div1 {
	position: relative;
}

#companydata .div1 .basic-width {
	position: sticky;
	height: fit-content;
	top: 0;
}

@media screen and (max-width:991px) {
	#companydata .ttl02 {
		margin-top: 50px;
	}

	#companydata .div1 .basic-width {
		position: static;
	}
}

#companyaccess h3 {
	padding-bottom: 0;
	font-family: "Shippori Mincho", serif;
}


/* ================================
   About
================================ */


#passion .intro {
	background-image: url("../images/about/intro_bg.jpg");
	background-repeat: no-repeat;
	background-position: center right;
}

#focus .head p {
	font-size: 26px;
}

#focus h3 {
	font-family: "Shippori Mincho", serif;
	margin-bottom: 30px;
}

#focus .head p {
	font-family: "Shippori Mincho", serif;
}

#focus .item {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
	align-items: center;
	margin-bottom: 15px;
}

#focus .items .item {
	padding: 60px;
}

#focus .text p {
	font-family: "Shippori Mincho", serif;
	font-size: 17px;
}

#focus .items .item h4 {
	height: 51px;
	padding-left: 88px;
	font-size: 32px;
	line-height: 51px;
	font-family: "Shippori Mincho", serif;
}

#focus .items .item.item-1 h4 {
	background: url("../images/about/icon-01.png") no-repeat left center;
}

#focus .items .item.item-2 h4 {
	background: url("../images/about/icon-02.png") no-repeat left center;
}

#focus .items .item.item-3 h4 {
	background: url("../images/about/icon-03.png") no-repeat left center;
}

#focus .items .item.item-4 h4 {
	background: url("../images/about/icon-04.png") no-repeat left center;
}

#focus .item .div1 {
	width: 47%;
}

#focus .item .div2 {
	width: 30%;
}

#focus .image {
	text-align: center;
}

#focus .voice {
	margin-top: 70px;
	margin-bottom: 35px;
}

#focus .voice p {
	font-size: 32px;
	font-weight: bold;
	line-height: 140%;
	font-family: "Shippori Mincho", serif;
}

#focus .items2 {}

#focus .items2 .item {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	align-items: center;
	margin-bottom: 15px;
	flex-direction: row-reverse;
}

#focus .items2 .item .div1 {
	width: 600px;
	margin-right: 40px;
}

#focus .items2 .item .div2 .text {
	padding-top: 52px;
}

#focus .items2 .item.item-1 .text {
	background: url("../images/about/p-01.png") no-repeat left top;
}

#focus .items2 .item.item-2 .text {
	background: url("../images/about/p-02.png") no-repeat left top;
}

#focus .items2 .item.item-3 .text {
	background: url("../images/about/p-03.png") no-repeat left top;
}

@media screen and (max-width:991px) {
	#focus .item {
		display: block;
	}

	#focus .item .div1 {
		width: 100%;
	}

	#focus .item .div2 {
		width: 100%;
	}
}

#impact {
	background-color: #090903;
}

#impact .container-fluid {
	max-width: 1300px;
}

#impact>div {
	background-image: url(../images/about/about_bg.png);
	background-position: center center;
	background-repeat: no-repeat;
	background-attachment: fixed;
}

#impact h3 {
	margin-top: 40px;
	margin-bottom: 10px;
	color: white;
	font-family: "Shippori Mincho", serif;
}

#impact .head {
	margin-bottom: 26px;
}

#impact .head p {
	color: white;
	font-size: 16px;
	max-width: 700px;
	font-family: "Shippori Mincho", serif;
	font-weight: 400;
	text-align: left;
	margin: auto;
}

#impact .image {
	margin-bottom: 60px;
	text-align: center;
}

#impact .div2 p {
	color: #fff;
	font-family: "Shippori Mincho", serif;
	font-weight: 400;
	margin-bottom: 30px;
}

#impact .separate {
	justify-content: space-between;
}

@media screen and (min-width:992px) {
	#impact .separate {
		flex-direction: row;
	}
}

#impact .div1 {
	width: 45%;
}

#impact .div2 {
	width: 45%;
	margin-top: 60px;
}

@media screen and (max-width:991px) {
	#impact .div1 {
		width: 100%;
	}

	#impact .div2 {
		width: 100%;
		margin-top: 0px;
	}
}

#faq dl {
	padding: 10px;
	margin-bottom: 0;
}

@media screen and (max-width:991px) {
	#faq dl {
		padding: 10px 15px;
	}
}

#faq h3 {
	font-size: 60px;
	font-family: "Shippori Mincho", serif;
	margin-bottom: 0;
	padding-bottom: 0;
}

#faq .sub {
	font-size: 16px;
	font-family: "Shippori Mincho", serif;
}

@media screen and (max-width:991px) {
	#faq h3 {
		font-size: 40px;
	}

	#faq .sub {
		padding: 0 15px;
	}
}

#faq dl dt {
	border-top: 1px solid #d7d7d7;
	padding-top: 20px;
	cursor: pointer;
	display: block;
	position: relative;
	font-family: "Shippori Mincho", serif;
	font-weight: 700;
}

#faq dl:last-child {
	padding-bottom: 20px;
	position: relative;
}

#faq dl:last-child:before {
	position: absolute;
	content: '';
	width: calc(100% - 20px);
	height: 1px;
	background-color: #d7d7d7;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
}

@media screen and (max-width: 991px) {
	#faq dl:last-child:before {
		width: calc(100% - 30px);
	}
}

#faq dl dt::after {
	position: absolute;
	top: 10px;
	right: 10px;
	content: '';
	display: block;
	width: 14px;
	height: 14px;
	background: url("../images/common/bottom_arrow.svg") no-repeat;
}

#faq dl dd {
	display: none;
	font-family: "Shippori Mincho", serif;
}

/*@media screen and (min-width:992px) and (max-width:1299px){

	#passion .intro{
		padding:20px;
	}
	#focus .head,
	#focus .items,
	#focus .items2,
	#focus .voice{
		padding:20px;
	}
	
	#impact .intro,
	#impact .head,
	#impact .body{
		padding:20px;
	}
	
	#faq .intro,
	#faq .head,
	#faq .body{
		padding:20px;
	}
}*/

@media screen and (max-width:1299px) {

	#passion h3,
	#focus h3 {
		text-align: center;
	}

	#passion p {
		font-size: 16px;
		padding: 0 25px;
	}

	#passion .intro {
		padding-bottom: 500px;
		background-position: bottom center;
		background-size: contain;
	}

	.about-passion-sub {
		width: fit-content;
		margin: auto;
	}

	#passion .intro .image {
		padding: 25px;
		width: 250px;
	}

	#focus h3 {
		padding-bottom: 10px;
	}

	#focus .head p {
		font-size: 22px;
		text-align: center;
		margin: auto;
		padding: 0 25px 35px 25px;
	}

	#focus .items {
		padding-left: 20px;
		padding-right: 20px;
	}

	#focus .items .item {
		padding: 30px;
	}

	#focus .voice {
		padding: 0 25px;
	}

	#focus .voice p {
		font-size: 22px;
		line-height: 180%;
	}

	#focus .items2 {
		padding-left: 20px;
		padding-right: 20px;
	}

	#focus .items2 .image {
		margin-bottom: 15px;
	}

	#focus .items2 .image img {
		max-width: 100%;
		width: 100%;
	}

	#impact .head {
		text-align: center;
		margin-bottom: 10px;
	}

	#impact .head img {
		max-width: 180px;
	}

	#impact .head p {
		font-size: 18px;
		text-align: left;
	}

	#faq h3 {
		text-align: center;
		padding-bottom: 25px;
	}
}

@media screen and (max-width:991px) {
	#impact .separate .div1 {
		width: 100%;
	}

	#passion .intro {
		padding-bottom: 0px;
		background-position: bottom center;
		background-size: 300px auto;
	}


}

@media screen and (max-width:600px) {
	.about-passion-sub {
		width: 100%;
	}
}

.about-passion-ttl {
	color: #fff;
	font-size: 36px;
	font-family: "Shippori Mincho", serif;
}

.about-passion-sub {
	color: #fff;
	font-family: "Shippori Mincho", serif;
	font-size: 18px;
}

#passion .strong-padding {
	position: relative;
}

#passion .image {
	margin-top: 70px;
}

.about-passion-bg {
	position: absolute;
	left: -3vw;
	top: 0;
	width: 606px;
}

@media screen and (max-width:1299px) {
	.about-passion-bg {
		left: 0px;
	}

	#passion .image {
		margin-top: 0px;
		margin-left: 15%;
	}
}

@media screen and (max-width:991px) {
	.about-passion-ttl {
		font-size: 24px;
	}

	.about-passion-sub {
		font-size: 14px;
	}

	.about-passion-bg {
		top: auto;
		bottom: 200px;
		width: 300px;
		left: -100px;
	}

	#passion .image {
		margin-top: 70px;
		margin-left: 0;
	}
}


/* ================================
   SDGs
================================ */

#sdgsintro {
	background-color: #F7F5F1;
	padding: 70px 0;
}

#sdgsintro h3,
#sdgsintro #sdgsintro p {
	color: #1d1d1d;
	font-family: "Shippori Mincho", serif;
}

#sdgsintro h3 {
	padding-bottom: 20px;
	margin-bottom: 0;
}

#sdgsintro p {
	margin-bottom: 30px;
	line-height: 200%;
	font-family: "Shippori Mincho", serif;
	font-size: 17px;
}

#sdgsintro .w-mid {
	padding-left: 15px;
}

@media screen and (min-width:1300px) and (max-width:1919px) {
	#sdgsintro .w-mid {
		width: calc(650px + 50vw) !important;
		margin: 0 0 0 auto;
	}
}

@media screen and (min-width:1920px) {
	#sdgsintro .w-mid {
		width: 1610px !important;
		margin-left: 310px;
	}
}

@media screen and (max-width:991px) {
	#sdgsintro .w-mid {
		padding-left: 0;
	}
}

#sdgswrap .box {
	border: 1px solid #1d1d1d;
	padding: 24px 33px;
	margin-bottom: 60px;
}

#sdgswrap .box h4 {
	font-size: 16px;
	color: #1d1d1d;
	font-family: "Shippori Mincho", serif;
}

#sdgswrap .box p {
	font-size: 14px;
	margin-bottom: 0;
	font-family: "Shippori Mincho", serif;
}

#sdgswrap .div2 {
	padding-left: 45px;
}


#sdgspoints .point {
	position: relative;
	margin-top: 80px;
}

#sdgspoints .point.point-3 {
	margin-bottom: 0;
}

#sdgspoints .point .ftPoint {
	position: absolute;
	top: -60px;
	left: 100px;
}

#sdgspoints .point .sdgsIcon {
	position: absolute;
	top: -45px;
	left: 55px;
}

#sdgspoints .point .innerBox {
	position: relative;
	background-color: white;
	padding: 80px;
}

#sdgspoints .point .innerBox .l {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
}

#sdgspoints .point .innerBox .l .l1,
#sdgspoints .point .innerBox .l .l2 {
	width: 50%;
}

#sdgspoints .point .innerBox .l .l1 {}

#sdgspoints .point .innerBox .l .l1 h4 {
	padding-bottom: 20px;
	font-size: 26px;
}

#sdgspoints .point .innerBox .l .l1 p {
	line-height: 180%;
	font-size: 16px;
}

#sdgspoints .point .innerBox .l .l2 {
	display: flex;
	justify-content: flex-end;
}

#sdgspoints .point .innerBox .l .l2 .image {
	padding-right: 10px;
}

#sdgspoints .point .innerBox .l .l2 .image img {}

#sdgspoints .panels {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

#sdgspoints .point-2 .panels {
	justify-content: center;
}

#sdgspoints .point-2 .item {
	margin: 0 15px;
}

#sdgspoints .torikumi h4 {
	font-size: 22px;
}

#sdgspoints .panels .image img {
	width: 100%;
}

#sdgspoints .panels .text {
	padding: 10px 15px 10px 15px;
	font-size: 16px;
	font-family: "Shippori Mincho", serif;
}

#sdgspoints .color {
	background-color: #F7F5F1;
	padding: 62px 110px 50px 110px;
}

#sdgspoints .color-box {
	border: 1px solid #090303;
	padding: 70px 15px 30px 15px;
	position: relative;
}

#sdgspoints .color-box h4 {
	text-align: center;
	font-family: "Shippori Mincho", serif;
	font-size: 28px;
	font-weight: 700;
}

#sdgspoints .color-box p {
	max-width: 730px;
	margin: auto;
	font-family: "Shippori Mincho", serif;
	font-size: 16px;
}

.sdgs-img {
	display: block;
	margin: auto;
}

@media screen and (max-width:991px) {
	#sdgspoints .color-box p {
		font-size: 14px;
		line-height: 1.8;
	}
}

#sdgspoints .color-box .icon {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate(-50%, -50%);
}

#sdgspoints .torikumi h4 {
	margin-top: 30px;
	text-align: center;
	color: #fff;
	font-family: "Shippori Mincho", serif;
	font-size: 20px;
	font-weight: 700;
	background-color: #090303;
	padding: 10px 0;
}

@media screen and (max-width:991px) {
	#sdgspoints .color {
		padding: 40px 15px;
	}

	#sdgspoints .color-box h4 {
		font-size: 21px;
	}

	#sdgspoints .panels .item {
		width: calc(50% - 10px);
	}

	#sdgspoints .point-2 .panels {
		justify-content: space-between;
	}

	#sdgspoints .point-2 .item {
		margin: 0;
	}
}

@media screen and (min-width:992px) and (max-width:1299px) {

	#sdgsintro .div1 {
		padding-left: 20px;
		padding-right: 20px;
	}

	#sdgsintro .div2 {
		padding-right: 20px;
	}

	#sdgspoints {
		padding: 20px;
	}

	#sdgspoints .point .innerBox .l .l1 {
		width: 60%;
		padding-right: 20px;
	}

	#sdgspoints .point .innerBox .l .l2 {
		width: 40%;
	}

	#sdgspoints .torikumi h4 {
		padding-bottom: 10px;
	}

	#sdgspoints .panels .item {
		width: 50%;
		margin-bottom: 25px;
	}

	#sdgspoints .panels .item .image {
		width: 100%;
	}

}

@media screen and (min-width:1300px) {
	#sdgsintro .div1 {
		padding-right: 0;
	}
}

#sdgspoints .torikumi .panels .item {
	width: calc(25% - 10px);
}

@media screen and (max-width:991px) {
	#sdgsintro {
		padding: 40px 0;
	}

	#sdgsintro .div1 {
		padding: 20px;
	}

	#sdgsintro .div1 .image {
		width: 280px;
	}

	#sdgswrap .box {
		margin-bottom: 30px;
	}

	#sdgsintro .div2 {
		padding: 25px;
	}

	#sdgspoints .color-box {
		margin-top: 40px;
	}

	#sdgspoints .point {
		margin-top: 0px;
	}

	#sdgspoints .point .ftPoint {
		top: -30px;
		left: 20px;
	}

	#sdgswrap .ftPoint img {
		width: 80px;
	}

	#sdgspoints .point .sdgsIcon {
		left: 25px;
	}

	#sdgswrap h3 {
		text-align: center;
	}

	#sdgspoints .point {
		padding: 80px 20px 20px 20px;
	}

	#sdgspoints .l {}

	#sdgspoints .point .innerBox .l .l1 {
		order: 2;
		width: 100%;
		padding: 25px;
	}

	#sdgspoints .point .innerBox .l .l2 {
		order: 1;
		width: 100%;
		padding: 50px 25px 0 25px;
	}

	#sdgspoints .point .innerBox .image {
		margin: auto;
	}

	#sdgspoints .point .innerBox {
		padding: 0;
	}

	#sdgspoints .torikumi {
		padding: 25px 0;
	}

	#sdgspoints .torikumi h4 {
		text-align: center;
	}

	#sdgspoints .torikumi .panels .item {
		width: calc(50% - 10px);
	}

	#sdgspoints .torikumi .panels .item .image,
	#sdgspoints .torikumi .panels .item .text {
		margin: auto;
	}
}



/* ================================
   News
================================ */

#news .btnWrap {
	text-align: right;
}

#news .pageNavi {
	width: 280px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 40px;
}

#news .pageNavi ul>li {
	padding: 5px;
}

.pageNavi li a {
	border: 1px solid #121212;
	background-color: #fff;
	color: #121212;
}

.pageNavi li a::after {
	background-image: url(../images/common/arrow-black.png);
}

.pageNavi li.active a {
	background-color: #121212;
	color: white;
	padding: 10px 20px;
}

.pageNavi li.active a::after {
	background-image: url(../images/common/arrow-white.png);
}

#news .items {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	padding-bottom: 100px;
}

#news .items .item {
	margin-bottom: 40px;
}

#news .items .item a {
	display: block;
	width: 100%;
	text-decoration: none;
}

#news .items .item .date {
	color: #1d1d1d;
	font-size: 14px;
	padding-top: 10px;
	padding-bottom: 3px;
	font-family: "Shippori Mincho", serif;
}

#news .items .item .photo {
	position: relative;
	overflow: hidden;
}

#news .items .item .photo span {
	display: block;
	position: absolute;
	padding: 2px 15px;
	font-size: 14px;
	top: 0;
	left: 0;
	color: #fff;
	background-color: #090303;
	font-family: "Shippori Mincho", serif;
}

#news .items .item .photo img {
	width: 100%;
	aspect-ratio: 314 / 239;
	object-fit: cover;
	transition: transform .6s ease;
}

#news .items .item a:hover img {
	transform: scale(1.1);
}

#news .items .item a:hover .title {
	color: #1d1d1d;
}

#news .items .item .title {
	font-size: 16px;
	margin-bottom: 8px;
	width: 100%;
	font-family: "Shippori Mincho", serif;
}

#news .items .item .text {
	color: #5B5B5B;
	line-height: 220%;

}

#news .items .item,
#news .items .date,
#news .items .title,
#news .items .text {

	width: 25%;
	padding-left: 10px;
	padding-right: 10px;
}

#news .pagination {
	margin: auto;
}

#news .pagination .page-numbers {
	display: block;
	border: 1px solid #1d1d1d;
	border-radius: 60px;
	text-align: center;
	line-height: 40px;
	width: 40px;
	height: 40px;
	margin: 5px;
}

#news .pagination .page-numbers:hover,
#news .pagination .page-numbers.current {
	text-decoration: none;
	border-radius: 60px;
	text-align: center;
	line-height: 40px;
	width: 40px;
	height: 40px;
	border: none;
	background-color: #1d1d1d;
	color: white;
}

#news .btnWrap {
	display: flex;
	justify-content: flex-start;
	margin-top: 25px;
	margin-bottom: 25px;
}

#news .ft-items {
	margin-top: 160px;
	padding-top: 64px;
	border-top: 1px solid #090303;
}

/*@media screen and (min-width:992px) and (max-width:1299px){*/
@media screen and (min-width:992px) and (max-width:1299px) {
	#news article {
		padding: 20px;
	}

	#news .btnWrap {
		padding: 20px;
	}

	#news .content .items .item {
		width: 25%;
		display: flex;
		justify-content: center;
	}
}

@media screen and (max-width:991px) {
	#news article {
		padding: 20px;
	}

	#news .btnWrap {
		padding: 20px;
	}

	#news .content .items .item {
		width: 50%;
	}
}

@media screen and (max-width:768px) {

	#news .content .items .item {

		width: 100%;
		display: flex;
		justify-content: center;
	}

	#news .ft-items .item {
		width: 100%;
	}

	#news .ft-items .item a {
		display: flex;
		justify-content: space-between;
	}

	#news .ft-items .item a .photo {
		width: 45%;
	}

	#news .ft-items .item a .txt {
		width: 50%;
	}

	#news .ft-items .item a .txt .text {
		width: 100%;
	}
}

.info .post-date {
	font-family: "Shippori Mincho", serif;
}

.info .category {
	font-family: "Shippori Mincho", serif;
	color: #fff;
	background-color: #090303;
	padding: 4px 10px;
	margin-left: 10px;
}

.info h3 {
	font-family: "Shippori Mincho", serif;
	font-size: 20px;
	padding-bottom: 0;
	margin-bottom: 30px;
}

.info .post-content {
	font-family: "Shippori Mincho", serif;
	max-width: 612px;
	line-height: 2.29;
}

.info.back {
	margin: 60px auto 0 0;
}

.example .post-date {
	font-family: "Shippori Mincho", serif;
}

.example .category {
	font-family: "Shippori Mincho", serif;
	color: #fff;
	background-color: #090303;
	padding: 4px 10px;
	margin-left: 10px;
}

.example h3 {
	font-family: "Shippori Mincho", serif;
	font-size: 20px;
	padding-bottom: 0;
	margin-bottom: 30px;
}

.example .post-content {
	font-family: "Shippori Mincho", serif;
	max-width: 612px;
	line-height: 2.29;
}

.example.back {
	margin: 60px auto 0 0;
}


/* ================================
   Product / category
================================ */

.categories {
	max-width: 950px;
	margin: auto;
}

.categories h3 {
	text-align: center;
	font-family: "Shippori Mincho", serif;
}

.categories ul {
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.categories ul li {
	width: calc(25% - 10px);
	list-style: none;
	margin-bottom: 40px;
}

.categories ul li a {
	display: block;
	text-align: center;
	font-family: "Shippori Mincho", serif;
}

.categories ul li a {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.categories img {
	width: 100%;
}

.category-items h3 {
	font-family: "Shippori Mincho", serif;
	text-align: center;
}

.category-items ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;

	gap: 10px;
}

.category-items ul li {
	width: 412px;
	height: 542px;
	list-style: none;
	text-align: center;
}

.category-items .item {
	background-color: #121212;
	padding: 60px 30px;
	min-height: 542px;
	position: relative;

}

.category-items .item .btnWrap {
	position: absolute;
	left: 0;
	width: 100%;
	bottom: 60px;
}

.category-items .item img {
	max-width: 230px;
	max-height: 230px;
}

.category-items .item .itemname {
	color: white;
	font-size: 24px;
	margin-bottom: 10px;
	font-family: "Shippori Mincho", serif;
}

.category-items {
	margin-bottom: 80px;
}

.product-list {
	padding: 0;
}

#allItems h3 {
	text-align: center;
}

@media screen and (min-width:992px) and (max-width:1299px) {
	.category-items ul {
		justify-content: center;
		gap: 20px;
	}

	.category-items ul li {}
}

@media screen and (max-width:991px) {
	.category-items {
		margin-bottom: 40px;
	}

	#categoryitems main {
		padding: 20px;
	}

	.categories>div {
		padding: 0;
	}

	.categories ul {}

	.category-items ul {
		padding-left: 0;
		justify-content: center;
	}

	.category-items ul li {
		margin-bottom: 25px;
	}

	.category-items h3 {}

	.category-items {
		width: 100%;
		margin: auto;
	}

	.category-items .item {
		margin-left: 20px;
		margin-right: 20px;
	}
}

#products .separate .div1,
#products .separate .div2 {
	width: 50% !important;
}

#products .separate {
	flex-direction: row !important;
}

@media (max-width: 991px) {

	#products .separate .div1,
	#products .separate .div2 {
		width: 100% !important;
	}

	#products .separate {
		flex-direction: column !important;
		/* 縦方向に並べる */
	}
}

@media (max-width: 768px) {
	.categories ul li {
		width: calc(50% - 10px);
		padding: 10px;
		margin-bottom: 0;
	}
}

/* ================================
   Product / detail
================================ */


#itemdetail .div1 .mainimage {
	width: 100%;
	height: 650px;
	margin-bottom: 10px;
}

#itemdetail .div1 .mainimage img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

#itemdetail .imageNavi ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	padding: 0;
	grid-gap: 10px;
}

#itemdetail .imageNavi ul>li {
	list-style: none;
	width: 120px;
	height: 120px;
}

#itemdetail .imageNavi ul>li>img {
	object-fit: cover;
	width: 100%;
	height: 100%;
	cursor: pointer;
}

#itemdetail .div2 {
	display: flex;
	justify-content: space-around;
}

#itemdetail .div2 .div2innerWrap {
	width: 400px;
	margin: 0 auto;
}

#itemdetail .div2innerWrap .slagTitle {
	font-size: 50px;
	font-weight: bold;
	margin-bottom: 10px;
	font-family: "Shippori Mincho", serif;
}

#itemdetail .div2innerWrap .categoryTitle {
	border: 1px solid #1d1d1d;
	border-radius: 60px;
	display: inline-block;
	padding: 12px 25px;
	font-weight: bold;
	margin-bottom: 45px;
}

#itemdetail .div2innerWrap h3 {
	font-size: 26px;
	padding-bottom: 0;
	font-family: "Shippori Mincho", serif;
}

#itemdetail .div2innerWrap .spec dl {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
}

#itemdetail .div2innerWrap .spec dl dt {
	width: 33%;
	font-family: "Shippori Mincho", serif;
}

#itemdetail .div2innerWrap .spec dl dd {
	width: 66%;
	font-family: "Shippori Mincho", serif;
}

#itemdetail .kataban {
	font-family: "Shippori Mincho", serif;
}

#itemdetail .kataban span {
	display: inline-block;
	padding: 4px 8px;
	background-color: #121212;
	color: white;
	font-weight: 400;
	margin-right: 10px;
	margin-bottom: 10px;
	font-family: 'BIZ UDP Gothic', sans-serif;
}

#itemdetail .icons ul {
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	grid-gap: 10px;
}

#itemdetail .icons ul li {
	list-style: none;
	width: 60px;
	margin-bottom: 10px;

}

#itemdetail .colors ul {
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	grid-gap: 10px;
}

#itemdetail .colors ul li {
	list-style: none;
	width: 60px;
	margin-bottom: 10px;

}

#itemdetail h4 {
	font-size: 18px;
	margin-bottom: 15px;
	font-family: "Shippori Mincho", serif;
}

#itemdetail .title {
	font-family: "Shippori Mincho", serif;
}

#itemdetail .graybox {
	background-color: #F7F5F1;
	padding: 40px;
}

#itemdetail .graybox .items {
	display: flex;
	justify-content: center;
	grid-gap: 10px;
}

#itemdetail .videobox {
	display: flex;
	justify-content: center;
}

#itemdetail #attention {
	margin-bottom: 45px;
}

#itemdetail #attention .items .item {
	border: 1px solid #1d1d1d;
	display: inline-block;
	padding: 12px 25px;
	font-weight: bold;
	margin-bottom: 5px;
}

#itemdetail #attention .items .item a {
	margin-bottom: 15px;
	font-family: "Shippori Mincho", serif;
}

#itemdetail .back {
	margin-top: 80px;
}

#itemdetail .items ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	column-gap: 10px;
}

#itemdetail .items ul li {
	list-style: none;
	width: 200px;
	text-align: center;
}

#itemdetail .items ul li div>a img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

#itemdetail .items ul li div.title span {
	font-size: 14px;
	color: #585858;
}

.back {
	border-bottom: 1px solid #212529;
	display: block;
	padding-left: 37px;
	max-width: 120px;
	margin: auto;
	margin-bottom: 80px;
}

.back-in {
	color: #212529;
	font-family: "Shippori Mincho", serif;
	font-weight: 600;
	font-size: 16px;
	position: relative;
}

.back-in::after {
	position: absolute;
	content: '';
	width: 27px;
	height: 8px;
	background-image: url(../images/top/pickup-arrow.svg);
	background-repeat: no-repeat;
	background-size: contain;
	left: -37px;
	top: 11px;
	background-position: right;
	transform: scale(-1, 1);
}

@media screen and (max-width:991px) {
	.back {
		margin-bottom: 40px;
	}

	#itemdetail .div1,
	#itemdetail .div2,
	#attention {
		padding: 20px;
	}

	#itemdetail .div2 .div2innerWrap {
		width: 100%;
	}

	#itemdetail .div1 .mainimage {
		width: 100%;
		height: auto;
	}

	#itemdetail .div1 .mainimage img {
		max-width: 100%;
		height: auto;
		object-fit: cover;
	}

	#itemdetail .imageNavi ul>li {
		width: 60px;
		height: 60px;
	}

	.div2innerWrap {
		width: 100%;
	}

	#itemdetail .items ul {
		padding-left: 0;
	}

	#itemdetail .items ul li {
		width: 100%;
		margin-bottom: 25px;
	}

	.optItem {
		padding-left: 20px;
		padding-right: 20px;
	}

	#itemdetail #attention .items {
		display: grid;
		justify-items: start;
	}

	#itemdetail #attention .items .item {}
}







/* ================================
   Contact
================================ */

#contact .box {
	background-color: #F7F5F1;
	padding: 40px;
	margin-bottom: 30px;
}

#contact .box .title {
	font-size: 20px;
	padding: 10px 0;
	border: 1px solid #1d1d1d;
	width: 280px;
	margin: auto auto 25px auto;
	text-align: center;
	font-family: "Shippori Mincho", serif;
}

#contact .bs p {
	font-family: "Shippori Mincho", serif;
}

#contact .box dl {
	margin: 0;
}

#contact .box dl dt,
#contact .box dl dd {
	text-align: center;
	font-family: "Shippori Mincho", serif;
}

#contact .box dl dt {
	font-size: 16px;
	font-weight: normal;
}

#contact .box dl dd {
	font-size: 24px;
	font-weight: bold;
	margin-bottom: 20px;
}

#contact .cateogories {
	margin: auto auto;
}

#contact .cateogories ul {
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	margin-bottom: 0;
}

#contact .cateogories ul li {
	list-style: none;
}

@media screen and (max-width: 991px) {
	#contact .cateogories ul li {
		margin-bottom: 10px;
	}
}

#contact .cateogories ul li a {
	display: block;
	color: #1d1d1d;
	padding: 10px 20px;
	border: 1px solid #121212;
	margin: 0 4px;
}

#contact .cateogories ul li a::after {
	content: '';
	width: 11px;
	height: 11px;
	background-image: url(../images/common/arrow-black.png);
	background-repeat: no-repeat;
	background-size: contain;
	display: inline-block;
	margin-left: 10px;
}

#contact .cateogories ul li.active a {
	display: block;
	background-color: #121212;
	color: white;
	padding: 10px 20px;
}

#contact .cateogories ul li.active a::after {
	background-image: url(../images/common/arrow-white.png);
}

#contact .step ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	padding: 0;
}

#contact .step ul li {
	background-color: #f8f8f8;
	list-style: none;
	padding: 10px 20px;
	text-align: center;
	display: block;
	width: 33%;
	height: 60px;
	line-height: 40px;
	position: relative;
	font-family: "Shippori Mincho", serif;
}

@media screen and (max-width: 991px) {
	#contact .step ul li {
		font-size: 12px;
		padding: 10px;
		height: 40px;
		line-height: unset;
	}

	.form-flow ul li::after {
		height: 40px !important;
	}
}

#contact .step ul li.active {
	background-color: #121212;
	color: white;
}

#contact .formWrap {}

#contact .formWrap li {
	list-style: none;
}

#contact .formWrap .form-input {
	display: flex;
	flex-wrap: wrap;
	border-top: 1px solid #d9d9d9;
}

#contact .formWrap .form-input .label {
	width: 30%;
	position: relative;
	padding: 30px;
	line-height: 100%;
}

#contact .formWrap .form-input .label p {
	font-family: "Shippori Mincho", serif;
}

#contact .formWrap .form-input .input {
	width: 70%;
	position: relative;
	padding: 30px;
}


#contact .formWrap span.required {
	position: absolute;
	top: 30px;
	right: 10px;
	display: inline-block;
	border: 1px solid red;
	color: red;
	font-size: 12px;
	border-radius: 3px;
	padding: 3px 5px;
	font-family: "Shippori Mincho", serif;
}

#contact .mwform-checkbox-field-text {
	font-family: "Shippori Mincho", serif;
}

@media screen and (max-width: 991px) {
	#contact .mwform-checkbox-field-text {
		font-size: 14px;
	}

	#contact .js-mw-checkbox {
		margin-top: 20px;
	}
}

#contact ::placeholder {
	font-family: "Shippori Mincho", serif;
}

#contact option {
	font-family: "Shippori Mincho", serif;
}

#contact input,
#contact textarea,
#contact select {
	border: none;
	background-color: #f8f8f8;
	padding: 15px;
}

#contact .form-submit {
	display: flex;
	justify-content: center;
}

.to-top-link {
	display: block;
	text-align: center;
	line-height: 80px;
}

.to-top-link:hover {
	color: #fff;

}

#contact .form-submit button,
.to-top-link {
	background-color: #121212;
	max-width: 320px;
	font-family: "Shippori Mincho", serif;
	width: 100%;
	border-radius: 100px;
	height: 80px;
	color: white;
	margin: auto;
}

#contact .form-submit button:hover,
.to-top-link:hover {
	opacity: .6;
}

#contact #contentsBottom {
	margin-top: 80px;
}

@media screen and (max-width:991px) {
	#contact #contentsBottom {
		margin-top: 40px;
	}

	#contact .box,
	#contact .step {
		margin-left: 20px;
		margin-right: 20px;
	}

	#contact input,
	#contact textarea {
		max-width: 100%;
	}

	#contact .p-contact-form {
		padding: 20px;
	}

	#contact ul.form-group {
		padding-left: 0;
	}

	#contact .formWrap .form-input .label,
	#contact .formWrap .form-input .input {
		width: 100%;
		padding: 0;
	}

	#contact .formWrap .form-input .input {
		margin-bottom: 25px;
	}

	#contact .formWrap span.required {
		top: 10px;
		right: 0;
	}
}

#contact .first {
	font-family: "Shippori Mincho", serif;
	font-size: 16px;
	line-height: 1.5;
}

@media screen and (max-width:991px) {
	#contact .first {
		padding: 0 15px;
	}
}

.form-flow ul li:first-child.active {
	position: relative;
	z-index: 3;
}

.form-flow ul li:first-child.active::after {
	position: absolute;
	content: "";
	width: 51px;
	height: 60px;
	background-image: url(../images/contact/step.svg);
	background-size: contain;
	right: 0;
	top: 0;
	transform: translateX(100%);
	background-repeat: no-repeat;
}

.form-flow ul li:first-child::after {
	position: absolute;
	content: "";
	width: 51px;
	height: 60px;
	background-size: contain;
	right: 0;
	top: 0;
	transform: translateX(100%);
	background-repeat: no-repeat;
}

.form-flow ul li:nth-child(1).step2 {
	z-index: 4;
}

.form-flow ul li:nth-child(1).step2::after {
	background-image: url(../images/contact/step2.svg);
	right: 6px;
}

.form-flow ul li:nth-child(2) {
	position: relative;
	z-index: 2;
}

.form-flow ul li:nth-child(2)::after {
	position: absolute;
	content: "";
	width: 51px;
	height: 60px;
	background-image: url(../images/contact/step3.svg);
	background-size: contain;
	right: 0;
	top: 0;
	transform: translateX(100%);
	background-repeat: no-repeat;
}

.form-flow ul li:last-child::after {
	display: none;
}

.form-flow ul li:nth-child(2).active {
	position: relative;
	z-index: 3;
}

.form-flow ul li:nth-child(2).active::after {
	position: absolute;
	content: "";
	width: 51px;
	height: 60px;
	background-image: url(../images/contact/step.svg);
	background-size: contain;
	right: 0;
	top: 0;
	transform: translateX(100%);
	background-repeat: no-repeat;
}

.form-flow ul li:nth-child(1).step3 {
	z-index: 4;
}

.form-flow ul li:nth-child(1).step3::after {
	background-image: url(../images/contact/step3.svg);
	right: 6px;
}

.form-flow ul li:nth-child(2).step3 {
	z-index: 4;
}

.form-flow ul li:nth-child(2).step3::after {
	background-image: url(../images/contact/step2.svg);
	right: 6px;
}

.p-privacy {
	position: relative;
	padding: 6rem 0 0rem;
	margin-bottom: 12rem;
}

.p-privacy .privacy-title {
	position: relative;
	margin-bottom: 3rem;
	font-size: 1.8rem;
	text-align: left;
	font-family: "Shippori Mincho", serif;
	font-weight: bold;
}

.p-privacy .privacy_item {
	margin-bottom: 2rem;
}

.privacy_item {
	width: 100%;
	margin-bottom: 40px;
	font-family: "kozGoPro6NM";
	font-size: 18px;
}

.p-privacy .privacy_item_title {
	display: block;
	padding: 0;
	font-weight: 500;
	font-size: 1.4rem;
	line-height: 2;
	text-align: left;
	color: #231815;
	font-family: "Shippori Mincho", serif;
	font-weight: bold;
}

.p-privacy .privacy_item_content {
	position: relative;
	display: block;
	padding: 0 0.5rem;
	font-family: "Shippori Mincho", serif;
	font-weight: 400;
	font-size: 1rem;
	line-height: 2;
	text-align: left;
	color: #231815;
}

@media screen and (max-width:991px) {
	.p-privacy {
		padding: 3rem 0 0rem;
	}

	.p-privacy .privacy-title {
		font-size: 1.2rem;
	}

	.p-privacy .privacy_item_title {
		font-size: 1rem;
	}

	.p-privacy .privacy_item_content {
		font-size: 0.8rem;
	}
}

.p-sitemap {
	position: relative;
	padding: 6rem 0 0rem;
}

.p-sitemap .sitemap-menu {
	position: relative;
	list-style: none;
	display: block;
	padding: 0;
}

.p-sitemap .sitemap-menu>li {
	position: relative;
	margin-bottom: 1.2rem;
}

.p-sitemap .sitemap-menu .menu-link {
	position: relative;
	display: block;
	width: 100%;
	background: linear-gradient(-90deg, #ddc77f, #deaf79);
	padding: 2rem 3rem;
	font-size: 1.8rem;
	line-height: 2rem;
	color: #FFFFFF;
	text-decoration: none;
	text-align: left;
	transition: all 0.3s ease-in-out;
}

@media screen and (max-width:991px) {
	.p-sitemap {
		padding: 3rem 0 0rem;
	}

	.p-sitemap .sitemap-menu .menu-link {
		padding: 1.5rem 2rem;
		font-size: 1.2rem;
	}
}

/* ================================
   パーツ
================================ */
.second {
	padding: 50px 0 20px 0;
}

.second .container-fluid {
	max-width: 1300px;
	margin: auto;
}

.second-ttl {
	text-align: left;
	font-size: 60px;
	font-family: "Cormorant", serif;
	margin-bottom: 0 !important;
}

.second-small {
	font-size: 16px;
	font-family: "Shippori Mincho", serif;
	margin-bottom: 40px;
}

.second-breadcrumbs {
	display: flex;
	align-items: center;
}

.second-breadcrumbs img {
	margin-right: 5px;
	margin-bottom: 2px;
}

.second-breadcrumbs span {
	font-size: 14px;
	font-family: "Cormorant", serif;
}

.second-breadcrumbs span:nth-child(n+2) {
	padding-left: 20px;
	position: relative;
}

.second-breadcrumbs span:nth-child(n+2)::before {
	width: 11px;
	height: 11px;
	position: absolute;
	content: '';
	background-image: url(../images/common/arrow.png);
	background-repeat: no-repeat;
	background-size: contain;
	left: 7px;
	top: 49%;
	transform: translateY(-50%);
}

@media screen and (max-width:991px) {
	.second {
		padding: 30px 0;
	}

	.second-ttl {
		font-size: 40px;
	}
}

.privacy-ttl {
	text-align: left;
	font-family: "Shippori Mincho", serif;
}