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

#gHeader {
}
.submv-wrap {
	padding-top: 140px;
	position: relative;
}
.submv-wrap::before {
	position: absolute;
	left: 0;
	top: 0;
	content: "";
	background:url("../images/water-color-1.svg") top right no-repeat;
	background-size: 100% auto;
	width: 29vw;
	height: 400px;
}
.submv-wrap::after {
	position: absolute;
	right: 0;
	top: 0;
	content: "";
	background:url("../images/water-color-2.svg") top left no-repeat;
	background-size: 100% auto;
	width: 29vw;
	height: 400px;
}
.submainVisual {
    box-sizing: border-box;
    position: relative;
	width: 100%;
	height: 600px;
	z-index: 10;
    }
.submainVisual .mv_txt {
	position: relative;
	z-index: 20;
	width: 100%;
	height: 100%;
}
.submainVisual .imgs {
	position: absolute;
	right: 0;
	top: 0;
	width: 77vw;
	height: 100%;
	z-index: 4;
}
.submainVisual .imgs img {
	width: 100%;
	height: 100%;
	border-radius: 80px 0 0 80px;
	object-fit: cover;
}
.submainVisual .mv_txt .txt {
	position: absolute;
	text-align: right;
	left: 6%;
	top:0;
	height: 100%;
	writing-mode: vertical-rl;
}
.submainVisual .mv_txt h1 {
	height: 100%;
	box-sizing: border-box;
	padding: 5% 0 20% 0;
	color: #F26A83;
	text-align: center;
	font-size: 50px;
	font-style: normal;
	font-weight: 700;
	line-height: 115%; /* 57.5px */
	letter-spacing: 5px;
}
.submainVisual .mv_txt h1 img {
	max-height: 100%;
	max-width: 100%;
}
.submainVisual .mv_txt small {
	display: block;
	color: #7E6060;
	font-size: 18px;
	font-size: 2vh;
	font-style: normal;
	font-weight: 700;
	line-height: 105%; /* 18.9px */
	letter-spacing: 0.54px;
	margin-right: 2vw;
}





@media all and (max-width: 768px) {
	.submv-wrap {
		padding-top: 55px;
		position: relative;
	}
	.submv-wrap::before {
		position: absolute;
		left: 0;
		top: 0;
		content: "";
		background:url("../images/water-color-1.svg") top right no-repeat;
		background-size: 100% auto;
		width: 29vw;
		height: 200px;
	}
	.submv-wrap::after {
		position: absolute;
		right: 0;
		top: 0;
		content: "";
		background:url("../images/water-color-2.svg") top left no-repeat;
		background-size: 100% auto;
		width: 29vw;
		height: 200px;
	}
	.submainVisual {
		box-sizing: border-box;
		position: relative;
		width: 100%;
		height: 200px;
		z-index: 10;
		}
	.submainVisual .mv_txt {
		position: relative;
		z-index: 20;
		width: 100%;
		height: 100%;
	}
	.submainVisual .imgs {
		position: absolute;
		right: 0;
		top: 0;
		width: 77vw;
		height: 100%;
		z-index: 4;
	}
	.submainVisual .imgs img {
		width: 100%;
		height: 100%;
		border-radius: 40px 0 0 40px;
		object-fit: cover;
	}
	.submainVisual .mv_txt .txt {
		position: absolute;
		text-align: right;
		left: 6%;
		top:0;
		height: 100%;
		writing-mode: vertical-rl;
	}
	.submainVisual .mv_txt h1 {
		height: 100%;
		box-sizing: border-box;
		padding: 5% 0 20% 0;
		color: #F26A83;
		text-align: center;
		font-size: 20px;
		font-style: normal;
		font-weight: 700;
		line-height: 115%; /* 57.5px */
		letter-spacing: 2px;
	}
	.submainVisual .mv_txt h1 img {
		max-height: 100%;
		max-width: 100%;
	}
	.submainVisual .mv_txt small {
		display: block;
		color: #7E6060;
		font-size: 18px;
		font-size: 2vh;
		font-style: normal;
		font-weight: 700;
		line-height: 105%; /* 18.9px */
		letter-spacing: 0.54px;
		margin-right: 2vw;
	}
}






.branch {
	display: block;
	background: #EFEFEF;
	padding: 18px 0;
}
@media all and (max-width: 1300px) {
	.branch {
		margin-left: 4%;
		margin-right: 4%;
	}
}
.branch ul {
	display: flex;
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
}
.branch ul li {
	display: block;
	position: relative;
	margin-left: 27px;
	font: normal normal bold 15px/16px Noto Sans JP;
	letter-spacing: 0.75px;
	color: #231815;
}
.branch ul li a {
	color: #BFBFBF;
}
.branch ul li::before {
	position: absolute;
	left: -15px;
	top: 0;
	content: "";
	width: 1px;
	height: 100%;
	background: #BFBFBF;
}
.branch ul li:nth-child(1) {
	margin-left: 0px;
}
.branch ul li:nth-child(1)::before {
	display: none;
}
@media all and (min-width: 769px) {
	.branch ul li a:hover {
		color:#c82b16;
	}
}
@media all and (max-width: 768px) {
	.branch {
		display: none;
	}
}



/* business----------------------------------------------- */
.subpages {
	background: url("../images/pattern.jpg") top center repeat-y;
	background-size: 100% auto;
}
.subpage-contents {
	color: #7E6060;
	position: relative;
	z-index: 20;
}
.subpage-contents p {
	color: #7E6060;
	font-family: "Zen Kaku Gothic Antique", sans-serif;
	font-size: 16px;
	font-style: normal;
	font-weight: 500;
	line-height: 150%; /* 24px */
	letter-spacing: 1.6px;
}
.fix-1430 {
	max-width: 1430px;
	margin-left: auto;
	margin-right: auto;
}
.bloglist {
	padding: 120px 0;
}
.ttl1 {
	display: block;
	color: #7E6060;
	font-size: 27px !important;
	font-style: normal;
	font-weight: 700;
	line-height: 100%; /* 27px */
	letter-spacing: 2.7px;
	margin-bottom: 40px;
}
.blog-cats {
	display: flex;
	flex-wrap: wrap;
}
.blog-cats li {
	display: block;
	margin-right: 35px;
	margin-bottom: 25px;
}
.blog-cats li a {
	display: inline-block;
	color: #F26A83;
	font-size: 20px;
	font-style: normal;
	font-weight: 700;
	line-height: 100%; /* 20px */
	letter-spacing: 2px;
	border-bottom: #F26A83 solid 1px;
	padding-bottom: 7px;
}
.blog-cats li a.current {
	opacity: 0.6;
}
.works-sub {
	display: flex;
	flex-wrap: wrap;
	padding-top: 60px;
}
.works-sub .slid-c1 {
	display: block;
	margin-bottom: 90px;
	margin-left: 70px;
    flex-basis: calc((100% - (70px * 2)) / 3 - .01px);
}
.works-sub .slid-c1:nth-child(3n+1) {
	margin-left: 0;
}
.works-sub .slid-c1 .works__img {
	display: block;
	width: 100%;
	aspect-ratio: 420 / 320;
	margin-bottom: 3px;
	position: relative;
}
.works-sub .slid-c1 .works__img img {
	width: 100%;
	aspect-ratio: 420 / 320;
	object-fit: cover;
	border-radius: 35px ;
}
.works-sub .slid-c1 .cats {
	position: absolute;
	left: 0;
	bottom: 0;
	z-index: 5;
	background: #FFF;
	color: #F26A83;
	font-size: 15px;
	font-style: normal;
	font-weight: 700;
	line-height: 100%; /* 15px */
	letter-spacing: 0.75px;
	padding: 12px 20px;
	border-radius: 0 10px 0 0;
}
.works-sub .slid-c1 .days {
	display: block;
	color: #F26A83;
	font-family: "Outfit", sans-serif;
	font-size: 15px;
	font-style: normal;
	font-weight: 600;
	line-height: 100%; /* 15px */
	letter-spacing: 0.75px;
	padding: 20px 0 12px 0;
}
.works-sub .slid-c1 p {
	color: #7E6060;
	font-size: 18px;
	font-style: normal;
	font-weight: 700;
	line-height: 100%; /* 18px */
	letter-spacing: 1.8px;
	overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1; /* 任意の行数を指定 */
}
.works-sub .slid-c1 .s-txt {
	color: #7E6060;
	font-size: 16px;
	font-style: normal;
	font-weight: 500;
	line-height: 150%; /* 24px */
	letter-spacing: 1.6px;
	margin-top: 9px;
	overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2; /* 任意の行数を指定 */
}

@media all and (min-width: 769px) {
	.blog-cats li a:hover {
		opacity: 0.6;
	}
}

@media all and (min-width: 769px) and (max-width: 1000px) {
	.blog-cats li {
		display: block;
		margin-right: 20px;
		margin-bottom: 15px;
	}
	.blog-cats li a {
		font-size: 16px;
	}
	.works-sub {
		display: flex;
		flex-wrap: wrap;
		padding-top: 60px;
	}
	.works-sub .slid-c1 {
		display: block;
		margin-bottom: 40px;
		margin-left: 30px;
		flex-basis: calc((100% - (30px * 2)) / 3 - .01px);
	}
	.works-sub .slid-c1:nth-child(3n+1) {
		margin-left: 0;
	}
	.works-sub .slid-c1 .works__img {
		display: block;
		width: 100%;
		aspect-ratio: 420 / 320;
		margin-bottom: 3px;
		position: relative;
	}
	.works-sub .slid-c1 .works__img img {
		width: 100%;
		aspect-ratio: 420 / 320;
		object-fit: cover;
		border-radius: 35px ;
	}
	.works-sub .slid-c1 .cats {
		position: absolute;
		left: 0;
		bottom: 0;
		z-index: 5;
		background: #FFF;
		color: #F26A83;
		font-size: 13px;
		font-style: normal;
		font-weight: 700;
		line-height: 100%; /* 15px */
		letter-spacing: 0.75px;
		padding: 12px 20px;
		border-radius: 0 10px 0 0;
	}
	.works-sub .slid-c1 .days {
		display: block;
		color: #F26A83;
		font-family: "Outfit", sans-serif;
		font-size: 15px;
		font-style: normal;
		font-weight: 600;
		line-height: 100%; /* 15px */
		letter-spacing: 0.75px;
		padding: 20px 0 12px 0;
	}
	.works-sub .slid-c1 p {
		color: #7E6060;
		font-size: 16px;
		font-style: normal;
		font-weight: 700;
		line-height: 100%; /* 18px */
		letter-spacing: 1.8px;
		overflow: hidden;
	  display: -webkit-box;
	  -webkit-box-orient: vertical;
	  -webkit-line-clamp: 1; /* 任意の行数を指定 */
	}
	.works-sub .slid-c1 .s-txt {
		color: #7E6060;
		font-size: 15px;
		font-style: normal;
		font-weight: 500;
		line-height: 150%; /* 24px */
		letter-spacing: 1.6px;
		margin-top: 9px;
		overflow: hidden;
	  display: -webkit-box;
	  -webkit-box-orient: vertical;
	  -webkit-line-clamp: 2; /* 任意の行数を指定 */
	}
}

