@charset "utf-8";
/*----------------------------------------------------------------------------------------------------------
	スマホ用（～768px）　　HOME【トップページ】のスタイルシート
------------------------------------------------------------------------------------------------------------*/
/*メインイメージ（スマホ）
*************************************************/
#mainImg{}
/*左…写真*/
#mainImg_left{
	width: 100%;
	aspect-ratio: 12 / 7;
	position: relative;
	margin-bottom: 1%;
	/*border-bottom: 2px dotted #000;*//*仮*/
}
#mainImg_left::before{
	position: absolute;
	content: '';
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: url("../image/home/mainImg_frame01.png")no-repeat 0 0;
	background-size: cover;
	z-index: 1;
	border-bottom: 1px solid #fff;
}
#mainImg_left::after{
	position: absolute;
	content: '';
	bottom: -11%;
	left: 0;
	width: 100%;
	height: 27%;
	z-index: 1;
	background-image: url("../image/home/img_vegetableBox01.png"), url("../image/home/img_tomato02.png");
	background-size: 48%, 13%;
	background-repeat: no-repeat, no-repeat;
	background-position: -5% 100%, 99% 0%;
	/*background-color: rgba(0,0,0,0.2);*//*仮*/
}
/*画像横スクロール*/
@keyframes infinity-scroll-left {
from {
	transform: translateX(0);
}
	to {
	transform: translateX(-100%);
}
}
.scroll-infinity-M{}
.scroll-infinity-M__wrap {
	display: flex;
	overflow: hidden;
}
.scroll-infinity-M ul {
	display: flex;
	list-style: none;
	padding: 0;
	animation: infinity-scroll-left 80s infinite linear 0.5s both;
}
.scroll-infinity-M ul li{
	width: calc(100vw / 4);
}
.scroll-infinity-M ul li>img {
	width: 100%;
}
/*右…スローガン*/
#mainImg_right{
	width: 100%;
	aspect-ratio: 11 / 6;
	background: url("../image/home/img_vegetables01.png") no-repeat center bottom;
	background-size: 135%;
	padding: 10% 0 0 0;
	/*border-bottom: 1px dotted #000;*//*仮*/
}
img.img_slogan01_sp{
	display: block;
	width: 58%;
	margin: 0 auto;
}
img.img_slogan01_pc{display: none;}

