@charset "UTF-8";

/* ====================================
	フォント設定
 ==================================== */
.garamond-premier-pro,
.sub-title,
.menu-title,
.vertical {
	font-family: garamond-premier-pro, serif;
	font-style: normal;
	font-weight: 400;
}

.source-han-serif-japanese,
article {
	font-family: source-han-serif-japanese, serif;
	font-style: normal;
	font-weight: 200;
}

/* ====================================
	プラグイン・アニメーション設定
 ==================================== */
/* スライドショー：ページネーション */
.swiper-pagination-bullets {
	margin-top: 1rem;
	text-align: center;
}

.swiper-pagination-bullets .swiper-pagination-bullet {
	width: 1rem;
	height: 1rem;
	margin-left: 1.6rem;
	background: #000;
}

/* ===============================
	共通スタイル
=============================== */
/* マウスオーバー：フェード */

.center {
	text-align: center;
}

.caption-r {
	font-size: 1.2rem;
	text-align: right;
}

/* グローバルナビ */
/* .global-header-navi .english a {
	color: #008EC8;
} */

.global-header-navi .site-logo .logo-text {
	color: #fff;
}

.menu-label {
	color: #008ec8;
	font-size: 1.4rem;
	margin-bottom: .6rem;
	transition: .2s ease;
}

/* menu色変更 */
/* #menuBtn.change .menu-label {
	color: #008EC8;
} */

/* .hamburger span {
	background-color: #fff;
} */

#menuBtn.change .hamburger span {
	background-color: #008EC8;
}

#menuBtn:hover {
	opacity: .6;
	cursor: pointer;
}

/* article:not(.is-scrolled) #globalHeader {
	transform: translate(0, -100%);
} */

/* news */
#news .news-box {
	display: flex;
	align-items: center;
	margin-top: 1rem;
}

#news .title {
	padding-right: 4rem;

}

#news .news-date {
	padding-left: 4rem;
	color: #008EC8;
}

#news .news-text {
	padding-left: 4rem;
}

#news .news-error {
	padding-left: 4rem;
}

/* リンクボタン */
.btn-detail {
	text-align: center;
}

.title-container-right {
	text-align: right;
}

.title-container {
	display: inline-block;
	text-align: left;
}

.sub-title {
	color: #66BBDE;
}

.sub-text {
	position: relative;
	display: inline-block;
	padding: .5em 0em .5em 0em;
	color: #7C8890;
	letter-spacing: .2em;
}

.sub-text:before {
	position: relative;
	top: -4px;
	left: 0;
	transform: translateY(-50%);
	content: '';
	width: 20px;
	height: 1px;
	background-color: #BCAC74;
	display: inline-block;
	margin-right: 1rem;
}



.side-menu a:hover {
	text-decoration: none;
}

.side-menu a {
	color: #fff;
}

.side-menu a:hover ul {
	opacity: 0.6;
	transition: .4s ease;
}

.side-menu.none {
	display: none;
}

/* スライダー：NEXT/PREV */
#slider1 .slider-next,
#slider1 .slider-prev {
	position: absolute;
	top: 45vw;
	width: 50px;
	height: 50px;
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	transform: translate(0, -50%);
	cursor: pointer;
	z-index: 1;
}

#slider1 .slider-prev {
	background-image: url(/common/images/chevron-left-solid.svg);
	left: 5vw;
	right: auto
}

#slider1 .slider-next {
	background-image: url(/common/images/chevron-right-solid.svg);
	right: 5vw;
	left: auto
}


/* 個別スタイル */
#message .flex-item.left .inner-text .sub-sub-title {
	font-weight: 100;
}

#message .flex-item.left .inner-text {
	position: relative;
}

#feature .flex-item .sub-sub-title {
	font-weight: 100;
}

#feature .osusume-ttl::before {
	content: '';
	position: absolute;
	bottom: -15px;
	display: inline-block;
	width: 100px;
	height: 1px;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	background-color: #66bbde;
}

#feature .text-container {
	position: relative;
	padding-left: 8rem;
}



#feature .text-container .vertical {
	position: absolute;
	top: 1.8rem;
	left: 0;
	writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	-webkit-writing-mode: vertical-rl;
	text-orientation: mixed;
	color: #008ec8;
	letter-spacing: .2rem;
}

#feature .text-container .vertical::after {
	position: absolute;
	top: 190%;
	left: -40px;
	/* transform: translateY(-50%); */
	content: '';
	width: 110px;
	height: 1px;
	background-color: #008EC8;
	transform: rotate(90deg);
}

#menu .flex-container.mt-none {
	margin-top: 0;
}

#menu .flex-container.half .text-container {
	text-align: center;
}

#menu .menu-title {
	color: #BCAC74;
}

#menu .text {
	margin-top: 1rem;
}

#menu .btn-arrow-right {
	width: 150px;
	position: relative;
	padding: .4em 1.4em .4em 1em;
	font-size: 1.6rem;
	font-weight: normal;
	border: 1px solid #292E2F;
	cursor: pointer;
	text-align: center;
	transition: .2s;
	margin-top: 3rem;
}


#menu .btn-arrow-right:after {
	display: inline-block;
	position: absolute;
	top: 50%;
	right: -6%;
	z-index: 1;
	content: '';
	display: block;
	height: .7px;
	width: 20%;
	background-color: #292E2F;
	transition: all .2s ease-in-out;
}

#menu a:hover .btn-arrow-right:after {
	right: -10%;
}

#menu a:hover .btn-arrow-right {
	background-color: #C2E3F2;
}

#menu a:hover {
	text-decoration: none;
}

/* hover 範囲拡大 */
/* a.hover-parent.hovering .btn-arrow-right.hover-trigger::after {
	right: -10%;
}

a.hover-parent.hovering .btn-arrow-right.hover-trigger {
	background-color: #C2E3F2;
	text-decoration: none;
}

a.hover-parent {
	display: block;
	pointer-events: none;
	text-decoration: none;
}

a.hover-parent .hover-trigger {
	pointer-events: auto;
}

a.hover-parent span.hover-trigger {
	display: inline-block;
}

a.hover-parent.hovering .hover-trigger {
	text-decoration: underline;
}

a.hover-parent.hovering .hover-trigger.fade {
	transition: 0.5s ease 0s;
	-webkit-transition: 0.5s ease 0s;
	-moz-transition: 0.5s ease 0s;
	-ms-transition: 0.5s ease 0s;
}

a.hover-parent.hovering .hover-trigger.fade {
	opacity: 0.6;
} */


