@charset "utf-8";
/* CSS Document */

/*==============================*/
/* mainvisual */
/*==============================*/
div.mainVisual{
	position: relative;
	margin-bottom: 32px;
	padding: 68px 64px 0 64px;
}
	/* ======= TB：個別設定 =======*/
	@media screen and (min-width: 768px) and (max-width: 1240px) {
		div.mainVisual{
			margin-bottom: 56px;
			padding: 56px 48px 0 48px;
		}
		div.mainVisual img{
			object-fit: cover;
			height: 320px;
		}
	}
	/* ======= SP =======*/
	@media (max-width: 767px) {
		div.mainVisual{
			margin-bottom: 64px;
			padding: 24px 24px 0 24px;
		}
		div.mainVisual img{
			object-fit: cover;
			height: 280px;
		}
	}


/*-- タイトル
------------------------- */
div.mainVisual h1{
	position: absolute; top: 160px; right: calc( calc( 100% - 1200px ) / 2 );
	height: 640px;
	padding: 96px 44px 0 48px;
	background: #fff;
	writing-mode: vertical-rl;
	font-size: 28px;
	font-family: "Zen Old Mincho", serif;
	font-weight: 500;
	letter-spacing: 0.1em;
	line-height: 1.55em;
}
div.mainVisual h1::before{
	position: absolute; top: 16px; right: 16px;
	content: "";
	width: 58px;
	height: 58px;
	background: url("/common/img/top/icon-catchcopy.svg");
	background-size: cover;
}
	/* ======= TB:個別設定 =======*/
	@media screen and (min-width: 1025px) and (max-width: 1350px) {
		div.mainVisual h1{
			position: absolute; top: 160px; right: 96px;
			height: 560px;
			padding: 88px 44px 0 48px;
			font-size: 28px;
		}
	}
	/* ======= TB：個別設定 =======*/
	@media screen and (min-width: 768px) and (max-width: 1240px) {
		div.mainVisual h1{
			position: absolute; top: 104px; right: 80px;
			height: 480px;
			padding: 70px 30px 0 36px;
			font-size: 24px;
			line-height: 1.414em;
		}
		div.mainVisual h1::before{
			position: absolute; top: 14px; right: 14px;
			width: 36px;
			height: 36px;
		}
	}
	/* ======= SP =======*/
	@media (max-width: 767px) {
		div.mainVisual h1{
			position: absolute; top: 80px; right: 40px;
			height: 400px;
			padding: 56px 20px 0 24px;
			font-size: 21px;
			letter-spacing: 0.1em;
			line-height: 1.3em;
		}
		div.mainVisual h1::before{
			position: absolute; top: 12px; right: 12px;
			width: 32px;
			height: 32px;
		}
	}


/*==============================*/
/* top Frame */
/*==============================*/
div.topWrap{
	max-width: 1368px;
	padding: 0 64px;
	margin: 0 auto;
}

	/* ======= TB：個別設定 =======*/
	@media screen and (min-width: 768px) and (max-width: 1240px) {
		div.topWrap{ padding: 0px 48px;}
	}
	/* ======= SP =======*/
	@media (max-width: 767px) {
		div.topWrap{ padding: 24px 24px 0 24px;}
	}


/*==============================*/
/* topMessage */
/*==============================*/
div.topMessage{
	display: flex;
}
div.topMessage figure{
	width: 260px;
}
div.topMessage > div{
	position: relative;
	flex: 1;
	margin-left: 52px;
	padding-top: 120px;
	padding-bottom: 72px;
	padding-right: 264px;
}

