/* reset */
html
,body
,article
,section
,aside
,ul
,li
,div
,img
,h1
,h2
,h3{
	padding: 0;
	margin: 0;
}
/*------------------------------------------------------------------------------------*/
/*								▼レスポンシブのためのCSS▼									*/
/*------------------------------------------------------------------------------------*/

/* ウィンドウ幅が1024px以上の場合 */
@media ( min-width:1024px ){
	aside{
	bottom: 5%;
	right: 0%;
	}
}

/* iPad用 */
@media ( min-width:768px ) and ( max-width:1024px ){
	img{
		max-width: 100%;
		height: auto;
	}
	.lips li{
	max-width: 200px;
	margin: 0 10px;
	}
	.concept{
	max-width: 88%;
	height: auto;
	}
	.concept p{
		padding: 0;
		line-height: 1.5;
		font-size: 90%;
	}
}

/* ウィンドウ幅が768px以下の場合 */
@media ( max-width:768px ){
	:root{
		font-size: 14px;
	}
	img{
		max-width: 100%;
		height: auto;
	}
	nav{
		font-size: 80%;
		padding: 2% 0;
	}
	nav li{
		padding: 0 10px!important;
	}
	div.hero{
		align-items: flex-start;
	}
	div.hero h1{
		position: relative;
		top: 5%;
		font-size: 250%;
		line-height: 1.5;
	}
	div.concept{
		margin: 0 auto;
		max-width: 85%;
		line-height: 2;
	}
	.lips{
		flex-direction: column;
		align-items: center;
	}
	.lips li{
		max-width: 88%;
		height: auto;
	}
	video{
		max-width: 88%;
		height: auto;
	}
	#shoplist h3{
	text-indent: 0!important;
	}
	div.shoplist{
		max-width: 80%;
		height: auto;
		padding: 5%;
	}
	div.shop{
		flex-direction: column;
		align-items: center;
	}
	div.shop:nth-child(even){
		flex-direction: column;
	}
	.shop div{
		text-align: center;
	}
	div.shop address{
		font-size: 0.8rem;
	}
	div.shop span{
		padding: 0;
	}
	
	/* お問い合わせフォームまわり */
	form
	,textarea
	,input{
		max-width: 90%;
		text-align: center;
	}
	.contact_us{
		max-width: 80%;
	}
	
	.contact_us p{
		font-size: 1.5rem!important;
	}
	
	/* フローティングメニューまわり */
	aside{
		max-width: 35px;
		padding: 5px!important;
	}
	.backTop a{
		max-width: 30px;
		height: auto!important;
		font-size: 1.5rem!important;
	}
	
	/* フッター */
	footer #foot{
		flex-wrap: wrap;
	}	
	footer #foot *{
		flex: 1 1 100%;
	}	
	footer #foot div:nth-child(1)
	,footer #foot p{
		text-align: center;
	}
	footer #foot *:not(.logo){
		font-size: 1rem;
	}

	/* items.html */
	ul#lineup{
		max-width: 95%;
		justify-content:space-around;
		padding:5px;
		margin-top: 15px;
	}
	ul#lineup li{
		flex: 0 0 45%;
		margin: 5px;
	}
	ul#lineup li h1{
		font-size: 200%;
		letter-spacing: normal;
		text-align: center;
	}
	div.itemlist{
		max-width: 85%;
		flex-wrap: wrap;
		padding: 40px 0!important;
	}
	
	/* contents */
	.contents{
		max-width: 80%;
	}
}



/*------------------------------------------------------------------------------------*/
/*										▼全体の設定▼									  */
/*------------------------------------------------------------------------------------*/



body{
	font-family: serif;
	line-height: 1.5;
	background-color: rgb(195,195,228);
	color: #333;
}

a:link{
	color: #fff;
	text-decoration: none;
}
a:visited{
	color: #fff;
}
a:hover{
	color: #fff;
}
a:active{
	color: #fff;
}

h2{
	font-family: 'Cinzel', serif;
}

img{
	border: 0;
}

ul{
	list-style: none;
}

article{
	margin: 0 auto;
}

address{
	font-style: normal;
}

.center{
	text-align: center;
}

