@import url(https://fonts.googleapis.com/earlyaccess/notosansjapanese.css);

/**
 * Noto Sans CJK JP: https://www.google.com/get/noto/#sans-jpan
 * Noto Sans JP: https://fonts.google.com/earlyaccess#Noto+Sans+JP
 */

@font-face {
	font-family: 'Noto Sans JP';
	font-weight: 100;
	font-style: normal;
	src: local('Noto Sans CJK JP Thin'), url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Thin.woff2) format('woff2'), url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Thin.woff) format('woff'), url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Thin.otf) format('opentype');
}

@font-face {
	font-family: 'Noto Sans JP';
	font-weight: 300;
	font-style: normal;
	src: local('Noto Sans CJK JP Light'), url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Light.woff2) format('woff2'), url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Light.woff) format('woff'), url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Light.otf) format('opentype');
}

@font-face {
	font-family: 'Noto Sans JP';
	font-weight: 400;
	font-style: normal;
	src: local('Noto Sans CJK JP Regular'), url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Regular.woff2) format('woff2'), url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Regular.woff) format('woff'), url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Regular.otf) format('opentype');
}

@font-face {
	font-family: 'Noto Sans JP';
	font-weight: 500;
	font-style: normal;
	src: local('Noto Sans CJK JP Medium'), url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Medium.woff2) format('woff2'), url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Medium.woff) format('woff'), url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Medium.otf) format('opentype');
}

@font-face {
	font-family: 'Noto Sans JP';
	font-weight: 700;
	font-style: normal;
	src: local('Noto Sans CJK JP Bold'), url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Bold.woff2) format('woff2'), url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Bold.woff) format('woff'), url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Bold.otf) format('opentype');
}

@font-face {
	font-family: 'Noto Sans JP';
	font-weight: 900;
	font-style: normal;
	src: local('Noto Sans CJK JP Black'), url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Black.woff2) format('woff2'), url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Black.woff) format('woff'), url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Black.otf) format('opentype');
}

/*
// ==========================================================================
// animation
// ==========================================================================
*/

/*
// ==========================================================================
// utility
// ==========================================================================
*/

/* margin reset */

.u-mt-reset {
	margin-top: 0 !important;
}

.u-mb-reset {
	margin-bottom: 0 !important;
}

.u-ml-reset {
	margin-left: 0 !important;
}

.u-mr-reset {
	margin-right: 0 !important;
}

/* padding reset */

.u-pt-reset {
	padding-top: 0 !important;
}

.u-pb-reset {
	padding-bottom: 0 !important;
}

.u-pl-reset {
	padding-left: 0 !important;
}

.u-pr-reset {
	padding-right: 0 !important;
}

/* align */

.u-align-center {
	margin-right: auto;
	margin-left: auto;
	text-align: center;
}

.u-align-left {
	margin-right: auto;
	text-align: left;
}

.u-align-right {
	margin-left: auto;
	text-align: right;
}

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

/* main */

.main {
	position: relative;
	padding: 20px 0;
}

.mainVisual {
	position: relative;
	z-index: 1;
	width: 100%;
	margin: auto;
}

.mainVisual .swiper-wrapper {
	position: relative;
	z-index: 1;
	width: 100%;
	margin: auto;
}

.mainVisual .swiper-slide {
	position: relative;
	width: 1000px;
	height: 451px;
	margin: auto;
	transition: .3s;
	text-align: center;
	opacity: .5;
	color: #fff;
}

.mainVisual .swiper-slide.swiper-slide-active {
	opacity: 1;
}

.mainVisual .swiper-slide img {
	width: auto;
}

.mainVisual .swiper-button-wrap {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 1px;
	height: 1px;
}

.mainVisual .swiper-button-next {
	top: 50%;
	right: calc(50% - 544px);
	width: 70px;
	height: 70px;
	margin-top: -35px;
	background: url(../img/top/arrow_right.png) no-repeat;
}

.mainVisual .swiper-button-prev {
	top: 50%;
	left: calc(50% - 544px);
	width: 70px;
	height: 70px;
	margin-top: -35px;
	background: url(../img/top/arrow_left.png) no-repeat;
}

.mainVisual .swiper-pagination {
	bottom: -5px;
	left: 0;
	width: 100%;
}

.mainVisual .swiper-pagination-bullet {
	display: inline-block;
	width: 7px;
	height: 7px;
	opacity: 1;
	border-radius: 100%;
	background: #b0c6d5;
}

.mainVisual .swiper-pagination-bullet-active {
	background: #3e525d;
}

.banner {
	width: 1000px;
	margin: 0 auto;
	padding: 30px 0;
}

.banner ul {
	overflow: hidden;
	zoom: 1;
	width: 1020px;
	margin: 0 -20px 0 0;
}

