@charset "UTF-8";

/*============================
Reset
============================*/
/* http://meyerweb.com/eric/tools/css/reset/
v2.0 | 20110126
License: none (public domain)
*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}

body {
	line-height: 1;
	overflow-x: hidden;
	background-color: #f5f5f5;
}

ol, ul {
	list-style: none;
}

blockquote, q {
	quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}


.lp-wrapper {
	width: 100%;
	margin: 0 auto;
}

.lp-wrapper .p-box {
	position: relative;
}

.lp-wrapper picture,
.lp-wrapper img {
	display: block;
	width: 100%;
	height: auto;
	/* vertical-align: bottom; */
}

.lp-inner {
	max-width: 750px;
	width: 100%;
	margin: 0 auto;
	background-color: #fff;
	box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
}

.lp-inner a {
	opacity: 1;
	transition: opacity 0.4s ease-in-out;
}

.lp-inner a:hover {
	opacity: 0.4;
}

/* offer */

.lp-inner .btn-offer {
	width: calc(675/750*100%);
	margin: 0 auto;
}

.lp-inner .btn-offer {
	width: calc(700/750*100%);
	margin: 8% auto 6%;
	position: relative;
	/* top:0; */
}

.lp-inner .offer-fv .btn-offer {
	width: calc(675/750*100%);
	margin: 1.5% auto 4%;
}

/* font-weight */
.fw-extrabold {
	font-weight: var(--fw-extrabold);
}
.fw-bold {
	font-weight: var(--fw-bold);
}
.fw-normal {
	font-weight: var(--fw-normal);
}


/* slider */

.lp-inner .slider-wrap {
	background-image: url(../img/intro-bg.png);
	background-size: cover;
	padding-bottom: 5%;
}

.lp-inner .slick-list {
	padding: 0 !important;
}

.lp-inner .slider-inner {
	padding: 0 calc(45/750*100%);
}

.lp-inner .slick-list img {
	width: 100%;
}

.lp-inner .slick-next,
.lp-inner .slick-prev {
	width: calc(75/750*100%);
	padding-top: min(calc(100/750*100vw), 100px);
	font-size: 0;
	background-size: contain;
	background-repeat: no-repeat;
	z-index: 10;
	top: 52%;
}

.lp-inner .slick-next {
	background-image: url(../img/slide-next.png);
	/* right: min(calc(-40/750*100vw), 40px); */
}

.lp-inner .slick-prev {
	background-image: url(../img/slide-prev.png);
	/* left: min(calc(-40/750*100vw), 40px); */
}

.lp-inner .slick-next:before,
.lp-inner .slick-prev:before {
	font-size: 0;
}

.lp-inner .slick-arrow {
	transition: opacity ease 0.3s;
}

.lp-inner .slick-arrow.slick-disabled {
	opacity: 0;
}

.lp-inner .slick-dots {
	bottom: -50px;
}

@media (max-width:750px) {
	.lp-inner .slick-dots {
		bottom: -5%;
	}
}

.slick-dots li button {
	width: min(calc(20/750*100vw), 20px);
	height: min(calc(20/750*100vw), 20px);
}

.slick-dots li button:before {
	opacity: 1;
	color: #dcf2ff;
}

.slick-dots li button:before {
	font-size: min(calc(30/750*100vw), 30px);
}

.slick-dots li.slick-active button:before {
	opacity: 1;
	color: #499cc3;
}

.slick-dots li {
	margin: 0 2.5%;
}

.slick-dotted.slick-slider {
	padding-bottom: 20px;
}

.risk {
	padding-bottom: 70px;
}


/* point */
.lp-inner .p-box {
	position: relative;
}

footer {
	background-color: #1C4986;
	padding: 3% 0;
	text-align: center;
	height: 100px;
}

footer p {
	color: #FFF;
	font-size: min(calc(20/750*100vw), 20px);
}

/* ---------------------------------------------
 追従エリア
--------------------------------------------- */
.fixd-container {
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	max-width: 750px;
	margin: auto;
	visibility: hidden;
	opacity: 0;
	transition: visibility .4s, opacity .4s;
	z-index: 10000;
}

.fixd-inner {
	position: relative;
	width: 100%;
	margin: 0 auto;
	background-color: rgba(255, 255, 255, 0.8);
}

.fixd-inner .btn-offer {
	margin-bottom: 0;
}

.fixd-inner .fixed-btnarea {
	display: flex;
	justify-content: space-between;
	flex-wrap: nowrap;
	width: 89.3%;
	margin: 0 auto;
	padding: 0 0 3%;
}

.fixd-inner .fixed-btnarea .btn-fixed {
	width: 47%;
}

.fixd-container.is-show {
	visibility: visible;
	opacity: 1;
}

/* ---------------------------------------------
 240327追加
--------------------------------------------- */
img.spB20 {
	margin: 20px auto;
}

img.spB30 {
	margin-bottom: 30px;
}

h2.spB30 {
	margin-bottom: 30px;
}

img.spT30 {
	margin-top: 30px;
}

.spT30 {
	margin-top: 30px;
}

.spT40 {
	margin-top: 40px;
}

.spT50 {
	margin-top: 50px;
}

html {
	max-width: 600px;
	margin: 0 auto;
	scroll-behavior: smooth;
}

p.txt_box {
	width: 90%;
	margin: 20px auto 30px;
	color: #151818;
	font-size: 24px;
	font-weight: 400;
	line-height: 1.7;
	font-family: var(--font-base);
}

p.txt_box03 {
	width: 87%;
	margin: 20px auto 40px;
	color: #151818;
	font-size: 17px;
	font-weight: 400;
	line-height: 1.6;
	font-family: var(--font-base);
}

@media (max-width:600px) {
	p.txt_box {
		width: 87%;
		margin: 20px auto;
		color: #151818;
		font-size: 17px;
		font-weight: 400;
		line-height: 1.9;
	}

	p.txt_box03 {
		width: 87%;
		margin: 20px auto;
		color: #151818;
		font-size: 17px;
		font-weight: 400;
		line-height: 1.6;
		font-family: var(--font-base);
	}
}

p.txt_box span {
	color: #0876c0;
	font-weight: 600;
}

@media (max-width:600px) {
	.lp-inner .map-wrap {
		position: absolute;
		width: min(calc(600/750*100vw), 600px);
		padding-top: min(calc(340/750*100vw), 330px);
		top: 13%;
		left: 50%;
		transform: translateX(-50%);
	}
}

sup {
	font-size: .6em;
	vertical-align: super;
}


/* ---------------------------------------------
 240328　FAQアコーディオン
--------------------------------------------- */
.lp-inner .clinic-box {
	width: 89.3%;
	margin: 0 auto 3%;
	border-left: #8D8D8D solid 3px;
	border-right: #8D8D8D solid 3px;
	border-bottom: #8D8D8D solid 3px;
}

.clinic-box .is-open {
	padding: 16px;
}

.lp-inner .clinic-box dt {
	position: relative;
	width: 100%;
	cursor: pointer;
}

.lp-inner .clinic-box dt::before {
	content: '';
	position: absolute;
	top: 52%;
	right: 3.5%;
	width: min(calc(21/750*100vw), 21px);
	height: 2px;
	transition: rotate(0deg);
	background: #ffffff;
	z-index: 2;
}

.lp-inner .clinic-box:nth-of-type(5) dt::before {
	top: 42%;
}