/*ピックアップ背景（スマホ）
*************************************************/
#contents_home01{
	overflow: hidden;
}
#area_home_pickup01{
	/*border: 1px dotted #ccc;*//*仮線*/
	position: relative;
	background-image: url("../image/home/bg_home_pickup01.png");
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center center;
	padding: 55px 0 70px 0;
	margin: 0 0 100px 0;
}
#area_home_pickup01::before{
	position: absolute;
	content: '';
	z-index: 2;
	left: 0;
	top: -25px;
	width: 100%;
	height: 45px;
	background: url("../image/home/img_edamame02.png") no-repeat 25% 0%;
	background-size: 58px;
	/*background-color: rgba(0,0,0,0.15);*//*仮*/
}
#area_home_pickup01::after{
	/*border: 1px dotted #000;*//*仮線*/
	position: absolute;
	content: '';
	left: 0;
	bottom: -80px;
	width: 100%;
	height: 140px;
	background-image:
		url("../image/home/img_strawberry01.png"),
		url("../image/home/img_lemon01.png"),
		url("../image/home/img_lemon02.png");
	background-size: 100px, 60px, 120px;
	background-repeat: no-repeat, no-repeat, no-repeat;
	background-position: calc(50% - 180px) 0%, calc(50% + 30px) 40%, calc(50% + 190px) 90%
}
/*新着（スマホ）
*************************************************/
#area_home_news01,
#area_home_business01{
	position: relative;
	max-width: 540px;
	background: #fff;
	box-shadow: 7px 7px 0px #1255a3;
	border-radius: 25px;
	padding: 20px 20px 35px 20px;
	margin: 0 auto 2.65rem auto;
}
.h2_home_news01,
.h2_home_business01{
	position: absolute;
	top: -12px;
	left: -10px;
	width: 95px;
	height: 95px;
	z-index: 2;
}
#area_home_news01 .title{
	text-align: center;
	font-size: 1.13rem;
	font-weight: bolder;
	padding: 0 0 0 20px;
	margin-bottom: 0.75rem;
}
#area_home_news01 .picture{
	margin-bottom: 1rem;
}
#area_home_news01 .picture img{
	aspect-ratio: 2 / 1;
	object-fit: cover;
	border-radius: 10px;
}
#area_home_news01 .data{
	color: #808080;
	font-weight: bolder;
	margin-bottom: 0.5rem;
}
#area_home_news01 .text{
	font-size: 0.88rem;
	line-height: 175%;
	height: 70px;
	overflow-y: hidden;
	margin-bottom: 1.50rem;
}
/*事業について（スマホ）
*************************************************/
#area_home_business01{
	margin: 0 auto 3rem auto;
}
.slider_business01{
	width:100%;
}
.slider_business01 .item img{
	border-radius: 10px;
}
#area_home_business01 .text{
	font-size: 0.88rem;
	line-height: 175%;
	margin-bottom: 1.50rem;
}
/*おすすめ商品（スマホ）
*************************************************/
#area_home_products01{}
.h2_home_products01{
	text-align: center;
	margin: 0 0 1rem 0;
	background-image: url("../image/common/img_effect02_01.png"), url("../image/common/img_effect02_02.png");
	background-size: 20px, 20px;
	background-repeat: no-repeat, no-repeat;
	background-position: calc(50% - 130px) 0%, calc(50% + 135px) 0%;
}
.h2_home_products01 .shun{
	display: block;
	margin: 0 0 5px 0;
}
.h2_home_products01 .shun img{
	width: 230px;
}
.h2_home_products01 .month{
	font-size: 0.88rem;
	color: #fff;
	background: #449633;
	padding: 4px 22px;
	border-radius: 12px;
}
/*リスト*/
.ul_home_products01{
	max-width: 540px;
	margin: 0 auto 2rem auto;
}
.ul_home_products01 li{
	background: #fff;
	box-shadow: 7px 7px 0px #449633;
	border-radius: 20px;
	padding: 16px 16px 20px 16px;
	margin: 0 0 1.5rem 0;
	display: flex;
	flex-flow: row wrap;
	justify-content: space-between;
}
.ul_home_products01 li .picture{
	width: 110px;
}
.ul_home_products01 li .picture img{
	aspect-ratio: 1 / 1;
	object-fit: cover;
	border-radius: 10px;
}
.ul_home_products01 li .text{
	width: calc(100% - 126px);
}
.ul_home_products01 li .name{
	font-size: 1rem;
	font-weight: bolder;
	background: url("../image/common/img_line01.png") no-repeat 0% 100%;
	background-size: 51px;
	padding: 0 0 12px 0;
	margin: 0 0 8px 0;
}
.ul_home_products01 li .info{
	font-size: 0.88rem;
	line-height: 175%;
}
/*リンク*/
#area_home_products01 .btn_com03{
	margin-bottom: 10px;
}
/*営業日カレンダー（スマホ）
*************************************************/
#area_home_calender01{
	position: relative;
	background: #f8e9e4;
	border: solid 5px #eec8bd;
	border-radius: 25px;
	padding: 32px 20px 20px 20px;
	margin: 0 0 4rem 0;
}
h2.h2_home_calender01{
	position: absolute;
	top: -16px;
	left: 0;
	width: 100%;
	height: 40px;
	text-align: center;
}
h2.h2_home_calender01 img{
	width: 250px;
}
/*カレンダー*/
.box_calendar01{
	margin: 0 0 1.5rem 0;
}
.box_calendar01_in{
	width: 100%;
	max-width: 310px;
	background: #fff;
	border-radius: 10px;
	padding: 1rem 1rem;
	margin: 0 auto 1rem auto;
}
table.table_calendar01{
	width: 100%;
	border-collapse: collapse;
	margin: 0;
}
table.table_calendar01 caption{
	color: #1255a3;
	font-weight: bolder;
	font-size: 1.06rem;
	margin-bottom: 4px;
}
table.table_calendar01 th,
table.table_calendar01 td {
	border: 1px solid #b3b3b3;
	text-align: center;
	padding: 7px 5px;
	font-size: 0.94rem;
}
table.table_calendar01 th{
	padding: 3px 5px;
	font-size: 0.88rem;
	background: #dfecf9;
}
table.table_calendar01 th.sun{
	color: #e53223;
}
table.table_calendar01 td.off{
	background: #ff989c;
}
/*テキスト部分*/
.box_calendar02{
	margin: 0 0 1rem 0;
}
.p_bizHours{
	font-weight: bolder;
}
.p_bizHours span{
	font-weight: normal;
	color: #fff;
	background: #1255a3;
	border-radius: 5px;
	padding: 5px 10px;
	margin: 0 8px 0 0;
}
.p_closedDays{
	font-size: 1rem;
}
.p_closedDays span{
	background: #ff989c;
	color: #ff989c;
	padding: 5px 5px;
}
/*営業日カレンダー詳細ページ*/
.box_calendar04{
	text-align: center;
	margin: 0 auto 1.5rem auto;
}
.box_calendar05{
	display: flex;
	flex-flow: row wrap;
}
.box_calendar05_in{
	width: 100%;
	max-width: 310px;
	padding: 1rem 1rem;
	margin: 0 auto 1rem auto;
}


