@charset "UTF-8";

article {
	overflow: hidden;
}

.bdr-box {
	padding: 0.5em;
	color: #000;
	border: solid 1px #000;
	text-align: center;
}

.bdr-box .l-text {
	text-align: left;
	display: inline-block;
}


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

.main-title .small-text {
	font-size: 1.6rem;
	font-weight: 500;
}

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

.img-text {
	font-size: 1.5rem;
}

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

.medium-bold {
	font-weight: 500;
}

.merit-num {
	background-color: #000;
	padding: .1em 1.4em;
	color: #fff;
}

/* リンクリスト */
ul.list-links li a {
	display: block;
}

/* コラム */
.column .title-box {
	text-align: center;
}

.column {
	content: '';
	display: block;
	width: 100%;
	background: #f5f5f5;
	top: 0;
	left: 0;
	position: relative;
}

.column .column-icon {
	font-weight: 700;
	color: #fff;
	background-color: #000;
	border-radius: 50px;
	display: inline-block;
	position: absolute;
	left: 50%;
	transform: translate(-50%, 0);
}

.column .title-box {
	padding-bottom: 0.4rem;
	margin-left: auto;
	margin-right: auto;
}

.column .column-title {
	font-weight: 700;
	line-height: 2.2;
	border-bottom: 2px dotted #000;
	padding-bottom: 3px;
}

.fig-caption-bottom figcaption {
	font-size: 1.2rem;
	font-weight: 300;
	text-align: left;
}

.fig-caption-bottom .min-h {
	min-height: 3.6rem;
}

.btn-arrow {
	max-width: 336px;
	margin: 8rem auto 0;
	display: block;
}

/*  コントロール */
.fig-caption-bottom {
	width: 100%;
	margin: 0 auto;
}

.bg-title {
	font-weight: 500;
	color: #fff;
	border-radius: 3px;
	text-align: center;
	margin-bottom: .5rem;
	padding: 3px 4px;
}

.bg-title.bg-green {
	background-color: #61C1BD;
}

.bg-title.bg-yellow {
	background-color: #D8AE61;
}

.bg-title.bg-pink {
	background-color: #DF7758;
}

.bg-title.bg-red {
	background-color: #E73428;
}

.slider-next.swiper-button-disabled,
.slider-prev.swiper-button-disabled {
	opacity: 0;
	cursor: auto;
	pointer-events: none;
}

.aburi .text-box {
	/* display: flex;
	align-items: flex-start; */
	display: table;
	font-size: 1.4rem;
}

.aburi .text {
	display: table-cell;
	padding-left: 1rem;
}

.aburi .title {
	border: 1px solid #535353;
	padding: .4px 0;
	/* margin-right: 1rem; */
	width: 12rem;
	text-align: center;
	font-weight: 500;
}

/* arrow */
.slider-next,
.slider-prev {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 8.4%;
	display: inline-block;
	left: 4em;
	height: 76px;
	margin-top: .4%;
	z-index: 2;
	cursor: pointer;
	background-size: 100% auto;
	background-position: center;
	background-repeat: no-repeat;
	/* opacity: 0.8; */
}

.slider-prev {
	background-image: url(images/chevron-left-solid.svg);
	left: -3%;
	right: auto
}

.slider-next {
	background-image: url(images/chevron-right-solid.svg);
	right: -3%;
	left: auto
}


/* ====================================
	プラグイン・アニメーション設定
 ==================================== */

/* 水で焼く */
.cap-text {
	text-align: right;
	font-size: 1.2rem;
}

ul.list-kinou .ttl {
	font-weight: 500;
}

ul.list-kinou .text {
	margin-top: 0.25em;
}

.kazari-num {
	display: inline-block;
	width: 1.5em;
	margin-right: 0.5em;
	background: #e60012;
	color: #fff;
	font-size: 0.8em;
	text-align: center;
	border-radius: 0.5rem;
	background: #e60012;
}



/* 動画サムネイル */
.movie-container .flex-movie-item.thumb-technology {
	background-image: url(images/bnr-technology.jpg);
}

/* 個別指定 */