@media all and (max-width: 1350px) {
	.fix-1430 {
		margin-left: 4%;
		margin-right: 4%;
	}
}

@media all and (max-width: 768px) {
	.subpages {
		background: url("../images/pattern.jpg") top center repeat-y;
		background-size: 150% auto;
	}
	.subpage-contents p {
		font-size: 15px;
		font-style: normal;
		font-weight: 500;
		line-height: 2; /* 24px */
		letter-spacing: 1px;
	}
	.fix-1430 {
		margin-left: 4%;
		margin-right: 4%;
	}
	.bloglist {
		padding: 60px 0;
	}
	.ttl1 {
		display: block;
		color: #7E6060;
		font-size: 20px !important;
		font-style: normal;
		font-weight: 700;
		line-height: 100%; /* 27px */
		letter-spacing: 1.7px;
		margin-bottom: 25px;
	}
	.blog-cats {
		display: flex;
		flex-wrap: wrap;
	}
	.blog-cats li {
		display: block;
		margin-right: 15px;
		margin-bottom: 15px;
	}
	.blog-cats li a {
		display: inline-block;
		color: #F26A83;
		font-size: 16px;
		font-style: normal;
		font-weight: 700;
		line-height: 100%; /* 20px */
		letter-spacing: 1px;
		border-bottom: #F26A83 solid 1px;
		padding-bottom: 7px;
	}
	.blog-cats li a.current {
		opacity: 0.6;
	}
	.works-sub {
		display: block;
		padding-top: 30px;
	}
	.works-sub .slid-c1 {
		display: block;
		margin-bottom: 25px;
		margin-left: 0px;
		flex-basis: calc((100% - (70px * 2)) / 3 - .01px);
	}
	.works-sub .slid-c1:nth-child(3n+1) {
		margin-left: 0;
	}
	.works-sub .slid-c1 .works__img {
		display: block;
		width: 100%;
		aspect-ratio: 420 / 320;
		margin-bottom: 3px;
		position: relative;
	}
	.works-sub .slid-c1 .works__img img {
		width: 100%;
		aspect-ratio: 420 / 320;
		object-fit: cover;
		border-radius: 35px ;
	}
	.works-sub .slid-c1 .cats {
		position: absolute;
		left: 0;
		bottom: 0;
		z-index: 5;
		background: #FFF;
		color: #F26A83;
		font-size: 13px;
		font-style: normal;
		font-weight: 700;
		line-height: 100%; /* 15px */
		letter-spacing: 0.75px;
		padding: 10px 15px;
		border-radius: 0 10px 0 0;
	}
	.works-sub .slid-c1 .days {
		display: block;
		color: #F26A83;
		font-family: "Outfit", sans-serif;
		font-size: 14px;
		font-style: normal;
		font-weight: 600;
		line-height: 100%; /* 15px */
		letter-spacing: 0.75px;
		padding: 10px 0 12px 0;
	}
	.works-sub .slid-c1 p {
		color: #7E6060;
		font-size: 15px;
		font-style: normal;
		font-weight: 700;
		line-height: 100%; /* 18px */
		letter-spacing: 1px;
		overflow: hidden;
	  display: -webkit-box;
	  -webkit-box-orient: vertical;
	  -webkit-line-clamp: 1; /* 任意の行数を指定 */
	}
	.works-sub .slid-c1 .s-txt {
		color: #7E6060;
		font-size: 14px;
		font-style: normal;
		font-weight: 500;
		line-height: 150%; /* 24px */
		letter-spacing: 1px;
		margin-top: 9px;
		overflow: hidden;
	  display: -webkit-box;
	  -webkit-box-orient: vertical;
	  -webkit-line-clamp: 2; /* 任意の行数を指定 */
	}
}


.blogdetail {
	display: block;
	padding: 120px 0;
}
.blogdetail .flx {
	display: flex;
	justify-content: space-between;
}
.blogdetail .lef {
	display: block;
	flex-basis: 70%;
}
.blog-ti {
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 10px;
}
.blog-ti p {
	display: block;
}
.blog-ti span {
	display:inline-block;
	margin-right: 8px;
	background: #FFF;
	color: #F26A83;
	font-size: 15px;
	font-style: normal;
	font-weight: 700;
	line-height: 100%; /* 15px */
	letter-spacing: 0.75px;
	padding: 10px 20px;
	border-radius: 10px;
}
.blog-ti h2 {
	padding-top: 2px;
	padding-bottom: 0;
	margin-bottom: 0;
}
.day-d {
	display: block;
	font-size: 15px;
	margin-bottom: 45px;
}
.blog-dbox1 {
	display: block;
	margin-bottom: 55px;
}
.blog-dbox1 .imgs {
	display: block;
	text-align: center;
	padding: 20px 0;
}
.blog-dbox1 .imgs img {
	display: inline-block;
	max-width: 100%;
	border-radius: 45px;
}
.sub-flx {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.sub-flx .blog-dbox1 {
	flex-basis: 48%;
	margin-bottom: 40px;
}
.blogdetail .ref {
	display: block;
	flex-basis: 25%;
}
.ttl2 {
	display: block;
	background: #ffbecb;
	padding: 8px 10px;
	font-size: 19px;
	letter-spacing: 1px;
	line-height: 1.6;
	border-radius: 10px;
	color: #FFF;
	margin-bottom: 22px;
}
.news-posts {
	display: block;
}
.news-posts a {
	display: flex;
	justify-content: space-between;
	padding-bottom: 20px;
	border-bottom: #efefef dotted 1px;
	margin-bottom: 20px;
}
.news-posts a .txt {
	display: block;
	flex-basis: 70%;
}
.news-posts a .txt small {
	display: block;
	font-size: 14px;
	margin-bottom: 5px;
}
.news-posts a .txt p {
	display: block;
	font-size: 15px;
	line-height: 2;
	overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2; /* 任意の行数を指定 */
}
.news-posts a .imgs {
	display: block;
	flex-basis: 27%;
	aspect-ratio: 1 / 1;
}
.news-posts a .imgs img {
	width: 100%;
	height: 100%;
	object-fit:cover;
	border-radius: 20px;
}
.backs-bt {
	display:flex;
	justify-content: center;
	margin-top: 45px;
}
.backs .btn001 {
	display: block;
	max-width: none !important;
}
.backs a {
	padding: 14px 60px 14px 14px !important;
	font-size: 16px;
}
.backs a::after {
	position: absolute;
	right: 0;
	top: 6px;
	content: "";
	width: 35px;
	height: calc(100% - 12px);
	border-left:#F26A83 dashed 2px;
	background: url("../images/arrow_down.png") center center no-repeat;
	background-size: 20px auto;
}
.backs a span {
	display: inline-block;
	position: relative;	
	font-size: 15px;
	font-style: normal;
	font-weight: 700;
	line-height: 100%; /* 18px */
	letter-spacing: 1px;
}
@media all and (min-width: 769px) {
	.backs a:hover::after {
		position: absolute;
		right: 0;
		top: 6px;
		content: "";
		width: 35px;
		height: calc(100% - 12px);
		border-left:#fff dashed 2px;
		background: url("../images/arrow_down-w.png") center center no-repeat;
		background-size: 20px auto;
	}
}
.other-posts {
	margin-top: 150px;
}
.icttl {
	display: flex;
	align-items: center;
}
.icttl span {
	display: block;
	width: 75px;
	margin-right: 15px;
}
.icttl h3,
.icttl h2{
	display:block;
	color: #7E6060;
	font-size: 27px !important;
	font-style: normal;
	font-weight: 700;
	line-height: 100%; /* 27px */
	letter-spacing: 2.7px;
}

@media all and (max-width: 768px) {
	.blogdetail {
		display: block;
		padding: 60px 0;
	}
	.blogdetail .flx {
		display: block;
	}
	.blogdetail .lef {
		display: block;
		flex-basis: 70%;
		margin-bottom: 35px;
	}
	.blog-ti {
		display: block;
		margin-bottom: 10px;
	}
	.blog-ti p {
		display: block;
	}
	.blog-ti span {
		display:inline-block;
		margin-right: 4px;
		background: #FFF;
		color: #F26A83;
		font-size: 13px;
		font-style: normal;
		font-weight: 700;
		line-height: 100%; /* 15px */
		letter-spacing: 0.75px;
		padding: 4px 10px;
		border-radius: 10px;
	}
	.blog-ti h2 {
		padding-top: 2px;
		padding-bottom: 0;
		margin-bottom: 0;
	}
	.day-d {
		display: block;
		font-size: 15px;
		margin-bottom: 25px;
	}
	.blog-dbox1 {
		display: block;
		margin-bottom: 25px;
	}
	.blog-dbox1 .imgs {
		display: block;
		text-align: center;
		padding: 15px 0;
	}
	.blog-dbox1 .imgs img {
		display: inline-block;
		max-width: 100%;
		border-radius: 25px;
	}
	.sub-flx {
		display: block;
	}
	.sub-flx .blog-dbox1 {
		flex-basis: 48%;
		margin-bottom: 20px;
	}
	.blogdetail .ref {
		display: block;
		flex-basis: 25%;
	}
	.ttl2 {
		display: block;
		background: #ffbecb;
		padding: 5px 10px;
		font-size: 17px;
		letter-spacing: 1px;
		line-height: 1.6;
		border-radius: 10px;
		color: #FFF;
		margin-bottom: 22px;
	}
	.news-posts {
		display: block;
	}
	.news-posts a {
		display: flex;
		justify-content: space-between;
		padding-bottom: 15px;
		border-bottom: #efefef dotted 1px;
		margin-bottom: 15px;
	}
	.news-posts a .txt {
		display: block;
		flex-basis: 70%;
	}
	.news-posts a .txt small {
		display: block;
		font-size: 12px;
		margin-bottom: 5px;
	}
	.news-posts a .txt p {
		display: block;
		font-size: 14px;
		line-height: 1.8;
		overflow: hidden;
	  display: -webkit-box;
	  -webkit-box-orient: vertical;
	  -webkit-line-clamp: 2; /* 任意の行数を指定 */
	}
	.news-posts a .imgs {
		display: block;
		flex-basis: 27%;
		aspect-ratio: 1 / 1;
	}
	.news-posts a .imgs img {
		width: 100%;
		height: 100%;
		object-fit:cover;
		border-radius: 20px;
	}
	.backs-bt {
		display:flex;
		justify-content: center;
		margin-top: 30px;
	}
	.backs .btn001 {
		display: block;
		max-width: none !important;
	}
	.backs a {
		padding: 14px 60px 14px 14px !important;
		font-size: 16px;
	}
	.backs a::after {
		position: absolute;
		right: 0;
		top: 6px;
		content: "";
		width: 35px;
		height: calc(100% - 12px);
		border-left:#F26A83 dashed 2px;
		background: url("../images/arrow_down.png") center center no-repeat;
		background-size: 20px auto;
	}
	.backs a span {
		display: inline-block;
		position: relative;	
		font-size: 15px;
		font-style: normal;
		font-weight: 700;
		line-height: 100%; /* 18px */
		letter-spacing: 1px;
	}
	.other-posts {
		margin-top: 50px;
	}
	.icttl {
		display: flex;
		align-items: center;
	}
	.icttl span {
		display: block;
		width: 45px;
		margin-right: 15px;
	}
	.icttl h3,
	.icttl h2{
		display:block;
		color: #7E6060;
		font-size: 19px !important;
		font-style: normal;
		font-weight: 700;
		line-height: 100%; /* 27px */
		letter-spacing: 1px;
	}
}


/* day----------------------------------------------- */

.dailylife {
	display: block;
	padding: 120px 0;
}
.flow-wrap {
	display: block;
	position: relative;	
	margin-top: 45px;
	margin-bottom: 90px;
}
.flow-wrap ul {
	display: block;
	padding-left: 120px;
	position: relative;
}
.flow-wrap ul::before {
	position: absolute;
	left: 10px;
	top: 0;
	content: "";
	width: 12px;
	height: 100%;
	background: #fad9df;
}
.flow-wrap li {
	display: block;
	position: relative;
	margin-bottom: 50px;
}
.flow-wrap li::before {
	position: absolute;
	left: -130px;
	top: -20px;
	/*bottom: 0;
	margin: auto;*/
	content: "";
	width: 30px;
	height: 30px;
	border-radius: 50%;
	border: #fad9df solid 10px;
	background: #f26a83;
}
li.nos-img::before {
	top: 0px;
}
.flows {
	display: flex;
	justify-content: space-between;
	position: relative;
	flex-direction: row-reverse;
}
.flows .times1 {
	position: absolute;
	left: -25px;
	top: -15px;
	display: inline-block;
	padding: 6px 16px;
	background: #FFF;
	color: #f26a83;
	border-radius: 6px;
	border:  #f26a83 solid 1px;
	min-width: 140px;
	text-align: center;
}
.flows.noflows .times1{
	top: 0px;
}
.flows .txt {
	display: block;
	flex-basis: 70%;
}
.flows.noflows .txt {
	display: block;
	flex-basis: 100%;
	margin-left: 180px;
}
.flows .txt p {
	font-size: 16px;
	line-height: 2;
}
.flows .imgs {
	display: block;
	aspect-ratio: 1000 / 750 !important;
	flex-basis: 27%;
}
.flows .imgs img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 30px;
}
.year-box {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin-top: 35px;
	margin-bottom: 90px;
}
.year-box .ones {
	display: block;
	position: relative;
	flex-basis: 48%;
	margin-bottom: 40px;
	box-sizing: border-box;
	padding: 70px;
	background: #fce5ea;
	border-radius: 30px;
}
.year-box .ones::after {
	position: absolute;
	left: 35px;
	top: 35px;
	content: "";
	width: calc(100% - 70px);
	height: calc(100% - 70px);
	background: #FFF;
	border-radius: 30px;
}
.year-box .ones .inn {
	display:block;
	position: relative;
	z-index: 6;
}
.ttl3 {
	display: block;
	text-align: center;
	position: relative;
	font-size: 26px;
	letter-spacing: 3px;
	line-height: 1.6;
	padding-bottom: 20px;
	margin-bottom: 25px;
	background: url("../images/gradation-line.png") bottom center no-repeat;
	background-size: 80px auto;
}
.picks-box {
	display: block;
	margin-top: 45px;
	position: relative;
}
.picks-box li {
	display: block;
	padding-bottom: 30px;
	border-bottom: #666 dotted 1px;
	margin-bottom: 30px;
}
.picks-box .flx {
	display: flex;
	justify-content: space-between;
}
.picks-box .txt {
	display: block;
	flex-basis: 70%;
}
.sub-ti2 {
	display: block;
	font-size: 20px;
	margin-bottom: 20px;
}
.picks-box .imgs {
	flex-basis: 27%;
}
.picks-box .imgs img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 30px;
}