/*アクセス（スマホ）
*************************************************/
#area_home_access01{
	position: relative;
	background: #dfecf9 url("../image/home/bg_home_access01.png") no-repeat 100% 100%;
	background-size: 320px;
	margin: 0 0 4rem 0;
	padding: 50px 0 125px 0;
}
.h2_home_access01{
	position: absolute;
	top: -13px;
	left: 0;
	width: 100%;
	height: 60px;
	text-align: center;
	font-family: "Open Sans", sans-serif;
	font-weight: 800;
	font-size: 2rem;
	text-shadow: 3px 2px 0px #fff;
}
.h2_home_access02{
	display: none;
	text-align: center;
	font-family: "Open Sans", sans-serif;
	font-weight: 800;
	font-size: 2rem;
	text-shadow: 3px 2px 0px #fff;
	margin: 0 0 1rem 0;
}
.h2_home_access01::first-letter,
.h2_home_access02::first-letter{
	color: #1255a3;
}
.h2_home_access01 span,
.h2_home_access02 span{
	display: block;
}
.h2_home_access01 span img,
.h2_home_access02 span img{
	width: 72px;
}
.h3_home_access01{
	color: #00489c;
	font-size: 1rem;
	font-weight: bolder;
	text-shadow: 2px 1px 0px #fff;
	margin: 0 0 0.25rem 0;
}
.googlemap_home01{
	margin: 0 0 1.5rem 0;
}
.googlemap_home01 iframe{
	width: 100%;
	height: 400px;
	border: none;
	border-radius: 20px;
	box-shadow: 7px 7px 0px #1255a3;
}
#area_home_access01 .box_add01{
	background: rgba(255,255,255,0.75);
	border-radius: 10px;
	padding: 12px 12px;
	font-size: 0.88rem;
	max-width: 500px;
}







/*-------------------------------------------------------------------------------------------------------------------------------
	大スマホ用（550px～）
---------------------------------------------------------------------------------------------------------------------------------*/
@media print, screen and (min-width:550px){

/*右…スローガン*/
#mainImg_right{
	width: 100%;
	height: 350px;
	background: url("../image/home/img_vegetables01.png") no-repeat center bottom;
	background-size: 780px;
	padding: 60px 0 0 0;
}
img.img_slogan01_sp{
	width: 345px;
}
/********/