#menu .flex-container.half .flex-item.right {
	display: flex;
	align-items: center;
	justify-content: center;
}


#voices .fukidashi {
	display: inline-block;
	position: relative;
	background: #fff;
	border: 1px solid #666;
	box-sizing: border-box;
}

#slideIntro .fukidashi.swiper-slide::before {
	content: "";
	position: absolute;
	bottom: -14px;
	left: 38px;
	margin-left: -15.5px;
	z-index: 2;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 15px 7.5px 0 7.5px;
	border-color: #fff transparent transparent transparent;
	transform: skewX(-25deg);
}

#slideIntro .fukidashi.swiper-slide::after {
	content: "";
	position: absolute;
	bottom: -16px;
	left: 38px;
	margin-left: -16.5px;
	z-index: 1;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 16px 8px 0 8px;
	border-color: #7C8890 transparent transparent transparent;
	transform: skewX(-25deg);
}



#slideIntro .swiper-wrapper.col4 .swiper-slide {
	position: relative;
	padding: 3rem 3rem 4rem 3rem;
	height: auto;
	line-height: 1.8;

}

#slideIntro .swiper-wrapper {
	padding-bottom: 20px;
}

#slideIntro .fukidashi.swiper-slide .inner .text {
	margin-bottom: 2rem;
}


#slideIntro .fukidashi.swiper-slide .age {
	color: #008EC8;
	text-align: right;
	position: absolute;
	bottom: 1.6rem;
	right: 1.4rem;
}



