body {
	font-family: "Zen Old Mincho", serif;
	font-weight: 400;
	font-style: normal;
	font-optical-sizing: auto;
	margin: 0;
	font-size: 18px;
	color: #000;
	margin: 0 auto;
	/* max-width: 390px; */
	background: #FFFBF2;
	letter-spacing: 5%;
}

.container {
	max-width: 390px;
	margin: 0 auto;
	background: #fff;
}

img {
	width: 100%;
	display: block;
}

p {
	font-size: 16px;
}

p.shippori-mincho-bold {
	font-family: "Shippori Mincho", serif;
	font-weight: 700;
	font-style: normal;
}

span.font_monts {
	font-size: 2.2em;
	padding-right: 3px;
	color: #FF1100;
}

section {
	padding: 40px 0;
}

.flex {
	display: flex;
	justify-content: center;
	align-items: center;
}

span.brown_txt {
	color: #C8A459;
}

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

.section-deco {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
}

.section-deco span {
	width: 40px;
	height: 1px;
	background: #c9ab6d;
}

.section-deco i {
	width: 4px;
	height: 4px;
	border: 1px solid #c9ab6d;
	transform: rotate(45deg);
	display: block;
	border-radius: 40px;
}


/* -------------

header 

---------------*/
.header {
	position: fixed;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 100%;
	max-width: 390px;
	z-index: 9999;
}

.header-inner {
	height: 55px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	background: rgba(255, 255, 255, 70%);
}

.hd-logo {
	width: 85%;
}

a.shippori-mincho-bold {
	font-family: "Shippori Mincho", serif;
	font-weight: 700;
	font-style: normal;
	line-height: 0;
	text-decoration: none;
}

span.line.hd-line {
	font-size: 18px;
	text-align: center;
	display: block;
}

i.bi.bi-line {
	font-size: 32px;
	color: #D4B678;
	padding-right: 7px;
}


/* =====================
hamburger
===================== */
.hamburger {
	width: 22%;
	height: 55px;
	position: relative;
	background: #D4B678;
	border: none;
	cursor: pointer;
	z-index: 1001;
	margin-right: 15px;
}

.hamburger span {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	width: 24px;
	height: 1px;
	background: #fff;
	transition: .4s;
}

.hamburger span:nth-child(1) {
	top: 20px;
}

.hamburger span:nth-child(2) {
	top: 28px;
}

.hamburger span:nth-child(3) {
	top: 36px;
}

/* active */

.hamburger.active span:nth-child(1) {
	transform:
		translateX(-50%) rotate(45deg);

	top: 21px;
}

.hamburger.active span:nth-child(2) {
	opacity: 0;
}

.hamburger.active span:nth-child(3) {
	transform:
		translateX(-50%) rotate(-45deg);

	top: 21px;
}