/*-------------------------------------------------------------------------------------------------------------------------------
	タブレット用（768px～）
---------------------------------------------------------------------------------------------------------------------------------*/
@media print, screen and (min-width:768px){

/*メインイメージ（タブレット）
*************************************************/
#mainImg{
	display: flex;
	flex-flow: row wrap;
	margin-bottom: 8%;
}
/*左…写真*/
#mainImg_left{
	width: 83%;
	margin-bottom: 0;
}
#mainImg_left::after{
	bottom: inherit;
	top: 0;
	left: 0;
	width: 102%;
	height: 116%;
	background-image:
		url("../image/home/img_edamame01.png"),
		url("../image/home/img_tomato02.png"),
		url("../image/home/img_tomato01.png"),
		url("../image/home/img_vegetableBox01.png");
	background-size: 8%, 11%, 4.5%, 48%;
	background-repeat: no-repeat, no-repeat, no-repeat, no-repeat;
	background-position: 100% 0%, 99% 80%, 90% 95%, -5% 100%;
	/*background-color: rgba(0,0,0,0.1);*//*仮*/
}
/*画像横スクロール*/
.scroll-infinity-M ul li{
	width: calc(83vw / 4);
}
/*右…スローガン*/
#mainImg_right{
	width: 17%;
	height: auto;
	background: none;
	padding: 0;
	position: relative;
}
#mainImg_right::after{
	position: absolute;
	content: '';
	top: 0;
	left: 0;
	width: 100%;
	height: 116%;
	z-index: 1;
	background: url("../image/home/img_radish01.png") no-repeat 0% 100%;
	background-size: 120%;
	/*background-color: rgba(0,0,0,0.30);*//*仮*/
}
img.img_slogan01_sp{
	display: none;
}
img.img_slogan01_pc{
	display: block;
	width: 80%;
	margin: 10% auto 0 auto;
}
/*ピックアップ背景（タブレット）
*************************************************/
#area_home_pickup01{
	padding: 75px 0 70px 0;
}
#area_home_pickup01::before{
	top: -40px;
	height: 110px;
	background-image:
		url("../image/home/img_edamame02.png"),
		url("../image/home/img_lotusRoot01.png"),
		url("../image/home/img_lettuce02.png");
	background-size: 58px, 100px, 134px;
	background-repeat: no-repeat, no-repeat, no-repeat;
	background-position: 20% 75%, 58% 0%, right -30px top 0px
}
#area_home_pickup01::after{
	background-size: 100px, 75px, 160px;
	background-position: calc(50% - 300px) 0%, calc(45% + 30px) 35%, right -30px top 90%
}
#area_home_pickup01 .inner_L{
	display: flex;
	flex-flow: row wrap;
	/*border: 1px dotted #0000ff;*//*仮線*/
}
.wrap_pickup_left{
	width: 47%;
	margin: 0 5% 0 0;
	/*border: 1px dotted #FF0004;*//*仮線*/
}
.wrap_pickup_right{
	width: 48%;
	/*border: 1px dotted #000;*//*仮線*/
}
/*営業日カレンダー（タブレット）
*************************************************/
#area_home_calender01{
	padding: 32px 20px 20px 20px;
	display: flex;
	flex-flow: row-reverse wrap;
	position: relative;
}
#area_home_calender01::after{
	position: absolute;
	content: '';
	width: 200px;
	height: 250px;
	left: 10%;
	bottom: -15px;
	background: url("../image/home/img_carrot01.png") no-repeat 0 0;
	background-size: 200px;
}
.box_calendar01{
	width: 330px;
	margin: 0;
	/*background: #ccc;*//*仮*/
}
.box_calendar02{
	width: calc(100% - 350px);
	margin: 0 20px 1rem 0;
}
.box_calendar02 .btn_com01{
	margin: 0 auto 0 0;/*左寄せ*/
}
/*アクセス（タブレット）
*************************************************/
#area_home_access01{
	padding: 0 0 40px 0;
	margin: 0 0 5rem 0;
	background: none;
}
#area_home_access01::before{
	position: absolute;
	content: '';
	right: -10%;
	bottom: -20px;
	width: 100%;
	height: 100%;
	z-index: -1;
	background: #dfecf9 url("../image/home/bg_home_access01.png") no-repeat 90% 100%;
	background-size: 320px;
	border-radius: 0 0 0 30px;
}
#area_home_access01 .inner_L{
	display: flex;
	flex-flow: row wrap;
}
.googlemap_home01{
	width: 54%;
	margin: 0 6% 0 0;
}
.googlemap_home01 iframe{
	height: 500px;
}
.wrap_access01{
	width: 40%;
	padding: 4px 0 0 0;
}
.h2_home_access01{display: none;}
.h2_home_access02{display: block;}
/********/
}












