@charset "UTF-8";

/* ================================
smartphone-size:style.css（~480px)
tablet-size:(~768px)
pc-size:(768px～)
================================ */


/* =============================================================
画面幅480px以上の記述
============================================================= */
@media screen and (min-width: 480px){

	.about_content h3 {
		width: 120px;
		height: 50px;
		line-height: 30px;
		padding: 15px 15px 20px 15px;
	}

	.menu_content .menu_item h3:before {
		top: -5px;
		height: 28px;
	}

	#js_spNav {
		padding-top: 180px;
	}

	.js_menuTab ul li a {
		height: 50px;
		line-height: 50px;
	}

	.js_menuTab #tab_contents .menuArea {
		padding: 50px 80px;
	}

}

/* =============================================================
画面幅768px以上の記述
============================================================= */
@media screen and (min-width: 768px){

	h2 {
		font-size: 24px;
	}

	.main_visual img {
		width: 100%;
		height: calc(80vw / 16 * 9);
	}

	.main_visual-desc p {
		font-size: 24px;
	}

	.pc_wrap {
		max-width: 980px;
		width: 100%;
		margin: 0 auto;
	}

	/* ハンバーガーメニューを非表示 */
	#js_toggle {
		display: none;
	}

	header {
		height: 80px;
	}

	.header_wrap {
		margin: 0 auto;
		display: flex;
		justify-content: space-between;
	}

	header h1 a {
		width: 100px;
		height: 80px;
	}

	.pcNav {
		display: block;
		display: flex;
	}

	.pcNav_gNav {
		display: flex;
		align-items: center;
		margin-right: 20px;
	}

	.pcNav_gNav li:first-of-type {
		margin-right: 10px;
	}

	.pcNav_gNav li:nth-child(2) {
		margin-right: 20px;
	}

	.pcNav_gNav li a {
		display: block;
		width: 75px;
		height: 80px;
		text-align: center;
		line-height: 75px;
		padding: 5px;
	}

	.pcNav_gNav li:first-of-type a {
		text-transform: uppercase;
	}

	.pcNav_icon {
		display: flex;
		align-items: center;
	}

	.pcNav_icon li {
		width: 44px;
	}

	.main_wrap {
		margin: 0 10px;
	}

	main {
		margin-top: 150px;
	}

	main section h2 {
		margin-bottom: 60px;
	}

	.about_content {
		width: 680px;
		margin-top: 0;
	}

	.about_content:nth-of-type(2) {
		flex-direction: column;
	}

	.about_content .content_wrap {
		display: flex;
		flex-direction: row-reverse;
		justify-content: space-between;
	}

	.about_content h3 {
		writing-mode: horizontal-tb;
		height: 45px;
		line-height: 35px;
		text-align: center;
		margin-right: 0;
		padding: 10px 0 0 0;
	}

	.about_content img {
		margin-bottom: 20px;
	}

	.menu_osusume h2 {
		margin-bottom: 150px;
	}

	.menu_osusume .osusume_left,
	.menu_osusume .osusume_right {
		width: 670px;
		display: flex;
		align-items: center;
		justify-content: flex-start;
		margin-top: -50px;
	}

	.menu_osusume figure img {
		width: 440px;
	}


	.menu_osusume .osusume_right {
		flex-direction: row-reverse;
	}

	.menu_osusume .osusume_left .menu_group {
		padding-left: 50px;
	}

	.menu_osusume .osusume_right .menu_group {
		padding-right: 50px;
	}

	.menu_osusume .osusume_left .menu_group::after {
		width: 400px;
		height: 5px;
		top: 26px;
		right: 0;
		z-index: -1;
	}

	.menu_osusume .osusume_right .menu_group::after {
		width: 400px;
		height: 5px;
		top: 26px;
		left: -5px;
		z-index: -1;
	}


	.menuSec_wrap {
		display: flex;
		flex-wrap: nowrap;
		justify-content: space-around;
		column-gap: 30px;
	}

	.menu_content {
		margin-top: 0;
	}

	.menu_content figcaption {
		margin-top: 15px;
	}

	.menu_tanpin .leftBox h3 {
		margin-top: 0;
	}

	.menu_tanpin .rightBox h3:first-of-type {
		margin-top: 0;
	}

	.menu_tanpin .flexBox {
		width: 740px;
		margin: 0 auto;
		display: flex;
		justify-content: space-between;
	}

	.moreBtn {
		width: 260px;
		height: 60px;
		border-radius: 30px;
		line-height: 20px;
		padding: 22px 0 18px;
		margin-top: 40px;
	}

	.infoSec_wrap {
		display: flex;
		justify-content: space-between;
		width: 680px;
	}

	.infoSec_wrap ul {
		margin: 0;
	}

	footer {
		height: 120px;
		padding-top: 16px;
	}

	.footer_wrap {
		max-width: 980px;
		margin: 0 auto;
		padding-left: 30px;
		padding-right: 30px;
	}

	.footer_infoGroup {
		display: flex;
	}

	.footer_logo {
		width: 100px;
	}

	.footer_shopInfo {
		display: block;
		font-size: 14px;
		margin-right: 40px;
	}

	.footer_shopInfo li {
		display: flex;
	}

	.footer_shopInfo li p {
		color: #ffffff;
	}

	.footer_shopInfo li .head {
		width: 80px;
		text-align: justify;
		text-align-last: justify;
		margin-right: 16px;
	}

	.footer_copy2 {
		display: block;
		color: #ffffff;
		margin-top: 25px;
	}

	.menu_main {
		margin-top: 100px;
	}

	.js_menuTab {
		width: 630px;
		margin: 30px auto 80px;
	}

	.js_menuTab #tab_contents .menuList_wrap  {
		display: flex;
		justify-content: space-between;
	}

	.js_menuTab #tab_contents .menuList li {
		width: 200px;
	}

	.js_menuTab #tab_contents .menuList_small li {
		width: 200px;
	}

}