.lp-inner .clinic-box dt::after {
	content: '';
	position: absolute;
	top: 52%;
	right: 3.5%;
	width: min(calc(21/750*100vw), 21px);
	height: 2px;
	transform: rotate(90deg);
	background: #ffffff;
	transition: transform 0.4s ease-in-out;
	z-index: 2;
}

.lp-inner .clinic-box:nth-of-type(5) dt::after {
	top: 42%;
}

.lp-inner .clinic-box:nth-of-type(4) dt::before {
	top: 42%;
}

.lp-inner .clinic-box:nth-of-type(4) dt::after {
	top: 42%;
}

.lp-inner .clinic-box dt.clicked::after {
	transform: rotate(0deg);
}

.lp-inner .clinic-box dd {
	width: 90%;
	margin: 0 auto;
	line-height: 0;
	height: 0;
	overflow: hidden;
	opacity: 0;
	transition: all ease 0.4s;

}

.lp-inner .clinic-box dd.is-open {
	height: auto;
	opacity: 1;

}

.lp-inner .clinic-box dt.faq-btn p {
	background-color: #8D8D8D;
	color: #fff;
	font-size: 18px;
	padding: 15px;
}

@media (max-width: 600px) {
	.lp-inner dd p.map-wrap2 {
		position: absolute;
		width: min(calc(600 / 750* 100vw), 600px);
		padding-top: min(calc(340 / 750* 100vw), 330px);
		top: 13%;
		left: 50%;
		transform: translateX(-50%);
	}
}

/* ---------------------------------------------
 240329　追加
--------------------------------------------- */

section.txt_box02 {
	background-image: url(../img/bg_14-16.png);
	/* margin: 0 auto ; */
	padding: 0 30px 55px;

}

section.txt_box02 p {
	width: 100%;
	text-align: left;
}

img.camsp {
	width: 90%;
	margin: 7% auto 10%;
}

.movie video {
	width: 100%;
}




/* ---------------------------------------------
 240409追加
--------------------------------------------- */

.txt-g {
	font-family: var(--font-base);
	font-optical-sizing: auto;
}

.txt-m {
	font-family: var(--font-serif);
}

.case-wrap {
	background-color: #e5f5ff;
	padding: 1em;
}

.swiper-p {
	margin-top: .8em;
	line-height: 1.4em;
	color: #262626;
	font-family: var(--font-base);
}

.swiper-p span {
	color: #0876c0;
}

.fukidashi {
	position: relative;
	padding: 10px;
	border-radius: 10px;
	border: 1px solid #c63390;
	background-color: #fff;
	color: #c63390;
	font-weight: 600;
	font-size: 16px;
	margin: 10px 10px 20px;
}

.fukidashi:before {
	position: absolute;
	top: 100%;
	right: 50px;
	transform: skew(-25deg);
	height: 25px;
	width: 15px;
	border-right: 1px solid #c63390;
	background-color: #fff;
	content: "";
}

.fukidashi p {
	line-height: 1.5;
	color: #c63390;
}

.strong {
	color: #c63390;
	text-decoration: underline 8px;
	text-decoration-color: yellow;
}

.stfaction h2 {
	text-align: center;
	font-size: 1.8rem;
	line-height: 1.2em;
	font-weight: 500;
}

.review {
	background-color: #ebf7ff;
	margin: 1.5em;
	padding: .8em;
	font-size: .7em;
	line-height: 1.5em;
	color: #555555;
	font-family:var(--font-base);
}

.review span {
	color: #c63390;
}

.review02 {
	background-color: #fcedf7;
	padding: 1.2em 1.8em;
	font-size: .7em;
	line-height: 1.5em;
	color: #555555;
	font-family:var(--font-base);
}

.review02 span {
	color: #c63390;
}

.horizontal-line {
	border-top: 1px solid #dce2e6;
	margin: 10px 0;
}

.cta-wrap.cta-wrap__price {
	position: relative;
	background: url('../img/benefit-top-back.webp') no-repeat center center / 100% 100%;
	aspect-ratio: 1542 / 2214;
	padding: 20px 0;
}

.cta-wrap {
	position: relative;
	background: url('../img/benefit-back.webp') no-repeat center center / 100% 100%;
	aspect-ratio: 1542 / 1622;
	padding: 20px 0;
}

.cta-wrap-m {
	/* position: absolute;*/
	/* top: 0;*/
	/* z-index: 1000;*/
	display: flex;
	width: 100%;
	margin-top: 1em;
	justify-content: space-around;
	align-items: flex-start;
}

.clinic-price {
	position: absolute;
	bottom: 62px;
	text-align: center;
	width: 100%;
}

.horizontal-line2 {
	border-top: 1px dotted #FFF;
	margin: 10px;
}

.cta-button {
	position: absolute;
	bottom: -55px;
}

@media (max-width:375px) {
	.cta-button-top {
		bottom: -40px;
	}
}

.explan2 {
	padding: 70px 0 0;
}

.explan2-m, .intro-m, .faq-m, .clinic-m {
	background-image: linear-gradient(160deg, #0f9fde 0%, #0b82c9 100%);
}

.explan2-m h2, .intro-m h2, .faq-m h2, .clinic-m h2 {
	font-size: 7.5vw;
	text-align: center;
	color: #FFF;
	padding: 50px 0;
}

h3.txt-m-cause.txt-m {
	font-size: 1.8em;
	color: #162853;
	border-left: solid 6px #162853;
	padding-left: .4em;
	margin: 2em 0 0 1em;
	font-weight: 500;
}

.explan2-txt {
	text-align: center;
	color: #162853;
	font-size: 1.2em;
	line-height: 1.5em;
	margin-top: 1em;
}

.figure01-wrap, .root-wrap, .quality-wrap {
	padding: 1em 2em;
}

.explan2 div.figure01-wrap {
	padding: 1em 2em;
}


.explan2-txt2 {
	text-align: center;
	color: #162853;
	font-size: 1.8em;
	margin-bottom: 1em;
}

/* 吹き出し本体 - 左右の中心 */
.balloon1 {
	position: relative;
	padding: 2em 0;
	background-color: #d7e9f5;
}

/* 三角アイコン - 左右の中心 */
.balloon1::before {
	content: '';
	position: absolute;
	display: block;
	width: 0;
	height: 0;
	left: 0;
	right: 0;
	bottom: -15px;
	margin: 0 auto;
	border-top: 15px solid #d7e9f5;
	border-right: 15px solid transparent;
	border-left: 15px solid transparent;
}

.balloon1 h3 {
	color: #0876c0;
	font-weight: 600;
	font-size: 1.35em;
	text-align: center;
}

.bg-text {
	position: relative;
}

.bg-text p {
	text-align: center;
	font-weight: 600;
	font-size: 2.3em;
	color: #162853;
	z-index: 1000;
	line-height: 1.5em;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 100%;
}

#campaign {
	margin-top: 70px;
}

.logo img {
	width: 120px;
	margin: 0.5em auto;
}

h1 span {
	color: #000;
}

@media (max-width: 600px) {
	.clinic-name {
		position: absolute;
		/* bottom: 65px;*/
		color: #FFF;
		text-align: center;
		width: 100%;
		font-size: 0.75rem;
		line-height: 0.5;
	}

	.clinic-price {
		position: absolute;
		bottom: 62px;
		text-align: center;
		width: 100%;
	}

}

/* SP */
@media screen and (min-width: 640px) {
	.fukidashi {
		font-size: 1.5rem;
	}

	.stfaction h2 {
		font-size: 2.1rem;
		line-height: 1.5em;
	}

	.review {
		font-size: 1.1em;
		font-family:var(--font-base);
	}

	.review02 {
		font-size: 1.1em;
		font-family:var(--font-base);
	}
	.fv-p-wrap p {
		font-size: 20px;
	}
	.explan2-m h2, .intro-m h2, .faq-m h2, .clinic-m h2 {
		font-size: 2em;
	}
	.clinic-price {
		bottom: 125px;
	}
}