.banner ul li {
	float: left;
	width: 234px;
	margin: 0 20px 0 0;
}

.banner ul li img {
	width: 100%;
	height: auto;
}

.blog_section {
	position: relative;
	width: 1000px;
	margin: 0 auto;
	margin-top: 80px;
}

.blog_title {
	font-size: 42px;
	font-size: 36px;
	font-weight: 400;
	line-height: 1;
	position: absolute;
	left: 0;
	padding-top: 40px;
	text-align: center;
	color: #40525e;
}

.blog_title::before {
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 40px;
	margin: 0 auto;
	padding-bottom: 40px;
	content: '';
	border-top: 4px solid #ec6202;
}

.blog_wrap {
	display: flex;
	width: 800px;
	margin-left: auto;
	justify-content: space-between;
}

.blog_item {
	width: 246px;
}

.blog_item img {
	width: 100%;
	height: auto;
}

.blog_name {
	font-size: 16px;
	margin-top: 16px;
	color: #78868e;
}

.blog_bottom {
	margin-top: 20px;
}

.blog_date {
	font-size: 14px;
	display: inline-block;
	padding-right: 35px;
	color: #40525e;
}

.blog_label {
	font-size: 14px;
	padding-bottom: 5px;
	border-bottom: 1px solid #78868e;
}

.blog_label:hover {
	text-decoration: none;
}

.overview_range {
	width: 100%;
	padding-top: 110px;
}

.overview_section {
	position: relative;
	margin: 0 auto;
}

.overview_title {
	font-family: 'Noto Sans Japanese';
	font-size: 36px;
	font-weight: 400;
	line-height: 50px;
	margin: 0;
	margin: 0 auto;
	padding-top: 40px;
	padding-bottom: 45px;
	text-align: center;
	color: #40525e;
}

.overview_title::before {
	display: block;
	width: 40px;
	margin: 0 auto;
	padding-bottom: 40px;
	content: '';
	border-top: 4px solid #ec6202;
}

.overview_title span {
	font-size: 24px;
	font-weight: 200;
	line-height: normal;
	padding-top: 20px;
	color: #78868e;
}

.overview_title_img {
	position: absolute;
	z-index: -1;
	top: 50px;
	left: 240px;
}

.overview_wrap {
	display: flex;
}

.overview_item {
	display: flex;
	flex-direction: column;
	width: 50vw;
	height: 33.333vw;
	align-items: center;
	justify-content: center;
}

.overview_item01 {
	background: url(../img/top/overview01.png) center top no-repeat;
	background-size: cover;
}

.overview_item02 {
	background: url(../img/top/overview02.png) center top no-repeat;
	background-size: cover;
}

.overview_item03 {
	background: url(../img/top/overview03.png) center top no-repeat;
	background-size: cover;
}

.overview_text {
	font-family: 'Noto Sans Japanese';
	font-size: 2vw;
	line-height: 1.5;
	text-align: center;
	color: white;
}

.overview_button {
	font-size: 20px;
	display: inline-block;
	width: 200px;
	margin-top: 40px;
	padding: 8px 45px 8px 45px;
	text-align: center;
	color: white;
	border-radius: 50px;
	outline: none;
	background-color: #b0c6d5;
}

.overview_button:hover {
	opacity: .7;
}

.labo_range {
	width: 100%;
	margin: 0 auto;
	padding-top: 100px;
	padding-bottom: 100px;
	background-color: #eff4f7;
}

.labo_section {
	position: relative;
	width: 1000px;
	margin: 0 auto;
}

.labo_section_title {
	font-family: 'Noto Sans Japanese';
	font-size: 36px;
	font-weight: 400;
	margin: 0;
	margin-bottom: 50px;
	text-align: center;
	color: #40525e;
}

.labo_section_title::before {
	display: block;
	width: 40px;
	margin: 0 auto;
	padding-bottom: 40px;
	content: '';
	border-top: 4px solid #ec6202;
}

.labo_orange_bar {
	position: absolute;
	top: -40px;
	left: 480px;
}

.labo_item {
	display: flex;
	width: 1000px;
	margin-bottom: 20px;
	background-color: white;
	align-items: center;
}

.labo_item:nth-of-type(3) {
	margin-bottom: 0;
}

.labo_item > a img {
	width: 100%;
}

.labo_item:hover .labo_img img {
	-webkit-transform: scale(1.1, 1.1);
	transform: scale(1.1, 1.1);
}

.labo_item:hover .labo_text {
	opacity: .7;
}

.labo_img {
	overflow: hidden;
	max-width: 400px;
	max-height: 250px;
}

.labo_img img {
	width: 100%;
	height: auto;
	transition: .5s;
	-o-object-fit: cover;
	object-fit: cover;
}

