@charset "UTF-8";
@import url(/css/cmn.css);
@import url(/css/base.css);

#hay img {
	width: auto;
	height: auto;
	max-width: 100%;
}





/*800以下*/
@media screen and (max-width: 800px) {}

/*----------------------------header-----------------------------------*/
/*#hay {
	margin-top: -115px;
	padding-top: 115px;
}*/
header {
	position: fixed;
	width: 96%;
	height: 115px;
	z-index: 1000;
	top: 0;
	pointer-events: none;
}

#head_logo {
	float: left;
	position: relative;
	pointer-events: auto;
}

#mmenu {
	display: none;
}

nav {
	float: right;
	margin-top: 50px;
	pointer-events: auto;
}

ul {
	width: 730px;
	margin-left: auto;
	display: flex;
	justify-content: center;
	align-items: center;
}

ul li {
	text-align: center;
	width: 100%;
	list-style: none;
}

.current {
	position: relative;

}

.current:after {
	position: absolute;
	content: url(/images/current.png);
	top: -20px;
	right: -10px;

}

.top_pd {
	padding: 0 2%;
}

/*1530以下*/

/*1000以下*/
@media screen and (max-width: 1000px) {
	.media_tablet ul {
		width: 530px !important;
	}
}

/*800以下*/
@media screen and (max-width: 800px) {
	header {
		position: relative;
		height: 0;
		z-index: 1000;
	}

	nav {
		margin-top: 0;
	}

	#mmenu {
		top: 15px;
		display: table;
		border: 3px solid #77C9CC;
		background: #77C9CC;
		width: 40px;
		height: 40px;
		position: fixed;
		top: 25px;
		right: 10px;
		z-index: 10;
		min-width: 0 !important;
		display: flex;
		align-items: stretch;
		clip-path: polygon(50% 0%,
				85% 15%,
				100% 50%,
				85% 85%,
				50% 100%,
				15% 85%,
				0% 50%,
				15% 15%);
	}

	#mmenu a {
		display: block;
		pointer-events: auto;
		width: 100%;
		position: relative;
	}

	#mmenu a:before,
	#mmenu a:after {
		content: "";
		display: block;
		width: 18px;
		height: 1px;
		background: #fff;
		position: absolute;
		top: 12px;
		left: 8px;
		transition: 0.2s ease-in-out;
	}

	#mmenu a:after {
		top: 21px;
	}

	#mmenu a.open:before,
	#mmenu a.open:after {
		top: 50%;
		left: 24%;
	}

	#mmenu a.open:before {
		transform: rotate(135deg);
	}

	#mmenu a.open:after {
		transform: rotate(-135deg);
	}

	#gnav {
		position: relative;
		z-index: 5;
	}

	header nav {
		display: block;
		position: fixed !important;
		text-align: left;
		top: 0;
		box-shadow: 0 0 5px rgba(0, 0, 0, 0.5);
		right: -70%;
		background-color: rgba(0, 0, 0, 0.7);
		height: 100%;
		width: 70%;
		z-index: 300;
	}

	header nav ul {
		border-top: 1px solid rgba(0, 0, 0, 0.5);
		border-bottom: 1px rgba(0, 0, 0, 0.5);
		margin-top: 90px;
		display: block;
	}

	header nav ul li {
		padding: 0;
		display: block;
		width: 100%;
		text-align: left;
		letter-spacing: 1px;
	}

	header nav ul li a {
		display: block;
		padding: 10px;
	}

	header nav ul li a:link,
	header nav ul li a:visited {
		color: #fff !important;
	}

	header nav ul li a:hover {
		color: #fff !important;
		background: #77C9CC;
	}

	.current {
		position: static;
		background: #77C9CC;
		color: #fff !important;

	}

	.current:after {
		display: none;
	}



	#head_logo {
		float: none;
		position: relative;
		left: 0;
		text-align: center;
	}

	#head_logo img {
		max-width: 30%;
	}

}

/*----------------------------main-----------------------------------*/
#mv_wrap {
	margin-top: -115px;
	padding-top: 115px;
}

#mv {
	position: relative;
	background: url(/images/mv.jpg)top center;
	max-width: 1910px;
	height: 864px !important;
	margin-top: 115px;
	margin-left: auto;
	margin-right: auto;
}

.form #mv {
	height: 400px !important;
}

#mv>img {
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	left: 0;
	margin: auto;
}

#mv_letter {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	align-content: center;
	justify-content: center;
	flex-wrap: wrap;
}