/* btn animation */
.mocchiri {
	animation: mocchiri 3s infinite;
}

@keyframes mocchiri {
	0% {
		transform: scale(0.9);
		-webkit-transform: scale(0.9);
	}

	50% {
		transform: scale(1);
		-webkit-transform: scale(1);
	}
}


/* ---------------------------------------------
 240416追加
--------------------------------------------- */

p.price-left.txt-g {
	font-size: 2.4vw;
	font-weight: 600;
	background-color: #0981ca;
	color: #FFF;
	padding: 1em;
	line-height: 1.2em;
}

p.price-right.txt-g {
	color: #0981ca;
}

span.price-right-p {
	font-size: 2.8vw;
	color: #162853;
}

.price-p {
	font-size: 3.0em;
	font-weight: 700;
}


@media screen and (min-width: 600px) {
	.sp-only {
		display: none;
	}

	.pc-only {
		display: block;
	}

	.price-p {
		font-size: 4.5em;
	}

	p.price-left.txt-g {
		font-size: 1em;
	}

	span.price-right-p {
		font-size: 1.2rem;
	}

}

@media screen and (max-width: 599px) {
	.sp-only {
		display: block;
	}

	.pc-only {
		display: none;
	}

}


/* ---------------------------------------------
 240422追加
--------------------------------------------- */


.dr-tnm {
	background-image: linear-gradient(rgb(255, 255, 255) 0%, rgb(221, 219, 215) 100%);
	position: relative;
	padding: 1.5em;
}

.dr-tnm-m1 {
	color: #5e849b;
	margin-bottom: 0.75em;
}

.dr-tnm-img {
	position: absolute;
	width: 50%;
	right: 0;
	top: -1em;
}

.dr-tnm-m2 {
	font-size: 1.4em;
	color: #162853;
	line-height: 1.35em;
	font-weight: 500;
}

.dr-tnm-name {
	font-size: x-small;
	color: #343434;
	line-height: 1.5em;
	margin: 1em 0;
}

.txt-g.dr-tnm-txt {
	position: relative;
	background-color: #FFF;
	padding: 1em;
	line-height: 1.8em;
	font-size: .8em;
	color: #555555;
	box-shadow: 0px 2px 8px 0px rgba(0, 0, 0, 0.15);
}

.supplement h3 {
	color: #162853;
	background-color: #dfecf1;
	padding: 10px 0;
	font-family: var(--font-serif);
	font-size: 1.5em;
	text-align: center;
	margin: 30px 0 20px 0;
	font-weight: 600;
}

.supplement .arrow_box {
	position: relative;
	width: 250px;
	background: #097cc4;
	text-align: center;
	border: 5px solid #097cc4;
	color: #FFFFFF;
	font-size: 13px;
	border-radius: 40px;
	-webkit-border-radius: 40px;
	font-family: var(--font-serif);
	font-weight: 500;
	margin: 0 auto;
}

.supplement .arrow_box:after, .arrow_box:before {
	border: solid transparent;
	content: '';
	height: 0;
	width: 0;
	pointer-events: none;
	position: absolute;
	top: 100%;
	left: 50%;
}

.supplement .arrow_box:after {
	border-color: rgba(0, 0, 255, 0);
	border-top-width: 10px;
	border-bottom-width: 10px;
	border-left-width: 10px;
	border-right-width: 10px;
	margin-left: -10px;
	border-top-color: #097cc4;
}

.supplement .arrow_box:before {
	border-color: rgba(0, 0, 255, 0);
	border-top-width: 10px;
	border-bottom-width: 10px;
	border-left-width: 10px;
	border-right-width: 10px;
	margin-left: -10px;
	margin-top: 5px;
	border-top-color: #097cc4;
}

.supplement h4 {
	color: #162853;
	padding: 10px 0;
	font-family:var(--font-serif);
	font-weight: 500;
	font-size: 1.7em;
	text-align: center;
	margin: 10px 0 10px 0;
}

.supplement img.raqnem_pk {
	width: 50%;
	margin: 0 auto;
	padding: 0 0 0 40px;
}

.supplement img.three_pt {
	width: 80%;
	margin: 0 auto;
}

.supplement p {
	font-size: 1.0em;
	margin: 0 auto;
	text-align: center;
	padding: 10px 0;
	line-height: normal;
}

.supplement .price_box {
	display: flex;
	font-family: var(--font-base);
	justify-content: center;
	align-items: center;
	padding: 20px 0 0 0;
}

.supplement .price_box .price_left {
	color: #fff;
	background-color: #f07931;
	padding: 5px 7px;
	font-size: 0.8em;
	text-align: center;
	margin: 0 10px 0 0;
	border-radius: 5px;
	line-height: normal;
}

.supplement .price_box .price_right {
	color: #f07931;
	padding: 5px 0;
	font-size: 2.5em;
	text-align: center;
	font-weight: 500;
}

.supplement .price_box .price_right span {
	font-size: 0.5em;
}

.supplement p.note {
	font-size: 1.0em;
	text-align: right;
	line-height: normal;
	padding: 0 10px 10px 0;
}

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

	.dr-tnm-m2 {
		font-size: 2.4em;
	}

	.dr-tnm-m1 {
		margin-bottom: 0.5em;
	}

	.dr-tnm-name {
		font-size: small;
	}

	.txt-g.dr-tnm-txt {
		width: 90%;
		margin: 0 auto;
	}


	.supplement h3 {
		padding: 10px 0;
		font-size: 1.9em;
		margin: 30px 0 20px 0;
	}

	.supplement .arrow_box {
		width: 300px;
		font-size: 15px;
	}

	.supplement img.raqnem_pk {
		width: 40%;
		margin: 0 auto;
		padding: 0 0 0 40px;
	}

	.supplement img.three_pt {
		width: 65%;
		margin: 0 auto;
	}

	.supplement h4 {
		padding: 20px 0;
		font-size: 2.0em;
	}

	.supplement .price_box {
		padding: 30px 0 0 0;
	}

	.supplement .price_box .price_left {
		padding: 5px 7px;
		font-size: 1.0em;
		margin: 0 15px 0 0;
	}

	.supplement .price_box .price_right {
		padding: 5px 0;
		font-size: 3.5em;
	}

	.supplement .price_box .price_right span {
		font-size: 0.5em;
	}

	.supplement p.note {
		font-size: 1.0em;
		text-align: right;
		line-height: normal;
		padding: 0 10px 10px 0;
	}

}

/* ---------------------------------------------
 クリニック紹介
--------------------------------------------- */

.clinic-intro-wrap {
	color: #162853;
	text-align: center;
	margin: 50px 0 40px;
}

.clinic-intro-wrap h2 {
	font-size: 1.6rem;
	background-color: #4C2312;
	color: #fff;
	padding: 15px 0;
	line-height: 1.9rem;
	margin: 10px 0;
	font-family: var(--font-base);
	font-weight: 600;
}

.swiper-p p.note {
	font-size: .5em;
	text-align: right;
}