/* ====================================
	767px以下専用スタイル
===================================== */
@media only screen and (max-width: 767px) {
	a .hover-fade:hover {
		transition: 0.5s ease 0s;
		-webkit-transition: 0.5s ease 0s;
		-moz-transition: 0.5s ease 0s;
		-ms-transition: 0.5s ease 0s;
		opacity: 0.6;
	}

	/* スライドショー・イントロ */


	.pc-only {
		display: none;
	}

	.btn-arrow-right {
		margin-top: 4rem;
	}

	/* ベース */
	article {
		font-size: 1.4rem;
		line-height: 1.8;
	}

	/* メインビジュアル */

	#mainVisual {
		padding-top: 90px;
	}

	.menu-label {
		font-size: 1.2rem;
	}

	/*パララックス */
	.wide-visual {
		width: 100%;
		height: 30vw;
		margin-bottom: 10rem;
		background-position: center center;
		background-repeat: no-repeat;
		background-size: contain;
		background-image: url(/index/images/wide-visual_sp.jpg);
	}

	/* メインビジュアル */

	.scroll-item {
		display: none;
	}


	/*サイドメニュー  */
	.side-menu {
		position: fixed;
		z-index: 10;
		bottom: 0;
		width: 100%;
	}

	.side-menu {
		opacity: 0;
		bottom: -124px;
		transition: .3s;
		z-index: 9;
	}

	.side-menu.sp-only.scroll-on {
		opacity: 1;
		bottom: 0;
	}

	/* .passed .side-menu {
		opacity: 1;
		bottom: 0;
	} */


	.side-menu .menu {
		display: flex;
		flex-wrap: wrap;
	}

	.side-menu .menu-wrap {
		margin-left: 5%;
		margin-right: 5%;
	}

	.side-menu .menu li.studio {
		width: 49.8%;
	}

	.side-menu .menu li.studio:nth-last-child(2) {
		margin-left: .4%;
	}

	.side-menu .menu li.online {
		width: 100%;
		margin-top: 1px;
	}

	.side-menu li {
		position: relative;
		text-align: center;
		padding: 14px 14px;
		color: #fff;
		background-color: #008EC8;
		font-size: 1.2rem;
		transition: 0.5s ease 0s;
		width: 100%;
		display: block;
	}

	a[target=_blank] span.link-top {
		background: url(/common/images/link_w.svg) right 100%/13px auto no-repeat;
		padding-right: 22px;
	}

	/* news sp */
	#news .news-box {
		display: flex;
		align-items: center;
		font-size: 1.2rem;
	}

	#news .title {
		font-size: 1.2rem;
		padding-right: 2rem;
	}

	#news .news-date {
		padding-left: 2rem;
	}

	#news .news-text {
		padding-left: 2rem;
	}

	#news .news-error {
		padding-left: 2rem;
	}

	#news .news-item {
		position: relative;
		display: flex;
		flex-direction: column;

	}

	#news .news-item::before {
		content: "";
		display: inline-block;
		width: 1px;
		height: 85%;
		background-color: #BCAC74;
		position: absolute;
		top: 54%;
		transform: translate(0, -50%);
	}

	/* サブセクション */
	.sub-section {
		/* padding-top: 14vw;
		padding-bottom: 18vw; */
		padding-top: 8rem;
		padding-bottom: 10rem;
	}

	.sub-title {
		font-size: 5rem;
		line-height: 1;
		letter-spacing: 2px;
	}

	.sub-text:before {
		width: 10px;
		margin-right: .6rem;
	}

	.title-container {
		margin-bottom: 4rem;
	}

	.title-container .sub-text {
		font-size: 1.2rem;
	}

	/* スライダー */
	#slider1 .swiper-pagination {
		top: 72vw;
		bottom: auto;
	}

	#slider1 .swiper-pagination-bullets .swiper-pagination-bullet {
		margin: 0 1vw;
	}

	#slider1 .swiper-pagination-bullet {
		width: 3vw;
		height: 3vw;
		background: #fff;
		border: solid 2px #78C3C9;
		opacity: 1;
	}

	#slider1 .swiper-pagination-bullet-active {
		background: #78C3C9;
	}

	#slider1 .slider-next,
	#slider1 .slider-prev {
		width: 24px;
		height: 24px;
	}

	/* 画像リスト */
	ul.list-figures li {
		margin-top: 1em;
	}

	ul.list-figures li:first-child {
		margin-top: 0;
	}

	ul.list-figures li .img {
		width: 100%;
	}

	ul.list-figures.sp-col2,
	ul.list-figures.col4 {
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}

	ul.list-figures.sp-col2 li,
	ul.list-figures.col4 li {
		width: 48%;
		margin-top: 1em;
	}

	ul.list-figures.sp-col2.no-gap li {
		width: 50%;
	}

	ul.list-figures.sp-col2 li:nth-child(-n+2),
	ul.list-figures.col4 li:nth-child(-n+2) {
		margin-top: 0;
	}

	/* 個別スタイル */
	#message.sub-section {
		padding-bottom: 0;
	}

	#message .flex-container {
		/* flex-direction: column-reverse; */
		position: relative;
		top: -8rem;
	}

	#message .flex-item.left .inner-text .sub-sub-title {
		font-size: 1.8rem;
		line-height: 2;
		max-width: 558px;
		margin-bottom: 4rem;
	}

	#message .flex-item.left .inner-text .text {
		font-size: 1.2rem;
		line-height: 2;
	}

	#message .flex-container.half>.flex-item.left {
		position: relative;
		z-index: 1;

	}


	#message .flex-container.half>.flex-item.left .sp-wrap {
		background-color: #F2F9FC;
		width: 106vw;
		position: relative;
		top: 0;
		left: -36px;
		padding-left: 4rem;
		padding-right: 3rem;
		padding-top: 16rem;
		padding-bottom: 60vw;
	}


	#message .flex-container.half>.flex-item.right {
		position: relative;
		z-index: 2;
		padding-bottom: 30vw;
	}


	#message .flex-container.half>.flex-item.right::before {
		content: '';
		background: url(../images/message01.jpg) no-repeat;
		background-size: 80%;
		width: 100vw;
		height: 102vw;
		position: absolute;
		top: -50vw;
		left: 15vw;
		/* max-width: 750px; */
	}

	#message .sub-title {
		position: relative;
		top: 8rem;
		z-index: 3;
	}

	#message .btn-arrow-right {
		position: relative;
		right: 3%;
		margin-left: 5%;
	}

	#message .flex-item.left .inner-text {
		padding-right: 7%;
		max-width: 710px;
	}

	#feature.sub-section {
		padding-top: 20vw;
	}

	#feature .flex-item .sub-sub-title {
		font-size: 1.8rem;
		line-height: 2;
		/* margin-top: 5rem; */
	}

	#feature .flex-item .text {
		margin-top: 2rem;
		font-size: 1.2rem;
		min-height: 5rem;
	}

	#feature .osusume-ttl {
		position: relative;
		font-size: 1.8rem;
		text-align: center;
		margin-bottom: 8rem;
		margin-top: 7rem;
	}

	#feature .osusume-ttl::before {
		width: 40px;
	}


	#feature ul.list-figures.col3 li {
		position: relative;
		padding: 4rem 2rem;
		margin-top: 4.2rem;
	}

	#feature ul.list-figures li.osusume .img {
		width: 6rem;
		position: absolute;
		top: -3rem;
		left: 1rem;
	}

	#feature ul.list-figures li.osusume .title {
		font-size: 1.6rem;
	}

	#feature ul.list-figures li.osusume .text {
		font-size: 1.2rem;
		line-height: 2;
		margin-top: 1rem;
	}

	#feature .text-container {
		padding-left: 4rem;
		margin-left: auto;
		margin-right: auto;
	}

	#feature .text-container .vertical::after {
		left: -10px;
		top: 140%;
		width: 40px;
	}

	#feature .text-container .vertical {
		top: 1rem;
		left: 0;
	}

	#feature .flex-container.half {
		margin-top: 7rem;
	}

	#feature .flex-container.half .flex-item.text {
		padding-left: 5%;
		padding-right: 5%;
		max-width: 600px;
	}

	#feature .flex-container.half.mt-none {
		margin-top: 0;
	}

	#feature .flex-container.half>.flex-item.img {
		position: relative;
		z-index: 1;
		padding-bottom: 47vw;
		margin-top: 4rem;
	}

	#feature .flex-container.half>.flex-item.img.img-item04 {
		margin-top: 5rem;
	}

	#feature .flex-container.half>.flex-item.img-item01::before {
		content: '';
		background: url(../images/feature01.jpg) no-repeat;
		background-size: 85%;
		width: 100vw;
		height: 47vw;
		position: absolute;
		top: 0;
		right: -20vw;
	}



	#feature .flex-container.half>.flex-item.img-item02::before {
		content: '';
		background: url(../images/feature02.jpg) no-repeat;
		background-size: 85%;
		width: 100vw;
		height: 47vw;
		position: absolute;
		top: 0;
		left: -5vw;
	}

	#feature .flex-container.half>.flex-item.img-item03::before {
		content: '';
		background: url(../images/feature03.jpg) no-repeat;
		background-size: 85%;
		width: 100vw;
		height: 47vw;
		position: absolute;
		top: 0;
		right: -20vw;
	}



	#feature .flex-container.half>.flex-item.img-item04::before {
		content: '';
		background: url(../images/feature04.jpg) no-repeat;
		background-size: 85%;
		width: 100vw;
		height: 47vw;
		position: absolute;
		top: 0;
		left: -5vw;
	}


	#menu .menu-title {
		font-size: 2rem;
		line-height: 1;
	}

	#menu .menu-sub-title {
		font-size: .8rem;
		line-height: 1;
		margin-top: .2rem;
	}

	#menu .text {
		font-size: 1.2rem;
		margin-top: 1rem;
		line-height: 1.8;
	}

	#menu .btn-arrow-right {
		margin-top: 2rem;
	}

	#menu .btn-wrap .btn-arrow-right {
		margin-top: 4rem;
		max-width: 320px;
		width: 100%;
    display: block;
		padding: 0;
		font-size: 1.4rem;
	}

	#menu .flex-container.half {
		justify-content: space-between;
	}


	#menu .flex-container {
		display: flex;
		flex-wrap: wrap;
		margin-top: 3rem;
	}

	#menu .flex-container.half>.flex-item {
		width: 36%;
	}

	#menu .flex-container.half>.flex-item.right {
		justify-content: left;
	}

	#menu .flex-container.half>.flex-item.right {
		width: 64%;
		padding: 5vw 1.6rem;
		background-color: #fff;
	}

	#menu .flex-container.half .text-container {
		text-align: left;
	}

	#menu .flex-container.half>.flex-item.menu01 {
		background-image: url(/index/images/menu01_sp.jpg);
		background-size: cover;
		background-repeat: no-repeat;
		background-position: center;
	}

	#menu .flex-container.half>.flex-item.menu02 {
		background-image: url(../images/menu02_sp.jpg);
		background-size: cover;
		background-repeat: no-repeat;
		background-position: center;
	}

	#menu .flex-container.half>.flex-item.menu03 {
		background-image: url(../images/menu03_sp.jpg);
		background-size: cover;
		background-repeat: no-repeat;
		background-position: center;
	}

	#menu .flex-container.half>.flex-item.menu04 {
		background-image: url(../images/menu04_sp.jpg);
		background-size: cover;
		background-repeat: no-repeat;
		background-position: center;
	}

	#menu a:hover {
		text-decoration: none;
	}

	
	#trial.sub-section {
		padding-top: 0;
	}


	#trial .flex-container.half>.flex-item.img {
		position: relative;
		z-index: 1;
		padding-bottom: 58vw;
	}

	#trial .flex-container.half>.flex-item.img-item02::before {
		content: '';
		background: url(../images/trial01.jpg) no-repeat;
		background-size: 85%;
		width: 100vw;
		height: 58vw;
		position: absolute;
		top: 0;
		left: -5vw;
	}

	#trial .trial-ttl::before {
		content: '';
		position: absolute;
		bottom: -15px;
		display: inline-block;
		width: 40px;
		height: 1px;
		left: 50%;
		-webkit-transform: translateX(-50%);
		transform: translateX(-50%);
		background-color: #66bbde;
	}

	#trial .trial-ttl {
		position: relative;
		text-align: center;
		font-size: 1.8rem;
	}

	#trial .trial-btn {
		margin-top: 6rem;
	}

	#trial .btn-arrow-right {
		margin-top: 1rem;
	}

	#trial .flex-container.half>.flex-item.text {
		display: flex;
		align-items: center;
		justify-content: center;
		margin-top: 3rem;
		width: 100%;
		display: block;
	}

	#slideIntro .fukidashi.swiper-slide::before {
		content: "";
		position: absolute;
		bottom: -11px;
		left: 37px;
		margin-left: -15px;
		z-index: 2;
		width: 0;
		height: 0;
		border-style: solid;
		border-width: 11px 5.5px 0 5.5px;
		border-color: #fff transparent transparent transparent;
		transform: skewX(-25deg);
	}

	#slideIntro .fukidashi.swiper-slide::after {
		content: "";
		position: absolute;
		bottom: -13px;
		left: 37px;
		margin-left: -16px;
		z-index: 1;
		width: 0;
		height: 0;
		border-style: solid;
		border-width: 12px 6px 0 6px;
		border-color: #7C8890 transparent transparent transparent;
		transform: skewX(-25deg);
	}


	#slideIntro .fukidashi.swiper-slide .age {
		font-size: 1rem;
		right: 2.4rem;
	}

	#slideIntro .swiper-wrapper.col4 .swiper-slide {
		/* margin-left: 1%; */
		width: 48%;
		padding: 3rem 1.6rem 3rem 1.6rem;
		line-height: 1.8;
		font-size: 1.2rem;
	}

	#slideIntro .fukidashi .text {
		margin-bottom: 1rem;
	}

	#slideIntro .scroll-in.move-tb-pc {
		transition: none;
	}

	#slideIntro .scroll-in.move-tb-pc:not(.passed) {
		transform: translate(0, 0px) !important;
		opacity: 1 !important;
	}
}