/* =====================
drawer
===================== */
.drawer-menu {
	position: fixed;
	top: 55px;
	left: 0;
	right: 0;
	width: 100%;
	max-width: 390px;
	height: calc(100vh - 55px);
	margin: 0 auto;
	z-index: 1000;

	background: linear-gradient(180deg, #D4B678 0%, #8C774B 100%);

	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transform: translateY(-10px);
	transition: .3s;
	overflow-y: auto;
}

.drawer-menu.active {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transform: translateY(0);
}

.drawer-inner {
	padding: 15px 15px 50px;
}

.drawer-nav li {
	border-bottom:
		1px solid rgba(255, 255, 255, .08);
	list-style: none;
}

.drawer-nav li:last-child {
	border: none;
}

.drawer-nav a {
	display: flex;
	flex-direction: column;
	padding: 20px 0;
	color: #fff;
	text-decoration: none;
}

.drawer-nav .en {
	font-size: 11px;
	letter-spacing: .18em;
	color: rgba(255, 255, 255, .5);
	margin-bottom: 8px;
}

.drawer-nav .jp {
	font-size: 18px;
	letter-spacing: .08em;
}

.drawer-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 56px;
	margin-top: 18px;
	background: linear-gradient(135deg, #D4B06A 0%, #B78D4A 100%);
	color: #fff;
	font-size: 16px;
	letter-spacing: .08em;
	border-radius: 5px;
	text-decoration: none;
	width: 90%;
	margin: 0 auto;
	margin-bottom: 17px;
}

/* -------------

kv 

---------------*/
section.top-kv {
	background-image: url(./img/top-mv_bg.png);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	padding-bottom: 1px;
	padding-top: 45px;
}

h1.kv-title {
	font-family: "Shippori Mincho", serif;
	font-weight: 500;
	font-style: normal;
	text-align: center;
	font-size: 45px;
	margin-bottom: 5px;
	text-align: left;
	text-shadow: 0 0 13px #fff;
}

h1.kv-title span {
	color: #CAA558;
}

.kv-inner {
	width: 94%;
	margin: 0 auto;
}

p.kv-text span {
	color: #CAA65A;
	font-weight: bold;
}

.kv-feature {
	display: flex;
	align-items: baseline;
	background: #FFFDF8;
	opacity: .9;
	justify-content: space-evenly;
	border-radius: 7px;
	padding: 10px 0;
	margin: 30px 0;
}

.kv-featureItem {
	border-right: 1px solid #C8A96A;
	padding-right: 13px;
}

.kv-featureItem:last-child {
	border: none;
	padding-right: 0;
}

.kv-featureItem img {
	width: 55%;
	margin: 0 auto;
}

.kv-featureItem p {
	font-size: 14px;
	margin-bottom: 10px;
	margin-top: 8px;
	text-align: center;
}

/* -------------

CTAボタン 

---------------*/
.cta-box {
	width: 90%;
	margin: 0 auto;
}

/* カード */
.cta-card {
	background-image: url(./img/cta_bg.png);
	background-position: center;
	background-size: inherit;
	position: relative;
	margin: 0 auto;
	border-radius: 12px;
	padding: 0px 13px 25px;
	box-shadow: 0 0 6px 4px #CACACA;
	text-align: center;
}

/* 上の帯 */
.cta-label {
	position: relative;
	display: inline-block;
	background-color: #8C774B;
	color: #fff;
	font-weight: bold;
	padding: 5px 30px;
	margin-bottom: 20px;
	z-index: 1;
	font-family: 'Noto Sans JP';
	letter-spacing: 4px;
	font-size: 20px;
}

/* 左側の切り欠き */
.cta-label::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 18px 0 18px 8px;
	/* 上下の半分がborder-widthの合計になるように調整 */
	border-color: transparent transparent transparent #f5f5f5;
	/* 背景色（薄いグレー）と同じ色にする */
}

/* 右側の切り欠き */
.cta-label::after {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 18px 8px 18px 0;
	border-color: transparent #f5f5f5 transparent transparent;
	/* 背景色（薄いグレー）と同じ色にする */
}

.cta-content {
	background: #fff;
	padding: 10px 0px;
	margin: 0 0 15px;
}

/* タイトル */
.cta-title {
	text-align: center;
	font-size: 19px;
	margin-bottom: 0px;
	margin-top: 0;
	text-align: left;
	padding-left: .5em;
	font-weight: 300;
}

/* 価格エリア */
.cta-price-area {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0px;
	width: 93%;
	margin: 0 auto;
}

.price-old {
	width: 32%;
}

.price-new {
	display: flex;
	align-items: flex-end;
	gap: 4px;
	display: inline-block;
	transform: skewX(-15deg);
}

.price-old_flex {
	justify-content: flex-start;
	transform: skewX(-15deg);
}

/* 数字 */
.price-num {
	font-size: 22px;
	font-weight: bold;
	color: #243b55;
	padding-right: 1px;
}

/* 通常価格 */
.price-old p {
	font-weight: 300;
	font-size: 12px;
	margin-bottom: -12px;
	text-align: left;
}

/* 新価格 */
.price-new span {
	font-size: 36px;
	color: #e74c3c;
	font-weight: bold;
}

/* 円 */
.price-old span.price-yen {
	font-size: 13px;
	margin-bottom: 11px;
	margin-top: -7px;
	display: block;
	font-weight: 300;
}

.price-new span.price-yen {
	font-size: 19px;
	margin-bottom: 4px;
	margin-top: -8px;
	display: block;
	font-weight: 300;
}

/* 税込 */
.price-old span.price-tax {
	font-size: 5px;
	font-weight: 300;
}

.price-new span.price-tax {
	font-size: 7px;
	font-weight: 300;
}

.price-old span {
	position: relative;
}

