@charset "UTF-8";
/****************************************
　　コラム　共通
****************************************/
.contentInner {
	color: #231815;
}
/*titleの<br>タグ除去*/
.title a > br:not(#columnList .title a > br),
.title > br:not(#columnList .title > br) {
	display: none;
}
footer {
	padding-top: 9em;
}
@media (min-width: 768px) {
	footer {
		padding-top: 145px;
	}
}
/*tagList
-----------------------------*/
.tagList {
	display: flex;
	flex-wrap: wrap;
}
.tagList li {
	margin-right: 0.5em;
	margin-top: 0.5em;
}
.tagList li a {
	line-height: 1;
	font-weight: 500;
	font-size: 10px;
	border-radius: 2em;
	padding: 0.5em 0.7em;
	background-color: #e6e6e6;
	position: relative;
	display: inline-block;
}
.tagList li:last-child {
	margin-right: 0em;
}
.tagList li a::before {
	content: "#";
	display: inline-block;
	margin-right: 0.2em;
}
@media (min-width: 768px) {
	.tagList li a {
		font-size: initial;
	}
}
/*角丸+影付き画像
-----------------------------*/
article figure img,
.rankingList figure img {
	border-radius: min(2.8vw, 28px);
	box-shadow: 5px 5px 5px rgba(91, 90, 90, 0.2);
	/*box-shadow: 5px 5px 5px rgba(124, 123, 123, 0.3);*/
	width: 100%;
	max-width: 380px;
}
/*---------------------------------------
　PICK UP／おすすめ スライド
---------------------------------------*/
#pickup {
	text-align: center;
	background-color: #d4dcc6;
	padding: 30px 0;
}
#pickup h2 {
	font-size: min(4.5vw, 20px);
	line-height: 1;
	font-weight: 500;
	border-radius: 2em;
	padding: 0.42em 1.6em;
	background-color: #ffffff;
	display: inline-block;
	margin: 0 auto 30px auto;
}
#slide_pickup {
	width: 91.66%;
	max-width: 1760px;
	margin: auto;
}
#slide_pickup article {
	margin: 0 min(1.6vw, 30px);
	text-align: left;
}
#slide_pickup article a {
	display: block;
}
#slide_pickup article figure {
	margin: 0 auto;
}
#slide_pickup article .title {
	margin-top: 1em;
	line-height: 1.3;
	font-weight: 800;
	font-size: min(3.4vw, 18px);
}
#slide_pickup article .title span {
	display: block;
	font-weight: 500;
	line-height: inherit;
	font-size: 80%;
	margin-top: 0.5em;
}
#slide_pickup article .tagList {
	margin-top: 0.5em;
}
@media (min-width: 768px) {
	#pickup {
		padding: 33px 0 40px 0;
	}
	#pickup h2 {
		font-size: min(1.56vw, 30px);
		margin: 0 auto 30px auto;
	}
	#slide_pickup article .title {
		line-height: 1.4;
		font-size: min(1.5vw, 20px);
	}
	#slide_pickup article .tagList {
		margin-top: 1em;
	}
	#slide_pickup article .tagList li a {
		font-size: min(1.2vw, 15px);
	}
}
/* スライダーJS
-----------------------------*/
#slide_pickup .slick-track {
	display: flex;
}
#slide_pickup .slick-slide {
	height: auto !important;
}
/*左右の矢印*/
#slide_pickup .slick-next,
#slide_pickup .slick-prev {
	width: min(8vw, 30px);
	height: 100%;
	top: 30%;
	z-index: 1;
}
#slide_pickup .slick-next:hover,
#slide_pickup .slick-prev:hover {
	opacity: 0.7;
}
#slide_pickup .slick-prev {
	background-image: url(/img/business/column/prev.svg);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	left: max(-3vw, -50px);
}
#slide_pickup .slick-next {
	background-image: url(/img/business/column/next.svg);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	right: max(-3vw, -50px);
}
#slide_pickup .slick-prev:before, 
#slide_pickup .slick-next:before {
	content:"";
}
@media (max-width: 600px) {
	#slide_pickup .slick-next,
	#slide_pickup .slick-prev {
		top: 25%;
	}
}
@media (min-width: 768px) {
	#slide_pickup .slick-next,
	#slide_pickup .slick-prev {
		width: min(3vw, 47px);
	}
}
/*下ドット*/
#slide_pickup .slick-dots {
	bottom: -1.5em;
}
#slide_pickup .slick-dots li,
#slide_pickup .slick-dots li button,
#slide_pickup .slick-dots li button:before {
	width: auto;
	height: auto;
}
#slide_pickup .slick-dots li {
	margin: 0 0.5em;
}
#slide_pickup .slick-dots li button:before {
	font-size: min(1.5vw, 8px);
	line-height: 1;
}
#slide_pickup .slick-dots li.slick-active button:before,
#slide_pickup .slick-dots li button:before {
	color: #a7a7a7;
}
/*スライド可変用画像トリミング*/
#pickup article figure img {
	/*slidesToShow: 2*/
	object-fit: cover;
	width: 42vw;
	height: 27.4vw;
	max-width: 380px;
	max-height:260px;
}
@media (max-width: 429px) {
	/*slidesToShow: 1*/
	#pickup article figure img {
		width: 55.9vw;
		height: 37.95vw;
	}
}
@media (max-width: 350px) {
	#pickup article figure img {
		width: 48vw;
		height: 32vw;
	}
}
@media (min-width: 768px) {
	/*slidesToShow: 3*/
	#pickup article figure img {
		width: 27vw;
		height: 19vw;
		max-width: 380px;
		max-height:260px;
	}
}
@media (min-width: 1200px) {
	/*slidesToShow: 4*/
	#pickup article figure img {
		height: 13.54vw;
		width: 19.79vw;
	}
}
/*---------------------------------------
　下部お問い合わせ
---------------------------------------*/
#contact {
	width: 86%;
	max-width: 690px;
	margin: 0 auto;
	/*border: 2px solid #87785e;
	border-radius: min(1.9vw, 19px);
	background-color: #f7f7f5;*/
	text-align: center;
	padding: 1.25em min(6vw, 60px) 0.5em;
	color: #87785e;
	font-weight: 500;
}
#contact p {
	font-size: min(3.5vw, 22px);
	font-weight: 500;
	margin-bottom: 0.6em;
}
#contact h2 {
	font-size: min(4.5vw, 32px);
	font-weight: 500;
	color: #ffffff;
	border-radius: 2em;
	padding: 0.36em;
	background-color: #a1cc56;
	max-width: 562px;
	margin: 0 auto 1.5em auto;
}
#contact a {
	display: inline-block;
	font-size: min(5vw, 40px);
	font-weight: 500;
	position: relative;
	padding: 0.3em 0 0.3em 3.3em;
	margin: 0 auto 0.9em auto;
}
#contact a#tel_link {
	font-size: min(8vw, 48px);
	padding-left: 2.5em;
}
#contact a::before,
#contact a::after {
	position: absolute;
	content: "";
	left: 0;
	top: 0;
	bottom: 0;
	margin: auto 0;
	height: auto;
}
#contact a#tel_link::before {
	background-image: url(/img/business/column/icon_tel.svg);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	width: 1em;
	max-width: 60px;
	left: 5px;
}
#contact a#mail_link::before {
	background-image: url(/img/business/column/icon_mail.svg);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	width: 2.2em;
	max-width: 89px;
}
/*#contact a#mail_link::after {
	background-image: url(/img/business/column/icon_arrow.svg);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	width: 0.93em;
	left: initial;
	right: 0;
}*/
#contact a#tel_link span {
	display: block;
	font-size: min(2.2vw, 19px);
	font-weight: inherit;
	margin-top: 0.5em;
}
@media (min-width: 500px) {
	#contact a#tel_link::before {
		width: 1.5em;
	}
}