.labo_text {
	margin: 0 auto;
	padding: 0 30px;
	flex: 1;
}

.labo_genre {
	font-size: 14px;
	display: inline-block;
	min-width: 62px;
	margin-bottom: 20px;
	padding: 2px 10px;
	text-align: center;
	background-color: #e6e6cc;
}

.labo_genre_report {
	width: 76px;
}

.labo_title {
	font-size: 20px;
	margin-bottom: 15px;
}

.labo_contents {
	font-size: 16px;
	color: #78868e;
}

.labo_button {
	font-family: 'Noto Sans Japanese';
	font-size: 28px;
	padding-top: 60px;
	text-align: center;
	color: white;
}

.product {
	position: relative;
	margin: 0 auto;
	margin-top: 70px;
	padding-top: 100px;
	padding-bottom: 80px;
	text-align: center;
	background-color: #fafaf5;
}

.product_title {
	font-family: 'Noto Sans Japanese';
	font-size: 36px;
	font-weight: 500;
	margin: 0;
	text-align: center;
	color: #40525e;
}

.product_title::before {
	display: block;
	width: 40px;
	margin: 0 auto;
	padding-bottom: 40px;
	content: '';
	border-top: 4px solid #ec6202;
}

.product_bird {
	position: absolute;
	top: -150px;
	left: 135px;
}

.product_wrap {
	position: relative;
	display: flex;
	width: 1000px;
	margin: auto;
	padding-top: 65px;
	justify-content: space-between;
}

.product_column {
	position: relative;
	width: 460px;
	padding-bottom: 50px;
}

.product_name_wrap {
	margin-bottom: 20px;
	text-align: center;
}

.product_name {
	font-size: 28px;
	font-weight: 500;
	display: flex;
	min-height: 85px;
	color: #40525e;
	align-items: center;
	justify-content: center;
}

.product_name_genre {
	font-size: 14px;
	font-weight: 500;
	display: block;
	margin-bottom: 10px;
	color: #ec6202;
}

.product_text {
	text-align: center;
}

.product_text h4 {
	font-size: 20px;
	font-weight: 500;
	padding: 1em 0 .8em;
}

.product_text p {
	font-size: 16px;
	line-height: 2;
	margin-bottom: 30px;
}

.product_pic img {
	width: 100%;
}

.product_button {
	position: absolute;
	bottom: 0;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
}

.foot-banner {
	width: 100%;
	padding-top: 80px;
	padding-bottom: 40px;
	background-color: #fafaf5;
}

.foot-banner_wrap {
	display: flex;
	width: 1000px;
	margin: 0 auto;
	justify-content: space-between;
}

.foot-banner_item {
	position: relative;
	width: 320px;
	margin: 0 auto;
}

.foot-banner_item img {
	width: 100%;
}

.btn-def {
	font-size: 20px;
	display: inline-block;
	padding: 10px 45px 10px 45px;
	color: white;
	border-radius: 50px;
	outline: none;
	background-color: #b0c6d5;
}

.btn-def:hover {
	opacity: .7;
}

@media screen and (min-width: 769px) {

.sp {
	display: none !important;
}

.blog_item:last-child {
	display: none;
}

.blog_item a:hover {
	opacity: .7;
}

}

@media screen and (min-width: 990px) {

.tab {
	display: none !important;
}

}