/*------------------------------------------------------------------------------------*/
/*									▼ここから中身▼									  */
/*------------------------------------------------------------------------------------*/
nav{
	color: #fff;
	position:fixed;
	top: 0;
	left: 0;
	background-color: rgba(255,255,255,0.4);
	width: 100%;
	text-align: center;
	z-index: 999;
}

nav li{
	display: inline;
	padding: 0 15px;
	border-right: 1px solid #fff;
}

nav li:nth-child(1){
	border-left: 1px solid #fff;
}

nav a:hover{
	border-bottom: 2px solid #fff;
	text-shadow: 2px 2px 5px #9f9f9f;
}


/* ▼背景色にグラデ */
.hero {
/*	position: relative;*/
	display: flex;
	align-items: center;
	justify-content: flex-start;
	height: 100vh;
	background: linear-gradient(rgba(229,93,135,0.3) 50%, rgba(195,195,228,1)), url(../image/gatag-00010365.jpg) center center / cover no-repeat;
}

.hero h1 {
/*	position: absolute;
	top: 40%;
	left: 0%;*/
	/*-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);  使わずにやってみる*/
	color: #fff;
	font-family: "Hannari";
	font-weight: normal;
	font-size: 300%;
}

.hero h1 span.mincho{
	font-family: "Mincho",serif;
}

.concept{
	width: 750px;
	padding:30px 10px;
	text-align: center;
	background-color: rgba(255,255,255,0.4);
	margin: 80px auto;
	line-height: 3;
	border-radius: 15px;
	border: 5px solid rgba(255,255,255,0.6);
}

.concept p{
	text-shadow: 2px 2px 5px #9f9f9f;
}

/* 記事 */
section{
	padding-bottom: 40px;
}

section h2{
	text-align: center;
/*	background-image: linear-gradient(rgba(229,93,135,.4), rgba(195,195,228,.4));*/
	padding: 10px;
/*	background-color: rgba(195,195,228,1);*/
	border-bottom: 8px solid rgba(229,93,135,.4);
	margin: 40px 0;
}

/* 商品メニュー */
.lips{
	display: flex;
	justify-content: center;
	text-align: center;
}

.lips li{
	width: 250px;
	margin: 0 15px;
}

.lips li img{
	border-radius: 50%;
	width:250px;
}

.lips a:hover{
	opacity: 0.8;
}

.lips h3{
	border-top: 2px solid #333;
	border-bottom: 2px solid #333;
}

.lips p{
	font-size: 80%;
}

/* 動画 */
#cm p{
	text-align: center;
	font-size: 0.8em;
}
video{
	display: block;
	margin: 0 auto;
	background-color: #fff;
	border: 5px solid rgba(255,255,255,0.4);
}


/* SHOP LIST */
#shoplist h3{
	text-indent: 1em;
	border-bottom: 2px solid #333;
}

.shoplist{
	width: 640px;
	margin: 0 auto;
	background-color: rgba(255,255,255,0.4);
	padding: 30px;
}

.shop{
	display: flex;
	justify-content:center;
	padding: 20px 0;
	border-bottom: 1px dotted #fff;
}

.shop:nth-child(even){
	flex-direction: row-reverse;
}

.shop:nth-child(3){
	border-bottom: none;
}

.shop div{	
	flex: 1;
}

.shop img{
	width: 320px;
	height: 200px;
}

address{
	padding: 15px 15px 0 15px;
}

.shop span{
	padding-left: 15px;
}

/* お問い合わせ窓口 */

.contact_us{
	font-family: "Osaka",sans-serif;
	width: 500px;
	text-align: center;
	line-height: 1;
	background-color: rgba(255,255,255,0.4);
	padding: 20px;
	margin: 0 auto;
	margin-top: 60px;
	margin-bottom: 60px;
	border: 5px solid #fff;
	border-radius: 15px;
}