#mv_letter h2 {
	width: 100%;
	text-align: center;
	color: #fff;
	font-weight: normal;
	margin-top: 10px;
	font-size: 150%;
	padding: 0;
}

#mv_sp {
	display: none;
}

#lead {
	margin: -130px auto 0;
	padding: 0 7%;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 2;
	position: relative;
}

#lead_L {
	background: #77c9cc;
	width: 50%;
	height: auto;
	margin: 50px 0;
	position: relative;
}

#lead_L_letter {
	margin: 130px 40px 130px 60px;
	font-family: "Hiragino Kaku Gothic ProN", "メイリオ", sans-serif;
	font-size: 400%;
	color: #fff;
	line-height: 40px;
	font-weight: bold;
	line-height: 100%;
}

#lead_L_letter span {
	font-size: 30%;
	font-weight: normal;
}

#icon {
	position: absolute;
	right: -42px;
	top: 35%;
}

#lead_R {
	background: #fff;
	align-self: stretch;
	width: 50%;
	height: auto;
	display: flex;
	align-items: stretch;
	justify-content: center;
}

#lead_R_letter {
	margin: 95px 80px;
	display: flex;
	align-content: center;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
}

#lead_R_letter>* {
	width: 100%;
}

#margin850 {
	padding-top: 1350px;
}

@media screen and (max-width: 1000px) {
	#lead {
		display: block;
	}

	#lead_L {
		width: 100%;
		margin-bottom: 0;
		padding: 0 20px;
	}

	#lead_L_letter {
		margin: 0;
		padding: 50px;
		text-align: center;
	}

	#lead_R {
		width: 100%;
	}
}

@media screen and (max-width: 500px) {
	#lead_L_letter {
		font-size: 9vw !important;
	}
}

#column1 {
	margin: 30px auto 0 auto;
	text-align: center;
}

.column1_wrap {
	overflow: hidden;
	margin-bottom: 70px;
}

.column1_L {
	float: left;
	width: 50%;
}

.column1_R {
	float: right;
	width: 47%;
	text-align: left;
	padding-top: 30px;
}

#column2 {
	text-align: center;
	overflow: hidden;
	margin-top: -115px;
	/* 固定ナビの高さ分のネガティブマージン */
	padding-top: 115px;
	/* 打ち消し用のパディング */
	display: flex;
	align-items: stretch;
	justify-content: space-between;
	flex-wrap: wrap;
}

#column2 h2 {
	width: 100%;
}

.column2_wrap {
	width: 48%;
	position: relative;
	margin-bottom: 60px;
}
.column2_wrap:before{
	content: "";
	display: block;
	width: 100%;
	height: 65%;
	background: #fff;
	position: absolute;
	bottom: 0;
	left: 0;
}

.column2_t {
	z-index: 100;
	position: relative;
	margin: 0 auto;
	z-index: 2;
}

.column2_u {
	text-align: left;
	padding: 50px 50px;
	margin: 0 auto 0;
	position: relative;
	z-index: 2;
}

#column3 {
	text-align: center;
	overflow: hidden;
	margin-bottom: 110px;
	margin-top: -50px;
	/* 固定ナビの高さ分のネガティブマージン */
	padding-top: 115px;
	/* 打ち消し用のパディング */
}

#column3_L {
	float: left;
	width: 40%;
	text-align: right;
}

#column3_R {
	float: left;
	text-align: left;
	margin-left: 70px;
	width: 50%;
}

#column4 {
	text-align: center;
	background: url(/images/contact_bg.png);
	color: #fff;
	margin-top: -115px;
	/* 固定ナビの高さ分のネガティブマージン */
	padding-top: 50px;
	/* 打ち消し用のパディング */
}

#column4 .inner {
	max-width: 800px;
	margin: 0 auto;
	padding-bottom: 100px;
}

#column4 .inner p {
	text-align: left;
}

#column4 ol {
	margin-top: 40px;
	text-align: left;
	padding-left: 20px;
}

#column4 ol li {
	list-style: decimal;
}

#column4 ol li+li {
	margin-top: 20px;
}

#column4 ol li::first-line {
	font-weight: 600;
	font-size: 15px;
}
#column4 label:has(input[type="checkbox"]){
	display: inline-block;
	margin: 0 20px 0 0;
}
#column4 label:has(input[type="checkbox"]):hover{
	opacity: 0.8;
	cursor: pointer;
}
#column4 label:has(input[type="checkbox"]) input[type="checkbox"]{
	margin-right: 5px;
}
#column4 label:has(input[type="checkbox"]) span{
	font-size: 11px;
	background: #333;
	padding: 2px 5px;
	line-height: 1;
	margin-right: 5px;
	color: #ddd;
}

