@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:18px;
		line-height: 220%;
	}
	
}

/* ================================
   Base 
================================ */

.page-template{
	margin-top:75px;
}

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

.page-template .basic-padding{
	padding-top:80px;
	padding-bottom:80px;
}
.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;
}
#contentsBottom{
	border-bottom-left-radius:  100px;
	border-bottom-right-radius: 100px;
}
@media screen and (min-width:992px) and (max-width:1299px){
	.page-template{
		
	}
}
@media screen and (max-width:991px){
	.page-template{
		margin-top:60px;
	}

	.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;
	}
	#contentsBottom{
		border-bottom-left-radius:  100px;
		border-bottom-right-radius: 100px;
	}
}

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

.pageNavi{
	max-width: 100%;
	width: 1126px;
	margin:auto;
	border-radius: 32px;
	background-color: #f8f8f8;
	padding: 24px 34px;
	margin-bottom: 100px;
}
.pageNavi ul{
	padding:0;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
	margin-bottom: 0;
}
.pageNavi ul>li{
	list-style: none;
}

@media screen and (max-width:991px){
	.pageNavi{
		background:#fff;
		margin-top:    0;
		margin-bottom: 20px;
	}
	.pageNavi ul{
		
	}
	.pageNavi ul li{
		background-color: #f8f8f8;
		padding:10px 20px;
		border-radius: 26px;
		margin-bottom: 10px;
		
	}
}
/* ================================
   Service
================================ */

#service h3{
	padding-bottom: 0;
}
#service .box{
	
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	background-color:#121212;
	border-radius: 26px;
}
#service .box .image{
	height: 437px;
	flex: 1;
	border-top-left-radius: 26px;
	border-bottom-left-radius: 26px;
}
#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{
	margin-bottom: 264px;
}
#service section:last-child{
	margin-bottom: 0;
}

@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{
		margin-bottom: 50px;
	}
	#service section:last-child{
		margin-bottom: 0;
	}
	#service section>p{
		
	}
	#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:#121212;
}
#philosophy h3{
	font-size: 36px;
	margin-bottom: 25px;
}

#philosophy p{
	font-size: 22px;
	margin-bottom: 25px;
}
#philosophy .image{
	width: 351px;
	margin:auto;
}
#company .greetings{
	background-color:#121212;
}
#company .greetings>div{
	background-color:white;
}
#company .greetings h3{
	font-size: 32px;
	margin-bottom: 25px;
}
#company .greetings .div1{
	padding-top: 60px;
	display: flex;
	justify-content: flex-end;
}
#company .greetings .message{
	max-width: 640px;
	width: 640px;
	padding-top:50px;
}
#company .greetings .div2{
	display: flex;
	justify-content: center;
	padding-top:120px;
}
#company .greetings .box{
	width: 477px;
	height: auto;
	text-align: center;
}

#companydata{
	background-color:#fff;
}
#companydata p{
	color:white;
}
#companydata>div{
	background-color:#121212;
}
#companydata h3{
	color:white;
}
#companydata .div1{
	display: flex;
	justify-content: right;
}
#companydata .div2 dl>dt{
	border-top: 1px solid #fff;
	padding-top:1rem;
	padding-bottom:5px;
	font-size: 15px;
	color:white;
}
#companydata .div2{

}
#companydata .div2 dl>dd{
	padding-bottom: 10px;
	font-size: 12px;
	font-weight: normal!important;
	color:white;
	
}

#companydata .yearBox p{
	margin:0;
	padding:15px 30px 30px 30px;
	
}

#companydata .yearBox .yimage{
	margin-top: -30px;
	margin-left: 30px;
}
#companydata .sep{
	width: 1px;
	height: 40px;
	background: rgba(119,89,23,1.00);
	margin:auto;
}

#companyaccess{
	background-color:#121212;
}
#companyaccess>div{
	background-color:#fff;
}
	
.offices{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.offices .item{
	padding: 20px 30px;
	background-color: #f8f8f8;
	width: 630px;
}
.offices .item .title{
	font-size: 28px;
	padding-bottom: 8px;
}


@media screen and (min-width:992px) and (max-width:1299px){
	#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;
	}
}

@media screen and (max-width:991px){
	
	#philosophy h3{
		padding-bottom: 0;
	}
	#philosophy p{
		padding-left:  20px;
		padding-right: 20px;
		font-size: 18px;
	}
	#philosophy .image{
		width: 200px;
	}
	
	#greetings h3{
		text-align: center;
	}
	#company .greetings .div1{
		padding-top:0;
	}
	#company .greetings .div1{
		padding: 20px;
	}
	#company .greetings .div2{
		padding: 120px 20px 120px 20px;
	}
	
	#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;
	}
}