.swiper-p p span {
	font-size: 0.5em;
	vertical-align: super;
}


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

	.clinic-intro-wrap {
		margin: 50px 0 20px;
	}

	.clinic-intro-wrap h2 {
		font-size: 1.3rem;
		padding: 15px 0;
		line-height: 1.7rem;
	}

	.swiper-p {
		margin-top: .8em;
		line-height: 1.4em;
		font-family: var(--font-base);
	}

	.swiper-p p span {
		font-size: 0.5em;
		vertical-align: super;
	}

	.swiper-p p.note {
		font-size: .5em;
		text-align: right;
	}

}


/* slider */

.clinic-intro .slider-wrap {
	padding-bottom: 8%;
}

.clinic-intro .slick-next,
.clinic-intro .slick-prev {
	width: calc(75/750*100%);
	padding-top: min(calc(100/750*100vw), 100px);
	font-size: 0;
	background-size: contain;
	background-repeat: no-repeat;
	z-index: 10;
	top: 52%;
}

.clinic-intro .slick-next {
	background-image: url(../img/slide-brown-next.webp);
	/* right: min(calc(-20/750*100vw), 40px); */
}

.clinic-intro .slick-prev {
	background-image: url(../img/slide-brown-prev.webp);
	/* left: min(calc(-20/750*100vw), 40px); */
}

.clinic-intro .slick-next:before,
.clinic-intro .slick-prev:before {
	font-size: 0;
}

.clinic-intro .slick-arrow {
	transition: opacity ease 0.3s;
}

.clinic-intro .slick-arrow.slick-disabled {
	opacity: 0;
}

.clinic-intro .slick-dots {
	bottom: -50px;
}

.slick-dotted.slick-slider {
	margin-bottom: 5px;
}

@media screen and (max-width: 768px) {
	.clinic-intro .slider-wrap {
		padding-bottom: 3%;
	}

	.clinic-intro .slick-dots {
		bottom: 0%;
	}

	.clinic-intro .slick-next {
		right: min(calc(-40/750*100vw), 40px);
	}

	.clinic-intro .slick-prev {
		left: min(calc(-40/750*100vw), 40px);
	}
}


.clinic-intro li button {
	width: min(calc(15/750*100vw), 15px);
	height: min(calc(15/750*100vw), 15px);
}

.clinic-intro li button:before {
	opacity: 1;
	color: #E4DCCA;
}

.clinic-intro li button:before {
	font-size: min(calc(20/750*100vw), 20px);
}

.clinic-intro li.slick-active button:before {
	opacity: 1;
	color: #4C2312;
}

.slick-dots li {
	margin: 0 2.0%;
}

.slick-dotted.slick-slider {
	padding-bottom: 20px;
}

.spB10 {
	margin-bottom: 10px;
}

@media screen and (max-width: 768px) {
	.slick-dots li {
		margin: 0 0.8%;
	}
}

/* 動画再生ボタン03 */
div.movie {
	position: relative;
	width: 100%;
	margin: 0 auto;
}

.movie video {
	width: 100%;
}

div.movie img.play-btn {
	display: block;
	width: 40%;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateY(-50%) translateX(-50%);
	-webkit-transform : translateY(-50%) translateX(-50%);
}

.movie .play-btn.playActive {
	display: none;
}

/* ---------------------------------------------
 250521追記
--------------------------------------------- */

.bg_blue {
	background-color: #E8F6FF;
}

div.change {
	width: 76%;
	margin: 0 auto;
	text-align: center;
	padding: 6%;
	background-color: #FFFFFF;
	border: 3px solid #71BBE8;
	font-size: 1.3em;
	line-height: 1.1;
	color: #0881CA;
	font-family: var(--font-serif);
	font-weight: 600;
}

.spB20 {
	margin-bottom: 20px;
}

/*//////////////////

トップキャンペーン 

//////////////////*/

.top-campaign {
	padding: 15% 0 0 0;
}

.top-campaign h2 {
	font-size: 2.5em;
	color: #162853;
	margin: 0 auto 5% auto;
	font-weight: 600;
	text-align: center;
	width: 90%;
	font-family: var(--font-serif);
}

.top-campaign img {
	width: 88%;
	padding: 2% 0 2% 0;
	margin: 0 auto;
}

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

	.top-campaign h2 {
		font-size: 1.8em;
	}

}

/* SP */
.cta-wrap-m h2 {
	color: #FFF;
	margin: auto 0;
	font-size: 1.9rem;
	line-height: 1.3em;
}

.cta-wrap-m img {
	width: 110px;
}

.cta-wrap-m {
	top: 10px;
}

ul.benefit-top {
	/* position: absolute; */
	padding: 1.5em;
	/* top: 135px; */
}

.clinic-name-top {
	/* position: absolute; */
	/* bottom: 225px; */
	color: #FFF;
	text-align: center;
	width: 100%;
	font-size: 0.75rem;
	line-height: 0.5;
}

.clinic-name-top.txt-g p {
	font-size: 14px;
}

.cta-button-top {
	position: absolute;
	bottom: -65px;
}

ul.benefit {
	/* position: absolute;*/
	padding: 1.7em;
	/* top: 150px;*/
}

.clinic-name {
	/* position: absolute;*/
	/* bottom: 70px;*/
	color: #FFF;
	text-align: center;
	width: 100%;
	font-size: 14px;
	line-height: 0.5;
}

.clinic-name.txt-g p {
	font-size: 14px;
}

/* PC */
@media screen and (min-width: 768px) {

	.flow {
		margin: 0 0 8% 0;
	}

	.cta-wrap-m h2 {
		font-size: 2.3em;
	}

	.cta-wrap-m img {
		width: 140px;
	}

	ul.benefit-top {
		top: 160px;
		padding: 2.7em;
	}

	.clinic-name-top {
		bottom: 340px;
		line-height: 1.0;
	}

	.clinic-name-top.txt-g p {
		font-size: 18px;
	}

	ul.benefit {
		top: 155px;
		padding: 2.7em 2.7em 1em;
	}

	.clinic-name {
		/* bottom: 125px;*/
		line-height: 1.0;
	}

	.clinic-name.txt-g p {
		font-size: 18px;
	}


	.cta-wrap-m {
		top: 20px;
	}

}

/* SE、mini以下 */
@media screen and (max-width: 375px) {

	.cta-wrap-m h2 {
		font-size: 1.4em;
	}

	.cta-wrap-m img {
		width: 85px;
	}



	.clinic-name-top {
		font-size: 0.6rem;
		bottom: 195px;
	}

	.cta-button-top {
		position: absolute;
		bottom: -40px;
	}

	ul.benefit {
		padding: 2.5ch;
		top: 103px;
	}

	.clinic-name {
		font-size: 0.6rem;
		/* bottom: 55px; */
	}

	ul.benefit-top {
		padding: 2.5ch;
		top: 100px;
	}

	.cta-wrap-m {
		top: 10px;
	}


}

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

.clinic-name {
    font-size: 0.53rem;
    /* bottom: 57px;*/
}
.clinic-name-top {
	font-size: 0.53rem;
    bottom: 198px;
}
.benefit-top li img,
.benefit li img
{
	width: 92%;
    margin: 0 auto;
}
}

/* ---------------------------------------------
 260312追記
--------------------------------------------- */

/* --- 共通・リセット補助 --- */
ul { list-style: none; padding: 0; margin: 0; }




/* --- Section 1: Check --- */
.section-check {
    background-color: #e8e9e8;
    padding: 20px 20px 45px;
    background-image: url('../img/section-check-back.webp');
    background-repeat: no-repeat;
    background-position: top right;
    background-size: 100% auto;
    position: relative;
    text-align: center;
    margin-top: 40px;
}