.contact_us h3{
	display: inline;
	padding: 0 15px;
	background: linear-gradient(transparent 70%, #fffa7b 70%);
}

.contact_us p{
	font-size: 2em;
	font-weight: bold;
	border-bottom: 2px solid #333;
	margin-bottom: 6px;
}

.contact_us span.fa.fa-phone{
	display: inline-block;
	font-size: 2rem;
	padding: 5px;
	margin: 0 1rem 1rem;
	width: 2rem;
	background-color: rgba(255,255,255,1);
	border: 3px solid currentColor;
	border-radius: 50%;
}

.contact_us p a{
	color: inherit;
}

hr{border: 0.5px dashed #fff;}

/* SNSメニュー */
aside{
	position: fixed;
	background-color: rgba(255,255,255,0.7);
	padding: 10px;
	border-radius: 10px 0 0 10px;
	z-index: 999;
	bottom: 15%;
	right: 0%;
}

aside ul li img{
	width: 55px;
	height: auto;
}

/* フッター */
footer{;
	font-size: 0.85rem;
	background-color: rgba(229,93,135,.4);
	width: 100%;
}

footer .logo{
	font-family: 'Cinzel', serif;
	font-size: 5rem;
	letter-spacing: normal;
	padding-left: 15px;
}

#foot{
	display: flex;
	align-items: center;
	padding: 10px;
	font-size: 0.9em;
	letter-spacing: 0.2em;
}

#foot *{
	flex: 1;
}

#foot p.sns a{
	display: inline-block;
	width: 15px;
	height: 15px;
	text-align: center;
	color: inherit;
}

#foot p.sns a:hover{
	color: rgba(255,255,255,1);
	background-color: rgba(0,0,0,0.3);
}

#foot ul{
	border-left: 1px solid #fff;
	text-align: left;
	padding: 10px;
}
#foot ul a{
	display: block;
}

#foot ul a:hover{
	background-color: rgba(0,0,0,0.3);
}

footer .copy{
	font-size: 0.85em;
	text-align: center!important;
}

/*------------------------------------------------------------------------------------*/
/*									▼ここからitems▼										*/
/*------------------------------------------------------------------------------------*/
section#top{
	height: 100vh;
}

#lineup{
	display: flex;
	align-items: center;
	justify-content: space-around;
	width: 1024px;
	flex-wrap: wrap;
	margin: 0 auto;
	height: 100%;
	padding: 15px;
}

#lineup li{
	flex: 0 0 250px;
	margin: 0 15px;
	position: relative;
}

#lineup li h1{
	max-width: 100%;
	font-size: 200%;
	letter-spacing: 1.5rem;
}

#lineup li img{
	width: 250px;
	border-radius: 50%;
	display: block;
	border: 3px solid #fff;
}

#lineup li:hover img{
	opacity: 0.4;
	border: 3px solid #000;
}

#lineup li:nth-child(2) a:hover{
	opacity: 1;
}

#lineup .hover{
	opacity: 0;
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	width: 85%;
	text-align: center;
	color: #333;
	font-family: 'Cinzel', Verdana, Geneva, "sans-serif";
	font-weight: bold;
}
#lineup li:hover .hover{
	opacity: 1;
}

/* 商品詳細 */

div.itemlist{
	display: flex;
	align-items: center;
	justify-content: space-around;
	width: 750px;
	margin: 0 auto;
	padding: 80px 0;
	border-bottom: 1px dashed #666;
}

div.itemlist img{
	width: 250px;
	height: 250px;
}

div.backTop a{
	position: fixed;
	bottom: 5%;
	right: 1%;
	width: 50px;
	height: 50px;
	text-align: center;
	font-size: 1.8rem;
	border: 2px solid currentColor;
	border-radius: 50%;
	background-color: rgba(255,255,255,0.2);
}

div.backTop a:hover{
	background-color: rgba(0,0,0,0.3);
}

/*------------------------------------------------------------------------------------*/
/*									▼ここからcontact▼									*/
/*------------------------------------------------------------------------------------*/
/* お問い合わせフォーム */


form{
	width: 500px;
	margin: 0 auto;
}

label{
	display: block;
}

input.text{
	width: 250px;
}

textarea{
	width: 500px;
	height: 200px;
}

button{
	width: 100px;
	padding: 5px;
	display: block;
	margin: 0 auto;
}

p.comment{
	text-align: center;
	font-size: 0.8rem;
	padding:30px 0;
}

p.comment a{
	color: inherit;
	text-decoration: underline;
}

/*------------------------------------------------------------------------------------*/
/*									▼ここからprivacy▼									*/
/*------------------------------------------------------------------------------------*/

.contents{
	width: 500px;
	margin: 0 auto;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.contents ul{
	list-style-type: disc;
	padding-left: 2rem;
	margin-bottom: 1.2rem;
}