@media all and (max-width: 768px) {
	.dailylife {
		display: block;
		padding: 60px 0;
	}
	.flow-wrap {
		display: block;
		position: relative;	
		margin-top: 35px;
		margin-bottom: 60px;
	}
	.flow-wrap ul {
		display: block;
		padding-left: 30px;
		position: relative;
	}
	.flow-wrap ul::before {
		position: absolute;
		left: 5px;
		top: 0;
		content: "";
		width: 6px;
		height: 100%;
		background: #fad9df;
	}
	.flow-wrap li {
		display: block;
		position: relative;
		margin-bottom: 75px;
	}
	.flow-wrap li::before {
		position: absolute;
		left: -33px;
		top: 7px;
		bottom: auto;
		margin: auto;
		content: "";
		width: 17px;
		height: 17px;
		border-radius: 50%;
		border: #fad9df solid 3px;
		background: #f26a83;
	}
	li.nos-img::before {
		top: 7px;
	}
	.flows {
		display: block;
	}
	.flows .times1 {
		position:relative;
		left: 0px;
		top: 0px;
		display: inline-block;
		padding: 6px 16px;
		background: #FFF;
		color: #f26a83;
		border-radius: 6px;
		border:  #f26a83 solid 1px;
		font-size: 15px;
		margin-bottom: 10px;
	}
	.flows .txt {
		display: block;
		flex-basis: 70%;
	}
	.flows.noflows .txt {
		display: block;
		flex-basis: 100%;
		margin-left: 0px;
	}
	.flows .txt p {
		font-size: 15px;
		line-height: 1.9;
		margin-bottom: 20px;
	}
	.flows .imgs {
		display: block;
		flex-basis: 27%;
	}
	.flows .imgs img {
		width: 100%;
		height: 100%;
		object-fit: cover;
		border-radius: 30px;
	}
	.year-box {
		display: block;
		margin-top: 25px;
		margin-bottom: 60px;
	}
	.year-box .ones {
		display: block;
		position: relative;
		flex-basis: 48%;
		margin-bottom: 24px;
		box-sizing: border-box;
		padding: 35px;
		background: #fce5ea;
		border-radius: 30px;
	}
	.year-box .ones::after {
		position: absolute;
		left: 20px;
		top: 20px;
		content: "";
		width: calc(100% - 40px);
		height: calc(100% - 40px);
		background: #FFF;
		border-radius: 30px;
	}
	.year-box .ones .inn {
		display:block;
		position: relative;
		z-index: 6;
	}
	.ttl3 {
		display: block;
		text-align: center;
		position: relative;
		font-size: 22px;
		letter-spacing: 2px;
		line-height: 1.6;
		padding-bottom: 16px;
		margin-bottom: 20px;
		background: url("../images/gradation-line.png") bottom center no-repeat;
		background-size: 80px auto;
	}
	.year-box .ones p {
		font-size: 15px;
	}
	.picks-box {
		display: block;
		margin-top: 25px;
		position: relative;
	}
	.picks-box li {
		display: block;
		padding-bottom: 20px;
		border-bottom: #666 dotted 1px;
		margin-bottom: 20px;
	}
	.picks-box .flx {
		display: block;
	}
	.picks-box .txt {
		display: block;
		flex-basis: 70%;
		margin-bottom: 20px;
	}
	.sub-ti2 {
		display: block;
		font-size: 16px;
		margin-bottom: 15px;
	}
	.picks-box .imgs {
		flex-basis: 27%;
	}
	.picks-box .imgs img {
		width: 100%;
		height: 100%;
		object-fit: cover;
		border-radius: 30px;
	}
}


/* about----------------------------------------------- */

.greeting {
	display: block;
	padding: 120px 0;
}
.flx001 {
	display: flex;
	justify-content: space-between;
	margin-top: 35px;
}
.flx001.ri {
	flex-direction: row-reverse;
}
.flx001 .txt {
	display: block;
	flex-basis: 65%;
}
.flx001 .txt p {
	font-size: 16px;
	letter-spacing: 2;
	line-height: 2.1;
	margin-bottom: 40px;
}
.names-right {
	display: block;
	text-align: right;
	font-size: 19px;
	letter-spacing: 2px;
	font-weight: 600;
}
.flx001 .imgs {
	display: block;
	flex-basis: 30%;
}
.flx001 .imgs img {
	width: 100%;
	border-radius: 30px;
}
.mb100 {
	margin-bottom: 100px;
}
.mb35 {
	margin-bottom: 35px;
}
.e-box {
	display: block;
	margin-bottom: 70px;
}
.enty1 {
	display: block;
	padding: 75px 70px;
	background: #fce8ec;
	background: rgba(252,232,236,0.6);
	text-align: center;
	border-radius: 30px;
	position: relative;
}
.enty1::before {
	position: absolute;
	left: -20px;
	bottom: -11px;
	content: "";
	background: url("../images/about/ic1.png") left bottom no-repeat;
	background-size: 100% auto;
	width: 140px;
	height: 400px;
}
.enty1::after {
	position: absolute;
	right: -20px;
	top: -20px;
	content: "";
	background: url("../images/about/ic2.png") top center no-repeat;
	background-size: 100% auto;
	width: 130px;
	height: 400px;
}
.enty1 b {
	display: block;
	text-align: center;
	position: relative;
	font-size: 29px;
	letter-spacing: 3px;
	line-height: 1.6;
	padding-bottom: 20px;
	margin-bottom: 25px;
	background: url("../images/gradation-line.png") bottom center no-repeat;
	background-size: 40px auto;
}
.enty1 p {
	font-size: 17px;
	line-height: 2.1;
}
.e-txt1 {
	display: block;
	font-size: 15px !important;
	line-height: 2.1 !important;
	letter-spacing: 1px !important;
	margin-top: 30px;
}
.com-base {
	padding-top: 40px;
	margin-bottom: 90px;
}
.comp-tab {
	display: block;
	max-width: 1100px;
	margin-left: auto;
	margin-right: auto;
	padding: 40px;
	background: #FFF;
	border: #ffbecb solid 7px;
	border-radius: 30px;
}
.comp-tab table {
	width: 100%;
	border-collapse: collapse;
}
.comp-tab table th {
	text-align: left;
	vertical-align: top;
	font-size: 18px;
	letter-spacing: 1px;
	line-height: 2;
	font-weight: 600;
	padding: 20px 2%;
	width: 23%;
	border-bottom: #666 dotted 1px;
}
.comp-tab table td {
	text-align: left;
	vertical-align: top;
	font-size: 16px;
	letter-spacing: 1px;
	line-height: 2;
	padding: 20px 2%;
	border-bottom: #666 dotted 1px;
}
.news-base .news-li {
	padding-block: 30px;
	display: block;
}
.news-base .news-li:first-of-type {
	padding-top: 0;
}
.news-base .news-li:hover {
	opacity: 1;
}
.news-base .link:hover::after {
	transform: translateX(20px);
}
.news-base .news-li + .news-li {
	border-top: #666 dotted 1px;
}
.news-base .news-li .tx {
	color: #7E6060;
}
.news-base .news-li .tx b{
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 30px;
	font-size: 19px;
	margin-bottom: 6px;
}
.news-base .news-li .tx .link{
	display: block;
	inline-size: fit-content;
	margin-inline-start: auto;
	margin-block-start: 15px;
	padding-right: 100px;
	text-align: right;
	position: relative;
}
.news-base .news-li .tx .link::after {
	position: absolute;
	right: 0;
	top: 6px;
	content: "";
	width: 75px;
	height: calc(100% - 12px);
	border-left:#F26A83 dashed 2px;
	background: url("../images/arrow_down.png") center center / cover no-repeat;
	background-size: 24px auto;
	transition: all 0.3s ease;
}
.news-base .news-li .tx b span {
	min-inline-size: fit-content;
	font-size: 14px;
	font-weight: 400;
}
.acc-base2 {
	display: flex;
	justify-content: space-between;
	max-width: 1100px;
	margin-left: auto;
	margin-right: auto;
	padding: 40px;
	background: #FFF;
	border: #ffbecb solid 7px;
	border-radius: 30px;
}
.acc-base2 .lef {
	display: block;
	flex-basis: 47%;
}
.acc-base2 .lef .tx b {
	display: block;
	font-size: 19px;
	margin-bottom: 6px;
}
.acc-base2 .lef .tx p {
	margin-bottom: 26px;
	font-size: 16px;
	line-height: 1.9;
}
.acc-base2 .lef .tx p span {
	display: block;
	font-weight: 600;
}
.acc-base2 .ref {
	flex-basis: 50%;
}
.acc-base2 .ref div {
	width: 100% !important;
	height: 100% !important;
}
.acc-base2 iframe {
	width: 100%;
	height: 100%;
	border-radius: 30px;
}

