@charset "utf-8";
:root {--main-color: #504D7F;}
:root {--sub-color: #FAF7F4;}
:root {--text-color: #5E5E5E;}
:root {--text-font: "Noto Sans JP";}
:root {--sub-font: "Noto Sans JP";}
section{
	width: 100%;
	position: relative;
	overflow: hidden;
}
.bg{
	background: var(--sub-color);
}
.inner{
	width: 90%;
	margin: 0 auto;
    position: relative;
}
h1,h2,h3,h4,h5,h6{
	font-weight: 300;
	line-height: 2;
	letter-spacing: 0.12em;
}
p,a,li{
	font-size: 15px;
	font-weight: 300;
	line-height: 2;
	letter-spacing: 0.12em;
}
footer a{
	color: #fff;
}
@media (min-width: 769px) and (max-width: 1279px) {
	p,a,li{
		font-size: 1.172vw;
	}
}
@media screen and (max-width: 768px) {
	.inner{
		max-width: 520px;
	}
}
/*==================================================================================================*/
/*共通記述*/
.catchcopy{
	font-size: 29px;
	color: #7D7BA3;
}
.catchcopy span{
	display: inline-block;
	line-height: 1.6;
	padding: 0 15px;
	border-radius: 5px;
	background: #FFF;
	margin: 0 2px;
}
.title{
	font-size: 29px;
	text-align: center;
	color: #B3B1D3;
	margin-bottom: 48px;
}
.title span{
	display: block;
	font-size: 14px;
	font-weight: 500;
}
.title + p{
	text-align: center;
}
.btn{
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	max-width: 230px;
	height: 55px;
	font-size: 12px;
	color: #7D7BA3;
	box-shadow: 0 0 4px 0 rgba(0,0,0,0.25);
	background: #FFF;
	margin: 0 auto;
	transition: .5s;
}
.btn:hover{
	color: #FFF;
	background: var(--main-color);
}
@media (min-width: 769px) and (max-width: 1279px) {
	.catchcopy{
		font-size: 2.266vw;
	}
	.catchcopy span{
		padding: 0 1.172vw;
		border-radius: 0.391vw;
		margin: 0 0.156vw;
	}
	.title{
		font-size: 2.266vw;
		margin-bottom: 3.75vw;
	}
	.title span{
		font-size: 1.094vw;
	}
	.btn{
		max-width: 17.969vw;
		height: 4.297vw;
		font-size: 0.938vw;
	}
	.btn:hover{
		background: var(--main-color);
	}
}
@media screen and (max-width: 768px) {
	.catchcopy{
		font-size: 24px;
		line-height: 1.8;
	}
	.title{
		font-size: 24px;
		margin-bottom: 40px;
	}
	.title span{
		font-size: 13px;
	}
	.btn{
		max-width: 100%;
	}
}
/*==================================================================================================*/
/*-*/
header{
	width: 100%;
	position: relative;
	z-index: 10000;
}
header h1{
	width: 113px;
	position: absolute;
	top: 32px;
	left: 44px;
}
header h1 a,
header h1 img{
	display: block;
	width: 100%;
	height: 100%;
}
.openbtn1{
	display: block;
	cursor: pointer;
	position: fixed;
	top: 0;
	right: 0;
	width: 87px;
	height: 87px;
	z-index: 10;
}
.openbtn1 span:nth-of-type(1),
.openbtn1 span:nth-of-type(2),
.openbtn1 span:nth-of-type(3){
	display: inline-block;
	transition: all .4s;
	width: 42px;
	height: 1px;
	left: 22px;
	background: #3C4C75;
	position: absolute;
}
.openbtn1 span:nth-of-type(1) { top:26px;}
.openbtn1 span:nth-of-type(2) { top:43px;}
.openbtn1 span:nth-of-type(3) { top:60px;}

.pcNav .openbtn1 span:nth-of-type(1) {
	top: 42px;
	background: #FFF;
	transform: rotate(-45deg);
}
.pcNav .openbtn1 span:nth-of-type(2){
	opacity: 0;
}
.pcNav .openbtn1 span:nth-of-type(3){
	top: 42px;
	background: #FFF;
	transform: rotate(45deg);
}
.sidemenu{
	display: flex;
	justify-content: center;
	align-content:flex-end;
	flex-wrap: wrap;
	width: 87px;
	height: 100vh;
	position: fixed;
	top: 0;
	right: 0;
}
.sidemenu a:nth-child(1){
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	width: fit-content;
	height: 80px;
	margin-bottom: 22px;
	position: relative;
}
.sidemenu a:nth-child(1) span{
	font-size: 10px;
	letter-spacing: 0.1em;
	transform: rotate(90deg);
	position: relative;
	top: -10px;
}
.sidemenu a:nth-child(1)::after{
	display: inline-block;
	content: "";
	width: 23px;
	height: 18px;
	background: center / contain no-repeat url("../img/icon-mail.svg");
	position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
}
.sidemenu a:nth-child(2){
	display: block;
	width: 100%;
	height: 26px;
	margin-bottom: 31px;
}
.sidemenu a:nth-child(2) img{
	display: block;
	width: 26px;
	height: 100%;
	margin: 0 auto;
}
@media (min-width: 769px) and (max-width: 1279px) {
	header h1{
		width: 8.828vw;
		top: 2.5vw;
		left: 3.438vw;
	}
	.openbtn1{
		width: 6.797vw;
		height: 6.797vw;
	}
	.openbtn1 span:nth-of-type(1),
	.openbtn1 span:nth-of-type(2),
	.openbtn1 span:nth-of-type(3){
		width: 3.281vw;
		height: 0.078vw;
		left: 1.719vw;
	}
	.openbtn1 span:nth-of-type(1) { top:2.031vw;}
	.openbtn1 span:nth-of-type(2) { top:3.359vw;}
	.openbtn1 span:nth-of-type(3) { top:4.688vw;}

	.pcNav .openbtn1 span:nth-of-type(1) {
		top: 3.281vw;
	}
	.pcNav .openbtn1 span:nth-of-type(3){
		top: 3.281vw;
	}
	.sidemenu{
		width: 6.797vw;
	}
	.sidemenu a:nth-child(1){
		height: 6.25vw;
		margin-bottom: 1.719vw;
	}
	.sidemenu a:nth-child(1) span{
		font-size: 0.781vw;
		top: -0.781vw;
	}
	.sidemenu a:nth-child(1)::after{
		width: 1.797vw;
		height: 1.406vw;
	}
	.sidemenu a:nth-child(2){
		height: 2.031vw;
		margin-bottom: 2.422vw;
	}
	.sidemenu a:nth-child(2) img{
		width: 2.031vw;
	}
}
@media screen and (max-width: 768px) {
	header h1{
		width: 70px;
		top: 15px;
		left: 20px;
	}
	.openbtn1{
		width: 60px;
		height: 60px;
	}
	.openbtn1 span:nth-of-type(1),
	.openbtn1 span:nth-of-type(2),
	.openbtn1 span:nth-of-type(3){
		width: 40px;
		height: 1px;
		left: 0;
	}
	.openbtn1 span:nth-of-type(1) { top:24px;}
	.openbtn1 span:nth-of-type(2) { top:38px;}
	.openbtn1 span:nth-of-type(3) { top:52px;}

	.pcNav .openbtn1 span:nth-of-type(1) {
		top: 40px;
	}
	.pcNav .openbtn1 span:nth-of-type(3){
		top: 40px;
	}
	.sidemenu{
		width: 60px;
		height: 160px;
		top: auto;
		bottom: 0;
	}
}
nav{
	align-content: center;
	justify-content: center;
	width: 100%;
	height: 100vh;
	position: fixed;
	top: -100vh;
	background: var(--main-color);
	z-index: 1;
	transition: .5s;
}
.pcNav nav{
	top: 0;
}
nav img{
	display: block;
	width: 90%;
	max-width: 392px;
	margin: 0 auto;
	margin-bottom: 72px;
}
nav ul{
	width: 100%;
}
nav ul li{
	width: 100%;
	margin-bottom: 30px;
}
nav ul li a{
	display: block;
	font-size: 16px;
	text-align: center;
	color: #FAF8F3;
	margin: 0 auto;
}
@media (min-width: 769px) and (max-width: 1279px) {
	nav img{
		max-width: 30.625vw;
		margin-bottom: 5.625vw;
	}
	nav ul li{
		margin-bottom: 2.344vw;
	}
	nav ul li a{
		font-size: 1.25vw;
	}
}
@media screen and (max-width: 768px) {
	nav img{
		margin: 0 auto 50px;
	}
	nav ul li{
		margin-bottom: 20px;
	}
}
/*==================================================================================================*/
/*fv-*/
main,iframe,footer{
	width: calc( 100% - 87px);
}
.fv{
	height: 100vh;
	min-height: 832px;
}
.fv .inner{
	align-content: center;
	max-width: 1200px;
	height: 100%;
	z-index: 1;
}
.fv .catchcopy{
	margin-top: 100px;
}
.fv .catchcopy + p{
	line-height: 1.6;
	color: #727272;
	margin-top: 5px;
}
.fvSlider{
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
}
.fvSlider img{
	display: block;
	width: 100%;
	height: 100vh;
	min-height: 832px;
	max-height: 832px;
	object-fit: cover;
}
@media (min-width: 769px) and (max-width: 1279px) {
	main,iframe,footer{
		width: calc( 100% - 6.797vw);
	}
	.fv{
		min-height: 65vw;
	}
	.fv .inner{
		max-width: 93.75vw;
	}
	.fv .catchcopy{
		margin-top: 7.813vw;
	}
	.fv .catchcopy + p{
		margin-top: 0.391vw;
	}
	.fvSlider img{
		min-height: 65vw;
		max-height: 65vw;
	}
}
@media screen and (max-width: 768px) {
	main,iframe,footer{
		width: 100%;
	}
	.fv{
		min-height: 100vh;
	}
	.fv .catchcopy{
		margin-top: 0
	}
	.fv .catchcopy + p{
		margin-top: 30px;
	}
	.fvSlider img{
		min-height: 100vh;
	}
}
/*==================================================================================================*/
/*copy-*/
.copy{
	padding: 170px 0 140px;
}
.copy::before{
	display: block;
	content: "";
	width: 100px;
	height: 1px;
	background: #ADADAD;
	position: absolute;
	top: 100px;
    left: 50%;
    transform: translateX(-50%);
}
.copy p{
	font-size: 16px;
	text-align: center;
	line-height: 3.5;
	margin-bottom: 60px;
}
.copy h2{
	font-size: 27px;
	line-height: 1.8;
	text-align: center;
	color: #3C4C75;
}
@media (min-width: 769px) and (max-width: 1279px) {
	.copy{
		padding: 13.281vw 0 10.938vw;
	}
	.copy::before{
		width: 7.813vw;
		height: 0.078vw;
		top: 7.813vw;
	}
	.copy p{
		font-size: 1.25vw;
		margin-bottom: 4.688vw;
	}
	.copy h2{
		font-size: 2.109vw;
	}
}
@media screen and (max-width: 768px) {
	.copy{
		padding: 100px 0 60px;
	}
	.copy::before{
		top: 60px;
	}
	.copy p{
		font-size: 15px;
		line-height: 3;
		margin-bottom: 40px;
	}
	.copy h2{
		font-size: 20px;
	}
}
/*==================================================================================================*/
/*contact-*/
article.contact{
	padding: 90px 0 80px;
}
article.contact h2{
	font-size: 31px;
	text-align: center;
	margin-bottom: 25px;
}
article.contact p{
	font-size: 16px;
	text-align: center;
	margin-bottom: 54px;
}
@media (min-width: 769px) and (max-width: 1279px) {
	article.contact{
		padding: 7.031vw 0 6.25vw;
	}
	article.contact h2{
		font-size: 2.422vw;
		margin-bottom: 1.953vw;
	}
	article.contact p{
		font-size: 1.25vw;
		margin-bottom: 4.219vw;
	}
}
@media screen and (max-width: 768px) {
	article.contact{
		padding: 60px 0 60px;
	}
	article.contact h2{
		font-size: 20px;
		margin-bottom: 20px;
	}
	article.contact p{
		font-size: 15px;
		margin-bottom: 40px;
	}
}
/*==================================================================================================*/
/*footer-*/
iframe{
	aspect-ratio: 3 / 1;
	margin-bottom: -5px;
}
footer{
	padding: 40px 0 20px;
	background: var(--main-color);
}
footer ul{
	width: fit-content;
	justify-content: center;
	margin: 0 auto;
	margin-bottom: 177px;
}
footer ul li{
	width: fit-content;
}
footer ul li a{
	font-size: 13px;
	color: #FAF8F3;
	padding: 0 15px;
	transition: .5s;
}
footer ul li a:hover{
	opacity: .7;
}
footer h2{
	width: 90%;
	max-width: 392px;
	margin: 0 auto;
	margin-bottom: 55px;
}
footer p{
	font-size: 13px;
	line-height: 1.6;
	text-align: center;
	color: #FAF8F3;
	margin-bottom: 23px;
}
footer p + a{
	display: block;
	font-size: 13px;
	text-align: center;
	color: #FAF8F3;
	margin-bottom: 60px;
}
small{
	display: block;
	font-size: 10px;
	letter-spacing: 0.16em;
	text-align: center;
	color: #FAF8F3;
}
@media (min-width: 769px) and (max-width: 1279px) {
	iframe{
		margin-bottom: -0.391vw;
	}
	footer{
		padding: 3.125vw 0 1.563vw;
	}
	footer ul{
		margin-bottom: 13.828vw;
	}
	footer ul li a{
		font-size: 1.016vw;
		padding: 0 1.172vw;
	}
	footer h2{
		max-width: 30.625vw;
		margin-bottom: 4.297vw;
	}
	footer p{
		font-size: 1.016vw;
		margin-bottom: 1.797vw;
	}
	footer p + a{
		font-size: 1.016vw;
		margin-bottom: 4.688vw;
	}
	small{
		font-size: 0.781vw;
	}
}
@media screen and (max-width: 768px) {
	iframe{
		aspect-ratio: 2 / 1;
	}
	footer ul.flex{
		width: fit-content;
		justify-content: center;
		margin: 0 auto 60px;
	}
	footer ul li a{
		display: block;
		margin: 0 auto 10px;
	}
	footer h2{
		margin: 0 auto 40px;
	}
	footer p{
		margin-bottom: 23px;
	}
	footer p + a{
		margin-bottom: 20px;
	}
}
/*==================================================================================================*/
/*-*/
.pageFv{
	padding: 54px 0;
}
.pageFv h2{
	width: calc( 100% - 562px);
	color: #7D7BA3;
	margin: 0;
}
.pageFv img{
	max-width: 562px;
	aspect-ratio: 1.2 / 1;
	border-radius: 16px;
}
.pageFv h2 + p{
	text-align: center;
	margin-top: 54px;
}
@media (min-width: 769px) and (max-width: 1279px) {
	.pageFv{
		padding: 4.219vw 0;
	}
	.pageFv h2{
		width: calc( 100% - 43.906vw);
	}
	.pageFv img{
		max-width: 43.906vw;
		border-radius: 1.25vw;
	}
	.pageFv h2 + p{
		margin-top: 4.219vw;
	}
}
@media screen and (max-width: 768px) {
	.pageFv{
		padding: 160px 0 40px;
	}
	.pageFv h2{
		width: 100%;
		margin: 0 0 40px;
	}
	.pageFv img{
		width: 100%;
	}
	.pageFv h2 + p{
		margin-top: 54px;
	}
}
/*==================================================================================================*/
/*about-当事務所について*/
#about .pageFv{
	margin-bottom: 130px;
}
#about .wrap01{
	margin-bottom: 236px;
}
#about .wrap01 .title{
	text-align: left;
}
#about .wrap01 .catchcopy{
	color: var(--text-color);
	margin-bottom: 20px;
}
#about .wrap01 .catchcopy span{
	color: #FFF;
	background: #7D7BA3;
}
#about .wrap01 img{
	border-radius: 20px;
	box-shadow: 0 4px 4px 0 rgba(0,0,0,0.25);
}
#about .wrap01 .inner:nth-child(1){
	flex-direction: row-reverse;
	margin-bottom: 258px;
}
#about .wrap01 .textBox{
	width: fit-content;
}
#about .wrap01 .inner:nth-child(1) .textBox{
	padding-right: 100px;
}
#about .wrap01 .inner:nth-child(2) .textBox{
	padding-left: 100px;
}
#about .wrap01 .imageBox{
	max-width: 478px;
	height: -webkit-fill-available;
	position: relative;
}
#about .wrap01 .inner:nth-child(1) .imageBox{
	left: -3%;
}
#about .wrap01 .inner:nth-child(2) .imageBox{
	right: -3%;
}
#about .wrap01 .inner:nth-child(1) .imageBox img:nth-child(1){
	border-radius: 0 20px 20px 0;
}
#about .wrap01 .inner:nth-child(2) .imageBox img:nth-child(1){
	position: absolute;
	top: auto;
	bottom: 0;
	border-radius: 20px 0 0 20px;
}
#about .wrap01 .imageBox img:nth-child(2){
	width: 270px;
	position: absolute;
}
#about .wrap01 .inner:nth-child(1) .imageBox img:nth-child(2){
	top: 329px;
	right: -181px;
}
#about .wrap01 .inner:nth-child(2) .imageBox img:nth-child(2){
	top: 0;
	left: -50px;
}
@media (min-width: 769px) and (max-width: 1279px) {
	#about .pageFv{
		margin-bottom: 10.156vw;
	}
	#about .wrap01{
		margin-bottom: 18.438vw;
	}
	#about .wrap01 .catchcopy{
		margin-bottom: 1.563vw;
	}
	#about .wrap01 img{
		border-radius: 1.563vw;
	}
	#about .wrap01 .inner:nth-child(1){
		margin-bottom: 20.156vw;
	}
	#about .wrap01 .inner:nth-child(1) .textBox{
		padding-right: 7.813vw;
	}
	#about .wrap01 .inner:nth-child(2) .textBox{
		padding-left: 7.813vw;
	}
	#about .wrap01 .imageBox{
		max-width: 37.344vw;
	}
	#about .wrap01 .inner:nth-child(1) .imageBox img:nth-child(1){
		border-radius: 0 1.563vw 1.563vw 0;
	}
	#about .wrap01 .inner:nth-child(2) .imageBox img:nth-child(1){
		border-radius: 1.563vw 0 0 1.563vw;
	}
	#about .wrap01 .imageBox img:nth-child(2){
		width: 21.094vw;
	}
	#about .wrap01 .inner:nth-child(1) .imageBox img:nth-child(2){
		top: 25.703vw;
		right: -14.141vw;
	}
	#about .wrap01 .inner:nth-child(2) .imageBox img:nth-child(2){
		left: -3.906vw;
	}
}
@media screen and (max-width: 768px) {
	#about .pageFv{
		margin-bottom: 0px;
	}
	#about .wrap01{
		margin-bottom: 40px;
        padding: 0 0 140px;
	}
	#about .wrap01 .title{
		text-align: center;
		margin-bottom: 20px;
	}
	#about .wrap01 .catchcopy{
		font-size: 18px;
		margin-bottom: 20px;
	}
	#about .wrap01 .textBox{
		width: 100%;
		margin-bottom: 40px;
	}
	#about .wrap01 .inner:nth-child(1){
		margin-bottom: 120px;
	}
	#about .wrap01 .inner:nth-child(1) .textBox{
		padding-right: 0;
	}
	#about .wrap01 .inner:nth-child(2) .textBox{
		padding-left: 0;
	}
	#about .wrap01 .inner:nth-child(1) .imageBox{
		left: -5%;
	}
	#about .wrap01 .inner:nth-child(2) .imageBox{
		right: -5%;
		height: auto;
	}
	#about .wrap01 .imageBox img:nth-child(2){
		width: 170px;
	}
	#about .wrap01 .inner:nth-child(1) .imageBox img:nth-child(2){
		top: 250px;
        right: -5%;
	}
	
	#about .wrap01 .inner:nth-child(2) .imageBox img:nth-child(1){
		position: relative;
		top: 0;
		bottom: auto;
	}
	#about .wrap01 .inner:nth-child(2) .imageBox img:nth-child(2){
		top: 240px;
        left: -5%;
	}
}
#about .wrap02{
	padding: 45px 0 41px;
}
#about .wrap02 .inner{
	max-width: 1047px;
	padding: 53px 0 73px;
	border-radius: 10px;
	background: #FFF;
}
#about .wrap02 dl{
	width: 90%;
	max-width: 551px;
	display: flex;
	justify-content: center;
	padding: 24px 0;
	border-bottom: solid 1px #CCCCCC;
	margin: 0 auto;
}
#about .wrap02 dl dt{
	width: 185px;
	font-size: 17px;
}
#about .wrap02 dl dt{
	width: calc( 100% - 185px);
	font-size: 17px;
}
@media (min-width: 769px) and (max-width: 1279px) {
	#about .wrap02{
		padding: 3.516vw 0 3.203vw;
	}
	#about .wrap02 .inner{
		max-width: 81.797vw;
		padding: 4.141vw 0 5.703vw;
		border-radius: 0.781vw;
	}
	#about .wrap02 dl{
		max-width: 43.047vw;
		padding: 1.875vw 0;
	}
	#about .wrap02 dl dt{
		width: 14.453vw;
		font-size: 1.328vw;
	}
	#about .wrap02 dl dt{
		width: calc( 100% - 14.453vw);
		font-size: 1.328vw;
	}
}
@media screen and (max-width: 768px) {
	#about .wrap02{
		padding: 40px 0 40px;
	}
	#about .wrap02 .inner{
		padding: 30px 0 40px;
	}
	#about .wrap02 .title{
		margin: 0;
	}
	#about .wrap02 dl{
		flex-wrap: wrap;
		padding: 20px 0;
	}
	#about .wrap02 dl dt{
		width: 100%;
		color: #B3B1D3;
	}
	#about .wrap02 dl dt{
		width: 100%;
	}
}
/*==================================================================================================*/
/*service-*/
#service .wrap01{
	padding: 130px 0 86px;
}
#service .wrap01 ul{
	max-width: 768px;
	justify-content: center;
	margin: 0 auto;
}
#service .wrap01 li{
	width: fit-content;
	font-size: 18px;
	padding: 10px 20px;
	border-radius: 10px;
	background: var(--sub-color);
	margin: 0 12px 32px;
	
}
@media (min-width: 769px) and (max-width: 1279px) {
	#service .wrap01{
		padding: 10.156vw 0 6.719vw;
	}
	#service .wrap01 ul{
		max-width: 60vw;
	}
	#service .wrap01 li{
		font-size: 1.406vw;
		padding: 0.781vw 1.563vw;
		border-radius: 0.781vw;
		margin: 0 0.938vw 2.5vw;

	}
}
@media screen and (max-width: 768px) {
	#service .wrap01{
		padding: 40px 0 40px;
	}
	#service .wrap01 li{
		width: 100%;
		font-size: 15px;
		text-align: center;
		padding: 10px 15px;
		margin: 0 0 10px;

	}
}
#service .wrap02{
	padding: 78px 0 90px;
}
#service .wrap02 .inner{
	max-width: 974px;
}
#service .wrap02 li{
	width: 300px;
	padding: 20px;
	border-radius: 20px;
	background: #FFF;
	box-shadow: 0 4px 10px rgba(0,0,0,0.25);
}
#service .wrap02 li h3{
	font-size: 24px;
	margin-bottom: 20px;
}
#service .wrap02 li h3 span{
	display: block;
	width: fit-content;
	font-size: 12px;
	color: #FFF;
	background: #B0AEAE;
	padding: 0 10px;
}
#service .wrap02 li:nth-child(2) h3 span{
	background: #B3B1D3;
}
#service .wrap02 li:nth-child(3) h3 span{
	background: #504D7F;
}
#service .wrap02 li dl{
	margin-left: 10px;
	margin-bottom: 20px;
}
#service .wrap02 li dl dt{
	font-size: 12px;
	line-height: 1.5;
	color: #B2B2B2;
}
#service .wrap02 li dl dd{
	font-size: 14px;
	line-height: 1.5;
	margin-bottom: 14px;
}
#service .wrap02 li div{
	padding: 10px 20px;
	background: #F3F3F3;
}
#service .wrap02 li div h4{
	display: flex;
	align-items: center;
	font-size: 15px;
	font-weight: 500;
	color: #7D7BA3;
	margin-bottom: 5px;
}
#service .wrap02 li div h4::before{
	display: inline-block;
	content: "";
	width: 18px;
	height: 19px;
	border-radius: 50%;
	background: #7D7BA3;
	margin-right: 5px;
}
#service .wrap02 li div p{
	line-height: 1.8;
}
@media (min-width: 769px) and (max-width: 1279px) {
	#service .wrap02{
		padding: 6.094vw 0 7.031vw;
	}
	#service .wrap02 .inner{
		max-width: 76.094vw;
	}
	#service .wrap02 li{
		width: 23.438vw;
		padding: 1.563vw;
		border-radius: 1.563vw;
	}
	#service .wrap02 li h3{
		font-size: 1.875vw;
	}
	#service .wrap02 li h3 span{
		font-size: 0.938vw;
		padding: 0 0.781vw;
	}
	#service .wrap02 li dl dt{
		font-size: 0.938vw;
	}
	#service .wrap02 li dl dd{
		font-size: 1.094vw;
		margin-bottom: 1.094vw;
	}
	#service .wrap02 li div{
		padding: 0.781vw 1.563vw;
	}
	#service .wrap02 li div h4{
		font-size: 1.172vw;
	}
	#service .wrap02 li div h4::before{
		width: 1.406vw;
		height: 1.484vw;
		margin-right: 0.391vw;
	}
}
@media screen and (max-width: 768px) {
	#service .wrap02{
		padding: 40px 0 40px;
	}
	#service .wrap02 .title{
		margin-bottom: 10px;
	}
	#service .title + p{
		margin-bottom: 40px;
	}
	#service .wrap02 li{
		width: 100%;
		margin-bottom: 20px;
	}
	#service .wrap02 li h3{
		font-size: 20px;
	}
}
#service .cloudBox{
	padding: 99px 0 126px;
}
#service .cloudBox .title{
	color: #5E5E5E;
}
#service .cloudBox .title + p{
	font-size: 13px;
	margin-bottom: 35px;
}
#service .cloudBox ul{
	max-width: 721px;
	align-items: flex-end;
	margin: 0 auto;
}
#service .cloudBox li:nth-child(1){
	width: 259px;
}
#service .cloudBox li:nth-child(2){
	width: 409px;
}
#service .cloudBox li a{
	display: block;
}
#service .cloudBox li a img{
	display: block;
	width: 100%;
}
@media (min-width: 769px) and (max-width: 1279px) {
	#service .cloudBox{
		padding: 7.734vw 0 9.844vw;
	}
	#service .cloudBox .title + p{
		font-size: 1.016vw;
		margin-bottom: 2.734vw;
	}
	#service .cloudBox ul{
		max-width: 56.328vw;
	}
	#service .cloudBox li:nth-child(1){
		width: 20.234vw;
	}
	#service .cloudBox li:nth-child(2){
		width: 31.953vw;
	}
}
@media screen and (max-width: 768px) {
	#service .cloudBox{
		padding: 40px 0 40px;
	}
	#service .cloudBox ul{
		justify-content: center;
	}
	#service .cloudBox li:nth-child(1){
		margin-bottom: 20px;
	}
}
#service .wrap03{
	padding: 50px 0 97px;
	background: #F6F5FF;
}
#service .wrap03 ul{
	max-width: 700px;
	margin: 0 auto;
}
#service .wrap03 ul li{
	background: #FFF;
	padding: 20px 20px;
	margin-bottom: 12px;
}
#service .wrap03 ul li:last-child{
	margin: 0;
}
#service .wrap03 ul li h3 span{
	display: block;
	font-size: 20px;
}
#service .wrap03 ul li h3{
	width: 100px;
	font-size: 12px;
	font-weight: 500;
	color: #B3B1D3;
}
#service .wrap03 ul li p{
	width: calc( 100% - 120px );
}
@media (min-width: 769px) and (max-width: 1279px) {
	#service .wrap03{
		padding: 3.906vw 0 7.578vw;
	}
	#service .wrap03 ul{
		max-width: 54.688vw;
	}
	#service .wrap03 ul li{
		padding: 1.563vw 1.563vw;
		margin-bottom: 0.938vw;
	}
	#service .wrap03 ul li h3 span{
		font-size: 1.563vw;
	}
	#service .wrap03 ul li h3{
		width: 7.813vw;
		font-size: 0.938vw;
	}
	#service .wrap03 ul li p{
		width: calc( 100% - 9.375vw );
	}
}
@media screen and (max-width: 768px) {
	#service .wrap03{
		padding: 40px 0 40px;
	}
	#service .wrap03 ul li h3{
		width: 100%;
		margin-bottom: 10px;
	}
	#service .wrap03 ul li p{
		width: 100%;
	}
}
#service .wrap04{
	padding: 99px 0 97px;
}
#service .wrap04 .inner{
	max-width: 980px;
}
#service .wrap04 .title{
	width: fit-content;
	text-align: left;
}
.accordion{
	max-width: 700px;
}
.toggle {
	display: none;
}
.Label {
	font-size: 18px;
	line-height: 1.6;
	padding: 23px;
	padding-right: 60px;
	display: block;
	background: #FAF7F4;
}
.Label::before{
	display: inline-block;
	content: "Q.";
	margin-right: 10px;
}
.Label span{
	display: block;
	width: 20px;
	height: 70px;
	position: absolute;
	top: 50%;
    right: 23px;
    transform: translateY(-50%);
}
.Label span::before,
.Label span::after{
	display: block;
	content: "";
	width: 12px;
	height: 1.5px;
	background: var(--text-color);
	position: absolute;
	top: 35px;
	transition: .5s;
}
.Label span::before{
	transform: rotate(45deg);
	left: 0;
}
.Label span::after{
	transform: rotate(-45deg);
	right: 0;
}
.Label,
.content {
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	transform: translateZ(0);
	transition: all 0.3s;
}
.content {
	height: 0;
	background: #FAFAFA;
	margin-bottom: 18px;
	padding: 0 23px;
	overflow: hidden;
}
.content p::before{
	display: inline-block;
	content: "A.";
	margin-right: 10px;
}
.content p{
	font-size: 18px;
	line-height: 1.6;
}
.toggle:checked + .Label + .content {
	height: auto;
	padding:23px ;
	transition: all .3s;
}
.toggle:checked + .Label span::before{
	transform: rotate(-45deg) !important;
}
.toggle:checked + .Label span::after{
	transform: rotate(45deg) !important;
}
/**/
.Label01 span::before{
	transform: rotate(-45deg);
}
.Label01 span::after{
	transform: rotate(45deg);
}
.Label01 + .content01 {
	height: auto;
	padding:23px ;
}
.toggle:checked + .Label01 span::before{
	transform: rotate(45deg) !important;
}
.toggle:checked + .Label01 span::after{
	transform: rotate(-45deg) !important;
}
.toggle:checked + .Label01 + .content01 {
	height: 0;
	padding: 0 23px;
	overflow: hidden;
}
@media (min-width: 769px) and (max-width: 1279px) {
	#service .wrap04{
		padding: 7.734vw 0 7.578vw;
	}
	#service .wrap04 .inner{
		max-width: 76.563vw;
	}
	.accordion{
		max-width: 54.688vw;
	}
	.Label {
		font-size: 1.406vw;
		padding: 1.797vw;
		padding-right: 4.688vw;
	}
	.Label::before{
		margin-right: 0.781vw;
	}
	.Label span{
		width: 1.563vw;
		height: 5.469vw;
		right: 1.797vw;
	}
	.Label span::before,
	.Label span::after{
		width: 0.938vw;
		height: 0.117vw;
		top: 2.734vw;
	}
	.content {
		margin-bottom: 1.406vw;
		padding: 0 1.797vw;
	}
	.content p::before{
		margin-right: 0.781vw;
	}
	.content p{
		font-size: 1.406vw;
	}
	.toggle:checked + .Label + .content {
		padding:1.797vw ;
	}
	/**/
	.Label01 + .content01 {
		padding:1.797vw ;
	}
	.toggle:checked + .Label01 + .content01 {
		padding: 0 1.797vw;
	}
}
@media screen and (max-width: 768px) {
	#service .wrap04 {
		padding: 40px 0 40px;
	}
	#service .wrap04 .title{
		width: 100%;
		text-align: center;
		margin-bottom: 20px;
	}
	.Label {
		font-size: 15px;
		padding: 15px 20px;
		padding-right: 30px;
	}
	.Label span{
		width: 13px;
		right: 13px;
	}
	.Label span::before,
	.Label span::after{
		width: 8px;
	}
	.content {
		margin-bottom: 10px;
		padding: 0 20px;
	}
	.content p{
		font-size: 15px;
	}
	.toggle:checked + .Label + .content {
		padding: 15px 20px;
	}
	/**/
	.Label01 + .content01 {
		padding: 15px 20px;
	}
	.toggle:checked + .Label01 + .content01 {
		padding: 0 20px;
	}
}
/*==================================================================================================*/
/*privacy-プライバシーポリシー*/
.pageFv.pageFv02{
	padding-top: 268px;
}
.pageFv.pageFv02 h2{
	width: 100%;
}
#privacy .wrap01{
	padding: 80px 0 173px;
}
#privacy .wrap01 .inner{
	max-width: 940px;
}
#privacy .wrap01 h2{
	font-size: 29px;
	margin-bottom: 20px;
}
#privacy .wrap01 h2 + p{
	margin-bottom: 122px;
}