/* ====================================
	スマートフォン専用スタイル
===================================== */
@media only screen and (max-width: 767px) {
	.main-title .small-text {
		font-size: 1.2rem;
		position: relative;
		margin-top: .1rem;
		font-weight: 500;
	}

	/* 画像タイトル */
	.img-sub-title {
		font-size: 1.5rem;
		margin-top: 3rem;
	}

	.img-sub-title+.flex-container .img-container {
		margin-top: .5em;
	}

	/* コラム */
	.column-outer {
		margin-left: 5%;
		margin-right: 5%;
	}

	.column {
		margin-top: 8rem;
		padding: 12% 8% 10%;
	}

	.column .column-icon {
		font-size: 1.4rem;
		top: -18px;
		padding: 0.4em 2.4em;
	}

	.column .title-box {
		padding-bottom: 0.4rem;
	}

	.column .column-title {
		font-size: 1.6rem;
		margin-top: 2rem;
	}

	.column .column-text {
		font-size: 1.5rem;
	}

	.column .flex-container>.flex-item .right {
		width: 100%;
		margin-top: 3rem;
	}


	/* 水で焼く */
	ul.list-kinou {
		margin-top: 2rem;
	}

	ul.list-kinou li:not(:first-child) {
		margin-top: 1em;
	}

	ul.list-kinou .text {
		font-size: 1.4rem;
	}

	.btn-wrap {
		margin-top: 3rem;
	}

	#sub01 .flex-col3 .img-container {
		margin-top: 1rem;
	}
	#sub01 .flex-col3.img-container {
		margin-top: 0;
	}
	#sub01 .flex-container.flex-col3>.flex-item {
		margin-top: 4rem;
	}

	#sub01 .btn-arrow {
		margin-top: 4rem;
	}
	#sub01  .flex-col3 .merit-ttl{
		font-size: 1.6rem;
	}
	#sub04 .sub-sub-title {
		margin-top: 0;
	}
	/*  コントロール */
	.bg-title {
		font-size: 1.2rem;
		line-height: 1.4;
	}
	.aburi .text-box {
		font-size: 1.3rem;
	}

	.aburi .text {
		flex: 1;
	}

	.aburi .title {
		border: 1px solid #535353;
		padding: .4px 0;
		display: block;
		width: 10rem;
		text-align: center;
		font-weight: 500;
	}

	/* arrow */
	.slider-prev {
		left: -5.8%;
	}

	.slider-next {
		right: -5.8%;
	}

	.slider-next,
	.slider-prev {
		width: 12%;
		height: 60px;
	}

	.fig-caption-bottom {
		width: 100%;
	}
}

/* ====================================
	567px以下専用スタイル
===================================== */
@media only screen and (max-width: 567px) {

	/* arrow */
	.slider-prev {
		left: -7.2%;
	}

	.slider-next {
		right: -7.2%;
	}

	.slider-next,
	.slider-prev {
		width: 15%;
		height: 52px;
		margin-top: -2%;
	}

	.sub-sub-title.adj {
		margin-top: 5rem;
	}

	/*  コントロール */
	.bg-title {
		font-size: 1.15rem;
	}

}

/* ====================================
	PC&タブレット、印刷専用スタイル
===================================== */
@media print,
screen and (min-width: 768px) {

	/* メインビジュアル */
	.category-section+.main-visual.has-small-text {
		margin-top: 2rem;
	}

	/* 画像タイトル */
	.img-sub-title {
		font-size: 1.6rem;
		margin-top: 4rem;
	}

	.img-sub-title+.flex-container .img-container {
		margin-top: .5em;
	}

	/* コラム */
	.column {
		margin-top: 11rem;
		padding: 3em 3em 3em;
	}

	.column .column-icon {
		font-size: 1.6rem;
		top: -18px;
		padding: 0.4em 2.5em;
	}


	.column .column-title {
		font-size: 2rem;
		margin-top: 2rem;
		padding-bottom: 4px;
	}

	.column .text-container,
	.column .img-container {
		margin-top: 3rem;
	}

	.column .flex-container .flex-item.left {
		width: 56%;
	}

	.column .flex-container .flex-item.right {
		width: 40%;
		margin-left: 4%;
	}
/* チェック */
.check {
	margin-top: 6rem;
	padding: 3em 3em 2em;
}

.check .check-icon {
	font-size: 1.6rem;
	top: -3.5%;
	padding: 0.4em 2.5em;
}

.check .check-title {
	font-size: 2rem;
	margin-top: 2rem;
}

.check .text-container,
.check .img-container {
	margin-top: 3rem;
}

.check .flex-container .flex-item.right {
	width: 56%;
	margin-left: 4%;
}

.check .flex-container .flex-item.left {
	width: 40%;

}

/* 健康効果 */
.kenkou .flex-item {
	margin-top: 3rem;
}

.kenkou .flex-item:nth-of-type(-n+2) {
	margin-top: 0;
}
	/* 健康効果 */
	.kenkou .flex-item {
		margin-top: 3rem;
	}

	.kenkou .flex-item:nth-of-type(-n+2) {
		margin-top: 0;
	}

	/* arrow */
	.slider-prev {
		left: -1%;
	}

	.slider-next {
		right: -1%;
	}


	/*  コントロール */

	.bg-title {
		font-size: min(1.8vw, 17px);
	}
	ul.list-figures.col4 li {
		width: 24.2%;
		margin-left: 1%;
	}
	/* arrow */
	.slider-prev {
		left: -2%;
	}

	.slider-next {
		right: -2%;
	}
	/* 水で焼く */
	ul.list-kinou li:not(:first-child) {
		margin-top: 2.5rem;
	}

	ul.list-kinou .text {
		font-size: 1.4rem;
	}

	/* 動画を見るボタン */
	.btn-wrap {
		margin-top: 8rem;
		max-width: 460px;
	}

	/* 個別スタイル */
	#sub01 .sub-title+.text-container+.sub-sub-item{
		padding-top: 5rem;
	}
		
	#sub01 .flex-col3 .img-container{
		margin-top: 2rem;
	}
	#sub01  .flex-col3 .img-text{
		margin-top: 1rem;
		font-size: 1.5rem;
	}
	#sub01  .flex-col3 .merit-ttl{
		font-size: 1.8rem;
	}

}