@charset "UTF-8";

/* ---------------------------------------
  index
-----------------------------------------*/


/* mv
--------------------------------*/
#sec_mv .wrap {
	width: 100%;
	max-width: 1400px;
}

#sec_mv .mv_slider .img {
	position: relative;
	width: 100%;
	border-radius: 0 0 40px 0;
	overflow: hidden;
}

#sec_mv .mv_slider .img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

#sec_mv .mv_slider .slick-dots {
	width: 1100px;
	font-size: 0;
	margin: 24px auto 0;
	z-index: 1;
}

#sec_mv .mv_slider .slick-dots li {
	display: inline-block;
	position: relative;
	width: 9px;
	height: 30px;
	line-height: 1;
	overflow: hidden;
	transform: rotate(45deg);
	transform-origin: right bottom;
}

#sec_mv .mv_slider .slick-dots li + li {
	margin-left: 20px;
}

#sec_mv .mv_slider .slick-dots button {
	position: absolute;
	left: 0;
	top: 0;
	text-indent: -9999px;
	width: 100%;
	height: 100%;
	border-radius: 4.5px;
	cursor: pointer;
	border: none;
	display: inline-block;
	padding: 0;
	margin: 0;
	background-color: #f29b8c;
	transition: .3s ease;
}

#sec_mv .mv_slider .slick-dots li button:hover,
#sec_mv .mv_slider .slick-dots li.slick-active button {
	background: #82cdd9;
}

@media screen and (max-width: 767px) {
	#sec_mv .wrap {
		max-width: inherit;
	}

	#sec_mv .mv_slider .img {
		border-radius: 0 0 3rem 0;
	}

	#sec_mv .mv_slider .slick-dots {
		width: 92%;
		margin: 3.6rem auto 0;
	}

	#sec_mv .mv_slider .slick-dots li {
		width: 1.2rem;
		height: 4rem;
	}

	#sec_mv .mv_slider .slick-dots li + li {
		margin-left: 3rem;
	}

	#sec_mv .mv_slider .slick-dots button {
		border-radius: .6rem;
	}
}



/* about
--------------------------------*/
#sec_about {
	padding: 90px 0 100px;
}

#sec_about .para_ob_pc {
	width: 445px;
	height: 632px;
	position: absolute;
	z-index: -1;
}

#sec_about .para_ob_pc._01 {
	right: calc(50% - 842px);
	top: -340px;
}

#sec_about .para_ob_pc._02 {
	left: calc(50% - 870px);
	top: 48px;
}

#sec_about .txtwrap {
	width: 450px;
	margin: 0 auto;
}

#sec_about .txtwrap .secttl {
	margin-bottom: 54px;
}

#sec_about .txtwrap .txt {
	text-align: center;
	font-size: 1.8rem;
	line-height: 2.0944444;
}

#sec_about .img_l {
	position: absolute;
	left: 0;
	top: 0;
}

#sec_about .img_r {
	position: absolute;
	right: 0;
	top: 0;
}

#sec_about .imgwrap .img {
	overflow: hidden;
}

#sec_about .imgwrap .img + .img {
	margin-top: 106px;
}

#sec_about .imgwrap .img._01 {
	width: 211px;
	border-radius: 0px 0px 0px 40px;
}

#sec_about .imgwrap .img._02 {
	width: 270px;
	border-radius: 0px 0px 40px 0px;
}

#sec_about .imgwrap .img._03 {
	width: 270px;
	border-radius: 0px 0px 0px 40px;
}

#sec_about .imgwrap .img._04 {
	width: 211px;
	margin-left: auto;
	border-radius: 0px 0px 40px 0px;
}

