@charset "utf8";
/*=============================
	- font-style
	- 汎用 color & background
	- 汎用 wrap & title
	- top.css  TOPページCSS
==============================*/

@import url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@500;700;800&family=Sawarabi+Gothic&display=swap');


/*----------------------------------------------------
	font-style
----------------------------------------------------*/
/*  全体 font  */
html {
  font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro",
    "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.my-font01 {
  font-family: "Montserrat", sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  letter-spacing: 0.02em;
}


.my-font02 {
	font-family: 'Open Sans', sans-serif;
	font-family: 'Sawarabi Gothic', sans-serif;
	letter-spacing: 0.02em;
}




/*----------------------------------------------------
	汎用 color & background
----------------------------------------------------*/
/* color */
.white {
  color: #fff;
}
.base-color01 {
  /*--メイン文字カラー--*/
  color: #000;
}
.base-back01 {
  /*--メイン背景カラー--*/
  background: #fff;
}
.point-color01 {
  /*--ポイント文字カラー オレンジ --*/
  color: #f28b00;
}
.point-color02 {
  /*--ポイント文字カラー 緑 --*/
  color: #1cb327;
}
.point-back01 {
  /*--ポイント背景カラー 緑 --*/
  background: #1cb327;
}
.point-back02 {
  /*--ポイント背景カラー オレンジ--*/
  background: #f28b00;
}
.accent-back01 {
  /*--アクセント背景カラー 薄グレー--*/
  background: #f3f6f9;
}
.accent-back02 {
  /*--アクセント背景カラー 薄緑--*/
  background: #f0fcea;
}
.border-color01 {
	/*--ボーダーカラー 緑--*/
    border-color: #107d18;
}
.border-color02 {
	/*--ボーダーカラー オレンジ--*/
    border-color: #c07602;
}

.maker-color01 {
	/*--マーカーカラー ベージュ--*/
    background: linear-gradient(transparent 55%, #f9ecda 65%);
}



/*----------------------------------------------------
	汎用 buttton
----------------------------------------------------*/
/* 無料相談ボタン */
.btn01 {
  display: inline-block;
  text-align: center;
  min-width: 320px;
  letter-spacing: 0.05em;
  border-radius: 80px;
  padding: 22px 0 21px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 680px) {
  .btn01 {
    width: 100%;
    max-width: 100%;
    min-width: auto;
    border-radius: 100px;
  }
}

/* 青枠丸ボタン */
.btn02 {
  display: inline-block;
  text-align: center;
  letter-spacing: 0.05em;
  min-width: 330px;
  border-radius: 140px;
  padding: 22px 0 21px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 680px) {
  .btn02 {
    width: 100%;
    min-width: 100%;
  }
}

/*----------------------------------------------------
	汎用 wrap & title
----------------------------------------------------*/
/*  width 管理  */
.mywidth {
  width: 100%;
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (min-width: 681px) and (max-width: 1280px) {
	.mywidth {
		padding-left: 3vw;
		padding-right: 3vw;
	}
}
 @media screen and (max-width: 680px) {
  .mywidth {
    padding-left: 5vw;
    padding-right: 5vw;
  }
}

/*  メインコンテンツwrap   */
#main-wrapp {
  overflow-x: hidden;
}

/* title */
.content-title01 {
	color: #000;
	position: relative;
	z-index: 1;
	display: flex;
	justify-content: center;
}
.content-title01 h2 {
	text-align: center;
	padding: 0 20px 15px;
	display: inline-block;
	position: relative;
}
.content-title01 h2::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	border-bottom: 3px solid #1cb327;
}

.content-title02 {}
.content-title02 span {
    font-size: 26px;
}

@media screen and (max-width: 680px) {
	.content-title01 .title-english {
		font-size: 40px;
	}
	.content-title02 span {
		font-size: 20px;
		line-height: 1.8em;
	}
	
	
}

/*----------------------------------------------------
	top.css  TOPページCSS
----------------------------------------------------*/
/*  content01  */
.content01 {
	padding: 50px 0;
}
.content01 .back {
	width: 80%;
    max-width: 992px;
    margin: 0 auto;
    padding: 30px 30px;
    background: url(../images/back_search_box.png) no-repeat;
    background-size: cover;
	box-sizing: border-box;
}

.content01 .content-title01 {
    display: flex;
	justify-content: flex-start;
}
.content01 .content-title01 h2 {
	padding: 0;
    display: flex;
	position: relative;
}
.content01 .content-title01 h2::before {
	content: "";
	display: inline-block;
	background: url(../images/i_search.png) no-repeat;
	background-size: contain;
	width: 33px;
	height: 33px;
	margin-right: 8px;
}
.content01 .content-title01 h2::after { content: none; }