/* ====================================
	768px以上印刷専用スタイル
===================================== */
@media print,
screen and (min-width: 768px) {


	.sp {
		display: none;
	}

	.sp-only {
		display: none;
	}

	.btn-arrow-right {
		margin-top: 4rem;
	}

	.title-container-center {
		text-align: center;
	}

	.title-container-center .title-container .sub-text-wrap {
		text-align: center;
	}

	/* メインビジュアル */

	#mainVisual {
		padding-top: 120px;
	}



	/* ベース */
	article {
		font-size: 1.6rem;
		overflow: hidden;
	}

	/* メインビジュアル */
	.menu-label {
		margin-bottom: -.6rem;
	}

	/*サイドメニュー  */
	.side-menu {
		position: fixed;
		top: 50%;
		transform: translate(0, -50%);
		right: 0;
		z-index: 9;
		font-size: 0;
		transition: .4s ease;
	}

	.side-menu {
		opacity: 0;
		right: -42px;

	}

	.side-menu.passed {
		opacity: 1;
		right: 0;

	}

	.side-menu ul {
		display: flex;
		flex-direction: column;
		align-items: end;
	}

	.side-menu li {
		position: relative;
	}

	.side-menu li::before {
		content: '';
		position: absolute;
		display: inline-block;
		width: 15px;
		height: 1px;
		bottom: 0;
		left: 50%;
		transform: translateX(-50%);
		background-color: #fff;
	}

	.side-menu li:last-child::before {
		display: none;
	}


	.side-menu li {
		-webkit-writing-mode: vertical-rl;
		/* Chrome,Safari対応*/
		-ms-writing-mode: tb-rl;
		/* IE対応*/
		writing-mode: vertical-rl;
		/*  フォントサイズ0になっているので指定する */
		/* 以下、装飾 */
		padding: 30px 10px;
		color: #fff;
		background-color: #008EC8;
		font-size: 1.4rem;
		transition: 0.5s ease 0s;
		letter-spacing: .6rem;
	}



	a[target=_blank] span.link-top {
		background: url(/common/images/link_w.svg) center bottom/14px auto no-repeat;
		padding-bottom: 18px;
	}



	/* news pc */
	#news .news-box {
		display: flex;
		align-items: center;
	}


	#news .title {
		font-size: 1.6rem;
	}

	#news .news-date {
		font-size: 2rem;
	}


	#news .news-text {
		font-size: 1.6rem;
	}

	#news .news-item {
		position: relative;
		display: flex;
		align-items: center;

	}

	#news .news-item::before {
		content: "";
		display: inline-block;
		width: 1px;
		height: 18px;
		background-color: #BCAC74;
		position: absolute;
		top: 50%;
		transform: translate(0, -50%);
	}


	/* サブセクション */
	.sub-section {
		padding-top: 14rem;
		padding-bottom: 16rem;
	}

	.sub-title {
		font-size: 8rem;
		line-height: 1;
		letter-spacing: 8px;
	}

	.title-container {
		margin-bottom: 14rem;
	}

	.title-container .sub-text {
		font-size: 1.6rem;
	}

	/* スライダー */
	#slider1 .swiper-pagination {
		top: 74vw;
		bottom: auto;
	}

	#slider1 .swiper-pagination-bullets .swiper-pagination-bullet {
		margin: 0 1vw;
	}

	#slider1 .swiper-pagination-bullet {
		width: 2vw;
		height: 2vw;
		background: #fff;
		border: solid 2px #78C3C9;
		opacity: 1;
	}

	#slider1 .swiper-pagination-bullet-active {
		background: #78C3C9;
	}

	#slider1 .slider-next,
	#slider1 .slider-prev {
		width: 24px;
		height: 24px;
	}

	/* ===== 製品固有スタイル ===== */

	/* 画像リスト */
	ul.list-figures {
		display: flex;
		flex-wrap: wrap;
	}

	ul.list-figures li .img {
		width: 100%;
	}

	ul.list-figures.col2 {
		justify-content: space-between;
	}

	ul.list-figures.col2 li {
		width: 48%;
		margin-top: 1em;
	}

	ul.list-figures.col2.no-gap li {
		width: 50%;
	}

	ul.list-figures.col2 li:nth-child(-n+2) {
		margin-top: 0;
	}

	ul.list-figures.col3 li {
		width: 32%;
		margin-left: 2%;
	}

	ul.list-figures.col3 li:nth-child(3n-2) {
		margin-left: 0;
	}

	/* 個別スタイル */


	#message.sub-section {
		padding-top: 13rem;
		padding-bottom: 6rem;
	}

	#message .flex-wrap {
		position: relative;
	}

	#message .flex-container.half {
		/* padding-top: 38rem; */
		/* flex-direction: row-reverse; */
	}

	#message .flex-item.left {
		/* position: absolute;
		top: 50%;
		left: 0%;
		transform: translateY(-50%); */
		padding: 8rem 0vw 6rem 0rem;
		width: 50%;
		margin-top: 12rem;
		z-index: 1;
		/* background: #F2F9FC;
		width: 100vw;
		margin: 0 calc(50% - 94vw); */
	}

	#message .flex-item.right {
		/* position: absolute;
		top: 50%;
		right: 0%;
		transform: translateY(-50%); */
		width: 50%;
		margin-top: -4rem;
	}

	#message .flex-container.half>.flex-item.left {
		position: relative;
		z-index: 1;
	}

	#message .flex-container.half>.flex-item.left::before {
		content: '';
		display: block;
		background-color: #F2F9FC;
		width: 100vw;
		height: 98rem;
		position: absolute;
		top: 0;
		right: -10vw;
	}

	#message .flex-item.left .inner-text .sub-sub-title {
		font-size: 2.5rem;
		line-height: 2;
		margin-bottom: 6rem;
	}

	#message .flex-item.left .inner-text .text {
		line-height: 2.6;
	}

	#message .flex-container.half>.flex-item.right {
		position: relative;
		z-index: 2;
	}

	#message .flex-container.half>.flex-item.right::before {
		content: '';
		background: url(../images/message01.jpg) no-repeat;
		background-size: 100%;
		width: 50vw;
		height: 64vw;
		position: absolute;
		top: 0;
		left: 0vw;
		max-width: 750px;
	}

	#message .btn-arrow-right {
		margin-top: 6rem;
		margin-left: 0;
	}


	/* #message .bg-item {
		position: absolute;
		width: 56vw;
		left: 0vw;
		bottom: 0;
		height: 100%;
		background-color: rgba(204, 232, 244, 0.4);
		padding-top: 10rem;
	} */
	#feature ul.list-figures.col3 {
		padding-bottom: 5rem;
	}

	#feature ul.list-figures.col3 li {
		position: relative;
		padding: 8rem 4rem;
		width: 31.3%;
		margin-left: 3%;
	}

	#feature ul.list-figures.col3 li:nth-child(3n-2) {
		margin-left: 0;
	}

	ul.list-figures.col3 li {
		width: 31%;
		margin-left: 3%;
	}

	/* #feature ul.list-figures.col3 li:nth-child(3n+2) {
		top: 50px;
	}

	#feature ul.list-figures.col3 li:nth-child(3n+3) {
		top: 100px;
	} */

	#feature ul.list-figures li.osusume .img {
		width: 32%;
		margin-left: auto;
		margin-right: auto;
	}

	#feature ul.list-figures li.osusume .title {
		font-size: 2rem;
		position: relative;
		margin-top: 6rem;
		line-height: 2;
	}

	#feature ul.list-figures li.osusume .title::before {
		content: '';
		position: absolute;
		bottom: -25px;
		display: inline-block;
		width: 20px;
		height: 1px;
		left: 0;
		background-color: #B9B6A9;
	}

	#feature ul.list-figures li.osusume .text {
		font-size: 1.4rem;
		margin-top: 5rem;
		line-height: 2;
	}

	#feature .flex-item .sub-sub-title {
		font-size: 2.5rem;
		line-height: 1.8;
	}

	#feature .flex-item .text {
		margin-top: 3rem;
		font-size: 1.4rem;
	}

	#feature .osusume-ttl {
		position: relative;
		font-size: 2.8rem;
		text-align: center;
		margin-bottom: 8rem;
		margin-top: 14rem;
	}

	#feature .flex-container.half {
		padding-bottom: 12vw;
	}

	#feature .flex-container.half.mt-none {
		margin-top: 0;
	}

	#feature .flex-container.half .flex-item .text-container {
		max-width: 440px;
		line-height: 2;
		height: 0;
	}

	#feature .flex-container.half:nth-child(odd) {
		flex-direction: row-reverse;
	}

	#feature .flex-container.half>.flex-item.img {
		position: relative;
		z-index: 1;
	}

	#feature .flex-container.half>.flex-item.img-item01::before {
		content: '';
		background: url(../images/feature01.jpg) no-repeat;
		background-size: 100%;
		width: 50vw;
		height: 30vw;
		position: absolute;
		top: 0;
		left: 0vw;
		max-width: 750px;
	}

	#feature .flex-container.half>.flex-item.img-item02::before {
		content: '';
		background: url(../images/feature02.jpg) no-repeat;
		background-size: 100%;
		width: 50vw;
		height: 30vw;
		position: absolute;
		top: 0;
		right: 0;
		max-width: 750px;
	}

	#feature .flex-container.half>.flex-item.img-item03::before {
		content: '';
		background: url(../images/feature03.jpg) no-repeat;
		background-size: 100%;
		width: 50vw;
		height: 30vw;
		position: absolute;
		top: 0;
		left: 0vw;
		max-width: 750px;
	}

	#feature .flex-container.half>.flex-item.img-item04::before {
		content: '';
		background: url(../images/feature04.jpg) no-repeat;
		background-size: 100%;
		width: 50vw;
		height: 30vw;
		position: absolute;
		top: 0;
		right: 0;
		max-width: 750px;
	}

	#feature .flex-container:first-child {
		margin-top: 0;
	}

	#menu .flex-container {
		margin-top: 6rem;
	}


	#menu .menu-title {
		font-size: 5.6rem;
		line-height: 1;
		letter-spacing: .4rem;
	}

	#menu.sub-section {
		padding-top: 12rem;
	}

	#menu .menu-sub-title {
		font-size: 1.2rem;
		line-height: 1;
		position: relative;
		margin-top: 1.4rem;

	}

	#menu .text {
		font-size: 1.4rem;
		margin-top: 3.4rem;
		line-height: 2;
	}

	#menu .btn-arrow-right {
		margin-top: 3.8rem;
	}
	#menu .btn-wrap .btn-arrow-right {
	width: 330px;
	display: block;
		margin-top: 8rem;
		padding: 0;
	}


	#menu .menu-sub-title::before {
		content: '';
		position: absolute;
		bottom: -18px;
		display: inline-block;
		width: 22px;
		height: 1px;
		left: 50%;
		-webkit-transform: translateX(-50%);
		transform: translateX(-50%);
		background-color: #BCAC74;
	}

	#menu .flex-container.half>.flex-item {
		width: 48%;
	}

	#menu .flex-container.half .flex-item.right {
		background-color: #fff;
		padding: 6rem 1rem 4rem;
		width: 52%;
	}

	#menu .flex-container.half .flex-item.menu01 {
		background-image: url(/index/images/menu01.jpg);
		background-size: cover;
		background-repeat: no-repeat;
		background-position: center;
	}

	#menu .flex-container.half .flex-item.menu02 {
		background-image: url(/index/images/menu02.jpg);
		background-size: cover;
		background-repeat: no-repeat;
		background-position: center;
	}

	#menu .flex-container.half .flex-item.menu03 {
		background-image: url(/index/images/menu03.jpg);
		background-size: cover;
		background-repeat: no-repeat;
		background-position: center;
	}

	#menu .flex-container.half .flex-item.menu04 {
		background-image: url(/index/images/menu04.jpg);
		background-size: cover;
		background-repeat: no-repeat;
		background-position: center;
	}

	#voicess .btn-arrow-right {
		margin-top: 10rem;
	}

	#trial.sub-section {
		padding-top: 0;

	}

	#trial .flex-container.half {
		padding-bottom: 29vw;
		position: relative;
	}

	#trial .flex-container.half .flex-item .text-container {
		line-height: 2;
	}

	#trial .flex-container.half>.flex-item.img {
		position: relative;
		z-index: 1;
	}

	#trial .flex-container.half>.flex-item.img-item02::before {
		content: '';
		background: url(../images/trial01.jpg) no-repeat;
		background-size: 100%;
		width: 50vw;
		height: 34vw;
		position: absolute;
		top: 0;
		right: 0;
		max-width: 750px;
	}

	#trial .trial-ttl::before {
		content: '';
		position: absolute;
		bottom: -36px;
		display: inline-block;
		width: 100px;
		height: 1px;
		left: 50%;
		-webkit-transform: translateX(-50%);
		transform: translateX(-50%);
		background-color: #66bbde;
	}

	#trial .trial-ttl {
		position: relative;
		text-align: center;
		font-size: 2.5rem;
	}

	#trial .trial-btn {
		margin-top: 8rem;
	}

	#trial .btn-arrow-right {
		margin-top: 1rem;
	}

	#trial .flex-container.half>.flex-item.text {
		display: flex;
		align-items: center;
		justify-content: center;
		position: absolute;
		top: 50%;
		transform: translate(0, -50%);
		right: 0;
	}

	#slideIntro .swiper-wrapper {
		display: flex;
		flex-wrap: wrap;
	}

	#slideIntro .fukidashi .text {
		margin-bottom: 1rem;
	}


	#slideIntro .fukidashi.swiper-slide .age {
		font-size: 1.2rem;
		right: 4.4rem;
	}

	#slideIntro .scroll-in.move-tb-pc:not(.passed) {
		transform: translate(0, 30px) !important;
	}

	#voices .btn-arrow-right {
		margin-top: 8rem;
	}

	#voice .slide-pagination {
		display: none;
	}

}


