@charset "utf-8";

/* フォント
------------------------------------- */
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP&display=swap');
@import url('https://fonts.googleapis.com/css2?family=M+PLUS+1:wght@300&display=swap');

/* 全体
------------------------------------- */
body {
	font-family: 'M PLUS 1', sans-serif;
}
h1,h2,h3,h4,h5 {
	font-family: 'Noto Serif JP', serif;
}

/* リンク
------------------------------------- */
a,
a:hover {
	text-decoration: none;
}


/* 見出し
------------------------------------- */
h2.content_title {
	padding: 0 10px 20px 10px;
	margin: 0;
	text-align: center;
	font-size: 1.8em;
	color: #2b1616;
}
h2.page_title {
	padding: 0 10px 20px 10px;
	margin: 0;
	font-family: 'Noto Serif JP', serif;
	text-align: center;
	font-size: 2em;
	color: #2b1616;
}

/* テキスト
------------------------------------- */
.attention {
	color: #960e0e;
}
.t_small {
	font-size: 0.8em;
}

/* ヘッダー
------------------------------------- */
header {
	padding: 10px 0;
	border-top: solid 5px #579BB0;
	border-bottom: solid 1px #ddd;
}
	header .logo_area {
		padding: 10px 0;
	}
		header .logo_area h1.logo {
			padding: 0 0;
			font-size: 1.9em;
			margin: 0;
			font-family: 'Noto Serif JP', serif;
		}
			header .logo_area h1.logo a {
				color: #579BB0;
			}
		header .logo_area .discription {
			padding: 0 0 3px 0;
			font-size: 0.8em;
		}
			/* モバイル（xs） iPhone6 Plus 縦 */
			@media (max-width: 539px) {
				header h1.logo {
					font-size: 1.3em;
				}
			}

/* ナビゲーション
------------------------------------- */
.nav_area {
	background: #fff;
	margin-top: 20px;
}
	nav.bg-light {
		background: #fff;
	}
	nav button.navbar-toggler {
		margin: 0 0 0 auto;
		border-color: #333;
		color: #333;
	}
	nav .navbar-collapse {
		display: flex;
		justify-content: flex-end;
		align-items: center;
		list-style: none;
	}
		nav ul.navbar-nav {
			padding: 0;
			margin: 0;
		}
			nav ul.navbar-nav li {
				padding: 4px 0  4px 10px;
				margin: 0 8px;
			}
				nav ul.navbar-nav li a {
					padding:0;
				}
			.navbar-light .navbar-nav .nav-link {
				color: #333;
			}

	/* モバイル（sm） iPhone6 Plus 横 */
	@media (min-width: 540px) and (max-width: 719px) {
	}
	/* モバイル（md）iPad mini 縦 */
	@media (min-width: 720px) and (max-width: 959px) {
	}
	/* タブレット（lg） iPad mini 横 */
	@media (min-width: 960px) and (max-width: 1139px) {
	}
	/* PC（xl） */
	@media (min-width: 1140px) {
	}

	/* モバイル（xs） iPhone6 Plus 縦 */
	@media (max-width: 539px) {
		.nav_area {
			margin: 0;
		}
		nav {
			margin-left: auto;
		}
		nav ul.navbar-nav {
			width: 100%;
		}
		nav ul.navbar-nav li {
			padding: 4px 10px;
			margin: 0 8px;
			border-bottom: solid 1px #ddd;
			text-align: center;
		}
	}


/* スライドショー
------------------------------------- */
.mainimage_area {
	background-image: url(./img/cafe_img2.jpg);
	background-size: cover;
	background-position: center center;
	height: 500px;
	position: relative;
	top: 0;
	left:0;
}
	.mainimage_bg {
		background-color: rgba(255, 255, 255, 0.2);
		height: 100%;
		display: flex;
		justify-content: center;
		align-items: center;
	}
	.mainimage_area .mainimage_text {
		border:solid 1px #fff;
		padding: 30px;
		width: 60%;
		color: #fff;
	}
		.mainimage_area .mainimage_text h2.mainimage_title {
			font-size: 1.7em;
			font-weight: bold;
			padding: 0 0 10px 0;
		}
		.mainimage_area .mainimage_text p {
			font-size: 0.9em;
		}