/* 斜線をそれっぽく */
.price-old .price-num::after {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	width: 110%;
	height: 2px;
	background: #C8A96A;
	transform: rotate(-10deg);
}

/* 矢印 */
.price-arrow {
	font-size: 23px;
	color: #C8A96A;
}

/* ボタン */
.cta-btn {
	font-family: "Noto Sans JP", sans-serif;
	display: block;
	text-align: center;
	background: #39b36e;
	color: #fff;
	padding: 10px 16px;
	border-radius: 999px;
	font-weight: bold;
	text-decoration: none;
	box-shadow: 0 4px 6px 0 rgba(0, 0, 0, 0.3);
	transition: 0.3s;
}

.cta-btn:hover {
	opacity: 0.9;
}

.cta-flex {
	display: flex;
	align-items: center;
	justify-content: space-around;
	margin-top: 15px;
	padding: 9px 0;
	background: #fff;
	border-radius: 6px;
	font-family: 'Noto Sans JP';
}

.cta-flex a {
	text-decoration: none;
	color: #000;
	font-weight: 400;
	font-size: 12px;
	text-align: center;
	display: block;
	width: 100%;
	padding: 10px 0;
	margin: 0 3px;
}

a.cta-btn-2 {
	border-right: 1px solid;
	padding: 0;
	position: relative;
	padding-left: 1em;
}

a.cta-btn-3 {
	padding: 0;
	position: relative;
	padding-left: 2em;
}

a.cta-btn-2::before {
	content: '';
	position: absolute;
	background: url(./img/cta_icon-1.png);
	background-size: contain;
	display: inline-block;
	width: 15px;
	height: 15px;
	background-repeat: no-repeat;
	left: 4%;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
}

a.cta-btn-3::before {
	content: '';
	position: absolute;
	background: url(./img/cta_icon-2.png);
	background-size: contain;
	display: inline-block;
	width: 15px;
	height: 15px;
	background-repeat: no-repeat;
	left: 4%;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
}

/* -----------------------

バナー

-------------------------- */
section.banner {
	padding-top: 0;
	width: 92%;
	margin: 0 auto;
}

/* -----------------------

お悩み

-------------------------- */
section.question {
	background: url(./img/trouble_bg.png);
	background-position: center;
	background-size: cover;
	padding: 40px 0 0;
	position: relative;
	z-index: 99;
}

.question-txt {
	text-align: center;
	line-height: 45px;
	font-weight: 600;
	position: relative;
}

.question-txt::before {
	content: '';
	position: absolute;
	bottom: -20px;
	display: inline-block;
	width: 35%;
	height: 2px;
	background-color: #D4B678;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	left: 50%;
}

.question-txt p {
	margin-top: 0;
	font-size: 35px;
	margin-bottom: 25px;
}

.question_list {
	margin: 45px 0 25px;
}

.question_list p {
	position: relative;
	padding-left: 2.5em;
	font-size: 20px;
	margin: 18px 0;
}

.question_list p::before {
	content: '';
	position: absolute;
	background: url(./img/check_icon.png);
	background-size: contain;
	display: inline-block;
	width: 25px;
	height: 25px;
	background-repeat: no-repeat;
	left: 3%;
	top: 54%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
}

/* -----------------------

answer

-------------------------- */
section.answer {
	background: url(./img/trouble_bg-2.png);
	background-position: center;
	background-size: cover;
	z-index: 9;
	position: relative;
	padding-top: 10px;
	text-align: center;
	padding-bottom: 25px;
}

section.answer:after {
	content: '';
	position: absolute;
	bottom: -13px;
	left: 50%;
	border: 25px solid transparent;
	border-top: 25px solid #C8A459;
	border-bottom: 0px;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
}

/* -----------------------

heading

-------------------------- */
span.answer-heading {
	font-size: 22px;
}

p.answer-main {
	font-size: 35px;
	margin: 20px 0;
	font-weight: 600;
	line-height: 46px;
}

p.answer-text {
	font-size: 22px;
	margin: 15px 0;
	font-weight: 600;
}

p.answer-text-2 {
	font-size: 18px;
	font-weight: 400;
	line-height: 28px;
	margin-top: 30px;
}

.heading h2 {
	margin-top: 8px;
	text-align: center;
	font-size: 28px;
}