/* ================================
   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 .item{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
	align-items: center;
	margin-bottom: 15px;
}
#focus .items .item{
	padding:60px;
}

#focus .items .item h4{
	height: 51px;
	padding-left: 88px;
	font-size: 32px;
	line-height: 51px;
}
#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: 500px;
}
#focus .item .div2{
	width: 350px;
}
#focus .image{
	
}

#focus .voice{
	margin-top: 70px;
	margin-bottom: 35px;
}
#focus .voice p{
	font-size: 32px;
	font-weight: bold;
	line-height: 140%;
}

#focus .items2{
	
}
#focus .items2 .item{
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: center;
	margin-bottom: 15px;
}
#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;}


#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;
}

#impact .head{
	margin-bottom: 120px;
}
#impact .head p{
	color:white;
	font-size: 16px;
	max-width: 700px;
}
#impact .image{
	margin-bottom: 60px;
}

#faq dl{
	padding:10px;
}
#faq dl dt{
	border-top: 1px solid #d7d7d7;
	padding-top:20px;
	padding-bottom:10px;
	cursor: pointer;
	display: block;
	position: relative;
}
#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;
}

/*@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: 22px;
		padding: 0 25px;
	}
	
	#passion .intro{
		padding-bottom:250px;
		background-position: bottom center;
		background-size: contain;
	}
	#passion .intro .image{
		padding: 25px;
		width: 250px;
	}
	
	#focus h3{
		padding-bottom: 10px;
	}
	#focus .head p{
		font-size: 22px;
		max-width: 340px;
		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;
		padding-left: 25px;
		padding-right:25px;
	}
	#impact .separate .div1{
		padding-left: 25px;
		width: 150px;
	}
	#impact .separate .div2{
		padding: 25px;
	}
	#faq h3{
		text-align: center;
		padding-bottom: 25px;
	}
}



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

#sdgsintro{
	margin-bottom: 80px;
}

#sdgsintro h3,
#sdgsintro #sdgsintro p{
	color:#1d1d1d;
}
#sdgsintro h3{
	padding-bottom: 20px;
	margin-bottom: 0;
}
#sdgsintro p{
	margin-bottom: 30px;
	line-height: 200%;
}
#sdgswrap .box{
	border: 1px solid #1d1d1d;
	padding: 20px;
	margin-bottom: 60px;
}
#sdgswrap .box h4{
	font-size: 18px;
	color:#1d1d1d;
}
#sdgswrap .box p{
	font-size: 14px;
	margin-bottom: 0;
}
#sdgswrap .div2{
	padding-left:45px;
}


#sdgspoints .point{
	position: relative;
	padding: 120px 55px 100px 55px;;
	border:1px solid #fff;
	margin-bottom:100px;
}
#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: flex-start;
}
#sdgspoints .panels .item{
	width: 25%;
}
#sdgspoints .panels .image{
	width: 244px;
	height: 200px;
}
#sdgspoints .torikumi h4{
	font-size: 22px;
}
#sdgspoints .panels .image img{
	border-radius: 18px;
}
#sdgspoints .panels .text{
	width: 244px;
	padding: 10px 15px 10px 15px;
	font-size: 16px;
}

@media screen and  (min-width:992px) and  (max-width:1299px){
	
	#sdgsintro .div1{
		padding-left: 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 (max-width:991px){

	#sdgsintro .div1{
		padding: 20px;
	}
	#sdgsintro .div1 .image{
		width: 280px;
	}
	#sdgswrap .box{
		margin-bottom: 30px;
	}
	#sdgsintro .div2{
		padding: 25px;
	}
	
	#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;
	}
	#sdgspoints .torikumi h4{
		text-align: center;
	}
	#sdgspoints .torikumi .panels .item{
		width: 100%;
	}
	#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;
}
#news .pageNavi li.active a{
	background-color: #121212;
	border-radius: 26px;
	color:white;
	padding: 10px 20px;
}

#news .content .items{
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	padding-bottom:100px;
}
#news .content .items .item{
	margin-bottom: 40px;
}
#news .content .items .item a{
	display: block;
	width: 360px;
	text-decoration: none;
}

#news .content .items .item .date{
	color: #5B5B5B;
	font-size: 16px;
	padding-top:10px;
	padding-bottom:3px;
}
#news .content .items .item .photo{
	width: 360px;
	height: 360px;
	position: relative;
}
#news .content .items .item .photo span{
	display: block;
	position: absolute;
	padding: 2px 15px;
	font-size: 14px;
	bottom:12px;
	left:  12px;
	background-color: rgba(255,255,255,0.80);
	border-radius: 60px;
	text-align: center;
}
#news .content .items .item .photo img{
	border-radius: 26px;
	width: 100%;
  height: 100%;
  object-fit: cover; /* 画像をコンテナ内にフィットさせる */
}
#news .content .items .item .title{	font-size:20px;
	margin-bottom: 8px;
	width: 360px;
	
}
#news .content .items .item .text{	width: 360px;
	color: #5B5B5B;
	line-height: 220%;
	
}

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

	width: 33.3%;
	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:100px;
}