@media all and (max-width: 768px) {
	.greeting {
		display: block;
		padding: 60px 0;
	}
	.flx001 {
		display: block;
		margin-top: 25px;
	}
	.flx001.ri {
		flex-direction: row-reverse;
	}
	.flx001 .txt {
		display: block;
		flex-basis: 65%;
		padding: 15px 0;
	}
	.flx001 .txt p {
		font-size: 15px;
		letter-spacing: 1;
		line-height: 2;
		margin-bottom: 20px;
	}
	.names-right {
		display: block;
		text-align: right;
		font-size: 15px;
		letter-spacing: 0px;
		font-weight: 600;
	}
	.flx001 .imgs {
		display: block;
		flex-basis: 30%;
	}
	.flx001 .imgs img {
		width: 100%;
		border-radius: 20px;
	}
	.mb100 {
		margin-bottom: 60px;
	}
	.mb35 {
		margin-bottom: 20px;
	}
	.e-box {
		display: block;
		margin-bottom: 50px;
	}
	.enty1 {
		display: block;
		padding: 25px 20px;
		background: #fce8ec;
		background: rgba(252,232,236,0.6);
		text-align: center;
		border-radius: 20px;
		position: relative;
	}
	.enty1::before {
		position: absolute;
		left: -10px;
		bottom: -45px;
		content: "";
		background: url("../images/about/ic1.png") left bottom no-repeat;
		background-size: 100% auto;
		width: 100px;
		height: 200px;
	}
	.enty1::after {
		position: absolute;
		right: -10px;
		top: -35px;
		content: "";
		background: url("../images/about/ic2.png") top center no-repeat;
		background-size: 100% auto;
		width: 60px;
		height: 140px;
	}
	.enty1 b {
		display: block;
		text-align: center;
		position: relative;
		font-size: 19px;
		letter-spacing: 1px;
		line-height: 1.6;
		padding-bottom: 20px;
		margin-bottom: 25px;
		background: url("../images/gradation-line.png") bottom center no-repeat;
		background-size: 40px auto;
	}
	.enty1 p {
		font-size: 16px;
		text-align: left;
		line-height: 2;
	}
	.e-txt1 {
		display: block;
		font-size: 15px !important;
		line-height: 2 !important;
		letter-spacing: 1px !important;
		margin-top: 50px;
	}
	.com-base {
		padding-top: 20px;
		margin-bottom: 50px;
	}
	.news-base .news-li .tx b {
		flex-wrap: wrap;
		gap: 5px 30px;
		margin-bottom: 20px;
	}
	.comp-tab {
		display: block;
		max-width: 1100px;
		margin-left: auto;
		margin-right: auto;
		padding: 15px;
		background: #FFF;
		border: #ffbecb solid 4px;
		border-radius: 20px;
	}
	.comp-tab table {
		width: 100%;
		border-collapse: collapse;
	}
	.comp-tab table th {
		display: block;
		text-align: left;
		vertical-align: top;
		font-size: 15px;
		letter-spacing: 1px;
		line-height: 2;
		font-weight: 600;
		padding: 12px 2%;
		width: auto;
		border-bottom: #666 dotted 0px;
		background: #fce6eb;
	}
	.comp-tab table td {
		display: block;
		text-align: left;
		vertical-align: top;
		font-size: 15px;
		letter-spacing: 1px;
		line-height: 2;
		padding: 12px 2% 24px 2%;
		border-bottom: #666 dotted 0px;
	}
	.acc-base2 {
		display: block;
		max-width: 1100px;
		margin-left: auto;
		margin-right: auto;
		padding: 15px;
		background: #FFF;
		border: #ffbecb solid 4px;
		border-radius: 20px;
	}
	.acc-base2 .lef {
		display: block;
		flex-basis: 47%;
		margin-bottom: 20px;
	}
	.acc-base2 .lef .tx b {
		display: block;
		font-size: 15px;
		margin-bottom: 6px;
	}
	.acc-base2 .lef .tx p {
		margin-bottom: 16px;
		font-size: 14px;
		line-height: 1.8;
	}
	.acc-base2 .lef .tx p span {
		display: block;
		font-weight: 600;
	}
	.acc-base2 .ref {
		flex-basis: 50%;
	}
	.acc-base2 .ref div {
		width: 100% !important;
		height: 320px !important;
	}
	.acc-base2 iframe {
		width: 100%;
		height: 320px;
		border-radius: 20px;
	}
}



/* inst----------------------------------------------- */

.gall-box {
	display: block;
	margin-bottom: 90px;
}
.gall-box .tx {
	font-size: 17px;
	letter-spacing: 2px;
	line-height: 2.1;
	margin-bottom: 45px;
}
.gall-box ul {
	display: flex;
	flex-wrap: wrap;
}
.gall-box ul li {
	display: block;
	margin-bottom: 40px;
	margin-left: 70px;
    flex-basis: calc((100% - (70px * 2)) / 3 - .01px);
}
.gall-box ul li:nth-child(3n+1) {
	margin-left: 0px;
}
.gall-box ul li img {
	width: 100%;
	aspect-ratio: 5 / 4;
	border-radius: 30px;
	object-fit:cover;
}


@media all and (max-width: 768px) {
	.gall-box {
		display: block;
		margin-bottom: 50px;
	}
	.gall-box .tx {
		font-size: 15px;
		letter-spacing: 2px;
		line-height: 2;
		margin-bottom: 25px;
	}
	.gall-box ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.gall-box ul li {
		display: block;
		margin-bottom: 15px;
		margin-left: 0px;
		flex-basis: 48%;
	}
	.gall-box ul li:nth-child(3n+1) {
		margin-left: 0px;
	}
	.gall-box ul li img {
		width: 100%;
		aspect-ratio: 5 / 4;
		border-radius: 20px;
		object-fit:cover;
	}
}


/* strength----------------------------------------------- */

.flx001.v2 .txt{
	flex-basis: 55%;
}
.flx001.v2 .imgs {
	flex-basis: 40%;
}
.positimg {
	position: relative;
}
.positimg .se2 {
	position: absolute;
	left: -20px;
	top: 120px;
	width: 49%;
	z-index: 3;
}
.positimg .se3 {
	position: absolute;
	right: 0px;
	top: 0px;
	width: 49%;
}
.com-base.v2 {
	padding-top: 5px;
}
.pb-x {
	padding-bottom: 200px;
}

@media all and (max-width: 768px) {
	.positimg {
		position: relative;
	}
	.positimg .se2 {
		position: relative;
		left: 0px;
		top: 0px;
		width: 100%;
		z-index: 3;
		margin-bottom: 13px;
		display: block;
	}
	.positimg .se3 {
		position: relative;
		right: 0px;
		top: 0px;
		width: 100%;
	}
	.com-base.v2 {
		padding-top: 5px;
	}
	.pb-x {
		padding-bottom: 50px;
	}
}