@media screen and (max-width: 767px) {
	#sec_about {
		padding: 9rem 0 10rem;
	}

	#sec_about .para_ob_sp {
		width: 44.5rem;
		height: 63.2rem;
		position: absolute;
		z-index: -1;
	}

	#sec_about .para_ob_sp._01 {
		right: -18rem;
		top: -38rem;
	}

	#sec_about .para_ob_sp._02 {
		left: -18rem;
		top: 75.8rem;
	}

	#sec_about .txtwrap {
		width: 100%;
	}

	#sec_about .txtwrap .secttl {
		margin-bottom: 8rem;
	}

	#sec_about .txtwrap .txt {
		font-size: 2.4rem;
		line-height: 2.333;
	}

	#sec_about .imgwrap {
		margin-top: 12rem;
		display: flex;
		justify-content: space-between;
	}

	#sec_about .img_l,
	#sec_about .img_r {
		position: static;
		width: 50%;
	}

	#sec_about .imgwrap .img + .img {
		margin-top: 4rem;
	}

	#sec_about .imgwrap .img._01 {
		width: 25rem;
		border-radius: 0px 0px 4.7rem 0px;
	}

	#sec_about .imgwrap .img._02 {
		width: 32rem;
		border-radius: 0px 4.7rem 0px 0px;
		margin-right: -.5rem;
	}

	#sec_about .imgwrap .img._03 {
		width: 32rem;
		border-radius: 0px 0px 0px 4.7rem;
		margin-left: -.5rem;
	}

	#sec_about .imgwrap .img._04 {
		width: 25rem;
		border-radius: 0px 0px 4.7rem 0px;
	}

}



/* feature
--------------------------------*/
#sec_feature {
	padding: 100px 0;
}

#sec_feature .block {
	position: relative;
}

#sec_feature .block + .block {
	margin-top: 100px;
}

#sec_feature .block::before {
	content: "";
	width: calc(50% - 108px);
	height: 100%;
	background-color: #82cdd9;
	position: absolute;
	top: 40px;
	left: 0;
}

#sec_feature .block:nth-of-type(even)::before {
	background-color: #f29b8c;
}

#sec_feature .block .wrap {
	align-items: center;
}

#sec_feature .block .img {
	width: 690px;
	border-radius: 0px 0px 0px 40px;
	overflow: hidden;
}

#sec_feature .block:nth-of-type(even) .img {
	border-radius: 0px 0px 40px 0px;
}

#sec_feature .block .txtwrap {
	position: relative;
	width: 570px;
	padding: 30px 0 30px 45px;
	background-color: rgba(255, 255, 255, .9);
	border-radius: 40px 0px 0px 0px;
	margin-left: -160px;
	z-index: 1;
}

#sec_feature .block .txtwrap .ttl {
	font-size: 2.2rem;
	line-height: 1.8181;
	margin-bottom: .55em;
}

#sec_feature .block .txtwrap .txt {
	font-weight: 500;
	font-size: 1.7rem;
	letter-spacing: 0.025em;
	text-align: justify;
}

@media screen and (min-width: 768px) {
	#sec_feature .block:nth-of-type(even)::before {
		left: auto;
		right: 0;
	}

	#sec_feature .block:last-child::before {
		top: -40px;
	}

	#sec_feature .block:nth-of-type(even) .wrap {
		flex-direction: row-reverse;
	}

	#sec_feature .block:nth-of-type(even) .txtwrap {
		padding: 30px 45px 30px 0;
		border-radius: 0px 40px 0px 0px;
		margin-left: auto;
		margin-right: -160px;
	}
}

@media screen and (max-width: 767px) {
	#sec_feature {
		padding: 10rem 0 0;
	}

	#sec_feature .block + .block {
		margin-top: 8rem;
	}

	#sec_feature .block::before {
		content: "";
		width: 100%;
		height: 32.3rem;
		top: 25rem;
	}

	#sec_feature .block .wrap {
		width: 100%;
	}

	#sec_feature .block .img {
		width: 100%;
		border-radius: 0px 0px 0px 4.3rem;
	}

	#sec_feature .block:nth-of-type(even) .img {
		border-radius: 0px 0px 4.3rem 0px;
	}

	#sec_feature .block .txtwrap {
		width: 84%;
		padding: 4.7rem 4.2rem;
		border-radius: 4.4rem 0px 0px 0px;
		margin: -6.8rem auto 0;
	}

	#sec_feature .block .txtwrap .ttl {
		font-size: 2.6rem;
		line-height: 1.77;
		letter-spacing: 0;
		margin-bottom: 1em;
	}

	#sec_feature .block .txtwrap .txt {
		font-size: 2.6rem;
		letter-spacing: 0;
	}
}



