@charset "utf-8";
h2 {
	text-align: center;
	margin-bottom: 50px;
}
h2 span {
	color: #ffb400;
	font-size: 0.625em;
	display: block;
}
#important, #news, #sns, #info, #contact, #banner {
	padding: 80px 0 100px;
}
#news, #sns, #info, #contact {
	min-height: 480px;
}
div:not([class]) ul li a:not([class]) {
	display: inline;
}
/* mainimg */
.mainimg {
	max-height: 70dvh;
	overflow: hidden;
}
/*重要なお知らせ */
#important {
	padding: 80px 0 60px;
}
#important .contents {
	border: 2px solid #e2041b;
	background: #fff1f0;
	border-radius: 10px;
	padding: 30px 2rem 50px;
	width: 90%;
	text-align: center;
}
#important .contents h2 {
	display: inline-block;
	padding: 0 0.5em 0.5rem;
	margin-bottom: 30px;
	position: relative;
}
#important .contents h2::after {
	content: "";
	width: 100%;
	height: 4px;
	background: #e66c79;
	border-radius: 3px;
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	display: inline-block;
}
#important .contents ul {
	text-align: left;
}
#important .contents ul li {
	padding: 0.5rem 0;
	border-bottom: 1px dashed #999;
	position: relative;
	text-indent: -0.75rem;
	padding-left: 1.75rem;
}
#important .contents ul li::before {
	content: "●";
	display: inline-block;
	margin-right: 0.5rem;
	color: #f4877b;
}
#important .contents ul li:last-of-type {
	border-bottom: none;
}
/*お知らせ*/
#news {
	/*background: #fffbec;*/
	padding: 60px 0 80px;
}
.news_bk {
	background: #fff;
	padding: 30px;
	margin-bottom: 40px;
}
#news ul {
	display: flex;
	align-items: stretch;
	flex-wrap: wrap;
	margin: 0 auto;
}
#news ul li {
	padding: 1.5rem 1rem;
	border-bottom: 1px dashed #e7e7e7;
	margin-bottom: 0;
}
#news ul li:nth-child(odd) {
	width: 200px;
	text-align: center;
}
#news ul li:nth-child(odd) span {
	color: #fff;
	background: #ffb400;
	font-weight: bold;
	display: block;
	padding: 0.5rem 0;
	font-size: clamp(0.75rem, 0.875rem, 1rem);
	border-radius: 5px;
}
#news ul li:nth-child(even) {
	width: calc(100% - 200px);
	display: flex;
	align-items: center;
}
#news ul li:last-child, #news ul li:nth-last-child(2) {
	border-bottom: 0;
}
#news ul li a {
	color: inherit;
}
#news ul li a:hover {
	color: #007bff;
}
/*会社概要*/
/*

#sns .flex > div:last-child {
	padding: 3rem 3rem 4vw;
	position: relative;
}
#sns .contact_box a {
	width: 90%;
	max-width: 350px;
	font-size: clamp(1rem, 2vw + 1rem, 1.125rem);
	padding-left: 4rem;
}
#sns .contact_box a:nth-child(2) {
	margin-top: 1rem;
}
#sns .contact_box a::before {
	left: 2rem;
}
*/
/*　公式Instagram */
#sns {
	position: relative;
	overflow: hidden;
	padding: 100px 0;
}
#sns::before {
	content: "";
	background-image: url(../img/sns_bg.jpg);
	background-position: left 20%;
	background-repeat: no-repeat;
	background-size: cover;
	opacity: .1;
	display: block;
	position: absolute;
	bottom: 0;
	height: 100%;
	width: 100%;
	z-index: -1;
}
#sns .flex:has(div:only-child) {
	align-items: center;
	justify-content: center;
}
.btn.instagram {
	border: 2px solid #ff0069;
	color: #ff0069;
	padding: 0 6rem 0rem 2.5rem;
	margin: 0 auto;
}
.btn.instagram:hover {
	color: #fff;
}
.btn.instagram::before {
	color: #ff0069
}
.btn.instagram:hover::before {
	color: #fff
}
.btn.instagram:hover::after {
	background: #ff0069;
}
.instagram:hover span:before {
	filter: invert(100%);
}
/*
	#sns .flex > div:last-child::before {
		content: '';
		position: absolute;
		left: 50%;
		top: 50%;
		transform: translate(-50%,-50%);
		width: 120%;
		height: 120%;
		background: #f5f5f5;
		z-index: -1;
	}*/