.check-title {
    font-size: 2.0rem;
    font-weight: 600;
    line-height: 1.2;
    margin-bottom: 36px;
    color: var(--main-color);
    font-family: var(--font-serif);
    text-align: center;
    margin-top: 15px;
}

.check-title span{
	font-size: 2.8rem;
}

.check-list {
	font-family: var(--font-base);
    background: #fff;
    /* width: 90%; */
    padding: 20px 22px 10px;
    text-align: left;
    display: inline-block;
    box-shadow: 5px 5px 0px rgba(0,0,0,0.1);
    border-radius: 10px;
}

.check-list li {
  position: relative;
  padding-left: 35px;
  padding-bottom: 5px;
  margin-bottom: 15px;
  line-height: 1.6;
  border-bottom: #93939370 2px dotted;
}

.check-list li::before {
    content: '✔';
    position: absolute;								
    left: 0;
    top: 0;
    width: 15px;
    height: 15px;
    border: 2px solid var(--main-color);
    color: var(--sub-color);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    border-radius: 6px;
    font-size: 0.55rem;
}

.check-list li:last-child {
    border-bottom: none;
}

.check-list span.highlight {
  color: var(--sub-color);
  border-bottom: #0876c0 2px double;
  font-weight: 600;
}

/* --- section-risk スタイル --- */
.section-risk {
  background-color: var(--main-color); /* 濃紺 */
  color: var(--white); /* 白 */
  padding: 25px 20px 55px;
  text-align: center;
}

/* 警告アイコン */
div.risk-icon-wrap img {
    width: 20%;
    margin: 10px auto;
}

/* タイトル：明朝体を使用 */
.risk-title {
  font-family: var(--font-serif);
  font-size: 2.2rem;
  line-height: 1.3;
  margin-bottom: 12px;
}

.risk-title .fs-big {
	font-size: var(--fs-big);
	color: var(--light-blue);
}

.risk-sub {
   font-size: var(--fs-h4);
   font-weight: 400;
}

/* 説明文とピンクのラベル */
.risk-description {
  font-family: var(--font-serif);
  font-size: var(--fs-h3);
  line-height: 1.8;
  margin-bottom: 30px;
}
.risk-label {
    background-color: var(--white);
    color: var(--accent-color);
    padding: 0px 9px;
    font-weight: 600;
    display: inline-block;
    line-height: 1.2;
}

/* リスト（チップ状の表示） */
.risk-list {
  display: flex;
  flex-wrap: wrap;      
  justify-content: center; 
  gap: 10px 7px;    
  max-width: 400px; 
  margin: 30px auto 0;
}

.risk-list li {
  font-family: var(--font-base);
  background-color: #e0e0e0;
  color: var(--main-color);
  padding: 8px 0;
  width: calc(33% - 10px);
  border-radius: 10px;
  font-weight: 700;
  font-size: 0.9rem;
  text-align: center;
}

/* 下段が4つ並びになるように、特定の画面幅で微調整 */
@media screen and (max-width: 480px) {
  .risk-list {
    max-width: 340px; /* スマホで3つ並び・4つ並びが綺麗に見える幅に */
  }
  .risk-list li {
    /* 2行目で4つ並ぶように、少しだけ横幅を狭める */
    width: calc(25% - 8px); 
  }
  
  /* 1〜3番目（上段）だけ少し幅を広くして、3つ並びを維持する */
  .risk-list li:nth-child(-n+3) {
    width: calc(33% - 8px);
  }
}

/* PCサイズ調整 */
@media screen and (min-width: 768px) {
  .risk-title {
    font-size: 3rem;
  }
  .risk-list {
    max-width: 100%;
	margin: 30px auto 20px;
  }
}

/* --- Section 3: Treatment --- */
.section-treatment { 
	text-align: center;
	margin-top: -20px;
 }

.hero-blue-box {
  background-color: var(--sub-color); /* 水色〜青 */
  color: #fff;
  padding: 0px 20px 60px;
  clip-path: polygon(0 0, 100% 0, 100% 85%, 50% 100%, 0 85%);
}
.hero-title .underline {
  border-bottom: 2px solid #fff;
  padding-bottom: 2px;
}

.treatment-body { 
	padding: 40px 20px;
	background-color: aliceblue;
	margin-top: -25px;
 }

 .treatment-info{
	font-family: var(--font-serif);
 }

.arrow-down {
  width: 2px; height: 50px;
  background: var(--main-color);
  margin: 0 auto 20px;
  position: relative;
}
.arrow-down::after {
  content: '';
  position: absolute; bottom: 0; left: 50%;
  transform: translateX(-50%);
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-top: 15px solid var(--main-color);
}

.product-name {
    color: var(--accent-color);
    font-size: 2.4rem;
    border: 2.5px solid var(--accent-color);
    display: inline-block;
    padding: 10px 16px;
    margin: 20px 0;
    background-color: white;
    font-weight: 600;
    box-shadow: #ced8e2 4px 4px 0;
}

.clinic-sub {
    font-size: var(--fs-h3);
    font-weight: 600;
}

.treatment-desc{
	font-family: var(--font-base);
	font-size: var(--fs-body);
	line-height: 1.5;
	margin-top: 20px;
	text-align: left;
	margin-bottom: 30px;
}


.treatment-image img {
  width: 100%;
  max-width: 500px;
  margin: 0 auto;
}

/* --- Treatment Hero 全体 --- */
.treatment-hero {
    text-align: center;
    }

/* --- 吹き出し (Message Bubble) --- */
.message-bubble {
	font-family: var(--font-base);
    position: relative;
    display: inline-block;
    background-color: var(--white);
    padding: 8px 20px;
    color: var(--main-color);   
    margin-bottom: -15px; /* ネガティブマージンで下の要素を引き寄せる */
    z-index: 2;           /* 青いボックスより上に表示 */
	border-radius: 6px;
}

.message-bubble::after,
.message-bubble::before {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: transparent solid 10px;
}
/* .message-bubble::before { border-top-color: #ccc; } */
.message-bubble::after { border-top-color: var(--white); margin-top: -2px; }

/* --- 青いV字ボックス (Hero Blue Box) --- */
.hero-blue-box {
    position: relative;  
    z-index: 1;         
    
    background-color: var(--sub-color);
    color: var(--white);
    
    /* ポイント2: 吹き出しが重なる分、上部のパディングを少し増やすと文字が隠れません */
    padding: 50px 20px 60px; 
    
    clip-path: polygon(0 0, 100% 0, 100% 85%, 50% 100%, 0 85%);
}

/* --- 青いV字ボックス (Hero Blue Box) --- */
.hero-blue-box {
    background-color: var(--sub-color); /* 青色 */
    color: var(--white);
    padding: 40px 20px 60px; /* 下側にV字の余白を多めに取る */
    /* V字にカットする指定 */
    clip-path: polygon(0 0, 100% 0, 100% 85%, 50% 100%, 0 85%);
    margin-top: -10px; /* 吹き出しと少し重ねる場合 */
}

.hero-title {
    font-family: var(--font-serif);
    font-size: 1.6rem;
    line-height: 1.3;
    font-weight: 400;
}

.hero-title .underline {
    display: inline-block;
    border-bottom: 2px solid var(--white); /* 白い下線 */
    padding-bottom: 2px;
    margin-top: 5px;
}

/* モバイル用の微調整 */
@media screen and (max-width: 480px) {
    .hero-title {
        font-size: 1.4rem;
    }
}