.content01 .search-select-wrap {}
.content01 .search-select-wrap select {
    padding: 10px 10px;
    min-width: 330px;
    background: #fff;
    border-radius: 10px;
	font-weight: bold;
}
.select-item { position: relative; }
.select-item:after {
	content: "";
	position: absolute;
	right: 10px;
	top: 20px;
	width: 10px;
	height: 10px;
	border-top: 2px solid #000;
	border-left: 2px solid #000;
	transform: translateY(-50%) rotate(-135deg);
	pointer-events: none;
}
.content01 .search-select-wrap .select-item:first-of-type {
    margin-right: 15px;
}
.content01 .search-select-wrap .select-item select{
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
.content01 .btn-wrap {
    margin-left: 20px;
}
.content01 .btn-wrap .btn-search {
    text-align: center;
    min-width: 220px;
    height: auto;
    letter-spacing: 0.05em;
    padding: 14px 0 10px;
	border-bottom-width: 5px;
    border-bottom-style: solid;
	border-radius: 50px;
    display: flex;
    align-items: center;
    position: relative;
}
.content01 .btn-wrap .btn-search::before {
	content: "";
	display: inline-block;
	background: url(../images/i_search_w.png) no-repeat;
	background-size: contain;
	width: 21px;
	height: 21px;
	margin-right: 8px;
}

@media only screen and (min-width: 681px) and (max-width: 1280px) {
	.content01 .back {
		width: 100%;
    	padding: 30px 20px;
	}
	.content01 .search-select-wrap {
		width: 70%;
	}
	.content01 .search-select-wrap .select-item {
		width: 50%;
	}
	.content01 .search-select-wrap select {
		min-width: inherit;
	}
	.content01 .btn-wrap {
		width: 30%;
		margin-left: 0;
		padding-left: 15px;
	}
	.content01 .btn-wrap .btn-search {
		min-width: inherit;
		padding: 14px 10px 10px;
		font-size: 1.8vw;
	}
	
}
@media screen and (max-width: 680px) {
	.content01 {
		padding: 20px 0;
	}

	.content01 .back {
		width: 100%;
		padding: 15px 15px;
		background: url(../images/back_search_box_sp.png) no-repeat;
		background-size: cover;
	}

	.content01 .search-select-wrap {
		width: 100%;
	}
	.content01 .search-select-wrap .select-item {
		margin-bottom: 10px;
	}
	.content01 .search-select-wrap select {
		padding: 10px 10px;
		min-width: 100%;
	}
	.content01 .search-select-wrap .select-item:first-of-type {
		margin-right: 0;
	}
	
	.content01 .btn-wrap {
		width: 100%;
		margin: 0 0;
	}
	.content01 .btn-wrap .btn-search {
		min-width: 100%;
	}
}




/*  content02  */
.content02 {
	padding-top: 50px;
	padding-bottom: 50px;
}
.content02 .box {
	width: 23%;
	margin-bottom: 30px;
	position: relative;
}
.content02 .box a {
	display: block;
	position: relative;
}
.content02 .box .image {
	width: 100%;
	height: 220px;
	overflow: hidden;
}
.content02 .box .image img {
	object-fit: cover;
	width: 100%;
	height: 100%;
	border-radius: 0 0 10px 10px;
}
.content02 .box .tag {
	text-align: center;
    border-radius: 10px 10px 0 0;
    background: rgba(0,0,0,0.7);
    padding: 4px 15px;
    display: block;
    /*position: absolute;
    top: 0;
    left: 0;*/
	text-align: left;
    line-height: 1.5em;
}
.content02 .box .text {
	font-feature-settings: "palt";
    letter-spacing: 0.05em;
    margin: 10px 0;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
}
.content02 .box .data-list {
}
.content02 .box .data-list li,
.content03 .box .data-list li {
	padding-bottom: 5px;
    font-size: 14px;
    display: flex;
    justify-content: flex-start;
    position: relative;
}
.content02 .box .data-list li::before {
	content: "";
	display: inline-block;
	width: 18px;
	min-width: 18px;
	height: 18px;
	margin-right: 10px;
}
.content02 .box .data-list li.saraly::before {
	background: url(../images/i_saraly.png) no-repeat;
	background-size: contain;
}
.content02 .box .data-list li.type::before {
	background: url(../images/i_type.png) no-repeat;
	background-size: contain;
}
.content02 .box .data-list li.area::before {
	background: url(../images/i_area.png) no-repeat;
	background-size: contain;
}
.content02 .btn02 {
	background: #fff;
	color: #1cb327;
    border: 1px solid #1cb327;
	border-bottom: 3px solid #1cb327;
}
@media only screen and (min-width: 681px) and (max-width: 1280px) {
	.content02 .box .image {
		height: 120px;
	}
}

@media screen and (max-width: 680px) {
	.content02 {
		padding: 20px 0 30px;
	}
	.content02 .box {
		width: 47%;
	}
	.content02 .box .image {
		height: 50%;
	}

}

/*  content03  */
.content03 {
	padding-top: 50px;
	padding-bottom: 50px;
	background: url(../images/back_green_line.png) no-repeat;
	background-size: cover;
}
.content03 .content-title01 h2 {
    display: flex;
    padding: 0 0 0;
}
.content03 .content-title01 h2 img {
    padding-bottom: 10px;
}
.content03 .content-title01 h2::after { content: none; }

.content03 .box {
    width: 31.33%;
    max-width: 335px;
}
.content03 .box h3 {
    padding: 30px 0 20px;
    text-align: center;
}
.content03 p {
    font-size: 15px;
    line-height: 1.7em;
}

.content03 .comment {
    width: 80%;
    margin: 20px auto 0;
}
.content03 .btn02 {
	border-bottom-width: 5px;
    border-bottom-style: solid;
}

@media screen and (max-width: 680px) {
	.content03 {
		padding-top: 30px;
		padding-bottom: 30px;
		background: url(../images/back_green_line_sp.png) no-repeat;
		background-size: cover;
	}
	.content03 .box {
		width: 100%;
	}	
	.content03 .box .image {
		width: 37%;
	}
	.content03 .box .text-wrap {
		width: 60%;
	}
	.content03 .box h3 {
		padding: 0 0 10px;
	}
	.content03 p {
		font-size: 14px;
		line-height: 1.5em;
	}
	
	.content03 .comment {
		width: 100%;
		margin: 30px 0 0;
	}
	
}


/*  content04 */
.content04 {
  padding-top: 50px;
  padding-bottom: 30px;
}
.content04 .menu-list {
	display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    align-items: stretch;
	justify-content: space-around;
	flex-wrap: wrap;
}
.content04 .menu-list li {
    width: 31.33%;
    margin-bottom: 20px;
}
.content04 .menu-list li a {
	height: 100%;
    padding: 20px 15px;
	border: 3px solid #f28b00;
	border-radius: 12px;
	box-shadow: 1px 0px 12px -5px rgba(0,0,0,0.6);
}
.content04 .menu-list li figure {
    width: 100px;
    height: auto;
    text-align: center;
    margin-right: 15px;
}
.content04 .menu-list li h3 {
	font-size: 18px;
	line-height: 1.8em;
}
@media only screen and (min-width: 681px) and (max-width: 1280px) {
	.content04 .menu-list li figure {
		width: 20%;
	}
	.content04 .menu-list li h3 {
		font-size: 2vw;
		line-height: 1.8em;
	}
}

@media screen and (max-width: 680px) {
	.content04 .menu-list li {
		width: 48%;
		margin-bottom: 15px;
	}
	.content04 .menu-list {
		justify-content: space-between;
	}
	.content04 .menu-list li a {
		padding: 10px 10px;
		min-height: 90px;
	}
	.content04 .menu-list li figure {
		width: 25%;
		margin-right: 10px;
	}
	.content04 .menu-list li h3 {
		font-size: 3.3vw;
		line-height: 1.6em;
	}
	
}



/*  content05 */
.content05 {
	padding-top: 50px;
	padding-bottom: 50px;
}
.content05 .out-wrap {
	text-align: center;
	width: 90%;
    max-width: 830px;
	margin-left: auto;
    margin-right: auto;
}
.content05 .list-wrap li {
	display: flex;
	align-items: center;
	overflow: hidden;
	padding: 20px 0;
    border-bottom: 1px solid #ddd;
}
.content05 .list-wrap li:first-of-type {
    border-top: 1px solid #ddd;
}
.content05 .list-wrap li .date {
	min-width: 120px;
	font-size: 14px;
	font-weight: bold;
	letter-spacing: 0.05em;
}
.content05 .list-wrap li .text {
	color: #000;
	font-weight: normal;
	font-size: 15px;
	line-height: 1.7;
	letter-spacing: 0.05em;
	overflow: hidden;
}

.content05 .btn02 {
    background: #fff;
    color: #1cb327;
    border: 1px solid #1cb327;
    border-bottom: 3px solid #1cb327;
}
@media screen and (max-width: 680px) {
	.content05 {
		padding: 30px 0;
	}
	.content05 .out-wrap {
		width: 100%;
	}
	.content05 .list-wrap li {
		padding: 12px 0;
		display: block;
	}
	.content05 .list-wrap li .date {
		display: block;
	}
	
}




/*  content06 */
.content06 {
	padding-top: 50px;
    padding-bottom: 50px;
    background: url(../images/back_bage_line.png) no-repeat;
    background-size: cover;
}
.content06 .box {
	width: 23.5%;
    margin-bottom: 30px;
}
.content06 .box a {
	display: block;
	position: relative;
}
.content06 .box .image {}
.content06 .box .image img {
    border-radius: 8px;
    width: 100%;
    height: 225px;
    object-fit: cover;
}
.content06 .box .text {
    padding-top: 10px;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
}
.content06 .btn02 {
    background: #fff;
    color: #1cb327;
    border: 1px solid #1cb327;
    border-bottom: 3px solid #1cb327;
}
@media only screen and (min-width: 681px) and (max-width: 1280px) {
	.content06 .box .image img {
		height: 150px;
	}
	
}
@media screen and (max-width: 680px) {
	.content06 {
		padding-top: 50px;
		padding-bottom: 50px;
		background: url(../images/back_bage_line_sp.png) no-repeat;
		background-size: cover;
	}
	.content06 .box {
		width: 48%;
		margin-bottom: 20px;
	}
	.content06 .box .image img {
		height: 150px;
	}
	
}


/*  content07 */
.content07 {
	padding-top: 80px;
    padding-bottom: 80px;
}
.content07 ul {}
.content07 ul li {
	width: 300px;
}
.content07 ul li a {
    text-align: center;
}

@media screen and (max-width: 680px) {
	.content07 {
		padding-top: 30px;
		padding-bottom: 30px;
	}
	.content07 ul li {
		width: 47%;
		max-width: inherit;
		margin-bottom: 20px;
	}
	
}


/*  content08  */
.content08 {
	padding-top: 50px;
	padding-bottom: 50px;
	background: #f5d1a1;
	background: -moz-linear-gradient(left, #c0f0c4 0%, #f5d1a1 100%);
	background: -webkit-gradient(linear, left center, right center, from(#c0f0c4), to(#f5d1a1));
	background: -webkit-linear-gradient(left, #c0f0c4 0%, #f5d1a1 100%);
	background: -o-linear-gradient(left, #c0f0c4 0%, #f5d1a1 100%);
	background: linear-gradient(to right, #c0f0c4 0%, #f5d1a1 100%);
}
.content08 .mywidth { position: relative; }
.content08 .mywidth::after {
	content: "";
	display: inline-block;
	width: 320px;
	height: 442px;
	background: url("../images/footer_img.png") no-repeat;
	background-size: contain;
	position: absolute;
    top: 80px;
    right: 0;
    transform: translateY(-50%);
}

.content08 .inner {
	width: 80%;
    max-width: 800px;
}
.content08 p {
    font-size: 15px;
    line-height: 1.7em;
}
.content08 .tel-btn {
	min-width: 320px;
    height: 75px;
    border-radius: 80px;
    padding: 22px 0 21px;
	font-size: 32px;
	letter-spacing: 0;
	border: 1px solid #1cb327;
	position: relative;
}
.content08 .tel-btn::before {
	content: "";
	display: inline-block;
	width: 32px;
	height: 21px;
	background: url("../images/phone.png") no-repeat;
	background-size: contain;
	margin-right: 8px;
}
.content08 .contact-btn {
    border-bottom-width: 5px;
    border-bottom-style: solid;
    margin: 0 0;
}
@media only screen and (min-width: 681px) and (max-width: 1280px) {
	.content08 .contact-wrap {
		width: 100%;
		max-width: 760px;
	}
}
@media screen and (max-width: 680px) {
	.content08 {
		padding: 50px 0;
	}
	.content08 .mywidth::after {
		content: none;
	}
	.content08 figure {
		width: 50%;
		margin: 0 auto;
	}
	.content08 .inner {
		width: 100%;
	}
	.content08 .tel-btn {
		font-size: 30px;
    	width: 100%;
	}
	.content08 .contact-btn {
		width: 100%;
    	margin: 0 0 20px;
	}
	
	
	.content08 #text-box {
		width: 100%;
		overflow: hidden; /*float解除*/
	}
	.content08 #text-box .space {
		float: right; /*画像の位置を右下にしたい場合はright*/
		height: 6.5em; /*画像上の余白の高さ*/
	}
	.content08 #text-box .img {
		float: right; /*画像の位置を右下にしたい場合はright*/
		clear: both;/*.spaceのfloat解除*/
		margin: 1.2em 0 0 1.2em;
		width: 50%;
	}

}