/* service
--------------------------------*/
#sec_service {
	padding: 100px 0 60px;
}

#sec_service::before {
	content: "";
	width: calc(50% - 322px);
	height: calc(100% - 100px);
	background-color: #f9d0c5;
	border-radius: 0px 40px 0px 0px;
	position: absolute;
	left: 0;
	top: 100px;
	z-index: -1;
}

#sec_service .tb dl {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 15px 0;
	border-bottom: 1px dashed #000000;
}

#sec_service .tb dl dt,
#sec_service .tb dl dd {
	font-size: 1.7rem;
	line-height: 1.75em;
}


#sec_service .tb dl dt {
	width: 228px;
	letter-spacing: 0;
}

#sec_service .tb dl dd {
	width: calc(100% - 250px);
	letter-spacing: -0.075em;
}

@media screen and (max-width: 767px) {
	#sec_service {
		padding: 10rem 0 4rem;
	}

	#sec_service::before {
		width: 6rem;
		height: calc(100% - 10rem);
		border-radius: 0px 4rem 0px 0px;
		position: absolute;
		top: 10rem;
	}

	#sec_service .tb {
		margin-left: 4rem
	}

	#sec_service .tb dl {
		display: block;
		padding: 3.5rem 0;
	}

	#sec_service .tb dl:last-child {
		border-bottom: none;
	}

	#sec_service .tb dl dt {
		width: 100%;
		font-size: 2.8rem;
		letter-spacing: 0;
		margin-bottom: .5em;
	}

	#sec_service .tb dl dd {
		width: 100%;
		font-size: 2.6rem;
		line-height: 2;
		letter-spacing: -0.05em;
	}
}



/* flow_area
--------------------------------*/
#sec_flow_area {
	padding: 100px 0 295px;
	background: url(../img/index/flow_area_bg_pc.png) no-repeat center bottom / 100% auto;
	margin-top: 100px;
}

#sec_flow_area .flow {
	width: 536px;
}

#sec_flow_area .area {
	width: 442px;
}

#sec_flow_area .area .ttl {
	text-align: center;
	color: #fff;
	font-size: 1.8rem;
	padding: .5em 1em;
	background-color: #f29b8c;
	border-radius: 11px;
	margin-bottom: 20px;
}

#sec_flow_area .area .img {
	position: relative;
}


#sec_flow_area .area .img .note {
	font-weight: 400;
	font-size: 1.4rem;
	line-height: 1.7;
	text-indent: -1em;
	padding-left: 1em;
	margin-bottom: -30px;
}

@media screen and (max-width: 1800px) and (min-width: 769px) {
	#sec_flow_area {
		background-size: 1800px auto;
	}
}

@media screen and (max-width: 767px) {
	#sec_flow_area {
		padding: 10rem 0 39rem;
		background: url(../img/index/flow_area_bg_sp.png) no-repeat center bottom / 100% auto;
		margin-top: 10rem;
	}

	#sec_flow_area .secttl {
		margin-bottom: 6rem;
	}

	#sec_flow_area .flow {
		width: 100%;
	}

	#sec_flow_area .area {
		width: 100%;
		margin-top: 20rem;
	}

	#sec_flow_area .area .ttl {
		font-size: 2.4rem;
		padding: .375em 1em;
		border-radius: 1.1rem;
		margin-bottom: 3rem;
	}

	#sec_flow_area .area .img img {
		display: block;
		width: 64.7rem;
		max-width: inherit;
		margin: 0 -.85rem;
	}

	#sec_flow_area .area .img .note {
		font-size: 2rem;
		margin-bottom: -1.5rem;
	}
}



/* gallery
--------------------------------*/
#sec_gallery {
	padding: 0 0 100px;
	margin-top: -107px;
}

#sec_gallery .list {
	width: 100%;
	max-width: 1400px;
	margin: 0 auto;
}