/*---------------------------------------
　一覧ページ用
---------------------------------------*/

/*　mainVisual
-----------------------------*/
#mainVisual {
	position: relative;
	overflow: hidden;
	width: 100%;
	z-index: 1;
	margin-bottom: min(4.2vw, 42px);
}
#mainVisual figure {
	position: relative;
	z-index: 1;
	top:0;
	left:0;
	right: 0;
	margin: auto;
	width:100%;
	max-width: 1920px;
	overflow:hidden;
	height: 100vh;
	max-height: 600px;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}
#mainVisual figure img {
	height: 100%;
	width: auto;
	max-width: none;
	position: relative;
	left: 0;
	right: 0;
	top: 0;
	margin:0 auto;
}
#mainVisual .titleArea {
	position: absolute;
	z-index:2;
	top: 0;
	left: 0;
	right: 0;
	margin: 0 auto;
    height: 100%;
	max-width: 1000px;
	width: 92%;
}
#mainVisual .titleArea h1 {
	position: absolute;
	z-index:3;
	left: 0;
	bottom: 0.5em;
	font-weight: 700;
	font-size: min(6.8vw, 40px);
	line-height: 1.2;
	color: #ffffff;
	text-shadow: 7px 7px 5px rgba(137, 137, 137, 0.25);
}
#mainVisual .titleArea h1 span {
	display: block;
	margin-left: 0.2em;
	font-size: 34%;
	line-height: 1.5;
	font-family: "Montserrat", sans-serif;
	font-weight: 200;
}
@media (min-width: 768px) {
	#mainVisual .titleArea h1 {
		font-size: min(5.5vw, 60px);
		left: 2em;
	}
}
@media (min-width: 1400px) {
	#mainVisual .titleArea h1 {
		font-size: min(7.6vw, 76px);
	}
	#mainVisual figure,
	#mainVisual figure img {
		height: 100%;
		width:auto;
	}
	#mainVisual figure {
		height: 100%;
		max-height: 800px;
	}
}
@media (max-width:430px) {
	#mainVisual figure {
		height: 50vh;
		max-height: 300px;
	}
}
/* intro
-----------------------------*/
#intro .leadText {
	font-weight: 500;
	color: #221714;
}
@media (min-width: 768px) {
	#intro {
		margin-bottom: min(50vw, 50px);
	}
	#intro .leadText {
		font-size: min(2vw, 18px);
	}
}
/*　column_flex
-----------------------------*/
#column_left {
	text-align: left;
	margin-top: 30px;
}
#column_right {
	text-align: center;
	margin: 4em auto 0 auto;
	width: 90%;
}
@media (min-width: 768px) {
	#column_flex {
		display: flex;
		justify-content: space-between;
		margin-bottom: min(90vw, 90px);
	}
	#column_left {
		margin-top: 78px;
		width: 73%;
		max-width: 730px;
	}
	#column_right {
		width: 24%;
		max-width: 215px;
		margin: 73px 0 0 0;
	}	
}
/*.tagList+*/
#column_right .tagList {
	display: block;
	margin-top: 0;
}
#column_right .tagList li {
	margin-right: 0;
}
#column_right .tagList li a {
	line-height: 1.375;
	min-width: 6.8em;
	font-size: min(3.8vw, 14px);
}
#column_right .tagList li a:not(.active):not(:hover) {
	background-color: initial;
}
#column_right .tagList li:first-child a::before {
	content: none;
}
@media (min-width: 768px) {
	#column_right .tagList li a {
		font-size: min(1.6vw, 16px);
	}
}
/*#searchWp*/
#searchWp {
	margin: 2em auto 0 auto;
	background-color: #d4dcc6;
	border-radius: 5px;
	padding: 13px 9px;
}
#searchWp h2 {
	font-weight: 500;
	text-align: left;
	margin-bottom: 0.5em;
}
.search_input {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	position: relative;
	border: 1px solid #999;
	padding: 2px 22px 2px 0.5em;
	border-radius: 4px;
	overflow: hidden;
	background-color: #fff;
}
.search_input input[type=text] {
	line-height: 1.6;
	border: none;
	font-size: 16px;
	width: 100%;
	font-family: sans-serif;
}
.search_input input[type=text]:focus {
	outline: 0;
}
.search_input .submit {
	position: absolute;
	right: 5px;
	top: 0;
	bottom: 0;
	margin: auto 0;
	border: none;
	background-color: transparent;
	outline: none;
	background-image: url(/img/business/column/icon_search.svg);
	background-repeat: no-repeat;
	background-position: right center;
	background-size: contain;
	width: 17px;
	height: 24px;
	cursor: pointer;
}
@media (min-width: 768px) {
	#searchWp {
		width: 100%;
		max-width: 150px;
	}
	#searchWp h2 {
		font-size: 12px;
	}
}
/*ranking*/
#ranking {
	margin: 4em auto;
	width: 90%;
}
#ranking .intro {
	text-align: center;
	margin-bottom: 0.5em;
}
#ranking .intro span {
	position: relative;
	padding: 0 1.15em;
	font-weight: 500;
	font-size: min(3vw, 13px);
	line-height: 1.3;
	color: #7ea770;
	display: inline-block;
}
#ranking .intro span::before,
#ranking .intro span::after {
	content: '';
	position: absolute;
	top: 0.5em;
	display: inline-block;
	width: 1.2em;
	height: 1px;
	background-color: #7ea770;;
}
#ranking .intro span::before {
	left:0;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