div.topMessage > div::before{
	position: absolute; top: -192px; left: 64px;
	content: "";
	width: 127px;
	height: 282px;
	background: url("/common/img/top/illust-message01.svg");
	background-size: cover;
}

	/* ======= PC =======*/
	@media (min-width: 1240px) {
		div.topMessage > div::after{
			position: absolute; bottom: -24px; right: 0;
			content: "";
			width: 226px;
			height: 342px;
			background: url("/common/img/top/illust-message02.svg");
			background-size: cover;
			z-index: 99;
		}
	}
	/* ======= TB =======*/
	@media screen and (min-width: 768px) and (max-width: 1240px) {
		div.topMessage figure{ width: 200px;}
		div.topMessage > div{
			margin-left: 40px;
			padding-top: 88px;
			padding-bottom: 72px;
			padding-right: 0px;
		}
		div.topMessage > div::before{
			position: absolute; top: -176px; left: 48px;
			width: 101px;
			height: 225px;
		}
		div.topMessage > div::after{
			position: absolute; bottom: -24px; right: 0;
			width: 226px;
			height: 342px;
		}
	}
	/* ======= SP =======*/
	@media (max-width: 767px) {
		div.topMessage{
			flex-direction: column-reverse; -webkit-flex-direction: column-reverse;
			margin-bottom: 32px;
		}
		div.topMessage figure{
			position: relative;
			width: 100%;
		}
		div.topMessage figure img{ width: calc(100% - 280px - 40px);}
		div.topMessage figure::before{
			position: absolute; bottom: -24px; right: 0;
			content: "";
			width: 280px;
			height: 440px;
			background: url("/common/img/top/illust-message02.svg");
			background-size: cover;
			z-index: 99;
		}
		
		div.topMessage > div{
			width: 100%;
			margin-left: 0px;
			margin-bottom: 24px;
			padding-top: 40px;
			padding-bottom: 0px;
			padding-right: 0px;
		}
		div.topMessage > div::before{
			position: absolute; top: -168px; left: 48px;
			content: "";
			width: 88px;
			height: 197px;
		}
		div.topMessage > div::after{
			position: absolute; bottom: -200px; right: 0;
			content: "";
			width: 135px;
			height: 205px;
		}
	}
	/* ======= SP =======*/
	@media (max-width: 600px) {
		div.topMessage figure img{ width: calc(100% - 200px - 20px);}
		div.topMessage figure::before{
			width: 200px;
			height: 320px;
		}
	}
	/* ======= SP =======*/
	@media (max-width: 450px) {
		div.topMessage figure img{ width: calc(100% - 160px - 20px);}
		div.topMessage figure::before{
			width: 160px;
			height: 240px;
		}
	}


/*-- タイトル
------------------------- */
/*--  -- */
div.topMessage h2{
	position: relative;
	margin-bottom: 18px;
	padding-top: 29px;
	line-height: 1.3em;
	font-size: 43px;
	font-weight: bold;
	letter-spacing: -0.01em;
	color: #000;
}
div.topMessage h2::before{
	position: absolute; top: 0; left: 0;
	content: "";
	width: 80px;
	height: 22px;
	background: url("/common/img/share/icon-title.svg");
	background-size: cover;
}
div.topMessage h2 small{
	position: relative; top: -3px;
	display: inline-block;
	margin: 0 0 0 6px;
	font-size: 37px;
	font-weight: bold;
}

/*--  -- */
div.topMessage h3{
	margin-bottom: 12px;
	color: #000;
	font-size: 28px;
	font-weight: 500;
	font-family: "Zen Old Mincho", serif;
	letter-spacing: 0.04em;
	line-height: 1.414em;
}
div.topMessage h3 small{
	position: relative; top: -5px;
	font-size: 18px;
	font-weight: bold;
}
	/* ======= TB =======*/
	@media screen and (min-width: 768px) and (max-width: 1024px) {
		div.topMessage h2{
			margin-bottom: 14px;
			padding-top: 29px;
			font-size: 38px;
		}
		div.topMessage h2::before{
			position: absolute; top: 0; left: 0;
			width: 72px;
			height: 19px;
		}
		div.topMessage h2 small{
			position: relative; top: -3px;
			font-size: 32px;
		}

		/*--  -- */
		div.topMessage h3{
			margin-bottom: 12px;
			font-size: 27px;
		}
		div.topMessage h3 small{
			position: relative; top: -5px;
			font-size: 17px;
		}
	}
	/* ======= SP =======*/
	@media (max-width: 767px) {
		/*--  -- */
		div.topMessage h2{
			margin-bottom: 12px;
			padding-top: 26px;
			font-size: 36px;
			letter-spacing: -0.03em;
		}
		div.topMessage h2::before{
			width: 64px;
			height: 17px;
		}
		div.topMessage h2 small{
			position: relative; top: -3px;
			margin: 0 0 0 6px;
			font-size: 30px;
		}

		/*--  -- */
		div.topMessage h3{
			margin-bottom: 13px;
			font-size: 24px;
		}
		div.topMessage h3 small{
			position: relative; top: -5px;
			font-size: 16px;
		}
	}


/*-- テキスト
------------------------- */
div.topMessage > div p{
	font-size: 15px;
	line-height: 1.8em;
}