/* ====================================
	768px以上1023px以下専用スタイル
===================================== */
@media only screen and (min-width: 768px) and (max-width: 1023px) {
	.sp-only {
		display: none;
	}

	/* ベース */
	article {
		font-size: 1.4rem;
		line-height: 1.8;
	}

	/* フレックスコンテナ：ハーフ */
	.flex-container.half {
		justify-content: space-between;
	}

	.flex-container.half>.flex-item {
		width: 48%;
	}

	/* メインビジュアル */
	.scroll-item {
		position: absolute;
		bottom: 100px;
		right: 140px;
	}



	/*パララックス */
	.wide-visual {
		width: 100%;
		height: 30vw;
		margin-bottom: 10rem;
		background-position: center center;
		background-repeat: no-repeat;
		background-size: 100% auto;
		background-image: url(/index/images/wide-visual_sp.jpg);
	}

	/*サイドメニュー  */

	.side-menu li {
		font-size: 1.4rem;
		padding: 20px 12px;
	}

	.side-menu {
		right: -45px;

	}

	.side-menu .menu {
		background-color: #008ec8;
	}

	/* サブセクション */

	.sub-title {
		font-size: 8rem;
		line-height: .9;
		letter-spacing: 8px;

	}

	.title-container {
		margin-bottom: 8rem;
	}

	.title-container .sub-text {
		font-size: 1.4rem;
	}

	/* スライダー */
	#slider1 .swiper-pagination {
		top: 74vw;
		bottom: auto;
	}

	#slider1 .swiper-pagination-bullets .swiper-pagination-bullet {
		margin: 0 1vw;
	}

	#slider1 .swiper-pagination-bullet {
		width: 2vw;
		height: 2vw;
		background: #fff;
		border: solid 2px #78C3C9;
		opacity: 1;
	}

	#slider1 .swiper-pagination-bullet-active {
		background: #78C3C9;
	}

	#slider1 .slider-next,
	#slider1 .slider-prev {
		width: 24px;
		height: 24px;
	}

	/* 画像リスト */
	/* ul.list-figures li {
		margin-top: 1em;
	} */

	ul.list-figures li:first-child {
		margin-top: 0;
	}

	ul.list-figures li .img {
		width: 100%;
	}

	ul.list-figures.sp-col2,
	ul.list-figures.col4 {
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}

	ul.list-figures.sp-col2 li,
	ul.list-figures.col4 li {
		width: 48%;
		margin-top: 1em;
	}

	ul.list-figures.sp-col2.no-gap li {
		width: 50%;
	}

	ul.list-figures.sp-col2 li:nth-child(-n+2),
	ul.list-figures.col4 li:nth-child(-n+2) {
		margin-top: 0;
	}

	#feature ul.list-figures.col3 {
		display: flex;
		flex-wrap: wrap;
	}

	ul.list-figures.col3 li {
		width: 32%;
		margin-left: 2%;
	}

	ul.list-figures.col3 li:nth-child(3n-2) {
		margin-left: 0;
	}

	/* 個別スタイル */
	#message.sub-section {
		padding-top: 8rem;
		padding-bottom: 0;
	}

	#message .flex-item.left {
		padding: 6rem 0vw 6rem 0rem;
		margin-top: 12rem;
	}

	#message .flex-item.right {
		width: 50%;
		margin-top: 2rem;
	}

	#message .flex-container.half>.flex-item.left::before {
		height: 76rem;
	}

	#message .flex-item.left .inner-text .sub-sub-title {
		font-size: 1.9rem;
		line-height: 2;
		margin-bottom: 4rem;
	}

	#message .flex-item.left .inner-text .text {
		line-height: 2;
	}


	#feature .flex-item .sub-sub-title {
		font-size: 2rem;
		line-height: 2;
	}

	#feature .osusume-ttl {
		font-size: 2.6rem;
	}

	#feature .osusume-ttl::before {
		bottom: -20px;
	}

	#feature .flex-container.half {
		padding-bottom: 30vw;
		margin-top: 8rem;
	}




	#feature .flex-container.half .flex-item .text-container {
		max-width: 360px;
		line-height: 2;
		height: 0;
	}

	#feature .text-container .vertical::after {
		left: -43px;
	}

	#feature ul.list-figures.col3 li {
		padding: 6rem 2rem;
	}


	#feature ul.list-figures li.osusume .title {
		font-size: 1.64rem;
		margin-top: 6rem;
	}

	#feature ul.list-figures li.osusume .title::before {
		bottom: -25px;
		width: 20px;
	}

	#feature ul.list-figures li.osusume .text {
		font-size: 1.4rem;
		margin-top: 5rem;
		line-height: 2;
	}

	#feature .flex-item .text {
		margin-top: 3rem;
	}

	#feature .osusume-ttl {
		font-size: 2.8rem;
		margin-bottom: 3em;
	}


	#menu .flex-container {
		margin-top: 6rem;
	}

	#menu .menu-title {
		font-size: 4.8rem;
		line-height: 1;
		letter-spacing: .1rem;
	}


	#menu .menu-sub-title {
		font-size: 1.2rem;
		line-height: 1;
		position: relative;
		margin-top: 1.4rem;
	}

	#menu .text {
		font-size: 1.4rem;
		margin-top: 2.6rem;
		line-height: 2;
	}

	#menu .btn-arrow-right {
		margin-top: 2rem;
		font-size: 1.4rem;
	}

	#trial .flex-container.half>.flex-item.img-item02::before {
		content: '';
		background: url(../images/trial01.jpg) no-repeat;
		background-size: 100%;
		width: 50vw;
		height: 30vw;
		position: absolute;
		top: 0;
		right: 0;
		max-width: 750px;
	}

	#trial .trial-ttl::before {
		content: '';
		position: absolute;
		bottom: -15px;
		display: inline-block;
		width: 100px;
		height: 1px;
		left: 50%;
		-webkit-transform: translateX(-50%);
		transform: translateX(-50%);
		background-color: #66bbde;
	}

	#trial .trial-ttl {
		position: relative;
		text-align: center;
		font-size: 2rem;
	}

	#trial .trial-btn {
		margin-top: 5rem;
	}

	#trial .btn-arrow-right {
		margin-top: 1rem;
	}

	#trial .btn-arrow-right {
		font-size: 1.4rem;
	}

	#slideIntro .swiper-wrapper.tab-col3 .swiper-slide {
		justify-content: flex-start;
	}

	#slideIntro .swiper-wrapper.tab-col3 .swiper-slide {
		width: 30%;
		margin-left: 5%;
		margin-top: 4rem;
	}

	#slideIntro .swiper-wrapper.tab-col3 .swiper-slide:nth-child(3n-2) {
		margin-left: 0;
	}



	#slideIntro .swiper-wrapper.tab-col3 .swiper-slide:nth-child(-n+3),
	#slideIntro .swiper-wrapper .col4 .swiper-slide li {
		margin-top: 0;
	}

	#slideIntro .swiper-wrapper.tab-col3 .swiper-slide li {
		margin-top: 4rem;
	}

	#slideIntro .swiper-wrapper.col4 {
		display: flex;
		justify-content: flex-start;
		flex-wrap: wrap;
	}

	#slideIntro .fukidashi.swiper-slide::before {
		content: "";
		position: absolute;
		bottom: -14px;
		left: 38px;
		margin-left: -16px;
		z-index: 2;
		width: 0;
		height: 0;
		border-style: solid;
		border-width: 15px 7.5px 0 7.5px;
		border-color: #fff transparent transparent transparent;
		transform: skewX(-25deg);
	}

	#slideIntro .fukidashi.swiper-slide::after {
		content: "";
		position: absolute;
		bottom: -16px;
		left: 38px;
		margin-left: -17px;
		z-index: 1;
		width: 0;
		height: 0;
		border-style: solid;
		border-width: 16px 8px 0 8px;
		border-color: #7C8890 transparent transparent transparent;
		transform: skewX(-25deg);
	}

	#slideIntro .fukidashi.swiper-slide .age {
		right: 3.4rem;
	}

	/* menuのソース tab */


}