/* コンテンツ背景(index.php）
------------------------------------- */
section.bg_off {
	margin: 0px auto;
	padding: 60px 0;
}
section.bg_on {
	margin: 0px auto;
	padding: 60px 0;
	background: rgb(247, 247, 247);
}

/* コンセプトとインフォメーション（index.php）
------------------------------------- */
.concept_area {
	padding: 0;
	margin: 0;
}
	.concept_area .concept {
		padding: 10px;
	}
		.concept_area .concept h2 {
			padding: 0 0 10px 0;
			font-size: 1.1em;
			color: #474747;
			/* font-weight: bold;
			font-family: 'M PLUS 1', sans-serif; */
		}
		.concept_area .concept p {
			padding: 0 0 10px 0;
			line-height: 2em;
		}
	.concept_area .information {
		padding: 10px;
	}
		.concept_area .information h2 {
			padding: 0 0 10px 0;
			font-size: 1.1em;
			color: #474747;
			/* font-weight: bold;
			font-family: 'M PLUS 1', sans-serif; */
		}
		.concept_area .information p {
			padding: 0 0 10px 0;
			line-height: 2em;
		}
			.concept_area .information p img.sns {
				width: 26px;
				height: 26px;
				padding: 0 8px 0 0;
				display: inline;
			}

/* 画像のみのコンテンツ（index.php）
------------------------------------- */
.img_bg {
	height: 360px;
	padding: 0;
	margin: 0;
}
	.img_bg img {
		object-fit: cover;
		width: 100%;
		height: 100%;
	}


/* ニュースエリア（index.php）
------------------------------------- */
	.news_area {
		padding: 30px 10px;
		margin: 20px auto;
	}
		.news_area .news_box {
			background: #fff;
			padding: 40px;
		}
			.news_area .news_box dl.news {
				padding: 0px;
				margin: 0 0 8px 0;
				display: flex;
				flex-wrap: wrap;
			}
				.news_area .news_box dl.news dt{
					width: 13%;
					padding-right: 20px;
					padding-bottom: 6px;
					margin-bottom: 10px;
					border-bottom: solid 1px #ddd;
					font-weight: normal;
				}
				.news_area .news_box dl.news dd {
					width: 87%;
					padding-right: 10px;
					padding-bottom: 6px;
					margin-bottom: 10px;
					border-bottom: solid 1px #ddd;
				}
		.news_area .news_box .link_list {
			font-size: 0.9em;
		}
			.news_area .news_box .link_list span.material-icons {
				font-size: 1.3em;
				vertical-align: middle;
			}

			/* モバイル（xs） iPhone6 Plus 縦 */
			@media (max-width: 539px) {
				.news_area .news_box dl.news dt{
					width: 100%;
					font-weight: bold;
					border: none;
					padding:0;
					margin: 0;
				}
				.news_area .news_box dl.news dd {
					width: 100%;
					margin-bottom: 20px;
					padding: 0 0 6px 0;
				}
			}

/* メニューエリア（index.php）
------------------------------------- */
.menu_area {
	padding: 30px 10px;
	margin: 20px auto;
}
	.menu_area .menu {
		padding: 20px 0;
	}
		.menu_area .menu .card {
			padding: 0px;
			border: none;
			border-radius: 0;
			width: 100%;
		}
			.menu_area .menu .card .img_wrap_16x9 {
				position: relative;
				display: inline-block;
				width: 100%;
			}
			.menu_area .menu .card .img_wrap_16x9:before {
				content:"";
				display: block;
				padding-top: 56.25%; /* 高さと幅の比を16:9に固定。9/16*100=56.25 */
			}
			.menu_area .menu .card .img_wrap_16x9 img {
				position: absolute;
				top: 0;
				left: 0;
				bottom: 0;
				right: 0;
				object-fit: cover;
				width:100%;
				height: 100%;
				margin-bottom: 10px;
			}
			.menu_area .menu .card .card-body {
				background: #fff;
				padding: 10px;
			}
				.menu_area .menu .card .card-body h3.card-title {
					font-size: 1em;
					padding: 0 0 10px 0;
					margin: 0;
				}
				.menu_area .menu .card .card-body p.card-text {
					font-size: 0.9em;
					padding: 0 0 10px 0;
					text-align: right;
				}

		/* モバイル（xs） iPhone6 Plus 縦 */
		@media (max-width: 539px) {
			.menu_area .menu .d-flex{
				margin-bottom: 20px;
			}
		}
	.menu_area .menu .link_more {
		text-align: center;
		padding: 40px 10px 20px 10px;
		font-size: 0.9em;
	}
		.menu_area .menu .link_more a {
			display: inline-block;
			padding: 4px 16px 6px 16px;
			border-radius: 4px;
			border: solid 2px #929292;
			color: #616161;
		}
			.menu_area .menu .link_more a span.material-icons {
				font-size: 1.1em;
				vertical-align: middle;
				color: #616161;
			}