#ranking .intro span::after {
	 right: 0;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
#ranking h2 {
	font-size: min(4.5vw, 20px);
	line-height: 1;
	font-weight: 500;
	color: #ffffff;
	border-radius: 2em;
	padding: 0.2em 1.9em;
	background-color: #7ea770;
	display: inline-block;
	margin-bottom: 0.5em;
}
.rankingList li {
	text-align: left;
	margin: 0 auto 2em auto;
	max-width: 380px;
}
.rankingList .title {
	font-size: min(4vw, 14px);
	line-height: 1.3;
	font-weight: 500;
	color: #7ea770;
	margin-bottom: 0.5em;
	text-indent: -1.5em;
	padding-left: 1.5em;
}
.rankingList .title > span {
	line-height: inherit;
	font-size: 227%;
	font-weight: 500;
}
.rankingList figure {
	width: 85%;
	margin: auto;
}
.rankingList figure img {
	border-radius: min(1.6vw, 16px);
}
@media (min-width: 768px) {
	#ranking {
		width: 100%;
	}
	.rankingList li {
		width: 100%;
		max-width: 190px;
		margin-bottom: 1em;
	}
	#ranking h2 {
		font-size: min(1.56vw, 20px);
	}
	.rankingList .title {
		text-indent: 0;
		padding-left: 0;
	}
	.rankingList .title > span {
		display: inline-block;
		margin-right: 3px;
	}
	.rankingList figure {
		width: 100%;
	}
}
/*#columnList*/
#columnList article {
	background-color: #ffffff;
	border-radius: min(3vw, 30px);
	box-shadow: 5px 5px 10px rgba(95, 95, 95, 0.6);
	margin-bottom: 20px;
	max-width: 730px;
	text-align: center;
	padding: 1em;
}
#columnList article {
	display: flex;
	justify-content: space-between;
}
#columnList article > figure {
	width: 40%
}
#columnList article > div {
	width: 58%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