/* ====================================
	1024px以上1199px以下専用スタイル
===================================== */
@media print,
screen and (min-width: 1024px) and (max-width: 1199px) {

	/*パララックス */
	.wide-visual {
		width: 100%;
		height: 450px;
		margin-bottom: 140px;
		background-position: center center;
		background-repeat: no-repeat;
		background-size: cover;
		background-attachment: fixed;
		position: relative;
	}

	ul.list-figures.col4 li {
		width: 23%;
		margin-left: 2.666%;
	}

	ul.list-figures.col4 li:nth-child(4n-3) {
		margin-left: 0;
	}

	.list-figures.col4 li:nth-of-type(n+5) {
		margin-top: 3rem;
	}



	#slideIntro .swiper-wrapper.col4 .swiper-slide {
		width: 22.2%;
		margin-left: 3.73%;
	}


	#slideIntro .swiper-wrapper.col4 .swiper-slide:nth-child(4n-3) {
		margin-left: 0;
	}

	#slideIntro .swiper-wrapper.col4 .swiper-slide:nth-of-type(n+5) {
		margin-top: 5rem;
	}

	#slideIntro .swiper-wrapper.col4 .swiper-slide:nth-child(-n+3) {
		margin-top: 0;
	}

	#message .flex-item.left .inner-text .sub-sub-title {
		font-size: 2.5rem;
		margin-bottom: 6rem;
	}

	#message .flex-item.left {
		margin-top: 6rem;
	}

	#slideIntro .fukidashi.swiper-slide::after {
		margin-left: -16.8px;
	}


	#feature .flex-container.half {
		padding-bottom: 30vw;
		margin-top: 8rem;
	}

	#trial .flex-container.half {
		padding-bottom: 34vw;
	}


}