#mailform {
	padding: 50px 0px 220px 0;
}

dl {
	display: table;
	width: 100%;
	table-layout: fixed;
	margin-bottom: 25px;
}

dt,
dd{
	vertical-align: middle;
}

dt {
	display: table-cell;
	width: 30%;
	text-align: right;
}

dd {
	display: table-cell;
	text-align: left;
	padding-left: 20px;
}

form input.text_area {
	display: ;
	background: #fff;
	border: 1px solid #ccc;
	padding: 10px;
	font-size: 13px;
	color: #333;
	width: 510px !important;
	font-family: "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", Osaka, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "MS P Gothic", Verdana, Arial, Helvetica, sans-serif;
}

form .long_text_area {
	display: ;
	background: #fff;
	border: 1px solid #ccc;
	padding: 10px;
	font-size: 13px;
	color: #333;
	width: 640px !important;
	font-family: "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", Osaka, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "MS P Gothic", Verdana, Arial, Helvetica, sans-serif;
}


form input[type="submit"] {
	font-size: 120% !important;
	display: inline-block;
	width: auto;
	padding: 12px 135px;
	margin: 0 auto;
	max-width: none !important;
	background: #77c9cc;
	color: #fff !important;
	cursor: pointer;
	border: none;
	letter-spacing: 10px;
	font-family: "Hiragino Kaku Gothic ProN", "メイリオ", sans-serif;
	-webkit-appearance: none;
	border-radius: 0;
}


form input[type="button"] {
	font-size: 120% !important;
	display: inline-block;
	width: auto;
	padding: 12px 30px;
	margin: 0 auto;
	max-width: none !important;
	background: #77c9cc;
	color: #fff !important;
	cursor: pointer;
	border: none;
	letter-spacing: 5px;
	font-family: "Hiragino Kaku Gothic ProN", "メイリオ", sans-serif;
	-webkit-appearance: none;
	border-radius: 0;
}

#fixbtn {
	width: 1218px;
	height: 160px;
	position: fixed;
	left: 50%;
	margin-left: -609px;
	z-index: 10000;
}

@media screen and (-webkit-min-device-pixel-ratio:0) {
	#fixbtn {
		height: 90px;
	}
}

#wk div:nth-child(1) {
	background-color: transparent;
	width: 100%;
	height: 10px;
	position: absolute;
	top: 0;
	left: 0;
}

#wk div:nth-child(2) {
	background-color: transparent;
	width: 10px;
	height: 100%;
	position: fixed;
	top: 0;
	left: 0;
}

#wk div:nth-child(3) {
	background-color: transparent;
	width: 10px;
	height: 100%;
	position: fixed;
	top: 0;
	right: 0;
}

footer {
	text-align: center;
	background: #282828;
	padding: 40px 0;
	color: #fff;
}

address {
	font-style: normal;
}

#page_top {
	position: fixed;
	bottom: 15px;
	right: 20px;
	z-index: 1000;
}

/*1500以下*/
@media screen and (max-width: 1600px) {
	#lead_R_letter {
		margin: 95px 80px;
	}
}

/*940以下*/
@media screen and (max-width: 1080px) {
	#lead_R_letter {
		margin: 70px;
	}

	form .long_text_area,
	form input.text_area {
		width: 90% !important;
	}

	#send {
		margin-left: 25%;
	}
}


/*940以下*/
@media screen and (max-width: 1000px) {

	#mv_letter h2 {
		font-size: 120%;
	}

	.column2_wrap {
		padding: 5px;
	}

	#lead_R_letter {
		margin: 60px;
	}
}