#columnList article a {
	display: block;
}
#columnList article .tagList {
	align-self: flex-end;
	justify-content: center;
}
#columnList article .title {
	line-height: 1.3;
	font-weight: 700;
	font-size: min(4.3vw, 20px);
	text-align: center;
	width: 100%;
}
#columnList article .title span {
	display: block;
	font-weight: 500;
	line-height: inherit;
	font-size: 10px;
	padding-top: 0.5em;
	margin-top: 0.5em;
	border-top: 1px solid #231815;
	width: 94%;
}
#columnList article figure img {
	width: 100%;
}
#columnList article .tagList li a {
	font-size: min(2.1vw, 10px);
}
@media (min-width: 768px) {
	#columnList article {
		padding: 27px 24px;
	}
	#columnList article > figure {
		width: 53.6%
	}
	#columnList article > div {
		width: 42.6%;
	}
	#columnList article .title {
		margin: 0.3em 0;
		font-size: min(2vw, 29px);
	}
	#columnList article .title span {
		font-size: max(52%, 10px);
		padding-top: 1em;
		margin-top: 1em;
	}
	#columnList article .tagList li a {
		font-size: 10px;
	}
}
/*#pager*/
#pager02 {
	margin: 2em auto 0 auto;
	text-align: center;
}
#pager02 ul {
	display: inline-flex;
	justify-content: center;
	background-color: #f2f2f3;
	border-radius: 2em;
}
#pager02 li {
	margin: 4px;
	line-height: 1;
	width: 2em;
	height: 2em;
	text-align: center;
	box-sizing: border-box;
	display: flex;
	align-items: anchor-center;
	justify-content: center;
}
#pager02 li a {
	font-size: inherit;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100%;
	width: 100%;
	color: #231815;
	font-weight: 500;
	box-sizing: border-box;
	border-radius: 2em;
}
#pager02 li.current a {
	background-color: #e6e6e6;
}
#pager02 li a:hover {
	opacity: 1;
	background-color: #d4dcc6;
}
#pager02 li.current a:hover {
	background-color: #e6e6e6;
	cursor: default;
}
#pager02 li.prev a,
#pager02 li.next a {
	background-color: #d4dcc6;
}
#pager02 li.prev.off,
#pager02 li.next.off {
	display: none;
}
#pager02 li.prev a:hover,
#pager02 li.next a:hover {
	opacity: 0.8;
}
@media (min-width: 768px) {
	#pager02 {
		margin-top: 100px;
		/*padding-left: 36%;*/
	}
}