/* セクション全体の背景設定 */
.section-features {
    background-image: url('../img/features-back.webp');
    background-repeat: no-repeat;
    background-position: bottom left;
    background-size: cover;
    /* background-color: aliceblue; */
    padding: 40px 20px 100px;
    text-align: center;
    font-family: var(--font-serif);
    position: relative;
}

/* 背景画像の上に半透明の白いオーバーレイを重ねる */
.section-features::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  /* height: 100%; */
  background-color: rgba(255, 255, 255, 0.6);
  z-index: 1;
}

/* 青いタイトル部分（オーバーレイより上に表示） */
.section-features h2 {
    position: relative;
    z-index: 2;
    background-color: #43a3db;
    color: #ffffff;
    display: inline-block;
    padding: 15px 42px;
    font-size: 1.3rem;
    font-weight: 600;
    line-height: 1.4;
    margin-bottom: 40px;
}

/* リスト全体のスタイル（オーバーレイより上に表示） */
.features-list {
  position: relative;
  z-index: 2; /* 最前面に */
  list-style: none;
  max-width: 600px;
  margin: 0 auto;
}

.features-list {
  position: relative;
  z-index: 2; 
  list-style: none;
  max-width: 600px;
  margin: 0 auto;
}

.features-list li {
    background-color: #ffffff;
    border: 2px solid #43a3db;
    border-radius: 4px;
    margin-bottom: 15px;
    padding: 10px 0px 10px 36px;
    font-size: 1.0rem;
    font-family: var(--font-base);
    font-weight: 400;
    color: #333;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    flex-wrap: nowrap;
    position: relative;
    box-shadow: 3px 3px 0px rgba(67, 163, 219, 0.2);
    text-align: left;
}

.features-list li::before {
    content: '✔';
    position: absolute;
    left: 5px;
    top: 9px;
    width: 15px;
    height: 15px;
    border: 2px solid #00a854;
    color: #00a854;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.55rem;
}

/* ピンクの強調文字 */
.features-list li span {
  color: #b53d83;
  font-weight: 600;
}


.section-score{
  padding: 40px 20px;
  font-family: var(--font-serif);
  text-align: center;
}

.section-score h2 {
    background-color: #43a3db;
    color: #ffffff;
    display: inline-block;
    padding: 15px 24px;
    font-size: 1.3rem;
    line-height: 1.4;
    margin-bottom: 40px;
    font-weight: 600;
}

.section-score div.swiper-p{
	text-align: left;
}


.section-root  {
	text-align: center;
	margin: 0 auto;
}

.root-inner{
	width: 100%;
    margin: 88px auto;
}   

.section-root h2 {
    color: var(--main-color);
    font-family: var(--font-serif);
    padding: 15px 48px;
    font-size: 2.0rem;
    line-height: 1.2;
    margin-bottom: 18px;
    font-weight: 600;
}

.section-root h2 span {
    font-size: 2.5rem;
}

.section-root .root-box-ttl {
    font-family: var(--font-base);
    background-color: #71A1D2;
    color: var(--white);
    padding: 13px 20px;
    font-weight: 500;
    width: 75%;
    font-size: 1.2rem;
    margin: 0 auto;
}

.section-root .root-box-ttl span {
    font-size: 0.9em;
    font-family: var(--font-serif);
    color: #71A1D2;
    background-color: #E4F5FF;
    border-radius: 6px;
    padding: 2px 13px;
    font-weight: 500;
}

.section-root .root-box-ttl2 {
    font-family: var(--font-base);
    font-weight: 500;
    font-size: 1.4rem;
    margin-top: 22px;
    color: var(--sub-color);
    line-height: 1.25;
    position: relative;
    display: inline-block;
    padding: 0 50px;
    font-weight: 600;
}


.section-root .root-box-ttl2::before,
.section-root .root-box-ttl2::after {
    content: "";
    position: absolute;
    top: 50%;
    width: 57px;
    height: 2px;
    background-color: #0981ca;
}

/* 前の線（右下がりに傾ける） */
.section-root .root-box-ttl2::before {
    left: 0;
    transform: translateY(-50%) rotate(60deg);
}

/* 後の線（右上がりに傾ける） */
.section-root .root-box-ttl2::after {
    right: 0;
    transform: translateY(-50%) rotate(-60deg);
}

.root-box{
	margin-bottom: 30px;
}

.root-box img {
	width: 85%;
	max-width: 400px;
	margin: 20px auto 45px;
}

.section-root div.message-bubble{
	font-family: var(--font-base);
	position: relative;
    display: inline-block;
    background-color: #D7E9F5;
    padding: 17px 26px;
    margin-bottom: -15px;
    z-index: 2;
    color: var(--main-color);
    font-weight: 600;
    font-size: 1.1rem;
}