/*800以下*/
@media screen and (max-width: 1000px) {
	#mv {
		display: none;
	}

	#mv_sp {
		display: block;
		background: url(/images/sp_mv.jpg) center top no-repeat;
		background-size: cover;
		margin-top: 90px;
	}

	#mv_sp img {
		padding-top: 100px;
	}

	#mv_sp h2 {
		font-size: 85%;
		color: #fff;
		text-align: center;
		padding: 0 30px 100px 30px;

	}

	#margin850 {
		display: none;
	}

	#lead {
		margin-top: -40px;
	}

	#lead_L {
		height: auto;
	}

	#lead_R {
		height: auto;
	}

	#lead_R_letter {
		margin: 0;
		padding: 50px 20px;
	}

	#lead_L_letter {
		margin: 20px 0 0 0;
		font-size: 255%;
		padding: 50px 0;
	}

	#lead_L {
		margin-top: 0;
		float: none;
		width: 100%;
		text-align: center;
	}

	#lead_R,
	.column1_L,
	.column1_R {
		float: none;
		width: 100%;
		text-align: center;
	}

	#icon {
		position: absolute;
		right: 0;
		top: 142px;
		left: 0;
		right: 0;
	}

	#column1 {
		margin: 0 auto;
		text-align: center;
		padding-top: 0;
	}

	.column2_wrap {
		float: none;
		width: 100%;
		height: auto;
		padding: 0;
	}

	.column2_u {
		text-align: center;
		top: 0;
		width: auto;
		height: auto;
		left: 0;
		padding: 30px;
	}

	#column3_L {
		float: none;
		width: 100%;
		text-align: center;
		margin-bottom: 20px;
	}

	#column3_R {
		float: none;
		text-align: left;
		width: 100%;
		margin-left: 0;
	}

	#wrap4 {
		width: 96%;
		margin: 0 auto;
	}

	#mailform {
		padding: 50px 0px;
	}

	form input[type="submit"] {
		width: 90%;
		max-width: 200px !important;
		padding: 10px;
	}

	dl,
	dt,
	dd {
		width: 100%;
		display: block;
	}

	dt {
		text-align: left;
	}

	form input.text_area,
	form .long_text_area {
		width: 95% !important;
	}

	#send {
		margin-left: 0;
	}

	#fixbtn {
		height: auto;
		z-index: 999;
		position: static;
		left: 0;
		width: auto;
		margin-left: 0;
		padding-bottom: 90px;
	}

	#fixbtn img {
		max-width: 100%;
	}


	#page_top {
		bottom: 10px;
		right: 0;
		z-index: 999;
	}

	#page_top img {
		max-width: 70%;
	}

}

/*----------------------------footer-----------------------------------*/



#column8{
	text-align: center;
	padding-bottom: 40px;
	counter-reset: number 0;
	padding-bottom: 0;
}
#column8 ol{
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	justify-content: flex-start;
	width: 100%;
	max-width: 1050px;
	margin: 30px auto 0;
}
#column8 ol li{
	display: block;
	width: 20%;
	text-align: left;
	padding: 0 10px;
	box-sizing: border-box;
	position: relative;
	margin-bottom: 20px;
}
#column8 ol li:before{
	counter-increment: number 1;
	content: "0" counter(number);
	clip-path: polygon(50% 0%,
			85% 15%,
			100% 50%,
			85% 85%,
			50% 100%,
			15% 85%,
			0% 50%,
			15% 15%);
	background-color: #77c9cc;
	color: #fff;
	aspect-ratio: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	line-height: 1;
	font-size: 20px;
	margin: 0 auto 20px;
	width: 120px;
	position: relative;
	z-index: 2;
}
#column8 ol li:after{
	content: "";
	width: 100%;
	height: 60px;
	border-bottom: 1px solid #77c9cc;
	position: absolute;
	top: 0;
	left: 0;
}
#column8 ol li:nth-child(1):after{
	width: 50%;
	left: 50%;
}
#column8 ol li:nth-last-child(1):after{
	width: 50%;
}
@media screen and (max-width: 800px) {
	#column8 ol li{
		width: 33.3%;
	}
}
@media screen and (max-width: 450px) {
	#column8 h2+p{
		text-align: left;
	}
	#column8 ol{
		display: block;
	}
	#column8 ol li{
		width: 100%;
		display: flex;
		align-items: center;
		justify-content: flex-start;
		padding: 0 0 0 90px;
		min-height: 70px;
	}
	#column8 ol li:before{
		position: absolute;
		top: 0;
		left: 0;
		width: 70px;
	}
	#column8 ol li:after{
		border: none;
		background-color: #77c9cc;
		width: 1px !important;
		height: calc(100% + 20px);
		left: 35px !important;
		top: 0;
	}
	#column8 ol li:nth-last-child(1):after{
		display: none;
	}
}

#column5 {
	background: #f3f3f3;
	padding-top: 20px;
	text-align: center;
	padding-bottom: 20px;
}
#column5 .wrap1300{
	max-width: 1600px;
}
#column5 h2+p{
	margin-bottom: 40px;
}
#column5 ul {
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	justify-content: center;
	width: 100% !important;
}