#privacy .wrap01 ol li{
	margin-bottom: 60px;
}
#privacy .wrap01 ol li h3{
	font-size: 24px;
	color: #B3B1D3;
	margin-bottom: 20px;
}
#privacy .wrap01 ol ul{
	margin-top: 20px;
}
#privacy .wrap01 ol ul li {
	margin-bottom: 0;
}

#privacy .wrap01 ol li:last-child a{
	display: inline-block;
	color: var(--text-color);
}
#privacy .wrap01 ol li a{
	display: block;
	color: #B3B1D3;
}
@media (min-width: 769px) and (max-width: 1279px) {
	.pageFv.pageFv02{
		padding-top: 20.938vw;
	}
	#privacy .wrap01{
		padding: 6.25vw 0 13.516vw;
	}
	#privacy .wrap01 .inner{
		max-width: 73.438vw;
	}
	#privacy .wrap01 h2{
		font-size: 2.266vw;
		margin-bottom: 1.563vw;
	}
	#privacy .wrap01 h2 + p{
		margin-bottom: 9.531vw;
	}

	#privacy .wrap01 ol li{
		margin-bottom: 4.688vw;
	}
	#privacy .wrap01 ol li h3{
		font-size: 1.875vw;
		margin-bottom: 1.563vw;
	}
	#privacy .wrap01 ol ul{
		margin-top: 1.563vw;
	}
}
@media screen and (max-width: 768px) {
	.pageFv.pageFv02{
		padding-top: 160px;
	}
	#privacy .wrap01{
		padding: 0 0 60px;
	}
	#privacy .wrap01 h2{
		font-size: 20px;
		margin-bottom: 10px;
	}
	#privacy .wrap01 h2 + p{
		margin-bottom: 60px;
	}

	#privacy .wrap01 ol li{
		margin-bottom: 30px;
	}
	#privacy .wrap01 ol li h3{
		font-size: 18px;
		margin-bottom: 15px;
	}
	#privacy .wrap01 ol ul{
		margin-top: 15px;
	}
}
/*==================================================================================================*/
/*contact-お問合せ*/
#contact .wrap01 {
	padding: 50px 0 125px;
}
#contact .wrap01 .title{
	margin-bottom: 5px;
}
#contact .wrap01 .title + p{
	margin-bottom: 84px;
}
.contactBox{
	justify-content: center;
	max-width: 954px;
	padding: 38px 0;
	background: var(--sub-color);
	margin: 0 auto;
}
.contactBox h3{
	width: fit-content;
	font-size: 20px;
	font-weight: 500;
	margin-right: 100px;
}
.contactBox div{
	width: fit-content;
}
.contactBox div a{
	display: flex;
	align-items: center;
	justify-content: center;
	width: 90%;
	max-width: 364px;
	height: 57px;
	font-size: 35px;
	letter-spacing: 0;
	font-weight: 700;
	color: #A19DE3;
	border: solid 1px #A19DE3;
	border-radius: 60px;
	background: #FFF;
	margin: 0 auto;
	margin-bottom: 5px;
}
.contactBox div a::before{
	display: block;
	content: "";
	width: 25px;
	height: 25px;
	background: center / contain no-repeat url("../img/icon-tel.svg");
	margin-right: 3px;
}
.contactBox div p{
	text-align: center;
}
.contactBox div p:nth-child(3){
	font-size: 13px;
}
@media (min-width: 769px) and (max-width: 1279px) {
	#contact .wrap01 {
		padding: 3.906vw 0 9.766vw;
	}
	#contact .wrap01 .title{
		margin-bottom: 0.391vw;
	}
	#contact .wrap01 .title + p{
		margin-bottom: 6.563vw;
	}
	.contactBox{
		max-width: 74.531vw;
		padding: 2.969vw 0;
	}
	.contactBox h3{
		font-size: 1.563vw;
		margin-right: 7.813vw;
	}
	.contactBox div a{
		max-width: 28.438vw;
		height: 4.453vw;
		font-size: 2.734vw;
		border-radius: 4.688vw;
		margin-bottom: 0.391vw;
	}
	.contactBox div a::before{
		width: 1.953vw;
		height: 1.953vw;
		margin-right: 0.234vw;
	}
	.contactBox div p:nth-child(3){
		font-size: 1.016vw;
	}
}
@media screen and (max-width: 768px) {
	#contact .wrap01 {
		padding: 40px 0 60px;
	}
	#contact .wrap01 .title{
		font-size: 20px;
	}
	.contactBox{
		padding: 20px 0;
	}
	.contactBox h3{
		font-size: 18px;
		margin-right: 0;
		margin-bottom: 5px;
	}
	.contactBox div{
		width: 100%;
	}
	.contactBox div a{
		font-size: 30px;
	}
	.contactBox div a::before{
		width: 20px;
		height: 20px;
	}
}
#contact .wrap02{
	padding: 84px 0 124px;
}
#contact .wrap02 .title + p{
	margin-bottom: 54px;
}
form{
	max-width: 800px;
	margin: 0 auto;
}
form label{
	display: flex;
	align-items: center;
	font-size: 18px;
	letter-spacing: 0.2em;
	margin-bottom: 15px;
}
form label.required::after{
	display: inline;
	content: "必須";
	width: 65px;
	height: 23px;
	font-size: 12px;
	text-align: center;
	color: #FFF;
	border-radius: 50px;
	background: #7D7BA3;
	margin-left: 20px;
}
form input,
form textarea{
	display: flex;
	align-items: center;
	width: 100%;
	height: 54px;
	font-size: 16px;
	letter-spacing: 0.2em;
	padding: 0 20px;
	border-radius: 10px;
	box-shadow: 0 4px 10px rgba(0,0,0,0.25);
	margin-bottom: 43px;
}
::placeholder {
	font-size: 16px;
	letter-spacing: 0.2em;
	color: #C5C5C5;
}
form fieldset{
	padding: 0;
	border: none;
	margin-bottom: 43px;
}
form fieldset input{
	display: inline-block;
	width: 24px;
	height: 24px;
	padding: 0;
	border-radius: 0;
	box-shadow: none;
	margin-bottom: 0;
	margin-left: 30px;
	margin-right: 10px;
}
form textarea{
	height: 254px;
	padding: 20px;
}
form p{
	margin-bottom: 43px;
}
form p a{
	color: #8982F0;
}
form input[type="submit"]{
	font-size: 18px;
	color: #FFF;
	padding: 0 20px;
	border-radius: 5px;
	box-shadow: none;
	background: #7D7BA3;
	margin-bottom: 0;
}
@media (min-width: 769px) and (max-width: 1279px) {
	#contact .wrap02{
		padding: 6.563vw 0 9.688vw;
	}
	#contact .wrap02 .title + p{
		margin-bottom: 4.219vw;
	}
	form{
		max-width: 62.5vw;
	}
	form label{
		font-size: 1.406vw;
		margin-bottom: 1.172vw;
	}
	form label.required::after{
		width: 5.078vw;
		height: 1.797vw;
		font-size: 0.938vw;
		border-radius: 3.906vw;
		margin-left: 1.563vw;
	}
	form input,
	form textarea{
		height: 4.219vw;
		font-size: 1.25vw;
		padding: 0 1.563vw;
		border-radius: 0.781vw;
		margin-bottom: 3.359vw;
	}
	::placeholder {
		font-size: 1.25vw;
	}
	form fieldset{
		margin-bottom: 3.359vw;
	}
	form fieldset input{
		width: 1.875vw;
		height: 1.875vw;
		margin-left: 2.344vw;
		margin-right: 0.781vw;
	}
	form textarea{
		height: 19.844vw;
		padding: 1.563vw;
	}
	form p{
		margin-bottom: 3.359vw;
	}
	form input[type="submit"]{
		font-size: 1.406vw;
		padding: 0 1.563vw;
		border-radius: 0.391vw;
		margin-bottom: 0;
	}
}
@media screen and (max-width: 768px) {
	#contact .wrap02{
		padding: 60px 0 60px;
	}
	#contact .wrap02 .title + p{
		margin-bottom: 40px;
	}
	form label{
		font-size: 15px;
		margin-bottom: 5px;
	}
	form label.required::after{
		margin-left: 5px;
	}
	form input,
	form textarea{
		font-size: 15px;
		padding: 0 15px;
		margin-bottom: 20px;
	}
	::placeholder {
		font-size: 15px;
	}
	form fieldset{
		margin-bottom: 20px;
	}
	form fieldset input{
		width: 20px;
		height: 20px;
		margin-left: 10px;
		margin-right: 5px;
	}
	form textarea{
		height: 200px;
		padding: 15px;
	}
	form p{
		text-align: center;
		line-height: 1.2;
		margin-bottom: 20px;
	}
}