/* ==================================================
	base
================================================== */

/* ----------------------------------------
	p
---------------------------------------- */
.main_content div + p,
.main_content ul + p,
.main_content ol + p,
.main_content img + p {
	margin-top: 1em;
}

.main_content * + .button,
.main_content * + [class*="c-button-"] {
	margin-top: 20px;
}
.main_content .list_basic > li {
	line-height: inherit;
}
.main_content .list_basic > li::before {
	top: 0;
}



/* ==================================================
	common
================================================== */

/* ----------------------------------------
	color
---------------------------------------- */
:root {
	--color1: #f2ebdc;
	--color2: #e6dcc8;
	--color3: #7f7f7f;
}

.bg1 { background-color: var(--color1) !important;}
.bg2 { background-color: var(--color2) !important;}
.bg3 { background-color: var(--color3) !important;}

.bg_e6e6e6 { background-color: #e6e6e6 !important; }
.bg_f4f4F4 { background-color: #f4f4F4; }

.bol_color60_s {
    border-left: 1px solid var(--color60);
}

.fc_color100 {
	color: var(--color100)
}


/* ----------------------------------------
	a
---------------------------------------- */

a.line {
	color: inherit;
	text-decoration: underline;
}
a.line:hover {
	text-decoration: none;
}


/* ----------------------------------------
	cont_wrap
---------------------------------------- */

.cont_wrap {
	padding: 40px 20px;
}
.cont_wrap.padding_ss {
	padding-top: 20px;
	padding-bottom: 20px;
}
.cont_wrap.padding_s {
	padding-top: 30px;
	padding-bottom: 30px;
}
.cont_wrap.padding_m {
	padding-top: 40px;
	padding-bottom: 40px;
}

@media screen and (min-width: 768px) {
	.cont_wrap {
		padding: 60px 30px;
	}
}


/* ----------------------------------------
	title_line
---------------------------------------- */

.title_line {
	padding: 20px 10px;
	border-bottom: 1px solid #000;
}

@media screen and (min-width: 768px) {
	.title_line {
		padding: 30px 10px;
	}
}

.title {
    padding: 25px 20px;
    border-bottom: 1px solid #000;
}

@media screen and (min-width: 768px) {
    .title {
        padding-right: 30px;
        padding-left: 30px;
    }
}



/* ==================================================
	main
================================================== */

.main {
	color: var(--color1);
	background: var(--color3);
}
@media screen and (min-width: 1024px) {
    .main .x4l {
        font-size: 130px;
        line-height: 160px;
    }
}
.main .text_area {
	top: 0;
	left: 0;
	width: 100%;
}
.main .title,
.main .subtitle,
.main .inner {
	padding: 15px 20px;
}
.main .title {
	background: var(--color3);
	border-bottom: solid 1px var(--color1);
}
.main .subtitle {
	background: var(--color3);
}


@media screen and (min-width: 768px) {
	.main .title,
	.main .subtitle {
		padding-right: 30px;
		padding-left: 30px;
	}
}



/* ==================================================
	main_under
================================================== */

.main_under {
	display: flex;
	flex-direction: column;
	color: #000;
}
.main_under .title {
	padding: 25px 20px;
	background: var(--color2);
}
.main_under .subtitle {
	background: var(--color2);
}
.main_under .title .inner,
.main_under .subtitle .inner {
	padding: 15px 20px;
}
.main_under .text .inner {
	padding: 30px 20px 50px;
}
.main_under .img_area img {
	object-fit: cover;
	width: 100%;
	height: auto;
}



@media screen and (min-width: 768px) {
	.main_under .text_area .inner {
		padding-right: 30px;
		padding-left: 30px;
	}
}

@media screen and (min-width: 768px) and (max-width: 1279px) {
	.main_under .img_area img {
		height: 520px;
	}
}

@media screen and (min-width: 1280px) {
	.main_under {
		flex-direction: row;
		min-height: 600px;
	}
	.main_under .text_area {
		width: calc(50% - 193px);
	}
	.main_under .text_area .inner {
		max-width: calc(416px + 30px);
		margin-left: auto;
	}
	.main_under .img_area {
		width: calc(50% + 193px);
	}
	.main_under .img_area img {
		max-width: 1920px;
		height: 100%;
	}
}

@media screen and (min-width: 1920px) {
	.main_under .text_area {
		width: calc(50% - 93px);
	}
	.main_under .text_area .inner {
		max-width: calc(516px + 30px);
	}
	.main_under .img_area {
		width: calc(50% + 93px);
	}
}


/* ----------------------------------------
	benefits swiper
---------------------------------------- */
.benefits .swiper {
	overflow: visible;
	position: relative;
	padding: 47px 20px 40px;
}
.benefits .swiper-slide {
	width: 300px;
	margin-right: 20px;
}
.benefits .swiper-slide:last-child {
	margin-right: 0;
}

@media screen and (min-width: 768px) {
	.benefits .swiper {
		padding-right: 30px;
		padding-left: 30px;
	}
	.benefits .swiper-slide {
		width: 429px;
		margin-right: 30px;
	}
}

@media screen and (min-width: 1280px) {
	.benefits .swiper {
		padding: 47px 0 0;
	}
	.benefits .swiper-slide {
		width: 490px;
	}
}


/* controller -------------------- */

.benefits .swiper-controller {
	display: flex;
	position: absolute;
	top: 0;
	right: 0;
}
.benefits .swiper-button-prev,
.benefits .swiper-button-next {
	position: relative;
	cursor: pointer;
	transition: .2s;
	width: 30px;
	height: 30px;
	margin-right: 20px;
}
.benefits .swiper-button-prev:hover,
.benefits .swiper-button-next:hover {
	background: #000;
}
.benefits .swiper-button-prev::before,
.benefits .swiper-button-next::before {
	content: "";
	position: absolute;
	top: -7px;
	left: -7px;
	transition: .2s;
	width: 44px;
	height: 44px;
	background-image: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 30 30"><path d="M0,0v30h30V0H0ZM29,29H1V1h28v28Z"/><polygon points="16.09 20.11 16.8 20.82 22.6 15.02 16.75 9.18 16.05 9.89 20.69 14.53 8.03 14.53 8.03 15.53 20.67 15.53 16.09 20.11"/></svg>');
	background-repeat: no-repeat;
	background-position: center center;
	background-size: 30px 30px;
}
.benefits .swiper-button-prev:hover::before,
.benefits .swiper-button-next:hover::before {
	background-image: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 30 30"><polygon points="16.09 20.11 16.8 20.82 22.6 15.02 16.75 9.18 16.05 9.89 20.69 14.53 8.03 14.53 8.03 15.53 20.67 15.53 16.09 20.11"/></svg>');
	filter: invert(1);
}
.benefits .swiper-button-prev::before,
.benefits .swiper-button-prev:hover::before {
	transform: rotate(180deg);
}
.benefits .swiper-button-disabled {
	opacity: .3;
	pointer-events: none;
}

@media screen and (min-width: 768px) {
	.benefits .swiper-controller {
		right: 10px;
	}
}

@media screen and (min-width: 1280px) {
	.benefits .swiper-controller {
		right: -20px;
	}
}

@media screen and (max-width:768px) {
	.benefits {
		overflow:hidden;
	}
}


/* pagination -------------------- */

.benefits .swiper-pagination {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	text-align: center;
	line-height: 1;
}
.benefits .swiper-pagination-bullet {
	display: inline-block;
	cursor: pointer;
	width: 9px;
	height: 9px;
	margin: 0 4px;
	background-color: rgba(0,0,0,.2);
	background-clip: padding-box;
	border: 2px solid transparent;
	border-radius: 20px;
}
.benefits .swiper-pagination-bullet-active {
	width: 60px;
	background-color: #000;
}

@media screen and (min-width: 1280px) {
	.benefits .swiper-pagination {
		display: none;
	}
}


/* スライダー非活性時 -------------------- */

.benefits .swiper:not(.swiper-initialized) .swiper-controller {
	display: none;
}
.benefits .swiper:not(.swiper-initialized) .swiper-wrapper {
	margin: 0;
}



/* ==================================================
	access
================================================== */
@media screen and (max-width:767px) {
	.col1 li:nth-of-type(n+2) {
		margin-top: 40px !important;
	}
}



/* ==================================================
	product title
================================================== */

.product .title {
	padding: 25px 20px;
	border-bottom: 1px solid #000;
}

@media screen and (min-width: 768px) {
	.product .title {
		padding-right: 30px;
		padding-left: 30px;
	}
}



/* ==================================================
	guidance
================================================== */
.guidance .swiper-slide {
	border-right: dotted 1px var(--color50);
	padding-right: 50px;
}
.guidance .swiper-slide:nth-of-type(5) {
	border-right: none;
}
@media screen and (max-width:767px) {
	.guidance .swiper-slide {
		border-top: dotted 1px var(--color50);
	}
	.guidance .swiper-slide:nth-of-type(5) {
		border-right: none;
	}
}