@charset "utf-8";
/*==================================================
	【トップ】ページ固有のスタイル
==================================================*/
#top_ttl {
	position: relative;
	z-index: 1;
}
#top_ttl img {
	width: 100%;
}
#top_ttl p {
	position:absolute;
	right: 0;
	bottom:0;
	color:#1a5a49;
	font-weight:bold;
	font-size:2em;
	font-family:'Times New Roman', Times, serif;
	mix-blend-mode: color-dodge;
}
#top_info .in {position: relative;}
#top_info .in::before, #top_info .in::after {
	content: "";
	width: 204px;
	height: 200px;
	background: url("../img/top/bg-news02.png") no-repeat center /100% auto;
	display: inline-block;
	position: absolute;
	bottom: -150px;
	left: -160px;
}
#top_info .in::after {
	background-image: url("../img/top/bg-news.png");
	width: 442px;
	height: 282px;
	bottom: auto;
	top: -140px;
	left: auto;
	right: -160px;
}
#top_info .imgs {
	display: grid;
	justify-content: space-between;
	grid-template-columns: repeat(4, 250px);
	position: relative;
	z-index: 1;
}
#top_concept {

}
#top_concept .in {
	position: relative;
}
#top_concept .in:nth-of-type(2) {
	padding-top: 300px;
}
#top_concept .img img {
	width: 100%;
	height: 600px;
	object-fit: cover;
}
#top_concept .img.w3 {
	display: flex;
	align-items: flex-start;
}
#top_concept .img.w3 img {
	width: 33.33%;
}
#top_concept .box {
	width: 500px;
	height: 500px;
	position: absolute;
	right: 0;
	bottom: -200px;
	background: rgba(26, 90, 73, 0.95);
	border-radius: 50%;
	color: #fff;
	text-align: center;
	padding-top: 110px;
}
#top_concept .box::before {
	content: "";
	width: 54px;
	height: 95px;
	background: url("../img/ico-reef02.png") no-repeat center /100% auto;
	position: absolute;
	right: 50px;
	top: 50px;
	display: inline-block;
}
#top_concept .in:nth-of-type(2) .box {
	right: auto;
	left: 0;
	bottom: auto;
	top: 100px;
}
#top_concept .in:nth-of-type(2) .box::before {
	background-image: url("../img/ico-reef03.png");
	right: auto;
	left: 50px;
}
#top_concept .box h3 {
	font-size: 40px;
	font-weight: normal;
	margin-bottom: 30px;
}
#top_concept .box h3 span {
	font-size: 16px;
	color: #ccc;
	display: block;
}
#top_concept .box .txt {
	width: 300px;
	margin: 0 auto;
}
#top_sales::before {
	background: url("../img/bg-reef.png") no-repeat right top 330px / 180px auto;
}
#top_sales .h3_line {
	border-top: 5px solid #1a5a49;
	border-bottom: 5px solid #1a5a49;
	padding: 5px 0;
	position: relative;
	margin-bottom: 50px;
}
#top_sales .h3_line::before {
	content: "";
	background: url("../img/top/ico01.png") no-repeat center /100% auto;
	width: 247px;
	height: 237px;
	display: inline-block;
	position: absolute;
	right: 0;
	top: -50px;
}
#top_sales .h3_line h3 {
	background: url("../img/bg-wall.jpg");
	font-size: 40px;
	color: var(--color-primary);
	font-weight: normal;
	padding: 35px 0 39px 35px;
}
#top_sales .h3_line h3 span {
	font-size: 16px;
	color: #ccc;
	margin-left: 30px;
}
#top_sales table {
	width: 100%;
	font-size: 20px;
	background: url("../img/top/ico02.png") no-repeat right top / 300px auto;
}
#top_sales table tr {
	border-bottom: 1px solid var(--color-primary);
}
#top_sales table tr th, #top_sales table tr td {
	padding: 15px;
}
#top_sales table tr th {
	color: var(--color-primary);
	vertical-align: top;
}
#top_sales table tr td dl {
	display: flex;
}
#top_sales table tr td dl dt {
	width: 190px;
}
#top_sales table tr td dl dd {
	width: calc(100% - 190px);
}
#top_sales .img {
	padding-top: 40px;
	padding-right: 40px;
}
#top_sales .img img {
	width: 316px;
}
#top_calendar h3 {
	color: var(--color-primary);
	font-size: 30px;
	font-weight: normal;
	border-bottom: 3px solid var(--color-primary);
	padding-bottom: 20px;
	margin-bottom: 70px;
}
#top_menu .img img {
	width: 100%;
	height: 600px;
	object-fit: cover;
}
#top_menu .box {
	padding: 150px 50px 0;
	position: relative;
	top: -100px;
	background: #fff;
}
#top_menu .box h3 {
	font-weight: normal;
	font-size: 200px;
	color: var(--color-primary);
	line-height: 1;
	position: absolute;
	right: 50px;
	top: -100px;
}
#top_menu .box .txt {
	font-size: 20px;
	margin-bottom: 60px;
	line-height: 2.5;
}
#contact h3 {
	font-size: 40px;
	color: var(--color-primary);
	font-weight: normal;
	margin-bottom: 50px;
}
#contact .txt {
	font-size: 20px;
}
#contact .tel {
	font-size: 25px;
	color: var(--color-primary);
}
@media print, screen and (min-width: 769px){ /* PCのみ */
	#top_menu {
		padding-bottom: 0;
	}
	#contact {
		padding-top: 100px;
	}
}
@media print, screen and (min-width: 641px){ /* PC・タブレット */
	#top_sales .img {
		display: none;
	}
	/* お知らせ */
	#top_info dl {
		display: flex;
	}
	#top_info dt {
		width: 100px;
	}
	#top_info dd {
		width: calc(100% - 100px);
	}
}
@media only screen and (max-width: 768px) and (min-width: 641px){ /* タブレットのみ */
}
@media only screen and (max-width: 768px) {  /* タブレット以下 */
	#top_info .imgs {
		grid-template-columns: repeat(4, 24%);
	}
	#top_concept .img img {
		height: 400px;
	}
	#top_concept .in:nth-of-type(2) {
		padding-top: 250px;
	}
	#top_concept .box {
		width: 400px;
		height: 400px;
		padding-top: 70px;
		bottom: -100px;
	}
	#top_concept .in:nth-of-type(2) .box {
		top: 100px;
	}
	#top_concept .box::before {
		width: 30px;
		height: 52px;
		right: 70px;
		top: 60px;
	}
	#top_concept .in:nth-of-type(2) .box::before {
		left: 70px;
	}
	#top_concept .box h3 {
		font-size: 30px;
		margin-bottom: 15px;
	}
	#top_sales .h3_line h3 {
		font-size: 30px;
	}
	#top_sales table {
		font-size: 18px;
		background: none;
	}
	#top_sales table tr th, #top_sales table tr td {
		display: block;
		padding: 0;
	}
	#top_sales table tr th {
		padding-top: 10px;
	}
	#top_sales table tr td {
		padding-bottom: 10px;
	}
	#top_sales table tr td dl dt {
		width: 170px;
	}
	#top_sales table tr td dl dd {
		width: calc(100% - 170px);
	}
	#top_sales .img {
		padding-right: 0;
		text-align: center;
	}
	#top_sales .img img {
		width: 250px;
	}
	#top_calendar h3 {
		font-size: 25px;
	}
	#top_calendar .cal {
		width: 49%;
	}
	#top_menu .img img {
		height: 400px;
	}
	#top_menu .box h3 {
		font-size: 100px;
		top: -50px;
	}
	#top_menu .box {
		padding: 50px 20px 0;
		top: -50px;
	}
	#top_menu .box .txt {
		font-size: 18px;
		line-height: 2;
		margin-bottom: 40px;
	}
	#contact h3 {
		font-size: 30px;
	}
	#contact .txt {
		font-size: 18px;
	}
	#contact .tel {
		font-size: 20px;
	}
}
@media only screen and (max-width: 640px){ /* スマホ */
	#top_info .in::after {
		width: 221px;
		height: 141px;
		top: -70px;
		right: -80px;
	}
	#top_info .imgs {
		grid-template-columns: repeat(2, 48%);
		gap: 10px;
	}
	#top_concept {
		margin-bottom: 100px;
	}
	#top_concept .in:nth-of-type(2) {
		padding-top: 150px;
	}
	#top_concept .img img {
		height: 300px;
	}
	#top_concept .box {
		width: 280px;
		/* height: 280px; */
		height: auto;
		padding-top: 20px;
		padding-bottom: 20px;
		border-radius: 30px;
		right: auto;
		left: 50%;
		transform: translateX(-50%);
		-webkit-transform: translateX(-50%);
		-ms-transform: translateX(-50%);
		box-sizing: border-box;
	}
	#top_concept .box::before {
		right: 30px;
		top: -10px;
	}
	#top_concept .in:nth-of-type(2) .box::before {
		left: 30px;
	}
	#top_concept .in:nth-of-type(2) .box {
		left: 50%;
		top: auto;
		bottom: -100px;
	}
	#top_concept .box h3 {
		font-size: 22px;
	}
	#top_concept .box .txt {
		width: 220px;
		/* display: -webkit-box;
		-webkit-box-orient: vertical;
		-webkit-line-clamp: 5;
		overflow: hidden; */
	}
	#top_sales .h3_line {
		margin-bottom: 30px;
	}
	#top_sales .h3_line h3 {
		position: relative;
		padding-left: 20px;
		padding-bottom: 15px;
		font-size: 22px;
	}
	#top_sales .h3_line h3 span {
		position: absolute;
		left: 0;
		margin-left: 20px;
		top: 10px;
	}
	#top_sales .h3_line::before {
		width: 150px;
		height: 145px;
		z-index: 1;
		top: -24px;
	}
	#top_sales table {
		width: 100%;
		font-size: 16px;
	}
	#top_sales table tr td dl {
		display: block;
	}
	#top_sales table tr td dl dt, #top_sales table tr td dl dd {
		width: 100%;
	}
	#top_sales .img img {
		width: 200px;
	}
	#top_calendar h3 {
		margin-bottom: 30px;
		font-size: 20px;
		padding-bottom: 10px;
	}
	#top_calendar .cal {
		width: 100%;
		margin-bottom: 20px;
	}
	#top_menu .img img {
		height: 300px;
	}
	#top_menu .box {
		padding-top: 40px;
	}
	#top_menu .box h3 {
		font-size: 70px;
		top: -35px;
		right: 20px;
	}
	#top_menu .box .txt {
		font-size: 100%;
		line-height: 1.8;
		margin-bottom: 20px;
	}
	#top_menu .box .btn01 a span {
		width: 240px;
	}
	#top_menu .box .btn01 a::before {
		width: 30px;
		right: -15px;
	}
	#contact h3 {
		font-size: 22px;
		margin-bottom: 25px;
	}
}