div.topMessage > div ul li{
	font-size: 15px;
	line-height: 1.58em;
}
div.topMessage > div ul li:not(:last-child){
	margin-bottom: 8px;
}

	/* ======= TB =======*/
	@media screen and (min-width: 768px) and (max-width: 1024px) {
	}
	/* ======= SP =======*/
	@media (max-width: 767px) {
	}



/*==============================*/
/* Service */
/*==============================*/
section.topService-wrap{
	position: relative;
	padding: 48px;
	background: #F3F3F3 url("/common/img/share/bg-texture.webp");
}
section.topService-wrap::before{
	position: absolute; top: 50%; right: 0;
	content: "";
	width: 280px;
	height: 280px;
	background: url("/common/img/top/icon-service.svg") no-repeat;
	background-size: cover;
	margin-top: -140px;
}
section.topService-wrap::after{
	position: absolute; bottom: 192px; right: 184px;
	content: "";
	width: 1px;
	height: 240px;
	background: #ccc;
}

section.topService-wrap > div{
	padding: 64px 64px 120px 64px;
	background: #fff;
}
	/* ======= TB:個別設定 =======*/
	@media screen and (min-width: 1025px) and (max-width: 1350px) {
		section.topService-wrap{ padding: 32px;}
		section.topService-wrap::before{
			position: absolute; top: 50%; right: 0;
			width: 224px;
			height: 224px;
			margin-top: -112px;
		}
		section.topService-wrap::after{
			position: absolute; bottom: 192px; right: 160px;
			width: 1px;
			height: 240px;
		}

		section.topService-wrap > div{ padding: 56px 40px 120px 40px;}
	}
	/* ======= TB =======*/
	@media screen and (min-width: 768px) and (max-width: 1024px) {
		section.topService-wrap{ padding: 32px;}
		section.topService-wrap::before{ display: none;}
		section.topService-wrap::after{ display: none;}
		
		section.topService-wrap > div{ padding: 56px 40px 160px 40px;}
	}
	/* ======= SP =======*/
	@media (max-width: 767px) {
		section.topService-wrap{
			width: calc(100% + 48px);
			margin-left: -24px;
			padding: 20px 16px 16px 16px;
		}
		
		section.topService-wrap::before{ display: none;}
		section.topService-wrap::after{ display: none;}
		
		section.topService-wrap > div{ padding: 40px 20px 104px 20px;}
	}