/* works----------------------------------------------- */
.workslist {
	display: block;
	margin-bottom: 130px;
}
.workslist .cats {
	display: block;
	margin-bottom: 60px;
	padding-top: 80px;
}
.workslist .cats li {
	display: inline-block;
	margin-right: 10px;
	margin-bottom: 18px;
}
.workslist .cats li a {
	display: inline-block;
	color: #464646;
	font-family: "Zen Kaku Gothic New";
	font-size: 22px;
	font-style: normal;
	font-weight: 700;
	line-height: 22px; /* 100% */
	letter-spacing: 2.2px;
	position: relative;
	padding: 15px 25px 18px 40px;
	
}
.workslist .cats li a::before {
	position: absolute;
	left: 15px;
	bottom: 0;
	top: 0;
	z-index: 5;
	margin: auto;
	content: "";
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: #E26D00;
	-webkit-transition: all 0.2s ease-in-out 0s;
  		transition: all 0.2s ease-in-out 0s;
}
.workslist .cats li a::after {
	position: absolute;
	left: 0;
	top: 0;
	content: "";
	width: 100%;
	height: 100%;
	border-radius: 50px;
	background: linear-gradient(267deg, #FFD86A 2.8%, #FF8C21 97.22%);
	-webkit-transition: all 0.2s ease-in-out 0s;
  		transition: all 0.2s ease-in-out 0s;
	opacity: 0;
}
.workslist .cats li.current a {
	color: #FFF;
	opacity: 1;
	-webkit-transition: all 0.2s ease-in-out 0s;
  		transition: all 0.2s ease-in-out 0s;
}
.workslist .cats li.current a::before{
	background: #FFD86F;
}
.workslist .cats li.current a::after {
    opacity: 1;
    background: linear-gradient(267deg, #FFD86A 2.8%, #FF8C21 97.22%);
    -webkit-transition: all 0.2s ease-in-out 0s;
    transition: all 0.2s ease-in-out 0s;
}
.workslist .cats li a span {
	position: relative;
	z-index: 5;
}
@media all and (min-width: 769px) {
	.workslist .cats li a:hover {
		color: #FFF;
		opacity: 1;
	}
	.workslist .cats li a:hover::after {
		opacity: 1;
		background: linear-gradient(267deg, #FFD86A 2.8%, #FF8C21 97.22%);
		-webkit-transition: all 0.2s ease-in-out 0s;
  		transition: all 0.2s ease-in-out 0s;
	}
	.workslist .cats li a:hover::before{
		background: #FFD86F;
	}
}
.workslist .lists {
	display: flex;
	flex-wrap: wrap;
}
.workslist .lists li {
	display: block;
	margin-bottom: 80px;
	margin-left: 80px;
	flex-basis: calc((100% - (80px * 3)) / 4 - .01px);
	max-width: calc((100% - (80px * 3)) / 4 - .01px);
	position: relative;
}
.workslist .lists li:nth-child(4n+1) {
	margin-left: 0px;
}
.workslist .lists li a {
	display: block;
}
@media all and (min-width: 769px) {
	.workslist .lists li a:hover {
		opacity: 0.7;
	}
}
.workslist .lists li .imgs {
	display: block;
	position: relative;
}
.workslist .lists li .imgs img {
	width: 100%;
	object-fit: cover;
	aspect-ratio: 9 / 10.8;
	border-radius: 30px 0;
}
.workslist .lists li .imgs span {
	position: absolute;
	display: inline-block;
	left: 5px;
	bottom: 5px;
	z-index: 5;
	color: #FFF;
	text-align: center;
	font-family: "Zen Kaku Gothic New";
	font-size: 18px;
	font-style: normal;
	font-weight: 500;
	line-height: 18px; /* 100% */
	letter-spacing: 1.8px;
	padding: 14px 25px;
	border-radius: 10px 0px;
	background: #E26D00;
}
.workslist .lists li .days {
	display: block;
	padding: 10px 0 5px 0;
	color: #464646;
	font-size: 16px;
	font-style: normal;
	font-weight: 700 !important;
	line-height: 18px; /* 112.5% */
	letter-spacing: 1.28px;
}
.workslist .lists li p {
	width: 100%;
	color: #464646;
	font-family: "Zen Kaku Gothic New";
	font-size: 18px;
	font-style: normal;
	font-weight: 700;
	line-height: 18px; /* 100% */
	letter-spacing: 1.44px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
@media all and (min-width: 769px) and (max-width: 1100px) {
	.workslist .lists li {
		display: block;
		margin-bottom: 40px;
		margin-left: 40px;
		flex-basis: calc((100% - (40px * 3)) / 4 - .01px);
		max-width: calc((100% - (40px * 3)) / 4 - .01px);
		position: relative;
	}
	.workslist .lists li .imgs span {
		font-size: 14px;
		line-height: 18px; /* 100% */
		padding: 10px 15px
	}
	.workslist .lists li .days {
		font-size: 14px;
	}
	.workslist .lists li p {
		font-size: 15px;
	}
}
@media screen and (max-width:768px) {
	.workslist {
		display: block;
		margin-bottom: 50px;
	}
	.workslist .cats {
		display: block;
		margin-bottom: 30px;
		padding-top: 0px;
	}
	.workslist .cats li {
		display: inline-block;
		margin-right: 5px;
		margin-bottom: 10px;
	}
	.workslist .cats li a {
		display: inline-block;
		color: #464646;
		font-family: "Zen Kaku Gothic New";
		font-size: 14px;
		font-style: normal;
		font-weight: 700;
		line-height: 18px; /* 100% */
		letter-spacing: 2.2px;
		position: relative;
		padding: 8px 10px 8px 10px;
		border-radius: 50px;
		-webkit-transition: all 0.3s ease-in-out 0s;
			transition: all 0.3s ease-in-out 0s;
	}
	
	.workslist .cats li a::before {
		display: none;
	}
	.workslist .cats li.current a {
		color: #FFF;
		background: linear-gradient(267deg, #FFD86A 2.8%, #FF8C21 97.22%);
	}
	.workslist .cats li.current a::before{
		background: #FFD86F;
	}
	.workslist .lists {
		display: block;
	}
	.workslist .lists li {
		display: block;
		margin-bottom: 30px;
		margin-left: 0px;
		flex-basis:100%;
		max-width: 100%;
		position: relative;
	}
	.workslist .lists li:nth-child(4n+1) {
		margin-left: 0px;
	}
	.workslist .lists li a {
		display: block;
	}
	.workslist .lists li .imgs {
		display: block;
		position: relative;
	}
	.workslist .lists li .imgs img {
		width: 100%;
		object-fit: cover;
		aspect-ratio: 9 / 6;
		border-radius: 30px 0;
	}
	.workslist .lists li .imgs span {
		position: absolute;
		display: inline-block;
		left: 5px;
		bottom: 5px;
		z-index: 5;
		color: #FFF;
		text-align: center;
		font-family: "Zen Kaku Gothic New";
		font-size: 14px;
		font-style: normal;
		font-weight: 700;
		line-height: 18px; /* 100% */
		letter-spacing: 1.8px;
		padding: 10px 15px;
		border-radius: 10px 0px;
		background: #E26D00;
	}
	.workslist .lists li .days {
		display: block;
		padding: 10px 0 5px 0;
		color: #464646;
		font-size: 14px;
		font-style: normal;
		font-weight: 700;
		line-height: 18px; /* 112.5% */
		letter-spacing: 1.28px;
	}
	.workslist .lists li p {
		width: 100%;
		color: #464646;
		font-family: "Zen Kaku Gothic New";
		font-size: 15px;
		font-style: normal;
		font-weight: 700;
		line-height: 18px; /* 100% */
		letter-spacing: 1.44px;
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
	}
}





/*pagenav*/
@media screen and (max-width:768px) {
	.wp-pagenavi {
		display:flex;
		justify-content: center;
		text-align: center;
		margin: 0px 0;
		padding-bottom: 0px;
		padding-top: 30px;
	}
	.wp-pagenavi li {
		display: inline-block;
		margin: 8px;
	}
	.wp-pagenavi a,
	.wp-pagenavi span {
		margin: 6px;
		display: flex;
		justify-content: center;
		text-align: center;
		align-items:center;
		width: 35px;
		height: 35px;
		border-radius: 7px;
		background: #fff;
		border:#F26A83 solid 2px;
		color: #F26A83;
		font-size: 15px;
		font-style: normal;
		font-weight: 700;
		line-height: normal;
		letter-spacing: .2px;
		font-family: "Outfit", sans-serif;
	}
	.wp-pagenavi a.page {
		color: #F26A83;
		text-align: center;
		font-family: "Outfit", sans-serif;
		border:#F26A83 solid 2px;
		background: #FFF;
		font-size: 15px;
		font-style: normal;
		font-weight: 700;
		line-height: normal;
		letter-spacing: .2px;
	}
	.wp-pagenavi .previouspostslink,
	.wp-pagenavi .nextpostslink {
		font-size: 15px;
	}
	.wp-pagenavi .previouspostslink {
		margin-right: 25px;
	}
	.wp-pagenavi .nextpostslink {
		margin-left: 25px;
	}
	.wp-pagenavi span {
		background: #FFF;
		color: #F26A83;
	}
}
@media screen and (min-width:769px) {
	.wp-pagenavi {
		display:flex;
		justify-content: center;
		text-align: center;
		margin: 0px 0;
		padding-bottom: 0px;
		padding-top: 50px;
	}
	.wp-pagenavi li {
		display: inline-block;
		margin: 8px;
	}
	.wp-pagenavi a,
	.wp-pagenavi span {
		margin: 6px;
		display: flex;
		justify-content: center;
		text-align: center;
		align-items:center;
		width: 50px;
		height: 50px;
		border-radius: 7px;
		background: #fff;
		border:#F26A83 solid 2px;
		color: #F26A83;
		font-size: 25px;
		font-style: normal;
		font-weight: 700;
		line-height: normal;
		letter-spacing: .2px;
		font-family: "Outfit", sans-serif;
	}
	.wp-pagenavi a.page {
		color: #F26A83;
		text-align: center;
		font-family: "Outfit", sans-serif;
		border:#F26A83 solid 2px;
		background: #FFF;
		font-size: 25px;
		font-style: normal;
		font-weight: 700;
		line-height: normal;
		letter-spacing: .2px;
	}
	.wp-pagenavi .previouspostslink,
	.wp-pagenavi .nextpostslink {
		font-size: 16px;
	}
	.wp-pagenavi .previouspostslink {
		margin-right: 35px;
	}
	.wp-pagenavi .nextpostslink {
		margin-left: 35px;
	}
	.wp-pagenavi a:hover {
		background: #F26A83;
		color: #fff;
		border:#F26A83 solid 2px;
	}
	.wp-pagenavi span {
		background: #FFF;
		color: #F26A83;
	}
	
	
}





/* works-detail----------------------------------------------- */
.worksdetail {
	display: block;
	padding-top: 30px;
	margin-bottom: 130px;
}
.worksdetail .ti {
	display: block;
	margin-bottom: 80px;
}
.worksdetail .ti dl {
	display: flex;
	margin-bottom: 24px;
}
.worksdetail .ti dt {
	display: block;
	color: #FFF;
	text-align: center;
	font-family: "Zen Kaku Gothic New";
	font-size: 18px;
	font-style: normal;
	font-weight: 500;
	line-height: 18px; /* 100% */
	letter-spacing: 1.8px;
	border-radius: 10px 0px;
	background: #E26D00;
	padding: 13px 25px;
	margin-right: 25px;
}
.worksdetail .ti dd {
	display: block;
	color: #464646;
	font-size: 21px;
	font-style: normal;
	font-weight: 700;
	line-height: 18px; /* 85.714% */
	letter-spacing: 1.68px;
	padding-top: 13px;
}
.worksdetail .ti h2 {
	display: block;
	color: #464646;
	font-family: "Zen Kaku Gothic New";
	font-size: 30px;
	font-style: normal;
	font-weight: 700;
	line-height: 22px; /* 73.333% */
	letter-spacing: 3px;
	padding-bottom: 30px;
	border-bottom: #E26D00 solid 2px;
}
.worksdetail .flx {
	display: flex;
	justify-content: space-between;
	margin-bottom: 70px;
}
.worksdetail .flx .imgs {
	display: block;
	flex-basis: 55%;
}
.worksdetail .flx .imgs img {
	width: 100%;
	border-radius: 30px 0;
}
.worksdetail .flx .txt {
	display: block;
	flex-basis: 40%;
}
.table02 {
	width: 100%;
	border-collapse: collapse;
}
.table02 tr:nth-of-type(odd) {
	background: #FFF6DD;
}
.table02 th {
	color: #464646;
	font-family: "Zen Kaku Gothic New";
	font-size: 18px;
	font-style: normal;
	font-weight: 700;
	line-height: 26px; /* 144.444% */
	letter-spacing: 1.44px;
	padding: 20px 30px;
	width: 32%;
	text-align: left;
	vertical-align: top;
}
.table02 td {
	color: #464646;
	font-family: "Zen Kaku Gothic New";
	font-size: 18px;
	font-style: normal;
	font-weight: 700;
	line-height: 32px; /* 177.778% */
	letter-spacing: 1.44px;
	padding: 20px 30px;
	text-align: left;
	vertical-align: top;
}
.worksdetail .sub-imgs {
	display: flex;
	flex-wrap: wrap;
}
.worksdetail .sub-imgs li {
	display: block;
	margin-bottom: 54px;
	margin-left: 54px;
	flex-basis: calc((100% - (54px * 3)) / 4 - .01px);
	max-width: calc((100% - (54px * 3)) / 4 - .01px);
}
.worksdetail .sub-imgs li:nth-child(4n+1) {
	margin-left: 0px;
}
.worksdetail .sub-imgs li img {
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
	border-radius: 30px 0;
}
@media screen and (min-width:769px) {
	a:hover {
		opacity: 0.7;
	}
}
.listback {
	display: block;
	text-align: center;
	position: relative;
	margin-top: 50px;
}
.listback .ons {
	display: inline-block;
}
.listback .ons a {
	display: block;
	text-align: center;
	color: #464646;
	font-family: "Zen Kaku Gothic New";
	font-size: 22px;
	font-style: normal;
	font-weight: 700;
	line-height: normal;
	letter-spacing: 2.2px;
	padding: 8px 50px;
	border-radius: 50px;
	background: #FFF;
	border: 3px solid #FFC939;
}
.listback .prevs,
.listback .nexts {
	width: 220px;
}
.listback .prevs {
	position:absolute;
	top: 7px;
	right: 0;
	left: -580px;
	margin: auto;
}
.listback .nexts {
	position:absolute;
	top: 7px;
	right: -580px;
	left: 0;
	margin: auto;
}
.listback .prevs a {
	display: block;
	position: relative;
	padding-left: 50px;
}
.listback .nexts a {
	display: block;
	position: relative;
	padding-right: 50px;
}
.listback .prevs a::before {
	position: absolute;
	left: 0;
	top:0;
	bottom: 0;
	margin: auto;
	content: "";
	border-radius: 50%;
	background: #FFC939;
	width: 50px;
	height: 50px;
	-webkit-transition: all 0.3s ease-in-out 0s;
  		transition: all 0.3s ease-in-out 0s;
}
.listback .nexts a::before {
	position: absolute;
	right: 0;
	top:0;
	bottom: 0;
	margin: auto;
	content: "";
	border-radius: 50%;
	background: #FFC939;
	width: 50px;
	height: 50px;
	-webkit-transition: all 0.3s ease-in-out 0s;
  		transition: all 0.3s ease-in-out 0s;
}
.listback .prevs a::after {
	position: absolute;
	left: 21px;
	top:0;
	bottom: 0;
	margin: auto;
	content: "";
	width: 7px;
	height: 7px;
	border-bottom: 2px solid #fff;
	border-left: 2px solid #fff;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	-webkit-transition: all 0.3s ease-in-out 0s;
  		transition: all 0.3s ease-in-out 0s;
}
.listback .nexts a::after {
	position: absolute;
	right: 21px;
	top:0;
	bottom: 0;
	margin: auto;
	content: "";
	width: 7px;
	height: 7px;
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	-webkit-transition: all 0.3s ease-in-out 0s;
  		transition: all 0.3s ease-in-out 0s;
}
.listback .prevs a span,
.listback .nexts a span{
	display: inline-block;
	position: relative;
	color: #464646;
	font-family: "Zen Kaku Gothic New";
	font-size: 22px;
	font-style: normal;
	font-weight: 700;
	line-height: normal;
	letter-spacing: 2.2px;
	border-bottom: #FFC939 solid 1px;
	padding-bottom: 5px;
	padding-left: 10px;
	padding-right: 10px;
}

@media screen and (min-width:769px) {
	.listback .prevs a:hover::before,
	.listback .nexts a:hover::before{
		background: #E26D00;
	}
}

@media screen and (min-width:769px) and (max-width:1000px) {
	.worksdetail .flx .imgs {
		display: block;
		flex-basis: 48%;
	}
	.worksdetail .flx .txt {
		display: block;
		flex-basis: 49%;
	}
	.table02 tr:nth-of-type(odd) {
		background: #FFF6DD;
	}
	.table02 th {
		font-size: 16px;
		line-height: 26px; /* 144.444% */
		padding: 13px 20px;
		width: 32%;
	}
	.table02 td {
		font-size: 16px;
		line-height: 32px; /* 177.778% */
		padding: 13px 20px;
	}
	.listback .ons a {
		font-size: 17px;
		padding: 8px 30px;
	}
	.listback .prevs,
	.listback .nexts {
		width: 220px;
	}
	.listback .prevs {
		position:absolute;
		top: 7px;
		right: 0;
		left: -400px;
		margin: auto;
	}
	.listback .nexts {
		position:absolute;
		top: 7px;
		right: -400px;
		left: 0;
		margin: auto;
	}
}
@media screen and (max-width:768px) {
	.worksdetail {
		padding-top: 20px;
		margin-bottom: 50px;
	}
	.worksdetail .ti {
		margin-bottom: 30px;
	}
	.worksdetail .ti dl {
		display: flex;
		flex-wrap: wrap;
		margin-bottom: 15px;
	}
	.worksdetail .ti dt {
		font-size: 14px;
		line-height: 16px; /* 100% */
		padding: 7px 14px;
		margin-right: 5px;
	}
	.worksdetail .ti dd {
		display: block;
		font-size: 14px;
		line-height: 15px; /* 85.714% */
		letter-spacing: 1.68px;
		padding-top: 5px;
	}
	.worksdetail .ti h2 {
		font-size: 21px;
		line-height: 22px; /* 73.333% */
		letter-spacing: 3px;
		padding-bottom: 14px;
		border-bottom: #E26D00 solid 2px;
	}
	.worksdetail .flx {
		display: block;
		margin-bottom: 40px;
	}
	.worksdetail .flx .imgs {
		display: block;
		flex-basis: 55%;
		margin-bottom: 20px;
	}
	.worksdetail .flx .imgs img {
		width: 100%;
		border-radius: 30px 0;
	}
	.worksdetail .flx .txt {
		display: block;
		flex-basis: 40%;
	}
	.table02 {
		width: 100%;
		border-collapse: collapse !important;
	}
	.table02 tr {
		background: #FFF !important
	}
	.table02 th {
		display: block;
		box-sizing: border-box;
		color: #464646;
		font-family: "Zen Kaku Gothic New";
		font-size: 15px;
		font-style: normal;
		font-weight: 700;
		line-height: 26px; /* 144.444% */
		letter-spacing: 1.44px;
		padding: 10px 15px;
		width: auto;
		text-align: left;
		vertical-align: top;
		background: #FFF6DD;
	}
	.table02 td {
		display: block;
		font-size: 15px;
		line-height: 24px; /* 177.778% */
		padding: 10px 15px;
	}
	.worksdetail .sub-imgs {
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}
	.worksdetail .sub-imgs li {
		display: block;
		margin-bottom: 15px;
		margin-left: 0px;
		flex-basis: 49%;
		max-width: 49%;
	}
	.worksdetail .sub-imgs li img {
		width: 100%;
		aspect-ratio: 4 / 3;
		object-fit: cover;
		border-radius: 15px 0;
	}
	.listback {
		display: block;
		text-align: center;
		position: relative;
		margin-top: 30px;
	}
	.listback .ons {
		display: inline-block;
	}
	.listback .ons a {
		font-size: 14px;
		font-style: normal;
		font-weight: 700;
		line-height: normal;
		letter-spacing: 2.2px;
		padding: 8px 16px;
		border-radius: 50px;
		background: #FFF;
		border: 2px solid #FFC939;
	}
	.listback .prevs,
	.listback .nexts {
		width: 90px;
	}
	.listback .prevs {
		position:absolute;
		top: 18px;
		right: 0;
		left: -190px;
		margin: auto;
	}
	.listback .nexts {
		position:absolute;
		top: 18px;
		right: -190px;
		left: 0;
		margin: auto;
	}
	.listback .prevs a {
		display: block;
		position: relative;
		padding-left: 0px;
	}
	.listback .nexts a {
		display: block;
		position: relative;
		padding-right: 0px;
	}
	.listback .prevs a::before {
		position: absolute;
		left: 0;
		top:0;
		bottom: 0;
		margin: auto;
		content: "";
		border-radius: 50%;
		background: #FFC939;
		width: 50px;
		height: 50px;
		-webkit-transition: all 0.3s ease-in-out 0s;
			transition: all 0.3s ease-in-out 0s;
	}
	.listback .nexts a::before {
		position: absolute;
		right: 0;
		top:0;
		bottom: 0;
		margin: auto;
		content: "";
		border-radius: 50%;
		background: #FFC939;
		width: 50px;
		height: 50px;
		-webkit-transition: all 0.3s ease-in-out 0s;
			transition: all 0.3s ease-in-out 0s;
	}
	.listback .prevs a::after {
		position: absolute;
		left: 21px;
		top:0;
		bottom: 0;
		margin: auto;
		content: "";
		width: 10px;
		height: 10px;
		border-bottom: 2px solid #fff;
		border-left: 2px solid #fff;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
		-webkit-transition: all 0.3s ease-in-out 0s;
			transition: all 0.3s ease-in-out 0s;
	}
	.listback .nexts a::after {
		position: absolute;
		right: 21px;
		top:0;
		bottom: 0;
		margin: auto;
		content: "";
		width: 10px;
		height: 10px;
		border-top: 2px solid #fff;
		border-right: 2px solid #fff;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
		-webkit-transition: all 0.3s ease-in-out 0s;
			transition: all 0.3s ease-in-out 0s;
	}
	.listback .prevs a span,
	.listback .nexts a span{
		display: none;
	}
}






/* privacy----------------------------------------------- */
.privacy1 {
	display: block;
	padding-top: 140px;
}
.privacy1 dl {
	display: block;
	margin-left: auto;
	margin-right: auto;
	max-width: 1020px;
	padding-top: 45px;
	counter-reset: number 0; 
}
.privacy1 dl dd {
	display: block;
	position: relative;
	font: normal normal bold 16px/32px Yu Gothic;
	letter-spacing: 0.8px;
	color: #757067;
	margin-bottom: 45px;
	padding-left: 30px;
}
.privacy1 dl dd::before {
	position:absolute;
	left: 0;
	top: 0;
	font: normal normal bold 23px/28px Montserrat;
	letter-spacing: 0px;
	color: #7890A0;
	counter-increment: number 1;      /* number カウンタを増加 */
  	content: "" counter(number) ".";
}
.privacy2 {
	display: block;
	background: url("../images/survey/gradient_bg.png") center center no-repeat;
	background-size: 100% 100%;
	padding: 110px 0;
	margin-top: 70px;
	margin-bottom: 140px;
}
.privacy2 small {
	display: block;
	font: normal normal bold 16px/32px Yu Gothic;
	letter-spacing: 0.8px;
	color: #757067;
	margin-bottom: 50px;
}
.privacy2 h3 {
	display: block;
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
	font: normal normal bold 40px/32px Yu Gothic;
	letter-spacing: 2px;
	color: #1C72D4;
	margin-bottom: 30px;
}
.privacy2 .fix {
	margin-left: auto;
	margin-right: auto;
	max-width: 700px;
	font: normal normal bold 23px/50px Yu Gothic;
	letter-spacing: 1.15px;
	color: #757067;
	margin-bottom: 25px;
}
.privacy2 .btn {
	width: 320px !important;
	margin-left: auto;
	margin-right: auto;
}
.privacy2 .btn a span {
	position: relative;
	padding-right: 30px;
}
.privacy2 .btn a span::after {
	background:url("../images/send1.png") center center no-repeat;
	background-size: 100% auto;
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	content: "";
	width: 24px;
	height: 21px;
	right: -6px;
}
@media all and (max-width: 768px) {
	.privacy1 {
		display: block;
		padding-top: 40px;
	}
	.privacy1 dl {
		display: block;
		margin-left: auto;
		margin-right: auto;
		max-width: 1020px;
		padding-top: 0px;
		counter-reset: number 0; 
	}
	.privacy1 dl dd {
		display: block;
		position: relative;
		font: normal normal bold 14px/22px Yu Gothic;
		letter-spacing: 0.8px;
		color: #757067;
		margin-bottom: 20px;
		padding-left: 30px;
	}
	.privacy2 {
		display: block;
		background: url("../images/survey/gradient_bg.png") center center no-repeat;
		background-size: 100% 100%;
		padding: 40px 0;
		margin-top: 20px;
		margin-bottom: 40px;
	}
	.privacy2 small {
		display: block;
		font: normal normal bold 13px/18px Yu Gothic;
		letter-spacing: 0.8px;
		color: #757067;
		margin-bottom: 20px;
	}
	.privacy2 h3 {
		display: block;
		text-align: center;
		max-width: 1000px;
		margin-left: auto;
		margin-right: auto;
		font: normal normal bold 24px/30px Yu Gothic;
		letter-spacing: 2px;
		color: #1C72D4;
		margin-bottom: 15px;
	}
	.privacy2 .fix {
		margin-left: auto;
		margin-right: auto;
		max-width: 700px;
		font: normal normal bold 17px/32px Yu Gothic;
		letter-spacing: 1.15px;
		color: #757067;
		margin-bottom: 25px;
	}
	.privacy2 .btn {
		width: 270px !important;
		margin-left: auto;
		margin-right: auto;
	}
	.privacy2 .btn a span {
		position: relative;
		padding-right: 30px;
	}
}


/* contact-top----------------------------------------------- */

.c-tops {
	display: block;
	padding: 100px 0 ;
	background: #EFEFEF;
}
.c-tops .boxs {
	display: block;
	max-width: 700px;
	margin-left: auto;
	margin-right: auto;
	background: #FFF;
	box-sizing: border-box;
	padding: 60px;
	text-align: center;
}
.c-tops .boxs h2 {
	display: block;
	text-align: center;
	font-size: 33px;
	letter-spacing: 2px;
	line-height: 1.4;
	font-weight: bold;
	color: #c82b16;
	margin-bottom: 40px;
}
.c-tops .boxs b,
.c-tops .boxs a {
	display: block;
	position: relative;
	font-size: 35px;
	font-weight: 600;
	font-family: "Lexend", serif;
	color: #000;
	line-height: 1;
	letter-spacing: 3px;
}
.c-tops .boxs small {
	display: block;
	padding-top: 10px;
	font-size: 17px;
	font-weight: 600;
}
.c-cont {
	padding: 100px 0;
}
.title03 {
	display: block;
	font-size: 24px;
	letter-spacing: 2px;
	line-height: 1.5;
	background:#EFEFEF;
	padding: 16px 25px;
	margin-bottom: 35px;
}
.fix-1100 {
	max-width: 1100px;
	margin-left: auto;
	margin-right: auto;
}
@media all and (max-width: 1100px) {
	.fix-1100 {
		margin-left: 4%;
		margin-right: 4%;
	}
}
@media all and (max-width: 768px) {
	.c-tops {
		display: block;
		padding: 40px 0 ;
		background: #EFEFEF;
	}
	.c-tops .boxs {
		display: block;
		max-width: 700px;
		margin-left: auto;
		margin-right: auto;
		background: #FFF;
		box-sizing: border-box;
		padding: 20px;
		text-align: center;
	}
	.c-tops .boxs h2 {
		display: block;
		text-align: center;
		font-size: 20px;
		letter-spacing: 2px;
		line-height: 1.4;
		font-weight: bold;
		color: #c82b16;
		margin-bottom: 20px;
	}
	.c-tops .boxs b,
	.c-tops .boxs a {
		display: block;
		position: relative;
		font-size: 23px;
		font-weight: 600;
		font-family: "Lexend", serif;
		color: #000;
		line-height: 1;
		letter-spacing: 3px;
	}
	.c-tops .boxs small {
		display: block;
		padding-top: 10px;
		font-size: 14px;
		font-weight: 600;
	}
	.c-cont {
		padding: 100px 0;
	}
	.title03 {
		display: block;
		font-size: 20px;
		letter-spacing: 2px;
		line-height: 1.5;
		background:#EFEFEF;
		padding: 12px 15px;
		margin-bottom: 24px;
	}
}


/* estimate----------------------------------------------- */
.forms-base {
	display: block;
	padding-top: 90px;
	margin-left: 4%;
	margin-right: 4%;
	padding-bottom: 90px;
}
.forms-base .title01 {
	margin-bottom: 40px;
}
.form-wraps {
	margin-top: 65px;
	border-radius: 10px;
}
.form-wraps .txt_01 {
	padding-top: 45px;
	text-align: center;
	margin-bottom: 50px;
}
.forms-table {
	width: 100%;
	border-collapse: collapse;
}
.forms-table th {
	display: block;
	text-align: left;
	vertical-align: top;
	position: relative;
	color: #3F3B3A;
	font-size: 18px;
	font-style: normal;
	font-weight: 700;
	line-height: 26px; /* 130% */
	letter-spacing: 1.6px;
	padding: 20px;
	background: #EFEFEF;
}
.forms-table th.requier::after {
	margin-left: 25px;
	content: "必須";
	background: #c82b16;
	color: #FFF;
	font-size: 15px;
	font-style: normal;
	font-weight: 500;
	line-height: 27px; /* 150% */
	letter-spacing: 1.8px;
	padding: 1px 11px 3px 11px;
	border-radius: 0px;
}
.forms-table td {
	display: block;
	text-align: left;
	vertical-align: top;
	padding-top: 15px;
	padding-bottom: 25px;
	
}
.bl-labs {
	background: none;
	padding-left: 0px;
	padding-right: 0px;
}
.n001 {
	width: 100%;
	box-sizing: border-box;
	padding: 20px;
	border: 0px;
	font-size: 16px;
	font-style: normal;
	font-weight: 700 !important;
	line-height: 32px; /* 177.778% */
	letter-spacing: 1.44px;
	background: #fff;
	border: #EFEFEF solid 1px;
}
.n002 {
	width: 60%;
	box-sizing: border-box;
	padding: 20px;
	border: 0px;
	font-size: 16px;
	font-style: normal;
	font-weight: 700;
	line-height: 32px; /* 177.778% */
	letter-spacing: 1.8px;
	background: #fff;
	border: #EFEFEF solid 1px;
}
.txer {
	width: 100%;
	height: 240px;
	box-sizing: border-box;
	padding: 20px;
	border: 0px;
	font-size: 16px;
	font-style: normal;
	font-weight: 600;
	line-height: 32px; /* 177.778% */
	letter-spacing: 1.8px;
	background: #fff;
	border: #EFEFEF solid 1px;
}
::placeholder {
	font-size: 18px;
	font-style: normal;
	font-weight: 600;
	line-height: 32px; /* 177.778% */
	letter-spacing: 1.44px;
	color: #888;
}
.form-in {
	margin-bottom: 10px;
}
.select-over {
	display: block;
	width: 60%;
}
.select-over select {
	width: 100%;
	height: 60px;
	background: #fff;
	font-size: 17px;
	font-style: normal;
	font-weight: 600;
	line-height: 32px; /* 177.778% */
	letter-spacing: 1.8px;
	padding-left: 20px;
	padding-right: 20px;
	border: none;
	color: #3F3B3A !important;
	border: #EFEFEF solid 1px;
}
.select-over select option:nth-child(1) {
	
}
select:invalid {
    color: #888 !important;
}
select option:first-child {
    color: #888 !important;
}

select:invalid {
    color: #888;
}

select option {
    color: #333;
}
/* radioBtn */
.blocks-label {
	margin-top: 17px;
}
.radio__list {
	border: 0px !important;
}
label {
	color: #333;
	font-size: 18px;
	font-style: normal;
	font-weight: 500;
	line-height: 32px; /* 177.778% */
	letter-spacing: 1.8px;
}
input.radioBtn {
	top: 3px;
	block-size: 2rem;
	inline-size: 2rem;
	position: relative;
	z-index: 1;
	margin-left: 5px;
	margin-right: 8px;
	border: 0px !important;
}
input.radioBtn::before {
  position: absolute;
  content: "";
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 17px;
  height: 17px;
  border-radius: 50%;
	background: #DBDBDB;
	border: 5px solid #FFF;
}

input.radioBtn::after {
  position: absolute;
  content: "";
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 16px;
  height: 16px;
  background: #43b23a;
  border-radius: 50%;
  opacity: 0;
}
input.radioBtn[type="radio"]:checked::after {
  opacity: 1;
}
label {
  cursor: pointer;
}
.blocks-label label {
	display: inline-block;
	margin-bottom: 10px;
	width: auto !important;
	font-weight: 600;
}
label.radio__list {
	margin-right: 30px;
}
.cbtn {
	display:flex;
	justify-content: center;
	flex-wrap: wrap;
	text-align: center;
	padding: 30px 0 40px 0;
}
.sbt {
	width: 400px;
	height: 65px;
	border: #c82b16 solid 1px;
	color: #FFF;
	border-radius: 50px;
	cursor: pointer;
	font-size: 17px;
	background: #c82b16;
	margin-left: 10px;
	margin-right: 10px;
	-webkit-transition: all 0.3s ease-in-out 0s;
  		transition: all 0.3s ease-in-out 0s;
}
.sbt.v2 {
	background: #333;
}
input[type="submit"] {
  -webkit-appearance: none;
}
.addf {
	margin-top: 14px;
}
@media all and (min-width: 769px) {
	.sbt:hover {
		background: #333;
		color: #fff;
	}
}


/* privacy__policy */
.privacy__policy--area {
	margin-top: 50px;
  padding: 0px 0;
	
  
}
.privacy__policy {
  padding: 20px 0px 40px 0px;
}
.privacy__policy .scr {
	height: 325px;
	padding-right: 50px;
	padding: 50px;
	margin-right: 26px;
	background: #EFEFEF;
  overflow-y: scroll;
}


.privacy__policy .scr::-webkit-scrollbar {
  width: 8px;  
  margin-top: 41px;
}
.privacy__policy .scr::-webkit-scrollbar-track {
	background-size: auto 5px;
}
.privacy__policy .scr::-webkit-scrollbar-thumb {
  background: #c82b16;
  height: 100px;
}

.privacy__policy p:first-of-type {
  font-size: 24px;
	font-weight: 700;
	margin-bottom: 24px;
}
.privacy__policy p.s-mt {
  color: #3F3B3A;
	font-size: 16px;
	font-style: normal;
	font-weight: 500;
	line-height: 29px; /* 108.333% */
	letter-spacing: 1.92px;
  margin-bottom: 16px;
}
.privacy__policy p.p-tt {
	font-size: 18px !important;
}
.privacy__policy p.mp-ti {
	font-size: 17px !important;
}
.privacy__policy p span {
  font-size: 17px;
  margin-bottom: 5px;
  display: block;
}
.privacy__policy ul {
  margin-bottom: 16px;
}
.privacy__policy ul li {
  list-style: disc;
  margin-left: 20px;
}
.form_consent_txt {
  text-align: center;
  color: #3F3B3A;
	font-size: 20px;
	font-style: normal;
	font-weight: 700 !important;
	line-height: normal;
	letter-spacing: 2.2px;
  padding: 50px 5px 0;
}
.form_consent_txt label {
	position: relative;
	font-weight: 700 !important;
}
input[type="checkbox"] {
  position: relative;
	top: 3px;
  width: 23px;
  height: 22px;
  border: 1px solid #000;
  vertical-align: -5px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

input[type="checkbox"]:checked:before {
  position: absolute;
  top: -5px;
  left: 7px;
  transform: rotate(50deg);
  width: 11px;
  height: 20px;
  border-right: 3px solid #c82b16;
  border-bottom: 3px solid #c82b16;
  content: '';
}
select {
	cursor: pointer;
}

.center-txt1 {
	color: #464646;
	text-align: center;
	font-size: 16px;
	font-style: normal;
	font-weight: 500;
	line-height: 32px; /* 177.778% */
	letter-spacing: 1.8px;
}

@media all and (max-width: 768px) {
	.forms-base {
		display: block;
		padding-top: 40px;
		padding-bottom: 50px;
	}
	.form-wraps {
		margin-left: auto;
		margin-right: auto;
		max-width: 1000px;
		padding: 15px 0;
	}
	.form-wraps .txt_01 {
		text-align: left;
		padding-top: 20px;
		margin-bottom: 20px;
	}
	.forms-base .center-txt1 {
		text-align: left;
		font-size: 16px;
		line-height: 1.9;
		margin-left: 4%;
		margin-right: 4%;
	}
	.forms-table {
		width: 100%;
		border-collapse: collapse;
	}
	.forms-table th {
		display: block;
		text-align: left;
		vertical-align: top;
		position: relative;
		width: 100%;
		box-sizing: border-box;
		font-size: 15px;
		letter-spacing: 0px;
		padding: 20px 15px;
	}
	.forms-table th.requier::after {
		position:relative;
		right: 15px;
		top: 0px;
		content: "必須";
		font-size: 14px;
		letter-spacing: 0px;
		padding: 3px 10px;
	}
	.forms-table td {
		display: block;
		text-align: left;
		vertical-align: top;
		padding-bottom: 0px;
		padding-top: 0px;
	}
	.bl-labs {
		padding-left: 15px;
		padding-right: 15px;
		padding-top: 1px !important;
		padding-bottom: 15px !important;
	}
	.bl-labs label {
		padding-bottom: 10px;
		margin-bottom: 0px;
	}
	.n001 {
		width: 100%;
		box-sizing: border-box;
		padding: 15px;
		font-size: 15px;
		border: 0px;
		border: #EFEFEF solid 1px;
	}
	.n002 {
		width: 100%;
		box-sizing: border-box;
		padding: 15px;
		font-size: 15px;
		border: 0px;
		border: #EFEFEF solid 1px;
	}
	.txer {
		width: 100%;
		height: 180px;
		box-sizing: border-box;
		padding: 15px;
		font-size: 15px;
		border: 0px;
		border: #EFEFEF solid 1px;
	}
	::placeholder {
		font-size: 15px;
	}
	.form-in {
		margin-bottom: 10px;
	}
	.select-over {
		display: block;
		width: 100%;
	}
	.select-over select {
		width: 100%;
		height: 55px;
		background: #fff;
		font-size: 15px;
		letter-spacing: 0px;
		color: #3F3B3A !important;
		padding-left: 20px;
		padding-right: 20px;
		border: #EFEFEF solid 1px;
	}
	.select-over select option:nth-child(1) {

	}

	select option {
		color: #333;
	}
	/* radioBtn */
	.radio__list {
		border: 0px !important;
		padding-top: 9px;
	}
	label {
		font-size: 15px;
		letter-spacing: 0px;
	}
	input.radioBtn[type="radio"]:checked::after {
	  opacity: 1;
	}
	label {
	  cursor: pointer;
	}
	.blocks-label label {
		display: block;
		width: auto !important;
	}
	label.radio__list {
		margin-right: 30px;
	}
	.cbtn {
		display: block;
		text-align: center;
		padding: 30px 0 40px 0;
	}
	.privacy__policy--area {
	  padding-top: 25px;
	  padding: 15px 0;
		margin-top: 20px;
		margin-right: 0px !important;
	}
	.privacy__policy {
	  padding: 20px 0px 20px 0px !important;
	}
	.privacy__policy .scr {
		height: 245px;
		padding-right: 20px;
		padding: 15px;
		margin-right: 0px;
	  overflow-y: scroll;
	}
	.privacy__policy .scr::-webkit-scrollbar {
	  width: 6px;
	  margin-top: 41px;
	}
	.privacy__policy .scr::-webkit-scrollbar-track {
	  background-color: #fff;
	}
	.privacy__policy .scr::-webkit-scrollbar-thumb {
	  height: 100px;
	}
	.privacy__policy p:first-of-type {
	  font-size: 17px;
		font-weight: 700;
		margin-bottom: 14px;
	}
	.privacy__policy p.s-mt {
		font-size: 14px;
		font-style: normal;
		font-weight: 500;
		line-height: 21px; /* 108.333% */
		letter-spacing: 1.92px;
	  margin-bottom: 16px;
	}
	.privacy__policy p span {
	  font-size: 15px;
	  margin-bottom: 5px;
	  display: block;
	}
	.privacy__policy ul {
	  margin-bottom: 16px;
	}
	.privacy__policy ul li {
	  list-style: disc;
	  margin-left: 20px;
	}
	.sbt {
		width: 270px;
		height: 55px;
		border: none;
		color: #FFF;
		border-radius: 50px;
		cursor: pointer;
		font-size: 15px;
		margin-bottom: 15px;
	}
	.form_consent_txt {
		background: none !important;
	}
}




.fl100p {
	flex-basis: 100% !important;
}
.no-ims {
	display: block !important;
	text-align: right !important;
	padding-top: 35px;
	flex-basis: 100% !important;
}
.no-ims span {
	display: block;
	font-size: 18px;
	text-align: right !important;
}
.mw_wp_form_confirm .privacy__policy--area {
	display: none !important;
}
.mw_wp_form_confirm  .bl-labs {
	padding-left: 0 !important;
	padding-right: 0 !important;
}


.mx-1100 {
	max-width: 1100px;
	margin-left: auto;
	margin-right: auto;
}
.mx-1000 {
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
}
@media all and (max-width: 999px) {
	.mx-1000 {

	}
}




.cols001 {
	text-align: center;
	font-weight: 900;
	background: #EFEFEF;
	padding: 22px 0 !important;
	font-size: 18px !important;
}
.mb35 {
	margin-bottom: 35px;
}
.bge2 {
	background: #fbeedf !important;
}
.bge2.go {
	padding-left: 2%;
	padding-right: 2%;
	font-size: 22px !important;
}
.bg-fff {
	background: #FFF;
}
.bg-fff .rectitle {
	background: #efefef;
}
.pt-01 {
	padding: 90px 0 40px 0!important;
}
.mb100 {
	margin-bottom: 100px;
}
@media all and (max-width:768px) {
	.cols001 {
		text-align: center;
		font-weight: 900;
		background: #eafce8 !important;
		padding: 14px 0 !important;
		font-size: 17px !important;
	}
	.table01.prices .bge2 {
		padding-left: 2%;
		padding-right: 2%;
		text-align: center !important;
		font-size: 20px !important;
		padding-top: 10px !important;
		padding-bottom: 10px !important;
	}
}



.flx-03 {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.flx-03 .txt {
	display: block;
	flex-basis: 55%;
}
.flx-03 .txt h3 {
	display: block;
	font-size: 22px;
	letter-spacing: 2px;
	line-height: 1.6;
	margin-bottom: 35px;
}
.flx-03 .imgs {
	display: block;
	flex-basis: 38%;
}
.flx-03 .imgs img {
	width: 100%;
}
@media all and (max-width:768px) {
	.flx-03 {
		display: block;
	}
	.flx-03 .txt {
		display: block;
		flex-basis: 55%;
		margin-bottom: 22px;
	}
	.flx-03 .txt h3 {
		display: block;
		font-size: 18px;
		letter-spacing: 2px;
		line-height: 1.6;
		margin-bottom: 20px;
	}
}


.prlink {
	margin-right: 14px;
}
.nxlink {
	margin-left: 14px;
}
.prlink a,
.nxlink a{
	display: block;
	text-align: center;
	width: 80px;
	padding: 13px 0;
	font-size: 17px;
	font-weight: 600;
	border-radius: 9px;
	color: #F26A83;
    background: #fff;
    border:#F26A83 solid 2px;
}
@media all and (min-width:769px) {
	.prlink a:hover,
	.nxlink a:hover{
		color: #fff;
		background: #F26A83;
		border:#F26A83 solid 2px;
	}
}

@media all and (max-width:768px) {
	.prlink {
		margin-right: 7px;
	}
	.nxlink {
		margin-left: 7px;
	}
	.prlink a,
	.nxlink a{
		display: block;
		text-align: center;
		width: 50px;
		padding: 13px 0;
		font-size: 17px;
		font-weight: 600;
		border-radius: 9px;
		color: #F26A83;
		background: #fff;
		border:#F26A83 solid 2px;
	}
}