#sec_gallery .img {
	width: 32.86%;
	max-width: 460px;
	border-radius: 0px 0px 40px 0px;
	overflow: hidden;
}

@media screen and (max-width: 767px) {
	#sec_gallery {
		padding: 0 6rem 10rem;
		margin-top: -6.5rem;
	}

	#sec_gallery .list {
		max-width: inherit;
	}

	#sec_gallery .img {
		width: 100%;
		max-width: inherit;
		border-radius: 0px 0px 5.5rem 0px;
	}

	#sec_gallery .img + .img {
		margin-top: 4rem;
	}

}




/* office
--------------------------------*/
#sec_office {
	padding: 100px 0;
}

#sec_office .flex {
	justify-content: space-between;
}

#sec_office .box {
	width: 536px;
	text-align: center;
	padding: 30px 30px 40px;
	background-color: #f1f3ef;
	border-radius: 40px 0px 0px 0px;
}

@media screen and (min-width: 768px) {
	#sec_office .box {
		margin-bottom: 28px;
	}
}

#sec_office .box .ttl {
    position: relative;
    font-size: 2.2rem;
    letter-spacing: 0;
    padding-bottom: 18px;
    margin-bottom: 1em;
    height: 3em;
    align-items: center;
    display: flex;
	justify-content: center;
}

#sec_office .box .ttl::before {
	content: "";
	width: 2.7em;
	height: 1px;
	background-color: #7f7f7f;
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	margin: 0 auto;
}

#sec_office .box .address {
	font-weight: 500;
	font-size: 1.7rem;
	line-height: 1.8;
}

#sec_office .box .tel {
	font-size: 2.6rem;
	line-height: 1.5;
	margin-top: 4px;
}

#sec_office .box .fax {
	font-size: 2rem;
	line-height: 1.5;
	margin-top: 4px;
}

#sec_office .box .office_number {
	font-size: 1.6rem;
	margin-top: .4em;
}

@media screen and (max-width: 767px) {
	#sec_office {
		padding: 10rem 0;
	}

	#sec_office .box {
		width: 100%;
		padding: 4rem 3rem 6rem;
		border-radius: 4rem 0px 0px 0px;
	}

	#sec_office .box + .box {
		margin-top: 4rem;
	}

	#sec_office .box .ttl {
		font-size: 2.85rem;
		letter-spacing: 0.05em;
		padding-bottom: 1.25em;
		margin-bottom: 1em;
		justify-content: center;
	}

	#sec_office .box .ttl::before {
		width: 7rem;
		height: .2rem;
	}

	#sec_office .box .address {
		font-size: 2.4rem;
	}

	#sec_office .box .tel {
		font-size: 4rem;
		margin-top: .6rem;
	}

	#sec_office .box .fax {
		font-size: 3rem;
		margin-top: .6rem;
	}

	#sec_office .box .office_number {
		font-size: 3.2vw;
		margin-top: 4vw;
	}
}


/* message
--------------------------------*/
#sec_message {
	padding: 100px 0;
}

#sec_message .inner {
	position: relative;
}

#sec_message .inner {
	width: calc(50% + 550px);
	margin-left: auto;
	align-items: center;
}

#sec_message .imgwrap {
	position: relative;
	width: calc(100% - 634px);
}

#sec_message .imgwrap::before {
	content: "";
	width: calc(100% - 273px);
	height: 269px;
	background-color: #c8e7ed;
	border-radius: 28px 0px 0px 0px;
	position: absolute;
	top: -102px;
	right: 0;
	z-index: -1;
}

#sec_message .img {
	position: relative;
	width: 100%;
	height: 380px;
	border-radius: 0px 0px 0px 40px;
	overflow: hidden;
}

#sec_message .img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: left center;
}


#sec_message .txtwrap {
	width: 540px;
}

#sec_message .txtwrap .ttl {
	font-size: 2.4rem;
	margin-bottom: 1em;
}

#sec_message .txtwrap .txt {
	font-weight: 500;
	font-size: 1.8rem;
	letter-spacing: 0;
	text-align: justify;
}

#sec_message .txtwrap .name {
	font-size: 1.7rem;
}