#column5 li {
	display: flex;
	align-items: stretch;
	justify-content: center;
	width: 18%;
	margin: 0 1% 40px;
	position: relative;
	box-sizing: border-box;
	padding-bottom: 70px;
	background: #fff;
}
#column5 li:before{
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	pointer-events: none;
	box-sizing: border-box;
	border: 1px solid #eee;
	border-bottom: none;
	z-index: 3;
}
#column5 li:has(input:checked):before{
	border: 2px solid #449b9e;
}
#column5 li a {
	display: block;
	line-height: 1.7;
	position: relative;
	text-align: left !important;
}
#column5 li label{
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	background-color: #77c9cc;
	color: #fff;
	padding: 10px;
	box-sizing: border-box;
	font-size: 14px;
	text-align: center !important;
	font-weight: 600;
	letter-spacing: 0.05em;
	cursor: pointer;
}
#column5 li label:hover{
	background-color: #449b9e;
}
#column5 li label input{
	display: none;
}
#column5 li label:after{
	content: "お申し込み";
}
#column5 li:has(input:checked) label{
	background-color: #449b9e;
}
#column5 li:has(input:checked) label:after{
	content: "解除";
}

#column5 li div {
	border: 1px solid #eee;
	margin-bottom: 15px;
	position: relative;
}
#column5 li div img{
	display: block;
	aspect-ratio: 320/180;
	width: 100%;
	object-fit: cover;
}
#column5 li a[href*="wiple-service.com"] div img,
#column5 li a[href*="isshin-kikaku.com"] div img{
	object-position: 50% 0;
}
#column5 li div span{
	background-color: #333;
	color: #fff;
	position: absolute;
	top: 0;
	left: 0;
	font-size: 12px;
	line-height: 1;
	padding: 3px 5px;
}

#column5 li p{
	padding: 0 20px;
	font-size: 14px;
}
#column5 li div+p {
	font-size: 16px;
	font-weight: 600;
	margin-bottom: 7px;
	color: #77c9cc;
}

#column5 li div+p+p {
	font-size: 13px;
	opacity: 0.7;
	margin-bottom: 10px;
}

@media screen and (max-width: 1100px) {
	#column5 li {
		width: 22%;
	}
}
@media screen and (max-width: 850px) {
	#column5 li {
		width: 31.3%;
	}
	#column5 li div+p+p {
		display: none;
	}
}
@media screen and (max-width: 650px) {
	#column5 ul {
		justify-content: flex-start;
	}
	#column5 li {
		width: 46%;
		margin-left: 2%;
		margin-right: 2%;
		margin-bottom: 30px;
		padding-bottom: 60px;
	}
	#column5 li div {
		margin-bottom: 10px;
	}
	#column5 li p{
		padding: 0 10px;
	}
}

#column6 {
	text-align: center;
	padding-bottom: 60px;
}

#column6 dl,
#column6 dt,
#column6 dd {
	display: block;
	width: 100%;
	max-width: 800px;
	margin: 0 auto;
	text-align: left;
	padding: 0;
	box-sizing: border-box;
}

#column6 dl {
	background-color: #fff;
	padding: 30px;
}

#column6 dl+dl {
	margin-top: 20px;
}

#column6 dt {
	font-size: 16px;
	font-weight: 600;
	margin-bottom: 15px;
}

#column6 dt,
#column6 dd {
	padding-left: 55px;
	position: relative;
}

#column6 dt:before,
#column6 dd:before {
	content: "Q";
	display: block;
	line-height: 1;
	width: 40px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	border-radius: 200px;
	background: #77c9cc;
	color: #fff;
	position: absolute;
	top: -7px;
	left: 0;
	font-weight: 600;
}
#column6 dd:before {
	content: "A";
}

#column6 dd:before {
	border: 1px solid #77c9cc;
	color: #77c9cc;
	background: #fff;
}

#column4.linked {
	margin-top: 0;
	padding-top: 40px;
}

#intro{
	text-align: center;
}
#intro .inner{
	max-width: 1100px;
	margin: 0 auto;
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	justify-content: space-between;
	margin-bottom: 20px;
	position: relative;
	line-height: 1.5;
}
#intro .inner:after{
	content: "";
	display: block;
	width: 1px;
	height: 100%;
	position: absolute;
	top: 0;
	left: 50%;
	background: #000;
}
#intro .inner>div{
	width: 45%;
	box-sizing: border-box;
}
#intro .inner img{
	display: block;
	margin: 0 auto 20px;
}
@media screen and (max-width: 500px) {
	#intro .inner:after{
		display: none;
	}
	#intro .inner>div{
		width: 85%;
		max-width: 300px;
		margin: 0 auto;
	}
	#intro .inner>div+div{
		margin-top: 25px;
	}
}