/*-- ボタン
------------------------- */
section.topService-wrap p.topService-btn{
	position: absolute; bottom: 80px; right: 80px;
	max-width: 216px;
	width: 100%;
}
section.topService-wrap p.topService-btn a{
	display: block;
	padding: 16px 8px 16px 0;
	background: #1DA25A;
	color: #fff;
	text-align: center;
}
section.topService-wrap p.topService-btn a::after{
	position: absolute; top: 26px; right: 20px;
	content: "";
	width: 10px;
	height: 10px;
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
section.topService-wrap p.topService-btn a:hover{ background: #16914E;}

 
	/* ======= TB:個別設定 =======*/
	@media screen and (min-width: 1025px) and (max-width: 1350px) {
		section.topService-wrap p.topService-btn{ position: absolute; bottom: 64px; right: 64px;}
	}
	/* ======= TB =======*/
	@media screen and (min-width: 768px) and (max-width: 1024px) {
		section.topService-wrap p.topService-btn{ position: absolute; bottom: 64px; right: 64px;}
	}
	/* ======= SP =======*/
	@media (max-width: 767px) {
		section.topService-wrap p.topService-btn{
			position: absolute; bottom: 16px; right: 16px;
			max-width: 176px;
		}
		section.topService-wrap p.topService-btn a{ padding: 14px 10px 14px 0;}
		section.topService-wrap p.topService-btn a::after{
			position: absolute; top: 22px; right: 16px;
		}
	}


/*-- コンテンツ
------------------------- */
div.topService{
	display: flex;
	flex-wrap: wrap; -webkit-flex-wrap: wrap;
	gap: 80px 32px;
	padding: 0 216px 0 24px;
}
div.topService > div:nth-child(1){ width: 100%;}

div.topService > div:nth-child(2),
div.topService > div:nth-child(3){ width: calc( calc( 100% - calc( 32px * 1 ) ) / 2 );}

/*--  画像 -- */
div.topService > div:nth-child(2) figure,
div.topService > div:nth-child(3) figure{
	position: relative;
	margin-bottom: 28px;
}


div.topService > div figure::before{
	content: "";
	z-index: 99;
}
div.topService > div:nth-child(2) figure::before{
	position: absolute; bottom: -48px; right: 10px;
	width: 169px;
	height: 140px;
	background: url("/common/img/top/icon-service02.png");
	background-size: cover;
}
div.topService > div:nth-child(3) figure::before{
	position: absolute; bottom: -64px; right: -10px;
	width: 211px;
	height: 174px;
	background: url("/common/img/top/icon-service03.png");
	background-size: cover;
}

div.topService > div:nth-child(2) figure a:hover,
div.topService > div:nth-child(3) figure a:hover{ opacity: 0.7;}


/*--  タイトル -- */
div.topService h3{
	margin-bottom: 14px;
	font-size: 25px;
	font-weight: bold;
	line-height: 1.414em;
	color: #000;
}
div.topService h3 small{
	margin-bottom: 4px;
	font-size: 16px;
	line-height: 1.414em;
}

div.topService > div:first-child h3{ font-size: 27px;}
div.topService > div:first-child h3 small{
	position: relative; top: -2px;
	margin-left: 8px;
}

div.topService > div:not(:first-child) h3 small{ display: block;}

/*--  テキスト -- */
div.topService p{
	font-size: 15px;
	line-height: 1.7em;
	text-align: justify;
	text-align-last: left;
}

	
	/* ======= TB:個別設定 =======*/
	@media screen and (min-width: 1025px) and (max-width: 1350px) {
		div.topService{
			gap: 72px 24px;
			padding: 0 176px 0 12px;
		}
		div.topService > div:nth-child(2),
		div.topService > div:nth-child(3){ width: calc( calc( 100% - calc( 24px * 1 ) ) / 2 );}
	}
	/* ======= TB =======*/
	@media screen and (min-width: 768px) and (max-width: 1024px) {
		div.topService{
			gap: 56px 24px;
			padding: 0;
		}
		
		/*--  画像 -- */
		div.topService > div:nth-child(2),
		div.topService > div:nth-child(3){ width: calc( calc( 100% - calc( 24px * 1 ) ) / 2 );}
		
		div.topService > div:nth-child(2) figure::before,
		div.topService > div:nth-child(3) figure::before{
			position: absolute; bottom: -48px; right: 8px;
			width: 112px;
			height: 88px;
		}
		
		/*--  タイトル -- */
		div.topService h3{
			margin-bottom: 10px;
			font-size: 23px;
		}
		div.topService h3 small{
			margin-bottom: 2px;
			font-size: 14px;
		}
		div.topService > div:first-child h3{
			display: flex;
			flex-direction: column-reverse; -webkit-flex-direction: column-reverse;
			font-size: 26px;
		}
		div.topService > div:first-child h3 small{
			position: relative; top: 4px;
			margin-left: 0px;
		}
		
		/*--  テキスト -- */
		div.topService p{
			font-size: 14px;
			line-height: 1.618em;
		}
	}
	/* ======= SP =======*/
	@media (max-width: 767px) {
		div.topService{
			flex-direction: column; -webkit-flex-direction: column;
			gap: 48px 0px;
			padding: 0;
		}
		div.topService > div:nth-child(1){ width: 100%;}

		div.topService > div:nth-child(2),
		div.topService > div:nth-child(3){ width: 100%;}

		/*--  画像 -- */
		div.topService > div:nth-child(2) figure,
		div.topService > div:nth-child(3) figure{ margin-bottom: 20px;}
		
		div.topService > div:nth-child(2) figure::before{
			position: absolute; bottom: -44px; right: 10px;
			width: 152px;
			height: 126px;
		}
		div.topService > div:nth-child(3) figure::before{
			position: absolute; bottom: -64px; right: -10px;
			width: 189px;
			height: 156px;
		}

		/*--  タイトル -- */
		div.topService h3{
			margin-bottom: 10px;
			font-size: 22px;
		}
		div.topService h3 small{
			margin-bottom: 2px;
			font-size: 15px;
		}
		
		div.topService > div:first-child h3{
			display: flex;
			flex-direction: column-reverse; -webkit-flex-direction: column-reverse;
			font-size: 24px;
		}
		div.topService > div:first-child h3 small{
			position: relative; top: 2px;
			margin-left: 0px;
		}
		
		/*--  テキスト -- */
		div.topService p{ font-size: 14px;}
	}


/*-- 
------------------------- */
div.topService div.topService-box figure{
	position: relative;
	margin-bottom: 32px;
}
div.topService div.topService-box figure::before{
	position: absolute; bottom: -56px; right: 50%;
	width: 182px;
	height: 158px;
	background: url("/common/img/top/icon-service01.png")no-repeat;
	background-size: 100%;
	margin-right: -40px;
}
div.topService div.topService-box figure a:hover{ opacity: 0.7;}

div.topService div.topService-box div.topService-content{
	display: flex;
}
div.topService div.topService-box div.topService-content div:nth-child(1){ width: 344px;}

div.topService div.topService-box div.topService-content div:nth-child(2){
	position: relative;
	flex: 1;
	margin-left: 36px;
}

/*--  補足説明 -- */
div.topService div.topService-box div dl{
	position: relative;
	padding: 24px;
	border: 1px solid #000;
	box-shadow: 6px 6px 0px 0px rgba(000,000,000,1);
	background: #fff;
	z-index: 99;
}
div.topService div.topService-box div dl dt{
	margin-bottom: 4px;
	color: #000;
	font-size: 17px;
	font-weight: 600;
}
div.topService div.topService-box div dl dd p{
	font-size: 13px;
	line-height: 1.618em;
	text-align: justify;
	text-align-last: left;
}
div.topService div.topService-box div dl dd p:not(:last-child){ margin-bottom: 8px;}

/*--  画像 -- */
div.topService div.topService-box div ul{
	display: flex;
	margin-top: 240px;
	gap: 0 16px;
}
div.topService div.topService-box div ul li{
	width: calc( calc( 100% - calc( 16px * 1 ) ) / 2 );
	border: 1px solid #D8D8D8;
}

	/* ======= SP以上 =======*/
	@media (min-width: 768px) {
		div.topService div.topService-box div dl{
			position: absolute; top: -96px; right: 50%;
			max-width: 312px;
			margin-right: -156px;
		}
	}
	/* ======= TB =======*/
	@media screen and (min-width: 768px) and (max-width: 1024px) {
		div.topService div.topService-box figure{ margin-bottom: 32px;}
		div.topService div.topService-box div.topService-content{
			display: flex;
		}
		div.topService div.topService-box div.topService-content div:nth-child(1){ width: 312px;}

		div.topService div.topService-box div.topService-content div:nth-child(2){
			margin-left: 24px;
		}

		/*--  補足説明 -- */
		div.topService div.topService-box div dl{
			padding: 20px;
			box-shadow: 4px 4px 0px 0px rgba(000,000,000,1);
		}
		div.topService div.topService-box div dl dt{
			margin-bottom: 2px;
			font-size: 16px;
		}
		div.topService div.topService-box div dl dd p:not(:last-child){ margin-bottom: 6px;}

		/*--  画像 -- */
		div.topService div.topService-box div ul{
			margin-top: 240px;
			gap: 0 12px;
		}
		div.topService div.topService-box div ul li{
			width: calc( calc( 100% - calc( 12px * 1 ) ) / 2 );
			border: 1px solid #D8D8D8;
		}
		
	}
	/* ======= SP =======*/
	@media (max-width: 767px) {
		div.topService div.topService-box figure{ margin-bottom: 24px;}
		div.topService div.topService-box figure::before{
			position: absolute; bottom: -56px; right: 8px;
			width: 163px;
			height: 142px;
			margin-right: 0px;
		}
		
		
		div.topService div.topService-box div.topService-content{ flex-direction: column; -webkit-flex-direction: column;}
		div.topService div.topService-box div.topService-content div:nth-child(1){
			width: 100%;
			margin-bottom: 24px;
		}

		div.topService div.topService-box div.topService-content div:nth-child(2){ margin-left: 0px;}

		/*--  補足説明 -- */
		div.topService div.topService-box div dl{
			margin-bottom: 28px;
			padding: 16px 20px 16px 20px;
			box-shadow: 4px 4px 0px 0px rgba(000,000,000,1);
		}
		div.topService div.topService-box div dl dt{
			margin-bottom: 4px;
			font-size: 16px;
		}
		div.topService div.topService-box div dl dd{
			font-size: 13px;
			line-height: 1.5em;
		}

		/*--  画像 -- */
		div.topService div.topService-box div ul{
			gap: 0 8px;
			margin-top: 0;
		}
		div.topService div.topService-box div ul li{ width: calc( calc( 100% - calc( 8px * 1 ) ) / 2 );}
	}