/* アクセス紹介エリア（index.php）
------------------------------------- */
.access_area {
	padding: 30px 0;
	margin: 20px auto;
}
	.access_area .access {
		padding: 10px 0;
	}
		/* Google Map */
		.access_area .access .gmap {
			padding: 20px 0;
		}
			.access_area .access .gmap iframe {
				width: 100%;
			}
		/* モバイル（xs） iPhone6 Plus 縦 */
		@media (max-width: 539px) {
			.access_area .access .d-flex {
				padding-bottom: 10px;
			}
		}
		.access_area .access .access_text {
			padding: 30px 10px;
			margin: 0;
			text-align: center;
			font-size: 0.9em;
			line-height: 2em;
		}			
			.access_area .access .access_text span.material-icons {
				font-size: 1.2em;
				vertical-align: middle;
			}			


/* 下層ページ
------------------------------------- */
section.page {
	margin: 0;
	padding: 60px 0;
	font-family: 'Noto Serif JP', serif;
	color: #383535;
}

/* ニュースページ（news.php）
------------------------------------- */
.news_page {
	padding: 20px 0;
	margin: 0;
}
	.news_page .news_list {
		background: #fff;
		padding: 30px 20px 20px 20px;
		margin: 0;
	}
		.news_page .news_list article {
			padding: 10px 10px 30px 10px;
			margin: 0 auto 30px auto;
		}
			.news_page .news_list article h3 {
				border-bottom: solid 1px #ddd;
				font-size: 1.4em;
				font-weight: bold;
				padding: 0 6px 6px 6px;
				margin: 0 0 10px 0;
			}
			.news_page .news_list article .date {
				font-size: 0.9em;
				padding: 0 0 10px 0;
				margin:0;
				text-align: right;
			}
			.news_page .news_list article .news_text {
				padding: 0 10px 10px 10px;
				margin:0;
			}
/* ページナビ */
.page_nav {
	text-align: center;
}
.page_nav a,
.page_nav span {
	display: inline-block;
	margin: 8px 0;
	text-decoration: none;
	border-radius: 100%;
	width: 32px;
	height: 32px;
	padding: 8px 0;
	box-sizing: border-box;
	color: #333;
	font-weight: bold;
	line-height: 1;
}
.page_nav a:hover {
	opacity: 0.7;
}
.page_nav .current {
	background: #ffc33c;
	color: #FFF;
}
@media screen and (max-width: 767px) {
	.page_nav a,
	.page_nav span {
		margin: 2px 0;
		width: 28px;
		height: 28px;
		padding: 6px 0;
	}
}