/* ====================================
	1024px以上専用スタイル
===================================== */
@media screen and (min-width: 1024px) {

	/*パララックス */
	.wide-visual {
		width: 100%;
		height: 40vw;
		margin-bottom: 14vw;
		background-position: center center;
		background-repeat: no-repeat;
		background-size: cover;
		background-attachment: fixed;
		position: relative;
	}

	.wide-visual {
		background-image: url(/index/images/wide-visual.jpg);
	}
}

/* ====================================
	1200px以上専用スタイル
===================================== */
@media screen and (min-width: 1200px) {

	/*パララックス */
	.wide-visual {
		width: 100%;
		height: 450px;
		margin-bottom: 140px;
	}

	.title-container {
		margin-bottom: 10rem;
	}

	ul.list-figures.col4 li {
		width: 23%;
		margin-left: 2.666%;
	}

	ul.list-figures.col4 li:nth-child(4n-3) {
		margin-left: 0;
	}

	.list-figures.col4 li:nth-of-type(n+5) {
		margin-top: 3rem;
	}

	#slideIntro .swiper-wrapper.col4 .swiper-slide {
		width: 22.2%;
		margin-left: 3.73%;
	}

	#slideIntro .swiper-wrapper.col4 .swiper-slide:nth-child(4n-3) {
		margin-left: 0;
	}

	#slideIntro .swiper-wrapper.col4 .swiper-slide:nth-of-type(n+5) {
		margin-top: 5rem;
	}

	#slideIntro .swiper-wrapper.col4 .swiper-slide:nth-child(-n+3) {
		margin-top: 0;
	}

	#message .flex-item.left {
		padding: 8rem 0vw 6rem 0rem;
		margin-top: 6rem;
	}

	#message .flex-container.half>.flex-item.left::before {
		height: 102rem;
	}


	#feature .flex-container.half {
		padding-bottom: 30vw;
		margin-top: 10rem;
	}

	#trial .flex-container.half {
		padding-bottom: 34vw;
	}

	#menu .text {
		line-height: 2.2;
	}

}

/* ====================================
	1500px以上専用スタイル
===================================== */
@media screen and (min-width: 1500px) {
	#feature .flex-container.half {
		padding-bottom: 44rem;
		margin-top: 12rem;
	}

	#trial .flex-container.half {
		padding-bottom: 51rem;
	}
}

/* ====================================
	IE
===================================== */
@media all and (-ms-high-contrast: none),
(-ms-high-contrast: active) {}