#sec_message .txtwrap .name span {
	font-size: 2.2rem;
}


@media screen and (max-width: 767px) {
	#sec_message {
		padding: 10rem 0 20rem;
	}

	#sec_message .secttl {
		margin-bottom: 6.5rem;
	}

	#sec_message .inner {
		width: 84%;
		margin: 0 auto;
	}

	#sec_message .imgwrap {
		width: 100%;
	}

	#sec_message .imgwrap::before {
		width: 35rem;
		height: 33.5rem;
		border-radius: 2.8rem 0px 0px 0px;
		top: -5.8rem;
		right: -6rem;
	}

	#sec_message .img {
		width: 69rem;
		height: 47.4rem;
		border-radius: 0px 0px 0px 6.9rem;
		margin-top: 10rem;
	}

	#sec_message .txtwrap {
		width: 100%;
	}

	#sec_message .txtwrap .ttl {
		font-size: 2.6rem;
	}

	#sec_message .txtwrap .txt {
		font-size: 2.6rem;
	}

	#sec_message .txtwrap .name {
		font-size: 2.26rem;
		margin-top: 1em;
	}

	#sec_message .txtwrap .name span {
		font-size: 2.92rem;
	}

}


/* topics
--------------------------------*/
#sec_topics {
	background-color: #f1f3ef;
}

#sec_topics .inner {
	width: calc(50% + 550px);
}

#sec_topics .img {
	position: relative;
	width: calc(100% - 820px);
	border-radius: 0px 0px 40px 0px;
	overflow: hidden;
}

#sec_topics .img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	transform: scale(1);
	transition: 12s ease;
}

#sec_topics .img.is-show img {
	transform: scale(1.1);
}

#sec_topics .txtwrap {
	width: 721px;
	padding: 100px 0;
}

#sec_topics .txtwrap .secttl {
	margin-bottom: 50px;
}

#sec_topics .list .item {
	border-bottom: 1px dashed #000000;
}

#sec_topics .list .item a {
	position: relative;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: flex-start;
	padding: 24px 0;
	transition: .3s ease;
}

#sec_topics .list .item .date {
	flex: 0 0 auto;
	width: 7em;
	line-height: 1.3125;
	margin-right: 18px;
}

#sec_topics .list .item .cate {
	line-height: 1;
}

#sec_topics .list .item .cate span {
	display: inline-block;
	/*	min-width: 103px;*/
	text-align: center;
	font-size: 1.4rem;
	line-height: 1.5;
	padding: 0 1.5em;
	background-color: #fff;
	margin-right: 5px;
	margin-bottom: 5px;
}

#sec_topics .list .item .ttl {
	width: 100%;
	font-weight: 500;
	font-size: 1.7rem;
	letter-spacing: 0.07em;
}


#sec_topics .txtwrap .btn {
	margin-top: 42px;
}

@media screen and (min-width: 768px) {
	#sec_topics .list .item a:hover {
		opacity: .7;
	}
}

@media screen and (max-width: 767px) {
	#sec_topics {
		background: none;
	}

	#sec_topics .inner {
		width: 100%;
	}

	#sec_topics .img {
		width: 100%;
		height: 61.9rem;
		border-radius: 0px 0px 5.5rem 0px;
	}

	#sec_topics .txtwrap {
		width: 100%;
		background-color: #f1f3ef;
		padding: 10rem 6rem;
	}

	#sec_topics .txtwrap .secttl {
		text-align: center;
		margin-bottom: 3.5rem;
	}

	#sec_topics .list .item a {
		padding: 5.5rem 0 3.5rem;
	}

	#sec_topics .list .item .date {
		margin-right: 3rem;
	}


	#sec_topics .list .item .cate span {
		font-size: 2.1rem;
		margin-right: 1rem;
		margin-bottom: 1rem;
	}

	#sec_topics .list .item .ttl {
		font-size: 2.6rem;
		letter-spacing: 0;
		margin-top: .5em;
	}

	#sec_topics .txtwrap .btn {
		text-align: center;
		margin-top: 4.5rem;
	}

}