/* メニューページ（menu.php）
------------------------------------- */
.menu_page {
	padding: 20px 0;
	margin: 0;
}
	.menu_page .menu_nav {
		padding: 0 0 20px 0;
		margin: 0;
	}
	.menu_page ul {
		padding: 6px 10px;
		margin: 0 auto 30px auto;
		text-align: center;
		background: #f2f2f2;
	}
		.menu_page ul li {
			padding: 10px 20px 10px 20px;
			margin: 0;
			display: inline-block;
			font-size: 1.2em;
		}
			.menu_page ul li span.material-icons {
				font-size: 1em;
				vertical-align: middle;
			}
			.menu_page ul li a {
				color: #333;
			}
	.menu_page h3.menu_cat {
		padding: 0 10px 10px 10px;
		margin: 0;
		font-family: 'M PLUS 1', sans-serif;
		text-align: center;
		font-size: 1.7em;
		color: #2b1616;
	}
	.menu_page .menu_area {
		background: #ccc;
		padding: 30px 20px 20px 20px;
		margin: 0;
	}
	.menu_page .menu_info {
		font-size: 0.9em;
		text-align: center;
		color: #666;
		padding: 10px 0 0 0;
	}
		.menu_page .menu_area .d-flex {
			margin-bottom: 30px;
		}
		.menu_page .menu_area .card {
			padding: 10px;
			border: none;
			width: 100%;
		}
			.menu_page .menu_area .card .img_wrap_16x9 {
				position: relative;
				display: inline-block;
				width: 100%;
			}
			.menu_page .menu_area .card .img_wrap_16x9:before {
				content:"";
				display: block;
				padding-top: 56.25%; /* 高さと幅の比を16:9に固定。9/16*100=56.25 */
			}
			.menu_page .menu_area .card .img_wrap_16x9 img {
				position: absolute;
				top: 0;
				left: 0;
				bottom: 0;
				right: 0;
				object-fit: cover;
				width:100%;
				height: 100%;
				margin-bottom: 10px;
			}
			.menu_page .menu_area .card .card-body {
				background: #fff;
				padding: 10px;
			}
				.menu_page .menu_area .card .card-body h3.card-title {
					font-size: 1em;
					padding: 0 0 10px 0;
					margin: 0;
				}
				.menu_page .menu_area .card .card-body p.card-text {
					font-size: 0.9em;
					padding: 0 0 10px 0;
					text-align: right;
				}
		/* モバイル（xs） iPhone6 Plus 縦 */
		@media (max-width: 539px) {
			.menu_page .menu_area .d-flex{
				margin-bottom: 20px;
			}
		}

	/* メニューリスト表示の場合 */
	.menu_page h3.menu_cat_list {
		padding: 0 10px 4px 10px;
		margin: 0 auto 20px auto;
		font-size: 1.7em;
		color: #2b1616;
		border-bottom: solid 1px #ddd;
	}
	.menu_page .menu_area .menu_description {
		margin: 10px;
		padding: 10px;
		background: #f8f8f8;
		font-size: 0.9em;
		line-height: 1.8em;
	}
	.menu_page .menu_area img.menu_img {
		margin: 10px auto;
		padding: 0 10px;
	}
	.menu_page .menu_area table.menu_list {
		font-family: 'M PLUS 1', sans-serif;
		padding: 0 10px;
		margin: 10px 0;
		width: 100%;
	}
		.menu_page .menu_area table.menu_list tr {
			padding:0;
			margin:0;
		}
			.menu_page .menu_area table.menu_list tr td {
				padding: 0px 10px 10px 10px;
				margin:0;
				font-size: 0.9em;
			}
			.menu_page .menu_area table.menu_list tr td.price {
				text-align: right;
			}


/* カスタム下層ページ（page.php）
------------------------------------- */
.custom_page {
	padding: 20px 0;
	margin: 0;
}
	.custom_page .custom_area {
		border-top: solid 1px #ddd;
		border-bottom: solid 1px #ddd;
		padding: 30px 20px 20px 20px;
		margin: 0;
	}
		.custom_page .custom_area .page_detail {
			padding: 10px;
		}
			.custom_page .custom_area .page_detail h3 {
				font-size: 1.2em;
				padding: 0 0 10px 0;
				margin: 0;
				font-weight: bold;
			}
			.custom_page .custom_area .page_detail h4,
			.custom_page .custom_area .page_detail h5 {
				font-size: 1em;
				padding: 0 0 10px 0;
				margin: 0;
				font-weight: bold;
			}
			.custom_page .custom_area .page_detail p {
				padding: 0 0 20px 0;
			}
			
			/* テーブル */
			.custom_page .custom_area .page_detail table {
				padding: 0;
				margin: 0 auto 20px auto;
				width: 100%;
				border: solid 2px #ddd;
				font-size: 0.9em;
				font-family: 'M PLUS 1', sans-serif;

			}
				.custom_page .custom_area .page_detail table tr {
					padding: 0;
					margin: 0;
				}
					.custom_page .custom_area .page_detail table tr th {
						padding: 6px 12px;
						margin: 0;
						border: solid 1px #ddd;
						background: #ebebeb;
						color: #332405;
					}
					.custom_page .custom_area .page_detail table tr td {
						padding: 6px 12px;
						margin: 0;
						border: solid 1px #ddd;
					}