/*-------------------------------------------------------------------------------------------------------------------------------
	PC用（1100px～）
---------------------------------------------------------------------------------------------------------------------------------*/
@media screen and (min-width: 1100px){

/*メインイメージ（PC）
*************************************************/
#mainImg{
}
/*ピックアップ背景（PC）
*************************************************/
#area_home_pickup01{
	background-image: url("../image/home/img_orange01.png"),url("../image/home/bg_home_pickup01.png");
	background-size: 165px, cover;
	background-repeat: 165px, no-repeat;
	background-position: calc(50% - 250px) 95%, center center;
	padding: 150px 0 150px 0;
	margin: 0 0 70px 0;
}
#area_home_pickup01::before{
	top: -50px;
	height: 190px;
	background-size: 105px, 180px, 220px;
	background-position: 20% 60%, 58% 0%, right -10% top 0%;
}
#area_home_pickup01::after{
	bottom: -75px;
	height: 220px;
	background-size: 160px, 115px, 250px;
	background-position: calc(50% - 550px) 0%, calc(50% + 250px) 40%, calc(50% + 650px) 100%
}
/*新着（スマホ）
*************************************************/
#area_home_news01{
	width: 96%;
	border-radius: 50px;
	padding: 2rem 2rem 2.5rem 2rem;
	margin: 0 0 4rem 0;
}
.h2_home_news01,
.h2_home_business01{
	top: -20px;
	left: -14px;
	width: 148px;
	height: 50px;
}
#area_home_news01 .title{
	font-size: 1.5rem;
	margin-bottom: 1rem;
}
#area_home_news01 .text{
	font-size: 0.94rem;
	line-height: 175%;
	height: 80px;
}
/*事業について（PC）
*************************************************/
#area_home_business01{
	width: 96%;
	border-radius: 50px;
	padding: 2.25rem 2rem 2.5rem 2rem;
	margin: 0 0 0 4%;
}
#area_home_business01 .text{
	font-size: 0.94rem;
	line-height: 175%;
}
/*おすすめ商品（PC）
*************************************************/
#area_home_products01{}
.h2_home_products01{
	/*margin: 0 0 1rem 0;*/
	background-size: 24px, 24px;
	background-position: calc(50% - 220px) 2px, calc(50% + 220px) 2px;
}
.h2_home_products01 .shun{
	display: inline;
	margin: 0;
}
.h2_home_products01 .shun img{
	width: 310px;
	vertical-align: middle;
}
.h2_home_products01 .month{
	font-size: 1.06rem;
	padding: 6px 12px;
	border-radius: 15px;
}
/*リスト*/
.ul_home_products01{
	margin: 0 auto 2.5rem auto;
}
.ul_home_products01 li{
	border-radius: 30px;
	padding: 30px 30px 30px 30px;
	margin: 0 0 2rem 0;
}
.ul_home_products01 li .picture{
	width: 200px;
}
.ul_home_products01 li .text{
	width: calc(100% - 224px);
}
.ul_home_products01 li .name{
	font-size: 1.19rem;
	margin: 0 0 12px 0;
}
.ul_home_products01 li .info{
	font-size: 1rem;
	line-height: 175%;
}
/*リンク*/
#area_home_products01 .btn_com03{
	width: 53%;
	margin: 0 0 0 2%;
	float: left;
}
#area_home_products01 .btn_com02{
	width: 41%;
	margin: 0 2% 0 0;
	float: right;
}
/*営業日カレンダー（PC）
*************************************************/
#area_home_calender01{
	border: solid 8px #eec8bd;
	border-radius: 50px;
	padding: 2.5rem 1.5rem 1.5rem 2.5rem;
	margin: 0 0 100px 0;
}
#area_home_calender01::after{
	left: inherit;
	right: -170px;
	bottom: -80px;
}
h2.h2_home_calender01{
	top: -25px;
	height: 45px;
}
h2.h2_home_calender01 img{
	width: 320px;
}
.box_calendar01{
	width: 650px;
}
.box_calendar02{
	width: calc(100% - 680px);
	margin: 0 30px 1rem 0;
}
.box_calendar01_in{
	margin: 0 14px 0 0;
	float: left;
}
/*アクセス（PC）
*************************************************/
#area_home_access01{
	padding: 0 0 30px 0;
	margin: 0 0 150px 0;
}
#area_home_access01::before{
	right: -20%;
	bottom: -30px;
	background: #dfecf9 url("../image/home/bg_home_access01.png") no-repeat 80% 100%;
	background-size: 540px;
	border-radius: 0 0 0 50px;
}
.googlemap_home01 iframe{
	height: 600px;
	border-radius: 30px;
}
.wrap_access01{
	padding: 12px 0 0 0;
}
.h2_home_access02{
	font-size: 2.63rem;
	margin: 0 0 1.50rem 0;
}
.h2_home_access02 span{
	margin: 10px 0 0 0;
}
.h2_home_access02 span img{
	width: 96px;
}
.h3_home_access01{font-size: 1.06rem;}
#area_home_access01 .box_add01{
	padding: 12px 16px;
}
/********/
}








/*-------------------------------------------------------------------------------------------------------------------------------
	大PC用（1750px～）
---------------------------------------------------------------------------------------------------------------------------------*/
@media screen and (min-width: 1750px){
#area_home_pickup01{
	background-image: url("../image/home/img_orange01.png"),url("../image/home/bg_home_pickup01.png");
	background-size: 165px, 1700px;
}
#area_home_pickup01::before{
	background-position: 20% 60%, 58% 0%, right -5% top 0%;
}
#area_home_access01::before{
	right: -22%;
}
/********/
}
}