@media screen and (max-width: 768px) {

.pc {
	display: none !important;
}

.main {
	padding: 20px 0 30px;
}

.mainVisual .swiper-slide {
	width: 100%;
	height: auto;
}

.mainVisual .swiper-slide img {
	width: 100%;
	height: auto;
}

.blog_section {
	width: 100%;
	margin-top: 0;
}

.blog_title {
	font-size: 21px;
	position: static;
}

.blog_title::before {
	position: static;
	width: 20px;
	padding-bottom: 4.66667vw;
	border-top: 2px solid #ec6202;
}

.blog_wrap {
	width: 100%;
	margin: 0 auto;
	margin-top: 8vw;
	padding: 0 4vw;
	flex-wrap: wrap;
}

.blog_item:nth-child(n + 3) {
	display: none;
}

.blog_item {
	width: 44vw;
	margin-bottom: 4vw;
}

.notice_contents_bottom {
	padding-top: 6.66667vw;
}

.blog_item img {
	width: 100%;
}

.blog_item a {
	text-decoration: none;
}

.blog_name {
	font-family: 'Noto Sans Japanese';
	font-size: 12px;
	font-weight: 400;
	line-height: 17px;
	margin-top: 2.66667vw;
}

.blog_bottom {
	margin-top: 1.33333vw;
}

.blog_date {
	font-size: 10px;
	padding-top: 2.66667vw;
	padding-right: 2.66667vw;
}

.blog_label {
	font-size: 10px;
	padding-bottom: 1.06667vw;
	border-bottom: 1px solid #78868e;
}

.overview_range {
	padding-top: 17.33333vw;
}

.overview_section {
	width: 100%;
}

.overview_title {
	font-size: 21px;
	line-height: normal;
	width: 100%;
	padding-top: 0;
	padding-bottom: 6vw;
}

.overview_title::before {
	width: 5.33333vw;
	padding-bottom: 5.33333vw;
	border-top: 2px solid #ec6202;
}

.overview_title span {
	font-size: 16px;
}

.overview_title_img {
	top: 13.33333vw;
	left: 2.66667vw;
	width: 23.2%;
}

.overview_title_img img {
	width: 100%;
}

.overview_wrap {
	flex-direction: column;
}

.overview_item {
	width: 100%;
	height: 53.33333vw;
}

.overview_item01 {
	background: url(../img/top/overview01.png) center top no-repeat;
	background-size: cover;
}

.overview_item02 {
	background: url(../img/top/overview02.png) center top no-repeat;
	background-size: cover;
}

.overview_item03 {
	background: url(../img/top/overview03.png) center top no-repeat;
	background-size: cover;
}

.overview_text {
	font-size: 18px;
	line-height: 28px;
}

.overview_button {
	font-size: 14px;
	margin-top: 5.33333vw;
	padding: 2.66667vw 9.33333vw 2.66667vw 9.33333vw;
}

.labo_range {
	padding-top: 15.33333vw;
	padding-bottom: 13.33333vw;
}

.labo_section {
	width: 100%;
}

.labo_section_title {
	font-size: 21px;
	font-weight: 500;
	margin-bottom: 6.66667vw;
}

.labo_section_title::before {
	width: 5.33333vw;
	padding-bottom: 5.33333vw;
	border-top: 2px solid #ec6202;
}

.labo_item {
	flex-direction: column;
	width: 80%;
	height: auto;
	margin: auto;
	margin: 0 auto;
	margin-bottom: 6.66667vw;
	padding-bottom: 2.66667vw;
}

.labo_item:nth-of-type(3) {
	margin-bottom: 6.66667vw;
}

.labo_item > a img {
	height: auto;
}

.labo_img {
	width: 100%;
	max-height: none;
	max-height: initial;
}

.labo_text {
	font-size: 14px;
	padding: 4vw 4vw;
}

.labo_genre {
	font-size: 10px;
	width: 11.33333vw;
	min-width: 0;
	min-width: initial;
	margin-top: 0;
	margin-bottom: 2.66667vw;
	margin-left: 0;
	padding: .66667vw 1.33333vw;
}

.labo_genre_report {
	width: 13.33333vw;
}

.labo_title {
	font-size: 14px;
	margin-bottom: 2.66667vw;
}

.labo_contents {
	font-size: 12px;
	line-height: 17px;
	margin-top: 2.66667vw;
}

.labo_button {
	padding-top: 0;
}

.product {
	width: 100%;
	margin-top: 13.33333vw;
	margin-bottom: 0vw;
	padding-top: 13.33333vw;
	padding-bottom: 0vw;
}

.product_title {
	font-size: 5.6vw;
}

.product_title::before {
	width: 5.33333vw;
	padding-bottom: 5.33333vw;
	border-top: 2px solid #ec6202;
}

.product_bird {
	top: -37.33333vw;
	left: 14.66667vw;
	width: 23.5%;
}

.product_bird img {
	width: 100%;
}

.product_wrap {
	flex-direction: column;
	width: 100%;
	padding-top: 8.66667vw;
}

.product_column {
	width: 100%;
	margin-bottom: 13.33333vw;
}

.product_name_wrap {
	font-size: 18px;
	margin-top: 0;
}

.product_name {
	font-size: 18px;
	min-height: 0;
	min-height: initial;
	margin-top: 0;
}

.product_name_genre {
	font-size: 10px;
	margin-bottom: 5px;
}

.product_text {
	padding: 0 20px;
}

.product_text h4 {
	font-size: 14px;
	font-weight: 700;
	margin: 2.66667vw auto 0;
}

.product_text p {
	font-size: 12px;
	font-weight: 500;
	margin: 0 auto 2.66667vw;
}

.product_pic {
	width: 92%;
	margin: 0 auto;
	margin-top: 8vw;
}

.foot-banner {
	padding-top: 10.66667vw;
	padding-bottom: 5.33333vw;
}

.foot-banner_wrap {
	flex-direction: column;
	width: 100%;
}

.foot-banner_item {
	margin-bottom: 2.93333vw;
}

.btn-def {
	font-size: 14px;
	padding: 2.66667vw 9.33333vw 2.66667vw 9.33333vw;
}

}

@media screen and (max-width: 767px) {

.tab {
	display: none !important;
}

}