/* メニューページ（menu.php）
------------------------------------- */
.menu_page {
	padding: 20px 0;
	margin: 0;
}
	.menu_page .menu_area {
		padding: 30px;
		margin: 0;
		background: #fff;
	}
		.menu_page .menu_area .menu_box {
			padding: 20px 0;
			margin: 0;
		}
			.menu_page .menu_area .menu_box h3 {
				padding: 0 0 6px 0;
				margin: 0 0 10px 0;
				font-size: 1.4em;
				font-weight: bold;
				color: #e46188;
				font-family: 'Noto Serif JP', serif;
				font-style: italic;
				border-bottom: solid 2px #e46188;
			}
			.menu_page .menu_area .menu_box .menu_info {
				padding: 0;
				margin: 0;
				font-size: 0.9em;
				text-align: right;
			}
			.menu_page .menu_area .menu_box table.price {
				padding: 0;
				margin: 0 0 20px 0;
				width: 100%;
			}
				.menu_page .menu_area .menu_box table.price tr {
					padding: 0;
					margin: 0;
					border-bottom: solid 1px #ddd;
				}
					.menu_page .menu_area .menu_box table.price tr th {
						padding: 6px;
						margin: 0;
						font-weight: normal;
					}
					.menu_page .menu_area .menu_box table.price tr td {
						padding: 6px;
						margin: 0;
						text-align: right;
					}

/* お問い合わせページ（contact.php）
------------------------------------- */
.contact_area {
	background: #fff;
	padding: 40px;
	margin: 20px auto;
}
	.page_attention {
		padding: 18px;
		margin-bottom: 20px;
		background: #eee;
	}
	.form_area {
		padding: 10px 0;
	}
		.form_area .form-group {
			padding: 10px 0;
			margin-bottom: 20px;
		}
			.form_area .form-group label {
				padding: 4px 8px;
				margin-bottom: 10px;
				border-left: solid 5px #eee;
			}
		.form_area .btn_area {
			padding: 10px 0;
			text-align: center;
		}
		.form_area .btn_area .btn-primary {
			background: #217a9c;
			padding: 10px 20px;
			font-size: 0.9em;
		}

/* フッター
------------------------------------- */
footer {
	font-family: 'Noto Serif JP', serif;
	color: #333;
	background: #F2F2F2;
}
	footer .footer_info	{
		padding: 20px 0;
	}
		footer .footer_info	.shopname{
			padding: 0 0 10px 0;
			font-size: 1.3em;
			font-style: italic;
		}
		footer .footer_info	.access{
			padding: 8px 0;
			font-size: 0.7em;
			line-height: 2em;
		}
		footer .footer_info	.copyright{
			padding: 8px 0;
			text-align: right;
			font-size: 0.8em;
		}

	footer .page_up {
		background: #fff;
		padding: 10px;
		text-align: center;
		font-size: 0.9em;
	}
		footer .page_up a {
			color: #333;
		}
		footer .page_up span.material-icons {
			font-size: 0.9em;
		}


/* レスポンシブ 
----------------------------------------------- */
/* スマホ非表示 */
@media only screen and (max-width:480px){
}
/* モバイル（xs） iPhone6 Plus 縦 */
@media (max-width: 539px) {
	.news_area dl.news {
		flex-flow: column;
	}
		.news_area dl.news dt{
			width: 100%;
			padding: 6px 12px;
			margin: 0;
		}
		.news_area dl.news dd{
			width: 100%;
			padding: 6px 12px;
			margin: 0 0 10px 0;
		}
}
/* モバイル（sm） iPhone6 Plus 横 */
@media (min-width: 540px) and (max-width: 719px) {
}
/* モバイル（md）iPad mini 縦 */
@media (min-width: 720px) and (max-width: 959px) {
}
/* タブレット（lg） iPad mini 横 */
@media (min-width: 960px) and (max-width: 1139px) {
}
/* PC（xl） */
@media (min-width: 1140px) {
}

/* 
------------------------------------- */
/* 
------------------------------------- */