/*　見学情報 */
#info {
	background: #fff0cb;
	padding: 80px 0 100px;
}
#info .contents {
	text-align: center;
}
#info h2 {
	padding: 1rem 5rem;
	display: inline-block;
	border-radius: 20px;
}
#info h2 span {
	/*color: #008b4f; */
}
#info .info_content {
	background: #fff;
	padding: 3% 5% 5%;
	border-radius: 10px;
	text-align: left;
}
#info .info_content div:has(>h3) {
	margin: 20px 0 40px;
}
#info .info_content div:has(>h3):first-of-type {
	margin: 0 0 40px;
}
#info .info_content div:has(>h3):last-of-type {
	margin: 20px 0 0;
}
#info .info_content h3, #info .info_content h4 {
	line-height: 1.0;
}
#info .info_content h3 {
	font-size: clamp(1.25rem, 0.806rem + 0.93vw, 1.5rem); /* 20 - 24 */
	margin-bottom: 0.5em;
	border-left: 10px solid #ffb400;
	padding: 0.75rem 2rem;
	position: relative;
}
#info .info_content h4 {
	font-size: clamp(1rem, 0.778rem + 0.46vw, 1.125rem); /* 18 - 16 */
	margin: 1.25rem 0 0.5rem;
	color: #ff9c00;
	padding: 0 calc(2rem + 10px);
}
#info .info_content div p, #info .info_content div ul {
	padding: 0 calc(2rem + 10px);
	display: block;
}
#info .info_content p.info_subtxt {
	margin: 20px auto 50px;
	line-height: 2.75;
	background-image: linear-gradient(#ddd .1px, transparent .1em);
	background-size: auto 2.75rem;
	position: relative;
	max-width: 95%;
	padding: 0 1rem;
}
#info .info_content p.info_subtxt::before {
	content: "";
	position: absolute;
	border-top: 2px solid #fff;
	width: 100%;
	left: 0;
}
#info .info_content div ul li {
	position: relative;
	text-indent: -0.75rem;
	padding-left: 1rem;
	margin: 0 0.75rem 0.5rem;
}
#info .info_content div ul li::before {
	content: "●";
	display: inline-block;
	margin-right: 0.5rem;
	color: #ffd163;
}
#info .info_content h4 + p, #info .info_content p.access {
	margin: 0 auto 1rem;
}
#info .info_content .red {
	font-weight: bold;
}
#info .info_content .large {
	font-size: clamp(1.25rem, 0.806rem + 0.93vw, 1.5rem); /* 20 - 24 */
}
#info .info_content .mini_large {
	font-size: clamp(1.125rem, 0.903rem + 0.46vw, 1.25rem); /* 18 - 20 */
	margin: 0 auto 10px;
}
#info .info_content div .flex {
	margin: 2rem auto 2.5rem;
	padding: 0 30px;
}
#info .info_content p.access {
	font-size: clamp(1.125rem, 0.903rem + 0.46vw, 1.25rem);
	font-weight: bold;
}
#info .info_content div div.flex:has(div iframe) {
	flex-wrap: wrap;
	justify-content: center;
	margin: 2rem auto 2.5rem;
	gap: 1.5rem
}
#info .info_content div div:has(+ div iframe) {
	max-width: 40%;
}
#info .info_content div div:has(+ div iframe) img {
	border: 1px solid #ddd;
	min-width: 200px;
	width: 90%;
}
/* 問合せ */
#contact h2 span {
	color: #008b4f;
}
#contact .flex {
	justify-content: space-around;
	flex-wrap: wrap;
}
#contact .flex div {
	width: 45%;
	text-align: left;
}
#contact .flex div a.btn {
	width: 100%;
	padding: 1.5rem 5rem;
	margin-bottom: 1rem;
	font-size: clamp(1.125rem, 0.903rem + 0.46vw, 1.25rem); /* 18 - 20*/
}
#contact .flex div a.btn + p {
	margin: 0 2.5rem;
}
/* バナー */
#banner {
	background: #eee;
}
#banner .flex {
	justify-content: space-between;
	flex-wrap: wrap;
}
#banner .flex > div {
	width: 22%;
}
@media screen and (max-width: 768px) {
	h2 {
		margin-bottom: 20px;
	}
	.news_bk {
		background: #fff;
		padding: 15px 30px 30px;
		margin-bottom: 40px;
	}
	#news ul {
		display: block;
	}
	#news ul li:nth-child(odd) {
		border-bottom: none;
		padding: 1rem 1rem 0;
	}
	#news ul li:nth-child(even) {
		width: 100%;
		padding: 0.5rem 1rem 1rem;
		align-items: flex-start;
	}
	#news ul li:nth-child(odd) span {
		padding: 0.25rem 0;
	}
	#sns {
		min-height: 320px;
		padding: 80px 0;
	}
	#sns .flex {
		display: block;
	}
	#sns .flex iframe {
		width: 100%;
		margin-bottom: 30px;
	}
	#sns .flex > div:last-child {
		padding: 0;
	}
	.btn.instagram {
		padding: 0 2rem;
		margin: 0 auto;
	}
	/* info */
	#info h2 {
		padding: 1rem 2rem;
	}
	#info .info_content h3 {
		padding: 1rem 1.5rem;
		border-left: 8px solid #ffb400;
	}
	#info .info_content {
		padding: 50px 20px;
	}
	#info .info_content p.info_subtxt {
		line-height: 2.5;
		background-size: auto 2.5rem;
	}
	#info .info_content h4, #info .info_content div p, #info .info_content div ul {
		padding: 0 calc(0.5rem + 8px);
	}
	#info .info_content div ul li, #info .info_content div p.access {
		margin-bottom: 0.5rem;
	}
	#info .info_content div div .flex {
		padding: 0;
	}
	#info .info_content div div:has(+ div iframe) {
		width: 100%;
		max-width: inherit;
		margin: 0 auto 2.5rem;
		text-align: center;
	}
	#info div:has(+ div iframe) img {
		max-width: 360px;
	}
	/* 問合せ */
	#contact .flex div {
		width: 100%;
	}
	#contact .flex div:first-of-type {
		margin-bottom: 3rem;
	}
	#contact .flex div a.btn {
		width: 90%;
		padding: 1rem 4rem 1rem 2rem;
		margin: 0 auto 0.75rem;
		display: block;
	}
	#contact .flex div a.btn + p {
		margin: 0 2.25rem;
	}
	/* banner */
	#banner .flex {
		display: flex;
		gap: 20px 0;
	}
	#banner .flex > div {
		width: 48%;
	}
}
@media screen and (max-width: 479px) {}
@media screen and (max-width: 382px) {
	.tel, .mail {
		min-width: 175px;
	}
	.mail {
		margin-top: 0.5rem;
	}
}