/*@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: 50%;
		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;
	}
}

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

.categories{
	max-width: 950px;
	margin:auto;
}
.categories h3{
	text-align: center;
}
.categories ul{
	padding:0;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.categories ul li{
	width: 25%;
	list-style: none;
	margin-bottom: 40px;
}
.categories ul li a{
	display: block;
	text-align: center;
}
.categories ul li a{
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.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;
}

.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){
	
	#categoryitems main{
		padding:20px;
	}
	
	.categories>div{
		padding:0;
	}
	.categories ul{
		
	}
	.categories ul li{
		width: 50%;
		padding:10px;
	}
	
	.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;
	}
}

@media (max-width: 1299px) {
	#products .separate .div1,#products .separate .div2{
		width: 100%;
	}
    #products .separate {
        flex-direction: column; /* 縦方向に並べる */
    }
}


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


#itemdetail .div1 .mainimage{
	width: 650px;
	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%;
	border-radius: 16px;
	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;
}
#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;
}

#itemdetail .div2innerWrap .spec dl{
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
}
#itemdetail .div2innerWrap .spec dl dt{
	width: 33%;
}
#itemdetail .div2innerWrap .spec dl dd{
	width: 66%;
}
#itemdetail .kataban span{
	display: inline-block;
	padding: 4px 8px;
	background-color: #121212;
	color:white;
	font-weight: 400;
	margin-right: 10px;
	margin-bottom: 10px;
}

#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 .colors ul li a img{
	border-radius: 5px;
}
#itemdetail h4{
	font-size: 18px;
	margin-bottom: 15px;
}
#itemdetail .graybox{
	background-color: #f8f8f8;
	padding: 40px;
}
#itemdetail .graybox .items{
	display: flex;
	justify-content: center;
	grid-gap: 10px;
}

#itemdetail #attention{
	margin-bottom: 45px;
}
#itemdetail #attention .items .item{
	border:1px solid #1d1d1d;
	border-radius: 60px;
	display: inline-block;
	padding: 12px 25px;
	font-weight: bold;
	margin-bottom: 15px;
}
#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;
}


@media screen and (max-width:991px){
	
	#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:#f8f8f8;
	padding: 40px;
	margin-bottom: 120px;
}
#contact .box .title{
	font-size: 20px;
	padding: 10px 0;
	border:1px solid #1d1d1d;
	border-radius: 60px;
	width: 280px;
	margin:auto auto 25px auto;
	text-align: center;
}
#contact .box dl{
	margin:0;
}

#contact .box dl dt,
#contact .box dl dd{
	text-align: center;
}
#contact .box dl dt{
	font-size:16px;
	font-weight: normal;
}
#contact .box dl dd{
	font-size:30px;
	font-weight: bold;
}

#contact .cateogories{
	background-color:white;
	padding:5px;
	border-radius: 100px;
	width: 300px;
	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;
	
}
#contact .cateogories ul li a{
	display: block;
	background-color: #fff;
	color:#1d1d1d;
	border-radius: 100px;
	padding:10px 20px;;
}
#contact .cateogories ul li.active a{
	display: block;
	background-color: #121212;
	color:white;
	border-radius: 100px;
	padding:10px 20px;;
}

#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:0 20px;
	text-align: center;
	display: block;
	width: 33%;
	height: 40px;
	line-height: 40px;
	position: relative;
	
}

#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 .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;
}

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

#contact .form-submit{
	display: flex;
	justify-content: center;
}
#contact .form-submit button{
	background-color: #121212;
	max-width: 320px;;
	width: 100%;
	border-radius: 100px;
	height: 80px;
	color:white;
	margin:auto;
}

@media screen and (max-width:991px){
	
	#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;
	}
}

.p-privacy {
    position: relative;
    padding: 6rem 0 0rem;
}
.p-privacy .privacy-title {
	position: relative;
    margin-bottom: 3rem;
    font-size: 1.8rem;
    text-align: left;
    font-family: KozGoPr6N-Bold;
    font-weight: bold;
	background: linear-gradient(-90deg, #ddc77f, #deaf79);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}
.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-family: KozGoPr6N-Medium;
    font-weight: 500;
    font-size: 1.4rem;
    line-height: 2;
    text-align: left;
    color: #231815;
}
.p-privacy .privacy_item_content {
    position: relative;
    display: block;
    padding: 0 0.5rem;
    font-family: KozGoPr6N-Regular;
    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;
	}
}