.section-root div.message-bubble::after,
.section-root div.message-bubble::before {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: transparent solid 10px;
}
/* .section-root div.message-bubble::before { border-top-color: #ccc; } */
.section-root div.message-bubble::after { border-top-color: #D7E9F5; margin-top: -2px; }

.section-root .comparison{
	font-family: var(--font-base);
	width: 90%;
	margin: 0 auto;
	text-align: center;
	display: flex;
	align-items: start;
	background-color: #F9E4E9;
	margin-top: 40px;
}

.section-root .comparison-item01 {
	background-color: #F1F1F1;
	padding: 20px 12px;
	border-right: 1px #707070 dotted;
}

.section-root .comparison-item01 h4{
	font-size: 1.2rem;
	background-color: var(--main-color);
	color: #ffffff;
	padding: 10px;
	font-family: var(--font-serif);
}

.section-root .comparison-item02 {
	background-color: #F9E4E9;
	padding: 20px 12px;
	
}

p.p-txt{
	text-align: left;
	font-size: 0.9rem;
	line-height: 1.4;
	padding: 10px 0 0 0;
}

.section-root .txt_box{
	text-align: left;
}

.section-root p.comparison-ttl {
	font-size: 0.85rem;
    font-weight: 600;
    margin-bottom: 10px;
}

.highlight-red {
	color:var(--accent-color);
}


.section-diff{
	text-align: center;
	margin: 0 auto;
}

.section-diff h2 {
   	color: var(--main-color);
    font-family: var(--font-serif);
    padding: 0px 0px 15px 0;
    font-size: 1.8rem;
    line-height: 1.3;
    margin-bottom: 18px;
    font-weight: 600;
    margin-top: -44px;
}

.section-diff-detail{
	width: 100%;
	margin: 0 auto;
	text-align: left;
	background-color: #ffffff;
	box-shadow: 3px 3px 0px rgba(67, 163, 219, 0.2);
}

.section-diff-detail h3{
	background-color: #979797;
	color: #ffffff;
	padding: 10px;
	font-size: 1.2rem;
	text-align: center;
	font-family: var(--font-serif);
}

.section-diff-detail-item{
	display: flex;
	align-items: start;
	padding:15px 0px 018px 22px;
	margin-bottom: 30px;
}

.section-diff-detail-item img {
	width: 34%;
	height: auto;
}

.section-diff-detail-item li {
    font-family: var(--font-base);
    font-size: 0.82rem;
    line-height: 1.6;
    padding: 12px 0 0 38px;
    position: relative;
}

.section-diff-detail-item li::before {
    content: '✔';
    position: absolute;
    left: 11px;
    top: 14px;
    width: 15px;
    height: 15px;
    border: 2px solid #8a8a8a;
    color: #8a8a8a;
    border-radius: 4px;
    font-size: 0.55rem;
    text-align: center;
    display: inline-block;
}

.highlight-b{
	font-weight: 600;
}

.section-diff-detail h3.ttl-pal{
	background-color: #2176C0;
	color: #ffffff;
	padding: 10px;
	font-size: 1.2rem;
	text-align: center;
	font-family: var(--font-serif);
}

.section-diff-detail-item ul.list-pal li::before {
    content: '✔';
    width: 15px;
    height: 15px;
    border: 2px solid #2176C0;
    color: #2176C0;
    border-radius: 4px;
    margin-right: 10px;
    font-size: 0.55rem;
    text-align: center;
    display: inline-block;
}

.section-diff-detail-item ul.list-pal span {
	color: #2176C0;
	font-weight: 600;
}

.highlight-yellow {
	background-color: #fffcb2;
    color: #2176C0;
    font-weight: 600;
    padding: 5px 6px;
    border-radius: 50px;
    font-size: 0.9rem;
    margin-right: 10px;
}

h3.section-diff-comparison{
	width: 100%;
    background-color: var(--sub-color);
    color: #ffffff;
    display: inline-block;
    font-size: 1.5rem;
    line-height: 1.4;
    margin-bottom: 30px;
	text-align: center;
	padding: 13px 0px;
}


/* section-explan */

.section-explan .comparison {
	font-family: var(--font-base);
	width: 90%;
	margin: 0 auto;
	text-align: center;
	display: flex;
	align-items: stretch;
	margin-top: 40px;
	margin-bottom: 50px;
}

.section-explan .comparison {
    display: flex;
    gap: 10px;
    padding: 0 10px;
}

.section-explan .comparison-item01, 
.section-explan .comparison-item02 {
    flex: 1; 
    background-color: #fff; 
    border-radius: 15px;
    overflow: hidden;
    border: 1px solid #eee;
    text-align: center;
}

.section-explan .comparison-item01{
	background-color: #F1F1F1;}
.section-explan .comparison-item02{
	background-color: #fae5e5;}

.section-explan .comparison-item01 img,
.section-explan .comparison-item02 img {
	width: 80%;
	height: auto;
	margin: 0 auto;
}

.section-explan .comparison-item01 h4,
.section-explan .comparison-item02 h4 {
    margin: 0;
    padding: 10px 0;
    color: #fff;
    font-size: 1.0rem;
    font-weight: 700;
}

.section-explan .comparison-item01 h4 {
    background-color: #5f5f5f;
}

.section-explan .comparison-item02 h4 {
    background-color: #CC3366 ;
     color: #ffffff;
}

/* 5. 中のテキスト部分の余白 */
.section-explan .comparison-item01-inner,
.section-explan .comparison-item02-inner {
    padding: 15px 5px 0px;
}

.section-explan .comparison-item01-inner p,
.section-explan .comparison-item02-inner p {
    font-size: 12px;
    line-height: 1.5;
    margin-top: 10px;
}

.section-explan .comparison-item02 img{
	width: 77%;
	height: auto;
	margin-top: 5px;
}

.section-explan p.p-txt{
	text-align: left;
	font-size: 0.95rem;
	line-height: 1.4;
	padding: 10px 0 0 0;
}

.section-explan .txt_box{
	text-align: left;
	font-size: 0.95rem;
}

.section-explan p.comparison-ttl {
	font-size: 0.85rem;
    font-weight: 600;
    margin-bottom: 10px;
}

.sleep-quality {
    font-size: 1.9rem;
    text-align: center;
    margin: 0 auto;
    color: #a8a8a8;
}

.sleep-quality .txt_box {
    background-color: #7fabd5;
    color: #ffffff;
    width: 88%;
    margin: 20px auto;
    text-align: center;
    padding: 5px 0;
    font-size: 2.1rem;
}

.sleep-quality img {
    width: 23%;
    margin: 0 auto 28px;
}

.text-pink{
	color: #c63490;
}

.sas-info {
    position: relative;
    border: 3px solid #b9d8eb;
    border-radius: 15px;
    padding: 30px 5px 14px;
    margin: 60px auto 40px;
    text-align: center;
    background-color: #fff;
    font-family: var(--font-serif);
    width: 86%;
}

.sas-info img.alarm {
	position: absolute;
    top: 0;
    left: 50%; 
    transform: translate(-50%, -50%);
    width: 20%;
    height: auto;
    display: block;
    margin: 0 0 20px 0; 
}

/* タイトルの設定 */
div.sas-info p.sas-title {
    color: #313131;
    font-size: 1.3rem;
    font-weight: 400;
    line-height: 1.4;
    margin: 20px 0 30px;
    display: inline-block;
    text-align: center;
}

.sas-symptoms {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0px;
    list-style: none;
    padding: 0;
    width: 100%;
    font-family: var(--font-base);
}

.sas-symptoms li {
    width: 88px;
    height: 88px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    background-image: url(../img/sas-circle.svg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    color: #262626;
    line-height: 1.2;
    list-style: none;
    font-weight: 500;
    font-size: 0.85rem;
}


.highlight-pink {
    background-color: #c63490;
    color: #ffffff;
    /* font-size: 1.4rem; */
    line-height: 1.5;
    padding: 4px;
}


/* PC用の幅制限（lp-innerが500px程度の場合） */
@media (min-width: 768px) {
    .sas-info {
        max-width: 460px;
        margin-left: auto;
        margin-right: auto;
    }
}

.lebel {
    position: relative;
	width: 100%;
    display: inline-block;
    color: #ffffff;
    font-size: 0.9rem;
    line-height: 1.2;
    margin-top: 10px;
	text-align: center;
}

.lebel img {
    top: 0;
    left: 0;
    width: 100%;
    z-index: 0;
}

.lebel p {
    position: absolute;
    top: 27%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    text-align: center;
    z-index: 1;
    font-weight: 600;
    color: #ffffff;
    font-family: var(--font-serif);
    font-size: 1.7rem;
    display: block;
    padding: 4px 8px;
}

.lebel ul {
    position: absolute;
    top: 60%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    z-index: 1;
	font-family: var(--font-base);
   }

/* リスト（チップ状の表示） */
.lebel-list {
  display: flex;
  flex-wrap: wrap;      
  justify-content: center; 
  gap: 12px 10px;       
  max-width: 400px; 
  margin: 30px auto 0;
}

.lebel-list li {
    background-color: #ffffff;
    color: var(--accent-color);
    padding: 8px 0;
    border-radius: 10px;
    font-weight: 700;
    font-size: 1.1rem;
    text-align: center;
}

/* 下段が4つ並びになるように、特定の画面幅で微調整 */
@media screen and (max-width: 480px) {
  .lebel-list {
    max-width: 340px; /* スマホで3つ並び・4つ並びが綺麗に見える幅に */
  }
  .lebel-list li {
    /* 2行目で4つ並ぶように、少しだけ横幅を狭める */
    width: calc(25% - 8px); 
  }
  
  /* 1〜3番目（上段）だけ少し幅を広くして、3つ並びを維持する */
  .lebel-list li:nth-child(-n+3) {
    width: calc(33% - 8px);
  }
}

/* PCサイズ調整 */
@media screen and (min-width: 768px) {
  .risk-title {
    font-size: 3rem;
  }
  .lebel-list {
    max-width: 100%;
  }
}

/* よくある質問 */
section.section-faq {
    background-color: #ffffff;
    text-align: left;
    font-family: var(--font-serif);
    margin-top: 45px;
    font-family: var(--font-base);
}

.section-faq h2 {
    font-size: 1.8rem;
    line-height: 1.3;
    margin: 0 auto;
    font-weight: 400;
    color: #ffffff;
    width: 100%;
    font-family: var(--font-serif);
    text-align: center;
    padding: 50px 0;
    background-image: linear-gradient(160deg, #0f9fde 0%, #0b82c9 100%);
}

.faq-m-inner {
    padding: 30px 20px 60px;
}

.section-faq .accordion{
	border: none !important;
}

.section-faq .accordion summary {
    padding: 15px 0px 15px 10px;
    line-height: 1.2;
    color: #ffffff;
    background-color: #3D8BBC;
    position: relative;
    font-size: 0.9rem;
    font-weight: 400;
    margin-bottom: 3px;
}

.section-faq .accordion summary::marker {
	display: none;
}

.section-faq .accordion summary::before {
    content: 'Q.';
    position: absolute;
    /* right: 20px; */
    /* top: 50%; */
    /* margin-right: 15px; */
    font-size: 1.2rem;
    color: #ffffff;
}

.section-faq .accordion summary span{
 padding-left: 25px;
}

.accordion-content{
	padding: 20px;
	line-height: 1.6;
	font-size: 0.9rem;
	color: #333;
	margin-bottom: 20px;

}

.campaign_swich_ank_bottom_back div.back-to-top{
	display: block;
	position:fixed;
	bottom: 7em;
	right: 1em;
	z-index: 10000;
	display:none;
}

.campaign_swich_ank_bottom_back div.back-to-top img{
	width:20px;
	height:20px;
	border-radius: 30px;
	background-color: #6d6d6d;
	padding:12px;
}

/* PC用 */
@media (min-width: 768px){
	.check-title {
    font-size: 2.5rem;
    margin-bottom: 40px;
}
	.check-title span {
    font-size: 4.0rem;
}
.check-list {
	padding: 20px 44px 20px;
}

div.risk-icon-wrap img {
    width: 16%;
}
.risk-sub {
    font-size: 2.0rem;
}
.risk-title .fs-big {
    font-size: 5.3rem;
}
.risk-list li {
    padding: 13px 0;
    width: calc(25% - 10px);
    font-size: 1.1rem;
	font-family: var(--font-base);
}
.risk-description {
    font-family: var(--font-serif);
    font-size: 1.8rem;
    line-height: 1.6;
    margin-bottom: 30px;
}

.message-bubble {
    position: relative;
    display: inline-block;
    background-color: var(--white);
    padding: 12px 26px;
    margin-bottom: -15px;
    z-index: 2;
    /* border-radius: 7px; */
	color: var(--main-color);
}

.clinic-sub {
    font-size: 2.2rem;
    line-height: 1.2;
}
.product-name {
    font-size: 3.6rem;
    border: 3.5px solid var(--accent-color);
    padding: 10px 33px;
    margin: 30px 0 50px;
	box-shadow: #ced8e2 6px 6px 0; 
}

.treatment-desc {
    font-family: var(--font-base);
    width: 90%;
    font-size: 1.2rem;
    line-height: 1.5;
    margin-top: 20px;
    text-align: left;
    margin-bottom: 30px;
    margin: 30px auto;
}

.section-features {
    padding: 40px 50px;
}

.section-features h2 {
    width: 80%;
    font-size: 1.5rem;
}

.section-score h2 {
    width: 80%;
}

.section-root h2 {
    font-size: 2.35rem;
}

.section-root h2 span {
    font-size: 3.0rem;
}
.section-root .root-box-ttl2 {
    font-size: 2.1rem;
    padding: 0 70px;
}
.section-root .root-box-ttl2::before, .section-root .root-box-ttl2::after {
    width: 80px;
    height: 3px;    
}

.section-root div.message-bubble {   
    padding: 17px 39px;   
    color: var(--sub-color);   
    font-size: 1.4rem;
}

.section-root div.message-bubble::after,
.section-root div.message-bubble::before {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: transparent solid 17px;
}
.section-root div.message-bubble::after {
    border-top-color: #D7E9F5;
    margin-top: -2px;
}
.section-root .comparison {
    width: 85%;
    margin: 0 auto;
    text-align: center;
    display: flex;
    align-items: start;
    background-color: #F9E4E9;
    margin-top: 50px;
}
.section-root p.comparison-ttl {
    font-size: 1.2rem;
    margin-bottom: 15px;
}

.section-root p.comparison-ttl {
    font-size: 1.2rem;
    font-weight: 600;
    margin-bottom: 15px;
}
p.p-txt {
    font-size: 1.1rem;
}
.section-diff h2 {
    font-size: 2.4rem;
	margin: 15px 0;
}
.section-diff-detail {
    width: 90%;
}
.section-diff-detail-item li {
    font-size: 1.25rem;
    line-height: 1.6;
    padding: 12px 0 0 43px;
}

.section-explan .comparison-item01 img,
.section-explan .comparison-item02 img {
    width: 67%;
}
.section-explan .comparison-item02 img {
    width: 65%;
}
.section-explan .comparison-item01 h4,
.section-explan .comparison-item02 h4 {
    font-size: 1.3rem;
	padding: 17px 0;
   }
.section-explan .comparison-item01-inner p,
.section-explan .comparison-item02-inner p {
    font-size: 1.0rem;
    line-height: 1.7;
    margin-top: 10px;
}
.explan2-txt {
    font-size: 1.7em;
    margin-bottom: 30px;
}

.sleep-quality .txt_box {
    padding: 13px 0;
    font-size: 2.3rem;
}
h3.section-diff-comparison {
    width: 100%;
    font-size: 1.9rem;
    padding: 25px 0px;
    margin-top: 40px;
    margin-bottom: 50px;
}
.explan2-txt2 {
    font-size: 2.0em;  
}
.sas-info img.alarm {
    width: 18%;
}
div.sas-info p.sas-title {
    font-size: 1.8rem;   
    margin: 30px 0 38px;
}

div.sas-info p.sas-title span {
    font-size: 2.0rem;   
}

.sas-symptoms {
    gap: 10px 15px;
}
.sas-symptoms li {
    width: 108px;
    height: 108px;
    font-size: 0.95rem;
}

.balloon1 h3 { 
    font-size: 1.6rem;
	font-family: var(--font-base);
}

.lebel p {
    font-size: 2.6rem;
    padding: 4px 8px;
    line-height: 1.3;
}

.lebel-list li {
    padding: 12px 30px;
    font-size: 1.4rem;
}

.section-explan .txt_box {
    text-align: left;
    font-size: 1.4rem;
}

h3.txt-m-cause.txt-m {
    font-size: 2.1em;
    margin: 2em 0 1.8rem 1em;
}
.balloon1 {
    position: relative;
    padding: 2.0em 0;
    background-color: #d7e9f5;
    margin: 50px 0;
}
.faq-m-inner {
    padding: 30px 33px 60px;
}
.section-faq .accordion summary {
     font-size: 1.3rem;
}
.accordion[open] div {
    font-size: 1.2rem;
}
.features-list li {
    padding: 17px 0px 17px 36px;
}
div.section-diff-detail ul {
   margin-left: 25px;
}
.features-list li::before {
    left: 9px;
    top: 15px;
}
.section-diff-detail-item li::before {    
    left: 11px;
    top: 18px;
}
.lp-inner .slider-inner {
        padding: 0 20px;
    }
.slick-prev {
    left: -20px;
}

.slick-next {
    right: -20px;
}
.sleep-quality .txt_box {
    text-align: center;
    padding: 15px 0;
    font-size: 2.1rem;
}

}



/* すべての要素に赤い枠線をつける 親要素のはみ出チェック用 */
/* * {
    outline: 1px solid red !important;
} */