/* -----------------------

what

-------------------------- */
section.what {
	background:
		linear-gradient(180deg,
			#faf7f2 0%,
			#f3e8d7 50%,
			#faf7f2 100%);
}

h2.what-heading {
	text-align: center;
	font-size: 28px;
	color: #1F3853;
}

p.center-text {
	text-align: center;
	font-weight: 500;
}

.efficacy-item {
	width: 92%;
	margin: 0 auto;
	border-bottom: 1px solid #EDE3CF;
}

.efficacy-ttl {
	position: relative;
	padding-top: .75em;
	margin-bottom: 0;
	color: #333333;
	font-size: 20px;
	text-align: center;
	font-weight: 600;
	letter-spacing: 10%;
}

.efficacy-ttl::before {
	position: absolute;
	bottom: .5em;
	left: 50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	width: 100%;
	color: #AE9D79;
	opacity: .25;
	font-size: 25px;
	line-height: 1;
	content: attr(data-word);
	pointer-events: none;
}

.efficacy-item:last-child {
	border: none;
}

/* -----------------------

saron

-------------------------- */
/* 全体 */
section.saron {
	background: url(./img/saron_bg.png);
	background-position: center;
	background-size: cover;
}

p.text-left {
	width: 90%;
	margin: 0 auto;
	font-weight: 600;
	line-height: 28px;
}

/* -----------------------

アプローチ

-------------------------- */
.approach-item {
	width: 75%;
	margin: 25px auto;
	border-radius: 18px;
	padding: 20px;
	border: 2px solid rgba(185, 151, 91, .4);
}

.approach-item img {
	width: 25%;
	margin: 0 auto;
}

.approach-item p {
	font-size: 19px;
	margin-bottom: 0;
	margin-top: 10px;
}

p.brown_txt {
	color: #CAA65A;
	font-size: 24px;
	text-align: center;
	font-weight: 500;
	margin-top: 5px;
}

/* -----------------------

voice

-------------------------- */
section.voice {
	background: #F8F4EC
}

img.graph-img {
	width: 60%;
	margin: 0 auto;
}

.voice-list {
	margin-top: 35px;
}

.voice-item {
	background: #fff;
	width: 85%;
	margin: 20px auto;
	padding: 10px 15px;
	box-shadow: 2px 4px 7px #EAEAEA;
}

.voice-item .flex {
	align-items: center;
	justify-content: flex-start;
	margin-bottom: 10px;
}

.voice-item img {
	width: 18%;
	margin-right: 10px;
}

p.voice-work {
	font-size: 18px;
	font-weight: 600;
}

p.voice-inner {
	margin: 0;
}

/* -----------------------

price

-------------------------- */
section.price {
	padding-bottom: 20px;
}

.price-table {
	width: 100%;
	max-width: 350px;
	margin: 0 auto 30px;
	border-collapse: collapse;
	background: #fff;
}

.price-table th {
	background: #8C774B;
	color: #fff;
	padding: 10px;
	font-size: 14px;
	border-right: 1px solid #fff;
}

.price-table td {
	border: 1px solid #cfd8e3;
	padding: 12px;
	font-weight: bold;
	color: #8C774B;
	text-align: center;
	font-size: 19px;
}

.price-table td span.table-item {
	font-size: 12px;
	padding-left: 2px;
}

/* モニターラベル */
.monitor-label {
	display: inline-block;
	background: #e85c4a;
	color: #fff;
	padding: 12px 30px;
	border-radius: 0 30px 30px 0px;
	margin-bottom: 20px;
	margin-top: 0;
	font-weight: bold;
	width: 40%;
	font-size: 18px;
}

/* 割引表 */
.monitor .old {
	color: #888;
	margin-right: 5px;
}

.monitor .arrow {
	margin: 0 5px;
	color: #D4B678;
	font-size: 13px;
}

.monitor .new {
	color: #e85c4a;
	font-weight: bold;
	font-size: 22px;
}

.old {
	position: relative;
}

.old::after {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	width: 100%;
	height: 1px;
	background: red;
	transform: rotate(-10deg);
}

.access {
	width: 94%;
	margin: 0 auto;
}

.access p {
	margin: 5px 0;
}

p.note_red {
	font-size: 13px;
	font-weight: 500;
	color: #E35848;
	margin-top: 12px;
}

span.red_bg {
	color: #fff;
	background: #E35848;
	padding: 2px 5px;
	margin-right: 5px;
	font-weight: bold;
}

/* -----------------------

flow

-------------------------- */
section.flow {
	background-color: #F9F6EF;
}

.flow-list {
	width: 94%;
	margin: 0 auto;
}

.flow-item {
	display: flex;
	gap: 20px;
	position: relative;
	position: relative;
}

.flow-left {
	display: flex;
	flex-direction: column;
	align-items: center;
	margin-right: -27px;
}

.flow-right {
	flex: 1;
	background: #fff;
	border-radius: 11px;
	padding: 15px;
	box-shadow: 2px 2px 15px rgba(0, 0, 0, .08);
	display: flex;
	align-items: center;
	margin-bottom: 5px;
	margin-top: 20px;
}

.flow-icon {
	width: 45%;
	margin-right: 9px;
}

.flow-icon img {
	width: 100%;
}

.flow-number {
	width: 45px;
	height: 45px;
	border-radius: 50%;
	background: linear-gradient(180deg,
			#dbc89e 0%,
			#c3a46b 45%,
			#a88445 100%);
	color: #fff;
	font-size: 20px;
	font-weight: bold;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 2;
}

.flow-line {
	width: 1px;
	flex: 1;
	background: #d8c39a;
}

.flow-right h3 {
	font-size: 18px;
	margin-bottom: 0px;
	margin-top: 0;
}

.flow-right p {
	font-size: 13px;
	line-height: 1.2;
	color: #666;
	margin-bottom: 0;
	margin-top: 4px;
}

/* -----------------------

qa

-------------------------- */
section.qa {
	background: #F5EDDC;
	text-align: center;
}

.heading-qa {
	display: inline-block;
	position: relative;
}

.heading-qa:before {
	content: '';
	display: inline-block;
	position: absolute;
	bottom: -15px;
	left: 50%;
	transform: translateX(-50%);
	width: 60px;
	height: 2px;
	background-color: #C8A96A;
}

.qa-wrap {
	background: #fff;
	width: 85%;
	margin: 20px auto;
	padding: 5px 10px;
}

p.qa-q span {
	font-family: "Montserrat";
	font-weight: bold;
	font-size: 30px;
	color: #C8A96A;
	margin-right: 10px;
}

p.qa-q {
	text-align: left;
	margin-top: 5px;
	border-bottom: 1px solid;
	padding-bottom: 15px;
	font-size: 18px;
}

.qa-a {
	text-align: left;
	font-weight: 500;
}

/* -----------------------

note

-------------------------- */
.note_inner {
	background: #FAF8F3;
	width: 81%;
	margin: 0 auto;
	padding: 5px 15px;
}

.note_inner p {
	font-size: 18px;
}

p.note-text {
	font-size: 16px;
}

span.red_txt {
	font-size: 1.1em;
	color: #E35848;
	font-weight: bold;
}

/* -----------------------

staff

-------------------------- */
section.staff {
	background: url(./img/staff_bg.png);
	background-position: center;
	background-size: cover;
}

.staff-wrap {
	background: #fff;
	width: 80%;
	margin: 25px auto 0;
	padding: 20px;
}

.staff-wrap .flex {
	justify-content: inherit;
}

.staff-wrap img {
	width: 20%;
}

p.staff-name {
	font-size: 20px;
	padding-left: 20px;
}

p.staff-text {
	font-size: 18px;
	font-weight: 500;
	margin: 5px 0;
}

/* -----------------------

footer

-------------------------- */
footer.footer {
	background: #8C774B;
	color: #fff;
	padding-top: 5px;
	text-align: center;
}

.footer__inner p {
	font-size: 14px;
}

.footer__copyright {
	font-size: 8px;
	font-weight: 100;
	padding-bottom: 10px;
}

.sns-links {
	display: flex;
	gap: 14px;
	align-items: center;
	justify-content: center;
	margin-bottom: 12px;
}

.sns-links a {
	width: 38px;
	height: 38px;
	border: 1px solid rgba(255, 255, 255, .3);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-size: 16px;
	transition: .3s;
}

.sns-links a:hover {
	background: rgba(255, 255, 255, .1);
	transform: translateY(-2px);
}