@font-face {
	font-family: "smartfontUI";
	src: url("./font/smartfontUI.otf") format("opentype");
}

/* ----------------------------------------
Base
---------------------------------------- */

* {
	min-height: 0;
}

html {
	font-size: 62.5%;
	/*visibility: hidden;*/
}

/*
html.wf-active,
html.wf-inactive,
html.loading-delay {
	visibility: visible;
}
*/

body {
	background-color: #fff;
	color: #595757;
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
	font-size: 1.6em;
	font-weight: 500;
	line-height: 1.5;
	position: relative;
}

body.is_fixed {
	height: 100%;
	position: fixed;
	width: 100%;
}

body.is_fixed iframe {
	pointer-events: none;
}

img {
	max-width: 100%;
	vertical-align: middle;
}

li {
	list-style: none;
}

a {
	color: #595757;
}

a:hover {
	opacity: 0.7;
}

.ovx_hidden {
	overflow-x: hidden;
}

.container {
	margin: 0 auto;
	max-width: 1220px;
	padding: 0 30px;
	width: 100%;
}

.container_lg {
	margin: 0 auto;
	max-width: 1400px;
	padding: 0 30px;
	width: 100%;
}

.container_sm {
	margin: 0 auto;
	max-width: 980px;
	padding: 0 30px;
	width: 100%;
}

main {
	margin-top: 14rem;
}

.mb7 {
	margin-bottom: 70px;
}

/* ----------------------------------------
Reset
---------------------------------------- */

html {
	-webkit-text-size-adjust: 100%;
	-moz-tab-size: 4;
	-o-tab-size: 4;
	box-sizing: border-box;
	tab-size: 4;
	word-break: normal;
}

*,
:after,
:before {
	background-repeat: no-repeat;
	box-sizing: inherit;
}

:after,
:before {
	text-decoration: inherit;
	vertical-align: inherit;
}

* {
	margin: 0;
	padding: 0;
}

hr {
	color: inherit;
	height: 0;
	overflow: visible;
}

details,
main {
	display: block;
}

summary {
	display: list-item;
}

small {
	font-size: 80%;
}

[hidden] {
	display: none;
}

abbr[title] {
	-webkit-text-decoration: underline dotted;
	border-bottom: none;
	text-decoration: underline;
	text-decoration: underline dotted;
}

a {
	background-color: transparent;
	outline: none;
	text-decoration: none;
}

a:active,
a:hover {
	outline-width: 0;
}

code,
kbd,
pre,
samp {
	font-family: monospace, monospace;
}

pre {
	font-size: 1em;
}

b,
strong {
	font-weight: bolder;
}

sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

table {
	border-color: inherit;
	text-indent: 0;
}

input {
	border-radius: 0;
}

[disabled] {
	cursor: default;
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
	height: auto;
}

[type=search] {
	-webkit-appearance: textfield;
	-moz-appearance: textfield;
	appearance: textfield;
	outline-offset: -2px;
}

[type=search]::-webkit-search-decoration {
	-webkit-appearance: none;
	appearance: none;
}

textarea {
	overflow: auto;
	resize: vertical;
}

button,
input,
optgroup,
select,
textarea {
	font: inherit;
}

optgroup {
	font-weight: 700;
}

button {
	overflow: visible;
}

button,
select {
	text-transform: none;
}

[role=button],
[type=button],
[type=reset],
[type=submit],
button {
	color: inherit;
	cursor: pointer;
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button::-moz-focus-inner {
	border-style: none;
	padding: 0;
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button:-moz-focusring {
	outline: 1px dotted ButtonText;
}

[type=reset],
[type=submit],
button,
html [type=button] {
	-webkit-appearance: button;
	-moz-appearance: button;
	appearance: button;
}

button,
input,
select,
textarea {
	background-color: transparent;
	border-style: none;
}

a:focus,
button:focus,
input:focus,
select:focus,
textarea:focus {
	outline-width: 0;
}

select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

select::-ms-expand {
	display: none;
}

select::-ms-value {
	color: currentColor;
}

legend {
	border: 0;
	color: inherit;
	display: table;
	max-width: 100%;
	white-space: normal;
}

::-webkit-file-upload-button {
	-webkit-appearance: button;
	appearance: button;
	color: inherit;
	font: inherit;
}

img {
	border-style: none;
}

progress {
	vertical-align: baseline;
}

[aria-busy=true] {
	cursor: progress;
}

[aria-controls] {
	cursor: pointer;
}

[aria-disabled=true] {
	cursor: default;
}

/* ----------------------------------------
header
---------------------------------------- */

.header {
	background-color: #fff;
	box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.16);
	display: flex;
	height: 14rem;
	left: 0;
	padding: 10px 0;
	position: fixed;
	right: 0;
	top: 0;
	z-index: 9999;
}

.header_top {
	align-items: flex-start;
	display: flex;
	justify-content: space-between;
	margin-bottom: 5px;
}

.header_ttl {
	line-height: 1;
	max-width: 371px;
}

.header_ttl .seo {
	height: 0;
	visibility: hidden;
	width: 0;
}

.header_ttl a {
	display: block;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
}

.header_catch {
	align-items: center;
	display: flex;
}

.header_archive {
	display: flex;
}

.header_archive li {
	position: relative;
}

.header_archive li:first-child::after {
	background-color: #595757;
	content: "";
	display: inline-block;
	height: 0.9em;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 1px;
}

.header_archive li a {
	padding: 13px;
}

.header_cta {
	display: flex;
	gap: 5px;
}

.header_cta__btn {
	align-items: center;
	color: #fff;
	display: flex;
	justify-content: center;
	padding: 5px 15px;
}

.header_cta__line {
	-o-object-fit: cover;
	height: 40px;
	margin-left: -5px;
	object-fit: cover;
	width: 45px;
}

.header_cta__reserve {
	margin-right: 5px;
	width: 20px;
}

.gnav_menu {
	display: flex;
	gap: 20px;
	justify-content: flex-end;
}

.gnav_menu__sp {
	display: none;
}

.gnav_cta{
	width: 315px;
}

.gnav_menu a {
	display: block;
	transition: opacity 0.3s;
}

.gnav_menu a:hover {
	opacity: 0.8;
}

.gnav_list {
	font-size: 1.8rem;
	font-weight: bold;
	position: relative;
}

.gnav_list::after {
	background-color: #55934f;
	content: "";
	height: 3px;
	left: 0;
	position: absolute;
	top: 27px;
	transform: scaleX(0);
	transform-origin: center;
	transition: transform 0.3s;
	width: 100%;
}

.gnav_list:hover::after {
	transform: scaleX(1);
}

.gnav_list__child {
	background-color: #fff;
	font-size: 1.6rem;
	opacity: 0;
	padding: 10px 20px;
	position: absolute;
	top: 100%;
	transition: opacity 0.3s, visibility 0.3s;
	visibility: hidden;
	width: -webkit-max-content;
	width: -moz-max-content;
	width: max-content;
}

.gnav_list__child a {
	padding: 10px;
	padding-left: 20px;
	position: relative;
}

.gnav_list__child a::before {
	background-color: #55934f;
	content: "";
	height: 16px;
	left: 5px;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 3px;
}

.gnav_list__child li {
	border-bottom: 1px dashed #918b8b;
	position: relative;
}

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

.gnav_list__child li::after {
	background-color: #55934f;
	content: "";
	height: 3px;
	left: 0;
	position: absolute;
	top: 100%;
	transform: scaleX(0);
	transform-origin: center;
	transition: transform 0.3s;
	width: 100%;
}

.gnav_list__child li:hover::after {
	transform: scaleX(1);
}

.gnav_list__hasChild:hover > ul,
.gnav_list__hasChild:active,
.gnav_list__hasChild ul li:hover > ul,
.gnav_list__hasChild ul li:active > ul {
	opacity: 1;
	visibility: visible;
}

.hamburgerBtn {
	display: none;
	height: 50px;
	position: relative;
	width: 50px;
}

.hamburgerBtn_line {
	background-color: #3b3938;
	border-radius: 5px;
	height: 3px;
	left: 0;
	position: absolute;
	transition: 0.3s;
	width: 100%;
}

.hamburgerBtn_line:nth-child(1) {
	top: 8px;
}

.hamburgerBtn_line:nth-child(2) {
	top: 24px;
}

.hamburgerBtn_line:nth-child(3) {
	top: 40px;
}

.overlay {
	background-color: rgba(255, 255, 255, 1);
	display: none;
	height: calc(100vh - 9rem);
	opacity: 0;
	position: absolute;
	right: -120%;
	top: 9rem;
	transition: opacity 0.5s, right 0.5s, visibility 0.5s;
	visibility: hidden;
	width: 100%;
}

/* ----------------------------------------
subPageMv
---------------------------------------- */

.subPageMv {
	align-items: center;
	border-radius: 60px;
	display: flex;
	height: 200px;
	overflow: hidden;
	position: relative;
}

.subPageMv_ttl {
	color: #fff;
	font-size: 4rem;
	padding-left: 30px;
	position: relative;
	z-index: 10;
}

.subPageMv_img {
	position: absolute;
	right: 100px;
	top: 30px;
	width: 330px;
}

.subPageMv_mask {
	background-image: linear-gradient(135deg, #94ca4e 60%, #6dae4a 70%, #459245 80%);
	height: 200px;
	left: 0;
	mix-blend-mode: multiply;
	position: absolute;
	top: 0;
	width: 100%;
}

/* ----------------------------------------
breadcrumb
---------------------------------------- */

.breadcrumb {
	margin-bottom: 40px;
	padding: 20px 40px;
}

.breadcrumb a {
	color: #25c6d1;
}

.breadcrumb .archive {
	display: inline;
	margin-bottom: 0;
}

/* ----------------------------------------
btn
---------------------------------------- */

.btn_wrap {
	padding-top: 40px;
	text-align: center;
}

.btn {
	border: 1px solid #595757;
	border-radius: 100px;
	display: inline-block;
	font-size: 1.8rem;
	font-weight: bold;
	letter-spacing: -1px;
	line-height: 1;
	min-width: 300px;
	padding: 20px 50px;
}

.btn.sp {
	display: none;
}

.btn__green {
	background-color: #00b900;
	border-color: #00b900 !important;
	color: #fff;
}

.btn__green span::before,
.btn__green span::after {
	border-color: #fff !important;
}

.btn__blue {
	background-color: #25c6d1;
	border-color: #25c6d1 !important;
	color: #fff;
}

.btn__blue span::before,
.btn__blue span::after {
	border-color: #fff !important;
}

.btn__icon {
	align-items: center;
	display: inline-flex !important;
	justify-content: center;
}

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

.btn__arrow span::after {
	border-right: 2px solid #595757;
	border-top: 2px solid #595757;
	content: "";
	display: inline-block;
	margin-left: 15px;
	min-height: 10px;
	min-width: 10px;
	transform: rotate(45deg);
}

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

.btn__back span::before {
	border-bottom: 2px solid #595757;
	border-left: 2px solid #595757;
	content: "";
	display: inline-block;
	margin-right: 15px;
	min-height: 10px;
	min-width: 10px;
	transform: rotate(45deg);
}

/* ----------------------------------------
cta
---------------------------------------- */

.cta {
	align-items: center;
	display: flex;
	gap: 20px;
	justify-content: space-between;
}

.cta_contents {
	width: calc((100% - 20px) / 2);
}

.cta_catch {
	font-size: 1.8rem;
	font-weight: bold;
	letter-spacing: -2px;
	margin: 0 auto 5px;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
}

.cta_catch span {
	font-family: "a-otf-ud-shin-go-pr6n", sans-serif;
	letter-spacing: 0;
}

.cta_catch__line {
	position: relative;
}

.cta_catch__line::before,
.cta_catch__line::after {
	background-color: #595757;
	bottom: 0;
	content: "";
	display: inline-block;
	height: 100%;
	position: absolute;
	width: 1px;
}

.cta_catch__line::before {
	left: -15px;
	transform: rotate(-30deg);
}

.cta_catch__line::after {
	right: -10px;
	transform: rotate(30deg);
}

.cta_btn {
	display: block;
}

.cta_btn.sp {
	display: none;
}

.cta_telWrap {
	align-items: center;
	display: flex;
	gap: 3%;
	justify-content: center;
}

.cta_tel {
	width: 57%;
}

.cta_tel img {
	width: 100%;
}

.cta_name {
	width: 21%;
}

.cta_time {
	display: block;
	margin: 0 auto;
}

.cta_info__sp {
	display: none;
}

.cta__primary {
	margin-bottom: 60px;
	margin-top: 60px;
}

.cta__primary .cta_btn {
	margin-bottom: 50px;
}

.cta__primary .cta_telWrap {
	margin-bottom: 20px;
}

.cta__primary .cta_time {
	width: 63.3%;
}

/* ----------------------------------------
tel
---------------------------------------- */

.tel {
	padding: 0 80px;
}

.tel_ttl {
	font-size: 2.6rem;
	margin-bottom: 20px;
	text-align: center;
}

.tel .cta {
	border: 1px solid #918b8b;
	border-radius: 24px;
	gap: 130px;
	justify-content: center;
	margin-bottom: 80px;
	padding: 20px;
	position: relative;
}

.tel .cta::after {
	background-color: #918b8b;
	content: "";
	display: inline-block;
	height: 75%;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 1px;
}

.tel .cta_content {
	text-align: center;
	width: 326px;
}

.tel .cta_name {
	margin-bottom: 10px;
	width: 100%;
}

.tel .cta_name__sp {
	display: none;
}

.tel .cta_telWrap {
	display: block;
}

.tel .cta_tel {
	display: block;
	margin-bottom: 10px;
	width: 100%;
}

/* ----------------------------------------
title
---------------------------------------- */

.topSection_ttl {
	font-size: 3.6rem;
	line-height: 1.3;
	margin-bottom: 40px;
	text-align: center;
}

.topSection_ttl img {
	width: 68px;
}

.section_ttl {
	margin-bottom: 50px;
	text-align: center;
}

.section_ttl__en {
	color: #55934f;
	font-family: "century-gothic", sans-serif;
	font-size: 6rem;
	font-weight: 500;
	line-height: 1;
	margin-bottom: 15px;
}

.section_ttl__ja {
	font-size: 2.2rem;
}

.heading_lv3 {
	color: #55934f;
	font-size: 3.8rem;
}

.heading_lv3__sm {
	font-size: 2.6rem;
}

/* ----------------------------------------
card
---------------------------------------- */

.card {
	position: relative;
	text-align: center;
}

.card_num {
	text-align: center;
}

.card_num__primary {
	color: #55934f;
	font-size: 4rem;
	margin-bottom: 30px;
	padding-right: 30px;
	position: relative;
}

.card_num__primary span {
	font-size: 3rem;
	font-weight: 500;
}

.card_num__primary::after {
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	background-image: repeating-linear-gradient(-45deg, #b8d554, #b8d554 2px, transparent 3px, transparent 5px);
	bottom: -5px;
	content: "";
	height: 5px;
	left: 0;
	position: absolute;
	width: 100%;
}

.card_heading {
	font-size: 2.2rem;
	margin-bottom: 20px;
}

.card_img {
	margin-bottom: 30px;
}

.card_txt {
	font-size: 2.2rem;
	font-weight: bold;
}

.card_btn {
	display: inline-block;
	font-size: 1.6rem;
	padding: 15px;
	width: 100%;
}

.card__ribbon {
	background-color: #55934f;
	border-radius: 20px;
	box-shadow: 2px 3.464px 8.19px 0.81px rgba(145, 139, 139, 0.31);
	color: #fff;
	padding: 50px 15px 30px;
	position: relative;
	text-align: center;
	z-index: 1;
}

.card__ribbon::after {
	border-color: transparent transparent #55934f transparent;
	border-style: solid;
	border-width: 0 10px 10px 10px;
	bottom: 100%;
	content: "";
	height: 0;
	left: 70px;
	position: absolute;
	width: 0;
	z-index: -1;
}

.card__ribbon .card_num {
	background-color: #b8d554;
	font-size: 3.2rem;
	font-weight: bold;
	height: 55px;
	left: 20px;
	line-height: 1.4;
	padding-top: 10px;
	position: absolute;
	text-align: center;
	top: -10px;
	width: 60px;
}

.card__ribbon .card_num::before,
.card__ribbon .card_num::after {
	border-style: solid;
	content: "";
	height: 0;
	position: absolute;
	top: 100%;
	width: 0;
}

.card__ribbon .card_num::before {
	border-color: transparent transparent transparent #b8d554;
	border-width: 0 0 10px 30px;
	left: 0;
}

.card__ribbon .card_num::after {
	border-color: transparent #b8d554 transparent transparent;
	border-width: 0 30px 10px 0;
	right: 0;
}

.card__primary {
	background-color: #fff;
	border-radius: 0 0 14px 14px;
	box-shadow: 2px 2px 5px 2px rgba(0, 0, 0, 0.16);
	padding: 20px 40px;
	position: relative;
	text-align: center;
}

.card__primary::before {
	background-color: #55934f;
	border-radius: 14px 14px 0 0;
	content: "";
	display: block;
	height: 15px;
	left: 0;
	position: absolute;
	top: -20px;
	width: 100%;
}

.card__primary .card_img {
	width: 100%;
}

/* ----------------------------------------
media
---------------------------------------- */

.media {
	align-items: center;
	display: flex;
	gap: 50px;
	justify-content: space-between;
}

.media_heading {
	font-size: 2.6rem;
	margin-bottom: 20px;
}

.media_heading__highlight {
	color: #55934f;
}

.media_heading__line {
	margin-bottom: 40px;
	position: relative;
}

.media_heading__line::after {
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	background-image: repeating-linear-gradient(-45deg, rgba(184, 213, 84, 0.7), rgba(184, 213, 84, 0.7) 3px, transparent 4px, transparent 8px);
	bottom: -15px;
	content: "";
	height: 8px;
	left: 0;
	position: absolute;
	width: 100%;
}

.media_heading__flex {
	align-items: center;
	display: flex;
}

.media_body {
	flex: 1;
}

.media_num {
	font-family: "century-gothic", sans-serif;
	font-weight: bold;
	line-height: 1;
}

.media_num__primary {
	color: #55934f;
	font-family: "century-gothic", sans-serif;
	font-size: 4rem;
	font-weight: bold;
	line-height: 1;
	padding-right: 30px;
}

.media_num__primary span {
	font-size: 3rem;
	font-weight: 500;
	margin-right: 8px;
}

.media_txt {
	line-height: 1.6;
}

.media_img {
	-o-object-fit: cover;
	object-fit: cover;
}

.halfMedia > * {
	width: calc((100% - 50px) / 2);
}

.media__ribbon {
	position: relative;
	z-index: 1;
}

.media__ribbon::after {
	border-color: transparent transparent #55934f transparent;
	border-style: solid;
	border-width: 0 10px 10px 10px;
	bottom: 100%;
	content: "";
	height: 0;
	left: 70px;
	position: absolute;
	width: 0;
	z-index: -1;
}

.media__ribbon .media_num {
	background-color: #b8d554;
	color: #fff;
	font-size: 2.6rem;
	height: 55px;
	left: 20px;
	padding-top: 10px;
	position: absolute;
	text-align: center;
	top: -10px;
	width: 60px;
}

.media__ribbon .media_num::before,
.media__ribbon .media_num::after {
	border-style: solid;
	content: "";
	height: 0;
	position: absolute;
	top: 100%;
	width: 0;
}

.media__ribbon .media_num::before {
	border-color: transparent transparent transparent #b8d554;
	border-width: 0 0 10px 30px;
	left: 0;
}

.media__ribbon .media_num::after {
	border-color: transparent #b8d554 transparent transparent;
	border-width: 0 30px 10px 0;
	right: 0;
}

/* ----------------------------------------
access
---------------------------------------- */

.access {
	margin-top: 100px;
}

.access_contents {
	color: #000;
	margin-bottom: 20px;
}

.access_contents a {
	color: #000;
}

.access .media {
	align-items: flex-start;
	margin-bottom: 80px;
}

.access .media_heading {
	font-size: 2.2rem;
	margin-bottom: 10px;
}

.access .media_img {
	aspect-ratio: 4/3;
}

.access_list {
	display: flex;
	flex-wrap: wrap;
	line-height: 1.6;
	padding: 5px 0;
}

.access_ttl {
	font-weight: bold;
	width: 100px;
}

.access_desc {
	width: calc(100% - 100px);
}

.access_desc a{
	color: #25c6d1;
}

.access iframe {
	height: 380px;
}

/* ----------------------------------------
accordion
---------------------------------------- */

.accordion_heading,
.accordion_body {
	position: relative;
}

.accordion_icon {
	border-radius: 50%;
	left: 30px;
	position: absolute;
	width: 40px;
}

.accordion_heading {
	background-color: #55934f;
	border-radius: 10px;
	color: #fff;
	cursor: pointer;
	display: flex;
	font-size: 2.2rem;
	font-weight: bold;
	line-height: 1.2;
	margin-bottom: 30px;
	padding: 20px 40px 20px 90px;
}

.accordion_heading .accordion_icon {
	top: 14px;
}

.accordion_heading::before,
.accordion_heading::after {
	background-color: #fff;
	content: "";
	display: inline-block;
	height: 2px;
	position: absolute;
	right: 30px;
	top: calc(50% - 2px);
	transition: 0.3s;
	width: 10px;
}

.accordion_heading::after {
	transform: rotate(90deg);
}

.accordion_heading.is_open::before {
	opacity: 0;
}

.accordion_heading.is_open::after {
	transform: rotate(0);
}

.accordion_body {
	color: #000;
	display: none;
	line-height: 1.5;
	margin-bottom: 40px;
	padding-left: 90px;
	padding-right: 40px;
}

.accordion_body p {
	padding-top: 8px;
}

/* ----------------------------------------
campaign
---------------------------------------- */

.campaign {
	margin-bottom: 60px;
}

.campaign_ttl {
	font-size: 3rem;
	margin-bottom: 15px;
}

.campaign_contents {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	justify-content: space-between;
}

.campaign_item {
	width: calc((100% - 20px) / 2);
}

.campaign_item a {
	display: block;
}

.campaign_item img {
	-o-object-fit: cover;
	aspect-ratio: 54/13;
	object-fit: cover;
	width: 100%;
}

/* ----------------------------------------
footer
---------------------------------------- */

.footer {
	background-color: #595757;
	padding-bottom: 30px;
	padding-top: 50px;
}

.footer_ttl {
	margin-bottom: 40px;
	text-align: center;
}

.footer_ttl a {
	display: inline-block;
}

.footer_ttl img {
	width: 470px;
}

.footer_nav {
	border-bottom: 1px solid #918b8b;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
	margin-bottom: 30px;
	padding-bottom: 30px;
}

.footer_list a {
	color: #d7dadf;
}

.footer_list:not(:first-child) {
	margin-top: 10px;
}

.footer_list__child li {
	color: #d7dadf;
	list-style-position: inside;
	list-style-type: "－";
	margin-top: 10px;
}

.footer_txt {
	font-size: 1.5rem;
	line-height: 1.5;
	margin-bottom: 50px;
}

.footer_txt dt {
	color: #fff;
}

.footer_txt dd {
	color: #d7dadf;
}

.footer_txt dd a {
	color: #d7dadf;
}

.footer_txt li {
	list-style-position: inside;
	list-style-type: "・";
}

.copyright {
	color: #d7dadf;
	font-size: 1.4rem;
	opacity: 0.6;
	text-align: center;
}

/* ----------------------------------------
listStyle
---------------------------------------- */

.listStyle_roundNum {
	counter-reset: my-counter;
	list-style: none;
}

.listStyle_roundNum li {
	padding-left: 1.2em;
	position: relative;
}

.listStyle_roundNum li::before {
	align-items: center;
	border: 1px solid #595757;
	border-radius: 50%;
	content: counter(my-counter);
	counter-increment: my-counter;
	display: flex;
	font-size: 0.9em;
	height: 1.2em;
	justify-content: center;
	left: 0;
	line-height: 1;
	padding-top: 0.1em;
	position: absolute;
	top: 0.2em;
	width: 1.2em;
}

/* ----------------------------------------
article
---------------------------------------- */

.article_heading {
	border-bottom: 1px solid #d7dadf;
	margin-bottom: 70px;
	position: relative;
}

.article_date {
	border-bottom: 5px solid #55934f;
	display: flex;
	font-family: "century-gothic", sans-serif;
	font-size: 1.5rem;
	gap: 20px;
	padding-bottom: 2px;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
}

.article_ttl {
	color: #000;
	font-size: 2.8rem;
	margin-bottom: 10px;
}

.article_sns {
	bottom: 10px;
	display: flex;
	gap: 10px;
	position: absolute;
	right: 0;
}

.article_sns img {
	width: 40px;
}

.article_body {
	color: #000;
}

.article_img {
	-o-object-fit: cover;
	aspect-ratio: 11/8;
	margin-bottom: 60px;
	object-fit: cover;
	width: 100%;
}

.article p {
	margin-bottom: 30px;
}

.article p a {
	color: #25c6d1;
}

.article h2,
.article h3,
.article h5,
.article h6 {
	color: #595757;
	margin-bottom: 30px;
}

.article h2 {
	border-bottom: 1px solid #d7dadf;
	font-size: 2.6rem;
}

.article h3 {
	font-size: 2.2rem;
	padding-left: 15px;
	position: relative;
}

.article h3::before {
	background-color: #55934f;
	content: "";
	display: inline-block;
	height: 75%;
	left: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 5px;
}

.article h4 {
	color: #55934f;
	font-size: 1.8rem;
	margin-bottom: 30px;
}

.article ul,
.article ol {
	border: 1px solid #d7dadf;
	margin-bottom: 10px;
	padding: 20px;
	padding-left: 40px;
	width: 440px;
}

.article ul li {
	list-style-type: disc;
}

.article ul li::marker {
	color: #55934f;
	font-size: 2rem;
	line-height: 1;
}

.article ol li {
	list-style-type: decimal;
}

.article ol li::marker {
	color: #55934f;
	font-weight: bold;
}

.article .checklist li {
	list-style-type: none;
	position: relative;
	text-indent: 0;
}

.article .checklist li::before {
	background-image: url(../img/check_green.png);
	background-size: contain;
	content: "";
	display: inline-block;
	height: 18px;
	left: -22px;
	position: absolute;
	top: 2px;
	width: 18px;
}

.article .wp-block-quote {
	background-color: #f2f3f7;
	margin-bottom: 30px;
	padding: 30px 60px;
	position: relative;
	width: 680px;
}

.article .wp-block-quote::before,
.article .wp-block-quote::after {
	height: 28px;
	position: absolute;
	width: 35px;
}

.article .wp-block-quote::before {
	background-image: url(../img/icon_blockquote.png);
	content: "";
	left: 15px;
	top: 15px;
}

.article .wp-block-quote::after {
	background-image: url(../img/icon_blockquote02.png);
	bottom: 15px;
	content: "";
	right: 15px;
}

.article .wp-block-quote p {
	margin-bottom: 0;
}

.article .wp-block-quote cite {
	display: block;
	margin-left: auto;
	margin-top: 10px;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
}

.article .wp-block-table {
	margin-bottom: 30px;
}

.article .wp-block-table table {
	border-collapse: collapse;
}

.article .wp-block-table tr:not(:last-child) {
	border-bottom: 3px solid #fff;
}

.article .wp-block-table td {
	background-color: #f2f3f7;
	height: 62px;
	padding: 10px 15px;
	width: 275px;
}

.article .wp-block-table td:not(:last-child) {
	border-right: 3px solid #fff;
}

.article .wp-block-table.column tr:first-child td {
	background-color: #e9f0d3;
	font-size: 1.8rem;
}

.article .wp-block-table.row tr td:first-child {
	background-color: #e9f0d3;
	font-size: 1.8rem;
}

.article .wp-block-table.both td:first-child {
	background-color: #e2e5ea;
	font-size: 1.8rem;
}

.article .wp-block-table.both tr:first-child td {
	background-color: #e9f0d3;
	font-size: 1.8rem;
}

.article .wp-block-table.scroll {
	overflow-x: scroll;
	padding-bottom: 5px;
}

.article .wp-block-table.scroll td {
	min-width: 275px;
}

.article .wp-block-table.scroll td:first-child {
	background-color: #e2e5ea;
	font-size: 1.8rem;
}

.article .wp-block-table.scroll tr:first-child td {
	background-color: #e9f0d3;
	font-size: 1.8rem;
}

.article .wp-block-buttons {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	justify-content: center;
	margin-bottom: 30px;
}

.article .wp-block-button__link {
	align-items: center;
	background-color: #55934f;
	border-radius: 12px;
	color: #fff;
	display: flex;
	font-size: 1.8rem;
	font-weight: bold;
	justify-content: center;
	/*max-width: 300px;*/
	padding: 20px 40px;
	position: relative;
}

.article .wp-block-button__link::after {
	border-right: 2px solid #fff;
	border-top: 2px solid #fff;
	content: "";
	display: inline-block;
	margin-left: 15px;
	min-height: 10px;
	min-width: 10px;
	transform: rotate(45deg);
}

.article .media {
	align-items: flex-start;
	border: 2px solid #d7dadf;
	border-radius: 20px;
	gap: 30px;
	margin-bottom: 30px;
	padding: 30px;
	width: 680px;
}

.article .media_img {
	height: 144px;
	width: 200px;
}

.article .media_body {
	flex: 1;
	padding-top: 10px;
}

.article .media_body time {
	color: #595757;
	display: block;
	font-family: "century-gothic", sans-serif;
	font-size: 1.5rem;
	margin-bottom: 5px;
}

.article .media_ttl {
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 4;
	color: #000;
	display: -webkit-box;
	font-size: 1.6rem;
	font-weight: 500;
	margin-bottom: 0;
	overflow: hidden;
	padding-left: 0;
}

.article .media_ttl::before {
	display: none;
}

.article .media_name {
	border-bottom: none;
	color: #000;
	font-size: 1.8rem;
	margin-bottom: 10px;
}

/* ----------------------------------------
calendar
---------------------------------------- */

.calendar {
	color: #000;
	width: 100%;
}

.calendar_heading {
	border-bottom: 1px dashed #918b8b;
	font-size: 1.8rem;
}

.calendar_row {
	align-items: center;
	display: grid;
	grid-template-columns: 180px repeat(7, 1fr);
	padding: 10px 0;
}

.calendar tbody .calendar_row:last-child {
	border-bottom: 1px dashed #918b8b;
	margin-bottom: 10px;
}

.calendar_hour {
	text-align: left;
}

.calendar_dot {
	color: #b8d554;
	font-size: 1.8rem;
	line-height: 1;
	text-align: center;
}

.calendar tfoot tr {
	display: grid;
}

.calendar_link {
	position: relative;
	text-align: right;
}

.calendar_link a {
	align-items: center;
	color: #000;
	display: flex;
	justify-content: flex-end;
	margin-left: auto;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
}

.calendar_link a::after {
	border-right: 2px solid #595757;
	border-top: 2px solid #595757;
	content: "";
	display: inline-block;
	margin-left: 15px;
	min-height: 8px;
	min-width: 8px;
	transform: rotate(45deg);
}

/* ----------------------------------------
form
---------------------------------------- */

#form {
	margin-top: -140px;
	padding-top: 140px;
}

.form {
	color: #000;
	margin-bottom: 40px;
	margin-top: -30px;
}

.form_itemWrap {
	border-bottom: 1px dotted #595757;
}

.form_itemWrap .form_item {
	border-bottom: none;
}

.form_nextItem {
	display: none;
}

.form_nextItem .form_item {
	margin-top: -20px;
}

.form_item {
	align-items: flex-start;
	border-bottom: 1px dotted #595757;
	display: flex;
	padding: 30px 0;
}

.form_label {
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 2.5;
	margin-top: 5px;
	padding-left: 60px;
	position: relative;
	width: 260px;
}

.form_label span {
	background-color: #a8a8a8;
	color: #fff;
	font-size: 1.5rem;
	font-weight: 500;
	left: 5px;
	line-height: 1.5;
	padding: 5px 8px;
	position: absolute;
	top: 5px;
}

.form_inputWrap {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.form_input,
.form_textarea {
	border: 1px solid #918b8b;
	padding: 15px 25px;
	vertical-align: bottom;
	width: 100%;
}

.form_textarea {
	height: 150px;
	resize: none;
}

.form_radio label {
	align-items: center;
	display: flex;
	gap: 10px;
	padding-top: 15px;
	width: 200px;
}

.form_radio input {
	aspect-ratio: 1;
	width: 20px;
}

.form select {
	border: 1px solid #595757;
	padding: 15px 25px;
}

.form_date,
.form_time label,
.form select,
.form_radio label,
.form_file {
	cursor: pointer;
}

.form_date,
.form_nextBtn {
	border: 1px solid #918b8b;
	padding: 15px 25px;
	width: 240px;
}

.form_time {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 20px;
}

.form_time .wpcf7-list-item {
	width: calc((100% - 80px) / 5);
}

.form_time input {
	display: none;
}

.form_time input:checked + .wpcf7-list-item-label {
	background-color: #e9f0d3;
}

.form_time .wpcf7-list-item-label {
	border: 1px solid #918b8b;
	display: block;
	padding: 5px 0;
	text-align: center;
}

.form_nextBtn {
	background-color: #f2f3f7;
	text-align: left;
}

.form_fileWrap {
	align-items: center;
	display: flex;
	flex: 1;
	gap: 15px;
}

.form_fileWrap p {
	flex: 1;
}

.form_file {
	border: 1px solid #595757;
	border-radius: 100px;
	padding: 15px 40px;
}

.form_file input {
	display: none;
}

.form_selectWrap {
	position: relative;
}

.form_selectWrap::after {
	border-color: #000 transparent transparent transparent;
	border-style: solid;
	border-width: 8px 4px 0 4px;
	content: "";
	height: 0;
	position: absolute;
	right: 20px;
	top: 30px;
	transform: translateY(-50%);
	width: 0;
}

.form_selectWrap select {
	padding-right: 35px;
	width: 240px;
}

.form_submit {
	border-radius: 50px;
	display: inline-block;
	font-size: 2.2rem;
	font-weight: normal;
	margin-top: 20px;
	padding: 18px;
	width: 280px;
}

.form_submit:disabled {
	filter: grayscale(100%);
	pointer-events: none;
}

.form_submit:hover {
	opacity: 0.7;
}

.required .form_label span {
	background-color: #ea8776;
}

.required .form_input,
.required .form_textarea {
	background-color: #feede6;
	border: 1px solid #ea8776;
}

.wpcf7-form-control-wrap {
	flex: 1;
}

.wpcf7-list-item {
	display: inline-block;
	margin: 0;
}

.wpcf7-not-valid-tip {
	display: none !important;
}

/* ----------------------------------------
privacy
---------------------------------------- */

.privacy {
	border: 1px solid #918b8b;
	color: #000;
	height: 150px;
	overflow-y: scroll;
	padding: 25px;
}

.privacy_ttl {
	font-size: 1.5rem;
	margin-bottom: 10px;
}

.privacy_txt {
	font-size: 1.5rem;
	margin-bottom: 15px;
}

.privacy_list dt {
	display: list-item;
	list-style: decimal inside;
}

.privacy_list dd:not(:last-child) {
	margin-bottom: 15px;
}

/* ----------------------------------------
contact
---------------------------------------- */

.contact_ttl {
	font-size: 4rem;
	margin-bottom: 40px;
	text-align: center;
}

.contact_txt {
	color: #000;
	margin-bottom: 40px;
	text-align: center;
}

/* ----------------------------------------
register
---------------------------------------- */

.register {
	align-items: center;
	border: 1px solid #918b8b;
	border-radius: 24px;
	display: flex;
	gap: 50px;
	justify-content: center;
	margin: 0 auto;
	max-width: 1000px;
	padding: 25px 45px;
}

.register_txt__sm {
	color: #000;
}

.register_txt__md {
	font-size: 2rem;
	font-weight: bold;
}

.register_txt__lg {
	font-size: 2.8rem;
	font-weight: bold;
}

.register_btn {
	margin-bottom: -10px;
	width: 430px;
}

.register_btn .sp {
	display: none;
}

.register_qr {
	width: 130px;
}

/* ----------------------------------------
pagenation
---------------------------------------- */

.pagenation {
	align-items: center;
	display: flex;
	gap: 15px;
	justify-content: center;
	margin-bottom: 80px;
}

.page-numbers {
	border: 1px solid #918b8b;
	color: #000;
	font-weight: bold;
	line-height: 1;
	padding: 6px 9px;
}

.page-numbers.current {
	background-color: #55934f;
	border: 1px solid #55934f;
	color: #fff;
}

.page-numbers.prev,
.page-numbers.next {
	border: none;
	padding: 6px 0;
}

.page-numbers.prev {
	margin-left: -53px;
}

.page-numbers.next {
	margin-right: -53px;
}

.page-numbers.dots {
	border: none;
	padding: 0;
}

/* ----------------------------------------
search
---------------------------------------- */

.searchform {
	border-bottom: 1px solid #d7dadf;
	border-top: 1px solid #d7dadf;
	margin-bottom: 90px;
	padding: 30px 0;
}

.searchform_ttl {
	color: #000;
	font-size: 2rem;
	font-weight: bold;
	padding-left: 20px;
}

.searchform_inputArea {
	display: flex;
}

.searchform input {
	aspect-ratio: 1;
	width: 20px;
}

.searchform_case {
	margin-bottom: 30px;
}

.searchform_case dd {
	gap: 20px;
}

.searchform_case dt {
	margin-bottom: 20px;
}

.searchform_case label {
	border-radius: 14px;
	position: relative;
	width: calc((100% - 40px) / 3);
}

.searchform_case input {
	left: 30px;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
}

.searchform_icon.sp {
	display: none;
}

.searchform_age {
	align-items: center;
	color: #000;
	display: flex;
	gap: 40px;
}

.searchform_age dd {
	gap: 35px;
}

.searchform_age label {
	align-items: center;
	display: flex;
	font-size: 1.8rem;
}

.searchform_age input {
	margin-right: 10px;
}

/* ----------------------------------------
table
---------------------------------------- */

.table_item {
	display: flex;
}

.table_ttl {
	background-color: #55934f;
	border: 1.5px solid #fff;
	color: #fff;
	font-size: 1.8rem;
	font-weight: bold;
	padding: 20px 30px;
	width: 200px;
}

.table_desc {
	background-color: #f2f3f7;
	border: 1.5px solid #fff;
	color: #000;
	flex: 1;
	padding: 20px 30px;
}

/* ----------------------------------------
archive
---------------------------------------- */

body.archive {
	display: block;
	margin-bottom: 0;
}

.archive {
	display: grid;
	gap: 60px 30px;
	grid-template-columns: repeat(4, 1fr);
	margin-bottom: 100px;
}

.archive_img {
	-o-object-fit: cover;
	aspect-ratio: 25/18;
	margin-bottom: 15px;
	object-fit: cover;
}

.archive time {
	display: inline-block;
	font-family: "century-gothic", sans-serif;
	font-size: 1.5rem;
	margin-bottom: 5px;
}

.archive_ttl {
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	color: #000;
	display: -webkit-box;
	font-size: 1.6rem;
	font-weight: 500;
	overflow: hidden;
}

/* ----------------------------------------
pageNav
---------------------------------------- */

.pageNav {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	justify-content: center;
	margin-bottom: 70px;
}

.pageNav_link {
	border-radius: 14px;
	overflow: hidden;
	width: calc((100% - 40px) / 3);
}

.pageNav_link a {
	background-color: #f2f3f7;
	display: block;
	font-size: 2.2rem;
	font-weight: bold;
	padding: 28px 35px;
	position: relative;
}

.pageNav_link a::before,
.pageNav_link a::after {
	background-color: #55934f;
	border-radius: 10px;
	content: "";
	display: inline-block;
	height: 2px;
	position: absolute;
	right: 35px;
	transform-origin: right;
	width: 10px;
}

.pageNav_link a::before {
	top: 50%;
	transform: rotate(45deg);
}

.pageNav_link a::after {
	top: calc(50% - 1px);
	transform: rotate(-45deg);
}

.pageNav_link .sp {
	display: none;
}

.pageNav_heading {
	color: #55934f;
	font-size: 3rem;
	margin-bottom: 40px;
	text-align: center;
}

/* ----------------------------------------
guideline
---------------------------------------- */

.guideline {
	color: #000;
	margin-bottom: 170px;
}

.guideline_txt {
	margin-bottom: 50px;
}

.guideline_content:not(:last-of-type) {
	margin-bottom: 60px;
}

.guideline_heading {
	border-bottom: 1px dashed #918b8b;
	font-size: 2.2rem;
	margin-bottom: 30px;
	padding-bottom: 5px;
}

.guideline_list {
	margin: 20px 0;
}

.guideline_list li {
	position: relative;
	text-indent: 15px;
}

.guideline_list li::before {
	content: "・";
	left: -15px;
	position: absolute;
}

.guideline_link {
	color: #25c6d1;
}

/* ----------------------------------------
thanks
---------------------------------------- */

.thanks_ttl {
	font-size: 3rem;
	margin-bottom: 40px;
	text-align: center;
}

.thanks_txt {
	color: #000;
	margin-bottom: 25px;
	text-align: center;
}

.thanks_txt:last-of-type {
	margin-bottom: 50px;
}

/* ----------------------------------------
br
---------------------------------------- */

.br_underMd {
	display: none;
}

.br_onlyMd {
	display: none;
}

.br_sp {
	display: none;
}

/* ----------------------------------------
image
---------------------------------------- */

.image_inner {
	background-color: #e9f0d3;
	border-radius: 14px;
	margin-bottom: 80px;
	padding: 30px 40px 50px;
}

.image_ttl {
	color: #55934f;
	font-size: 3rem;
	margin-bottom: 30px;
	text-align: center;
}

.image_heading {
	color: #000;
	font-weight: bold;
}

.image_heading span {
	font-size: 1.8rem;
}

.image .media {
	align-items: flex-start;
	background-color: #fff;
	border-radius: 14px;
	box-shadow: 2px 3.464px 8.19px 0.81px rgba(145, 139, 139, 0.1);
	gap: 30px;
	padding: 40px 30px;
}

.image .media:not(:last-of-type) {
	margin-bottom: 20px;
}

.image .media > * {
	width: calc(50% - 15px);
}

.image .media_img {
	align-items: center;
	background-color: unset;
	display: flex;
	gap: 30px;
	justify-content: center;
	position: relative;
}

.image .media_img::after {
	border-color: transparent transparent transparent #55934f;
	border-style: solid;
	border-width: 16.5px 0 16.5px 15px;
	content: "";
	height: 0;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 0;
}

.image .media_img img {
	-o-object-fit: cover;
	aspect-ratio: 1;
	border: 1px solid #d7dadf;
	object-fit: cover;
	width: calc(50% - 15px);
}

.image .media_body {
	flex: 1;
}

.image .media_heading {
	background-color: #f2f3f7;
	border-radius: 6px;
	font-size: 2.2rem;
	padding: 10px 20px;
}

.image_desc:not(:last-of-type) {
	margin-bottom: 20px;
}

/* ----------------------------------------
example
---------------------------------------- */

.example#aga,
.example#faga,
.example#circle,
.example #plan01,
.example #plan02,
.example #plan03 {
	margin-top: -140px;
	padding-top: 140px;
}

.example:not(:last-of-type) {
	margin-bottom: 90px;
}

.example_ttl {
	align-items: center;
	display: flex;
	font-size: 4rem;
	justify-content: center;
	margin-bottom: 30px;
}

.example_ttl img {
	margin-right: 20px;
}

.example_item:not(:last-of-type) {
	margin-bottom: 50px;
}

.example_heading {
	align-items: center;
	background-color: #55934f;
	border-bottom: 5px solid #b8d554;
	border-radius: 14px 14px 0 0;
	color: #fff;
	display: flex;
	font-size: 3.4rem;
	font-weight: bold;
	padding: 15px 40px;
}

.example_num {
	font-family: "century-gothic", sans-serif;
	font-size: 3.6rem;
	margin-right: 30px;
}

.example_num span {
	font-weight: 500;
}

.example_body {
	background-color: #f2f3f7;
	border-radius: 0 0 14px 14px;
	padding: 40px 30px;
}

.example_beforeAfter {
	margin-bottom: 40px;
}

.example_beforeAfter p {
	color: #55934f;
	font-size: 2.6rem;
	font-weight: bold;
	margin-bottom: 10px;
	text-align: center;
}

.example_beforeAfter div {
	display: flex;
	gap: 30px;
	justify-content: center;
	position: relative;
}

.example_beforeAfter div::after {
	border-color: transparent transparent transparent #55934f;
	border-style: solid;
	border-width: 15px 0 15px 15px;
	content: "";
	height: 0;
	left: 50%;
	position: absolute;
	top: 35%;
	transform: translateX(-50%);
	width: 0;
}

.example_beforeAfter img {
	-o-object-fit: cover;
	aspect-ratio: 1;
	margin-bottom: 10px;
	object-fit: cover;
	width: 220px;
}

.example_beforeAfter figcaption {
	background-color: #55934f;
	border-radius: 50px;
	color: #fff;
	margin: 0 auto;
	padding: 3px;
	text-align: center;
	width: 120px;
}

.example h5 {
	color: #000;
	font-size: 2rem;
	margin-bottom: 10px;
	padding-left: 10px;
}

.example .accordion_heading {
	background-color: #d7dadf;
	border-radius: 0;
	color: #000;
	font-size: 2rem;
	margin-bottom: 15px;
	padding: 10px;
	padding-right: 70px;
}

.example .accordion_heading::before,
.example .accordion_heading::after {
	background-color: #000;
}

.example .accordion_body {
	color: #000;
	padding: 0 10px;
}

.plan1 .plan_info {
	width: calc(50% - 10px);
}

.plan1 .plan_item {
	padding-left: 0;
}

.plan1 .plan_item dt {
	width: 100px;
}

.plan1 .plan_item dd {
	width: 390px;
}

.plan3 .plan_item__price {
	height: 140px;
}

.planCircle .plan_item {
	justify-content: center;
	padding-left: 0;
}

.planCircle .plan_item dt {
	width: 110px;
}

.planCircle .plan_item dd {
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
}

.plan {
	margin-bottom: 90px;
}

.plan_contents {
	line-height: 1.2;
}

.plan_wrap {
	display: flex;
	justify-content: space-between;
}

.plan_info {
	margin-bottom: 50px;
}

.plan_ttl {
	background-color: #fff;
	border-radius: 10px;
	color: #55934f;
	font-size: 3rem;
	margin-bottom: 30px;
	padding: 10px;
	text-align: center;
}

.plan_item {
	align-items: center;
	border-bottom: 1px dashed #918b8b;
	display: flex;
	height: 90px;
	justify-content: center;
	padding: 20px 0;
	padding-left: 5%;
}

.plan_item dt {
	width: 180px;
}

.plan_item dd {
	color: #000;
	width: 550px;
}

.plan_heading {
	font-size: 2.6rem;
	font-weight: bold;
}

.plan_desc {
	align-items: center;
	display: flex;
	font-size: 3.6rem;
	font-weight: bold;
}

.plan_desc__md {
	font-size: 2.6rem;
	font-weight: bold;
}

.plan_desc__box {
	width: 150px;
}

.plan_desc > p:last-child {
	margin-bottom: -15px;
}

.plan_price {
	color: #55934f;
	font-size: 4rem;
}

.plan_price__lg {
	font-family: "century-gothic", sans-serif;
	font-size: 6rem;
}

.plan_price__sm {
	font-size: 2.2rem;
}

.plan_note {
	margin-bottom: 20px;
	margin-top: 30px;
}

.plan_link {
	color: #25c6d1;
}

/* ----------------------------------------
catch
---------------------------------------- */

.catch {
	color: #55934f;
	display: flex;
	justify-content: center;
	line-height: 1;
	text-align: center;
}

.catch li {
	margin-bottom: 20px;
	width: calc((100% - 160px) / 3);
}

.catch_heading {
	font-size: 2.4rem;
	font-weight: bold;
}

.catch_num {
	font-size: 6rem;
	font-weight: bold;
}

.catch_num__lg {
	font-family: "century-gothic", sans-serif;
	font-size: 14rem;
}

.catch_note {
	color: #000;
	font-size: 1.8rem;
	margin-bottom: 60px;
	text-align: center;
}

/* ----------------------------------------
list
---------------------------------------- */

.list {
	margin: 0 auto 100px;
	max-width: 750px;
}

.list li {
	align-items: center;
	border-bottom: 1px dashed #918b8b;
	display: flex;
	justify-content: space-between;
	padding: 15px 50px 20px;
}

.list_heading {
	font-size: 2.8rem;
	font-weight: bold;
	padding-top: 10px;
}

.list_num {
	color: #55934f;
	font-size: 4rem;
	font-weight: bold;
	line-height: 1;
}

.list_num__lg {
	font-family: "century-gothic", sans-serif;
	font-size: 6rem;
	margin-right: 5px;
}

/* ----------------------------------------
flowStep
---------------------------------------- */

.flowStep {
	background-color: #f2f3f7;
	margin-bottom: 70px;
	padding-bottom: 70px;
	padding-top: 70px;
}

.flowStep .media {
	align-items: flex-start;
	background-color: #fff;
	border-radius: 20px;
	padding: 25px;
	padding-left: 60px;
}

.flowStep .media:not(:last-child) {
	margin-bottom: 40px;
	position: relative;
}

.flowStep .media:not(:last-child)::after {
	border-color: #55934f transparent transparent transparent;
	border-style: solid;
	border-width: 15px 15px 0 15px;
	bottom: -30px;
	content: "";
	height: 0;
	left: 50%;
	position: absolute;
	transform: translateX(-50%);
	width: 0;
}

.flowStep .media_heading {
	font-size: 3rem;
}

.flowStep .media_img {
	width: 340px;
}

.flowStep__sp {
	display: none;
}

/* ----------------------------------------
home
---------------------------------------- */

#home .mainvisual {
	padding: 0;
}

#home .mainvisual_inner {
	border-radius: 50px;
	overflow: hidden;
	position: relative;
	padding:0 15px;
}

#home .mainvisual_img__sp {
	display: none;
}

#home .topCta_inner {
	background-color: #fff;
	border-radius: min(1.3793103448vw, 16px);
	box-shadow: 2px 3.464px 8.19px 0.81px rgba(145, 139, 139, 0.31);
	margin: max(-3.4482758621vw, -40px) auto 60px;
	padding: min(1.724137931vw, 20px) min(3.4482758621vw, 40px);
	position: relative;
}

#home .topCta .cta_btn {
	margin-bottom: min(1.724137931vw, 20px);
}

#home .topCta .cta_info {
	align-items: center;
	display: flex;
	gap: min(0.8620689655vw, 10px);
}

#home .topCta .cta_name {
	width: 26.2%;
}

#home .topCta .cta_telWrap {
	width: 68.6%;
}

#home .topCta .cta_tel.pc {
	width: 70.8%;
}

#home .topCta .cta_tel.sp {
	display: none;
}

#home .topCta .cta_time.pc {
	width: 27.4%;
}

#home .topCta .cta_time.sp {
	display: none;
}

#home .campaign {
	margin-bottom: 60px;
}

#home .feature {
	padding-bottom: 80px;
	padding-top: 80px;
	position: relative;
}

#home .feature_bg {
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	height: 53%;
	position: absolute;
	top: 0;
	width: 100%;
	z-index: -1;
}

#home .feature_bg__sp {
	display: none;
}

#home .feature_contents {
	display: flex;
}

#home .feature_contents li {
	width: 25%;
}

#home .case {
	background-color: #f2f3f7;
	padding-bottom: 80px;
	padding-top: 80px;
}

#home .case .slick-list {
	overflow: visible;
}

#home .case .slick-track {
	display: flex;
}

#home .case .slick-slide {
	height: auto;
}

#home .case_prev,
#home .case_next {
	background-color: #55934f;
	border-radius: 50%;
	height: 40px;
	position: absolute;
	top: 40%;
	width: 40px;
	z-index: 1;
}

#home .case_prev::after,
#home .case_next::after {
	border-right: 3px solid #fff;
	border-top: 3px solid #fff;
	content: "";
	height: 12px;
	position: absolute;
	top: 14px;
	transform-origin: center;
	width: 12px;
}

#home .case_prev {
	left: 20px;
}

#home .case_prev::after {
	left: 16px;
	transform: rotate(-135deg);
}

#home .case_next {
	right: 20px;
}

#home .case_next::after {
	right: 16px;
	transform: rotate(45deg);
}

#home .case_dots {
	display: flex;
	gap: 20px;
	justify-content: center;
	margin-top: 50px;
}

#home .case_dots li {
	background-color: #d7dadf;
	border-radius: 50%;
	color: transparent;
	height: 12px;
	width: 12px;
}

#home .case_dots li.slick-active {
	background-color: #61b633;
}

#home .case_item {
	background-color: #fff;
	border-radius: 20px;
	margin: 0 20px;
	padding: 40px 30px;
}

#home .case_ttl {
	background-color: #e9f0d3;
	border-radius: 6px;
	font-size: 2.2rem;
	margin-bottom: 20px;
	padding: 10px 20px;
}

#home .case_img {
	display: flex;
	gap: 10px;
	position: relative;
}

#home .case_img::after {
	background-image: url(../img/arrow.png);
	background-size: contain;
	content: "";
	filter: drop-shadow(0 0 3px rgba(0, 0, 0, 0.5));
	height: 57px;
	left: 47%;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 48px;
}

#home .case_img img {
	aspect-ratio: 1;
	width: calc((100% - 10px) / 2);
	object-fit: cover;
}

#home .case_txtArea {
	color: #000;
}

#home .case_heading {
	color: #333;
	margin-bottom: 5px;
	margin-top: 20px;
}

#home .case_heading p {
	display: inline-block;
	font-size: 1.8rem;
	margin-left: 5px;
}
#home .top-homePlan{
	background-color: #EDF8E3;
	margin-bottom: 0;
	padding-bottom: 80px;
	padding-top: 80px;
	position: relative;
}
@media screen and (max-width: 768px) {
	#home .top-homePlan{
		padding-bottom: 8vw;
		padding-top: 8vw;
	}
}
#home .top-homePlan__contents{
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	flex-wrap: wrap;
	gap: 18px;
	justify-content: center;
}
@media screen and (max-width: 1024px) {
	#home .top-homePlan__contents{
		grid-template-columns: repeat(2, 1fr);
	}
}
@media screen and (max-width: 768px) {
	#home .top-homePlan__contents{
		grid-template-columns: repeat(1, 1fr);
	}
}

#home .top-homePlan__item{
	width: 100%; 
	height: 100%; 
	background: #F2F3F7; 
	box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25); 
	border-radius: 10px
}
#home .top-homePlan__item_img{

	width: 100%;
	height: auto;
	aspect-ratio: 328 / 205;
	border-radius: 10px;
}
#home .top-homePlan__item_img img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 10px;
}
#home .top-homePlan__item_contents{
	padding: 20px 26px 0 26px;
}
#home .top-homePlan__item_text{
color: #202020;
 font-size: 18px;
 font-family: Yu Gothic;
 font-weight: 700;
 letter-spacing: 1.08px;
 text-align: center;

}
@media screen and (max-width: 768px) {
	#home .top-homePlan__item_text{
		font-size: 4.2666666667vw;
	}
}
#home .top-homePlan__item_tags{
	color: #fff;
 font-size: 14px;
 font-family: Yu Gothic;
 font-weight: 700;
 letter-spacing: 0.84px;
 background: #6BA165;
 border-radius: 10px;
 text-align: center;
 padding: 4.5px 0;
 width: 100%;
 margin-top: 12px;
}
@media screen and (max-width: 768px) {
	#home .top-homePlan__item_tags{
		font-size: 4.2666666667vw;
	}
}
#home .top-homePlan__item_tags-small{
	color: #fff;
	font-size: 14px;
	font-family: Yu Gothic;
	font-weight: 700;
	letter-spacing: 0.84px;
	background: #BAD554;
	border-radius: 10px;
	text-align: center;
	padding: 4.5px 0;
	width: 100%;
	margin-top: 12px;
}
@media screen and (max-width: 768px) {
	#home .top-homePlan__item_tags-small{
		font-size: 4.2666666667vw;
	}
}
#home .top-homePlan__item_price{
	color: #6BA165;
	 font-size: 92px;
	 font-family: Helvetica;
	 font-weight: 700;
	 letter-spacing: 5.52px;
	 word-wrap: break-word;
	 text-align: center;
}
@media screen and (max-width: 768px) {
	#home .top-homePlan__item_price{
		font-size: 13.2666666667vw;
	}
}
#home .top-homePlan__item_price-small{
	color: #6BA165;
	font-size: 42px;
	font-family: Helvetica;
	font-weight: 700;
	letter-spacing: 2.52px;
	word-wrap: break-word;
	text-align: center;
}
@media screen and (max-width: 768px) {
	#home .top-homePlan__item_price-small{
		font-size: 13.2666666667vw;
	}
}
#home .top-homePlan__item_price-3{
	color: #6BA165;
font-size: 64px;
font-family: Helvetica;
font-weight: 700;
letter-spacing: 3.84px;
word-wrap: break-word;
text-align: center;
margin-top: 21px;
margin-bottom: 25px;
}
@media screen and (max-width: 768px) {
		#home .top-homePlan__item_price-3{
			font-size: 13.2666666667vw;
	}
}
#home .top-homePlan__item_price_unit{

	color: #6BA165;
	 font-size: 54px;
	 font-family: Helvetica;
	 font-weight: 700;
	 letter-spacing: 3.24px;
	 word-wrap: break-word;
}
@media screen and (max-width: 768px) {
	#home .top-homePlan__item_price_unit{
		font-size: 3.2666666667vw;
	
	}
}
#home .top-homePlan__item_price_unit-small{

	color: #6BA165;
font-size: 18px;
font-family: Helvetica;
font-weight: 700;
letter-spacing: 1.08px;
word-wrap: break-word;
text-align: center;
}
#home .top-homePlan__item_price_unit-3{
	color: #6BA165;
	font-size: 24px;
	font-family: Helvetica;
	font-weight: 700;
	letter-spacing: 1.44px;
	word-wrap: break-word;
	text-align: center;
}

#home .top-homePlan__item_btn{
	color: black;
	 font-size: 14px;
	 font-family: Yu Gothic;
	 font-weight: 700;
	 letter-spacing: 0.84px;
	 word-wrap: break-word;
	 padding: 14px 0;
	 text-align: center;
	 border-top: 1px solid #FFFFFF;
	 margin-left: calc(50% - 50%);
	 margin-right: calc(50% - 50%);
	 position: relative;
}
@media screen and (max-width: 768px) {
	#home .top-homePlan__item_btn{
		font-size: 4.2666666667vw;
		padding: 3.2666666667vw 0;
	}
}
#home .top-homePlan__item_btn::after {
	content: "";
	position: absolute;
	right: 20px;
	top: 50%;
	transform: translateY(-50%) rotate(45deg);
	width: 8px;
	height: 8px;
	border-right: 2px solid #6BA165;
	border-top: 2px solid #6BA165;
	transition: all 0.3s ease;
}
@media screen and (max-width: 768px) {
	#home .top-homePlan__item_btn::after{
		width: 3.2666666667vw;
		height: 3.2666666667vw;
		right: 10.2666666667vw;
	}
}

#home .top-homePlan__info-text{
color: #616062;
 font-size: 12px;
 font-family: Noto Sans JP;
 font-weight: 500;
 letter-spacing: 0.60px;
 word-wrap: break-word;
 text-shadow: 0px 0px 30px rgba(255, 255, 255, 1.00);
 margin-top: 19px;
}
@media screen and (max-width: 768px) {
	#home .top-homePlan__info-text{
		font-size: 3.2666666667vw;
	}
}

#home .homePlan {
	background-color: #EDF8E3;
	margin-bottom: 0;
	padding-bottom: 80px;
	padding-top: 80px;
	position: relative;
}
@media screen and (max-width: 768px) {
	#home .top-homePlan__info{
		padding-top: 10vw;
		padding-bottom: 10vw;
	}
}

#home .homePlan_bg {
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	height: 53%;
	position: absolute;
	top: 0;
	width: 100%;
}

#home .homePlan_bg__sp {
	display: none;
}

#home .homePlan .topSection_ttl {
	position: relative;
}

#home .homePlan_txt {
	color: #fff;
	margin-bottom: 60px;
	position: relative;
	text-align: center;
}

#home .homePlan_contents {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	justify-content: center;
}


#home .homePlan_item {
	background-color: #fff;
	border: none;
	border-radius: 14px;
	box-shadow: 2px 3.464px 8.19px 0.81px rgba(145, 139, 139, 0.31);
	display: block;
	overflow: hidden;
	padding: 0;
	position: relative;
	text-align: center;
	width: calc((100% - 40px) / 3);
}

#home .homePlan_heading {
	background-color: #55934f;
	border-bottom: 5px solid #b8d554;
	color: #fff;
	font-family: "century-gothic", sans-serif;
	font-size: 3.6rem;
	padding: 15px;
}

#home .homePlan_heading__sm {
	font-weight: 500;
}

#home .homePlan_body {
	padding: 30px;
	padding-bottom: 110px;
}

#home .homePlan_catch {
	font-size: 2.6rem;
}

#home .homePlan_img {
	display: grid;
	height: 200px;
	place-items: center;
}

#home .homePlan_desc {
	line-height: 1.6;
	text-align: justify;
}

#home .homePlan_btn {
	bottom: 30px;
	font-size: 1.6rem;
	left: 50%;
	min-width: auto;
	position: absolute;
	transform: translateX(-50%);
	width: calc(100% - 60px);
}

#home .top-feature{
	background-color: #FFFFFF;
	margin-bottom: 0;
	padding-bottom: 80px;
	padding-top: 80px;
	position: relative;
}
@media screen and (max-width: 768px) {
	#home .top-feature{
		padding-bottom: 8vw;
		padding-top: 8vw;
	}
}
.top-feature__contents{
	margin-top: 64px;
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
	gap: 24px;
}
@media screen and (max-width: 768px) {
	#home .top-feature__contents{
		margin-top: 10vw;
		gap: 4vw;
	}
}
@media screen and (max-width: 768px) {
	#home .top-feature__contents{
		margin-top: 6vw;
		gap: 4vw
	}
}
#home .top-feature__item{
	display: flex;
	align-items: center;
	gap: 24px;
}
@media screen and (max-width: 768px) {
	#home .top-feature__item{
		gap: 4vw;
	}
}
#home .top-feature__item-1{
	display: flex;
	align-items: flex-start;
	gap: 24px;

}
@media screen and (max-width: 768px) {
	#home .top-feature__item-1{
		gap: 4vw;
		align-items: center;
	}
}
@media screen and (max-width: 768px) {
	#home .top-feature__item-1{
		flex-direction: column-reverse;
	}
	#home .top-feature__item{
		flex-direction: column-reverse;
	}
}
#home .top-feature__item_img{
	max-width: 317px;
	width: 100%;
	height: auto;
	aspect-ratio: 1 / 1;
	border-radius: 16px;
}
@media screen and (max-width: 768px) {
	#home .top-feature__item-1{
		gap: 4vw;
	}
}
#home .top-feature__item_img img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 16px;
}
.top-feature__item_heading_sub{
color: #56934E;
 font-size: 18px;
 font-family: Yu Gothic;
 font-weight: 700;
 letter-spacing: 1.08px;
 word-wrap: break-word;
}
@media screen and (max-width: 768px) {
	#home .top-feature__item_heading_sub{
		font-size: 4.2666666667vw;
	}

}
.top-feature__item_heading_title{
color: black;
 font-size: 24px;
 font-family: Yu Gothic;
 font-weight: 700;
 letter-spacing: 1.44px;
 word-wrap: break-word
}
@media screen and (max-width: 768px) {
	#home .top-feature__item_heading_title{
		font-size: 4.2666666667vw;
	}
}
.top-feature__item_text{
 color: black;
font-size: 16px;
font-family: Yu Gothic;
font-weight: 700;
letter-spacing: 0.96px;
word-wrap: break-word;
}
@media screen and (max-width: 768px) {
	#home .top-feature__item_text{
		font-size: 3.2666666667vw;
	}
}
.top-feature__item_text:last-child{
 margin-top: 16px;
}
@media screen and (max-width: 768px) {
	#home .top-feature__item_text:last-child{
		margin-top: 4vw;
	}
}
.top-feature__item_wrapper{
 display: flex;
 flex-direction: column;
 gap: 8px;
 margin-top: 26px;
}
@media screen and (max-width: 768px) {
	#home .top-feature__item_wrapper{
		margin-top: 4vw;
	}
}
.top-feature__item_wrap-1{
 display: flex;
 gap: 16px;
 border-radius: 8px;
border: 1px solid #CACACA;
padding: 12px 16px;
}
@media screen and (max-width: 768px) {
	.top-feature__item_wrap-1{
		flex-direction: column;
		align-items: center;
		padding: 4vw;
	}
}
.top-feature__item_wrap-1_img{
 max-width: 91px;
 width: 100%;
 height: auto;
 aspect-ratio: 1 / 1;
}
@media screen and (max-width: 768px) {
	.top-feature__item_wrap-1_img{
		max-width: 40vw;
	}
}
.top-feature__item_wrap-1_img img{
 width: 100%;
 height: 100%;
 object-fit: contain;
}
.top-feature__item_wrap-1_texts_title{

color: black;
 font-size: 16px;
 font-family: Yu Gothic;
 font-weight: 700;
 letter-spacing: 0.96px;
 word-wrap: break-word;
}
@media screen and (max-width: 768px) {
	.top-feature__item_wrap-1_texts_title{
		font-size: 4.2666666667vw;
	}
}
.top-feature__item_wrap-1_texts{
	
}
.top-feature__item_wrap-1_texts_text{
 display: flex;
 align-items: center;
 gap: 8px;
 margin-top: 10px;
}
@media screen and (max-width: 768px) {
	.top-feature__item_wrap-1_texts_text{
		margin-top: 4vw;
	}
}
.top-feature__item_wrap-1_texts_text_tag{
 display: flex;
 width: 84px;
 padding: 2px 8px;
 justify-content: center;
 align-items: center;
 gap: 10px;
 background-color: #EEEEEE;
 border-radius: 50px;
 font-size: 14px;
 font-weight: 700;
 letter-spacing: 0.84px;
 word-wrap: break-word;
}
@media screen and (max-width: 768px) {
	.top-feature__item_wrap-1_texts_text_tag{
		font-size: 3.2666666667vw;
		width: 20vw;
	}
}
.top-feature__item_wrap-1_texts_text_tag-2{
 display: flex;
 width: 84px;
 padding: 2px 8px;
 justify-content: center;
 align-items: center;
 gap: 10px;
 border-radius: 50px;
border: 1px solid #589450;
background: #FFF;
color: #000;
font-family: "Yu Gothic";
font-size: 14px;
font-style: normal;
font-weight: 700;
line-height: normal;
letter-spacing: 0.84px;

}
@media screen and (max-width: 768px) {
	.top-feature__item_wrap-1_texts_text_tag-2{
		font-size: 3.2666666667vw;
		width: 20vw;
	}
}

.top-feature__item_wrap-1_texts_text_item{
 color: #000;
font-family: "Yu Gothic";
font-size: 14px;
font-style: normal;
font-weight: 700;
line-height: normal;
letter-spacing: 0.84px;
flex: 1 0 0;
}
@media screen and (max-width: 768px) {
	.top-feature__item_wrap-1_texts_text_item{
		font-size: 3.2666666667vw;
	}
}
/* 割引 */
#home .top-discount{
 background-color: #EDF8E3;
 margin-bottom: 0;
 padding-bottom: 80px;
 padding-top: 80px;
 position: relative;
}

@media screen and (max-width: 750px) {
 #home .top-discount {
 padding-bottom: 8vw;
 padding-top: 8vw;
 }
}
.top-discount__contents{
 display: flex;
 gap: 39px;
 justify-content: center;
 align-items: flex-start;
 margin-top: 64px;
}
@media screen and (max-width: 750px) {
 .top-discount__contents{
 flex-direction: column;
 gap: 40px;
 margin-top: clamp(40px, 4vw, 60px);
 padding: 0 0;
 align-items: center;
 }
 
 .discount-card,
 .discount-card--student {
 width: 100%;
 }
}
.top-discount__text{
 color: #000;
text-align: center;
font-family: "Yu Gothic";
font-size: 18px;
font-style: normal;
font-weight: 700;
line-height: normal;
letter-spacing: 1.08px;
text-align: center;
}
/* 割引カード */
.discount-card {
 position: relative;
 max-width: clamp(350px, 45vw, 500px);
 width: 100%;
 background: #ffffff;
 border: 3px solid #57944f;
 border-radius: clamp(20px, 4vw, 40px);
 box-shadow: 0px 1px 34px 0px rgba(0, 0, 0, 0.15);
 padding: clamp(20px, 4vw, 40px) clamp(15px, 2.7vw, 27px) clamp(15px, 2.7vw, 27px);
}

.discount-card__badge {
 position: absolute;
 top: clamp(-20px, -2.5vw, -25px);
 left: 50%;
 transform: translateX(-50%);
 background: #57944f;
 border-radius: clamp(20px, 4vw, 40px);
 padding: clamp(4px, 0.6vw, 6px) clamp(25px, 3vw, 40px);
}

.discount-card__badge-text {
 color: #ffffff;
 font-family: "Yu Gothic", sans-serif;
 font-weight: 700;
 font-size: clamp(18px, 2.4vw, 24px);
 line-height: 1.6;
 letter-spacing: 0.06em;
}

.discount-card__max-text {
 color: #57944f;
 font-family: "Yu Gothic", sans-serif;
 font-weight: 700;
 font-size: clamp(16px, 2vw, 40px);
 line-height: 1.4;
 text-align: center;
 margin: clamp(10px, 1.5vw, 25px) 0 clamp(-5px, -0.5vw, -3px);
}

.discount-card__discount {
 color: #57944f;
 font-family: "YuGothic", sans-serif;
 font-weight: 700;
 font-size: clamp(48px, 8vw, 92px);
 line-height: 1.0;
 letter-spacing: 0.06em;
 text-align: center;
 margin:0 0 clamp(15px, 2vw, 20px);
}

.discount-card__divider {
 width: 454px;
 max-width: 90%;
 height: 2px;
 background: #57944f;
 margin: 0 auto 16px;
}

.discount-card__conditions {
 margin-bottom: 20px;
}

.discount-card__condition {
 display: flex;
 align-items: flex-start;
 gap: 8px;
 margin-bottom: 16px;
}

.discount-card__condition:last-child {
 margin-bottom: 0;
}

.discount-card__check-icon {
 width: 20px;
 height: 20px;
 background: #57944f;
 border-radius: 50%;
 flex-shrink: 0;
 position: relative;
}

.discount-card__check-icon::after {
 content: "✓";
 position: absolute;
 top: 50%;
 left: 50%;
 transform: translate(-50%, -50%);
 color: #ffffff;
 font-size: 12px;
 font-weight: bold;
}

.discount-card__condition-text {
 color: #000000;
 font-family: "Yu Gothic", sans-serif;
 font-weight: 700;
 font-size: clamp(14px, 1.6vw, 16px);
 line-height: 1.5;
 letter-spacing: 0.06em;
 flex: 1;
}

.discount-card__note {
 color: #000000;
 font-family: "Yu Gothic", sans-serif;
 font-weight: 700;
 font-size: clamp(9px, 1vw, 10px);
 line-height: 1.6;
 letter-spacing: 0.06em;
 margin: 0;
}
.discount-card__text{
 color: #000;
 text-align: center;
 font-family: "Yu Gothic";
 font-size: 16px;
 font-style: normal;
 font-weight: 700;
 line-height: normal;
 letter-spacing: 0.96px;
 text-align: center;
 padding-top: 24px;
 max-width: 500px;
 width: 100%;
}
.discount-card-wrap-text{
 color: #000;
text-align: center;
font-family: "Yu Gothic";
font-size: 12px;
font-style: normal;
font-weight: 700;
line-height: normal;
letter-spacing: 0.72px;
margin-top: 34px;
text-align: left;
display: grid;
place-items: center;
}
/* レスポンシブ対応 */
@media screen and (max-width: 750px) {
 .top-discount__text {
 font-size: clamp(12px, 2.5vw, 18px);
 letter-spacing: 0.96px;
 margin-bottom: 20px;
 }
 
 .discount-card {
 padding: clamp(10px, 4vw, 40px) clamp(10px, 2vw, 20px) clamp(10px, 2vw, 20px);
 margin: 0 auto;
 }
 
 .discount-card__badge {
 padding: 4px 8px;
 top: -20px;
 }
 
 .discount-card__badge-text {
 font-size: clamp(16px, 2.5vw, 20px);
 }
 
 .discount-card__max-text {
 font-size: clamp(16px, 2.5vw, 18px);
 margin: clamp(20px, 1.2vw, 12px) 0 clamp(-3px, -0.3vw, -2px);
 }
 
 .discount-card__discount {
 font-size: clamp(50px, 10vw, 60px);
 margin: 0 0 clamp(10px, 2vw, 15px);
 }
 
 .discount-card__discount-unit {
 font-size: clamp(24px, 8vw, 32px);
 letter-spacing: clamp(1.5px, 0.5vw, 2px);
 }
 
 .discount-card__divider {
 width: 90%;
 }
 
 .discount-card__condition {
	align-items: flex-start;
	
	}
 .discount-card__condition-text {
 font-size: clamp(14px, 2.5vw, 16px);

 }
 
 .discount-card__note {
 font-size: clamp(12px, 2.5vw, 14px);
 line-height: 1.4;
 }
 
 .discount-card__text {
 font-size: clamp(12px, 2.5vw, 14px);
 letter-spacing: 0.84px;
 padding-top: 20px;
 text-align: left;
 }
 
 .discount-card-wrap-text {
 font-size: 10px;
 letter-spacing: 0.6px;
 margin-top: 24px;
 text-align: left;
 }
}
.discount-card__discount-unit{
 color: #57944F;
 font-family: Helvetica;
 font-size: clamp(32px, 5.4vw, 54px);
 font-style: normal;
 font-weight: 700;
 line-height: normal;
 letter-spacing: clamp(2px, 0.32vw, 3.24px);
}

/* 学生割引カード */
.discount-card--student {
 position: relative;
 max-width: clamp(350px, 45vw, 500px);
 width: 100%;
 background: #ffffff;
 border: 3px solid #f17400;
 border-radius: clamp(20px, 4vw, 40px);
 box-shadow: 0px 1px 34px 0px rgba(0, 0, 0, 0.15);
 padding: clamp(20px, 4vw, 40px) clamp(15px, 2.7vw, 27px) clamp(15px, 2.7vw, 27px);
}

.discount-card__badge--student {
 position: absolute;
 top: clamp(-20px, -2.5vw, -25px);
 left: 50%;
 transform: translateX(-50%);
 background: #f17400;
 border-radius: clamp(20px, 4vw, 40px);
 padding: clamp(4px, 0.6vw, 6px) clamp(25px, 4vw, 40px);
}

.discount-card__discount--student {
 color: #57944f;
 font-family: "YuGothic", sans-serif;
 font-weight: 700;
 font-size: clamp(48px, 8vw, 92px);
 line-height: 1.5;
 letter-spacing: 0.06em;
 text-align: center;
 margin: clamp(20px, 3vw, 30px) 0 clamp(10px, 1.5vw, 15px);
}

.discount-card__divider--student {
 width: 454px;
 max-width: 90%;
 height: 2px;
 background: #f17400;
 margin: 0 auto 16px;
}

.discount-card__check-icon--student {
 width: 20px;
 height: 20px;
 background: #f17400;
 border-radius: 50%;
 position: relative;
 flex-shrink: 0;
}

.discount-card__check-icon--student::after {
 content: "✓";
 position: absolute;
 top: 50%;
 left: 50%;
 transform: translate(-50%, -50%);
 color: #ffffff;
 font-size: 12px;
 font-weight: bold;
}

@media screen and (max-width: 750px) {
 .discount-card--student {
 padding: clamp(10px, 4vw, 40px) clamp(10px, 2vw, 20px) clamp(10px, 2vw, 20px);
 margin: 0 auto;
 }

 .discount-card__badge--student {
 padding: 4px 30px;
 top: -20px;
 }

 .discount-card__badge--student .discount-card__badge-text {
 font-size: clamp(16px, 2.5vw, 20px);
 }

 .discount-card__discount--student {
 font-size: clamp(50px, 10vw, 60px);
 margin: 0 0 clamp(10px, 2vw, 15px);
 }

 .discount-card__divider--student {
 width: 90%;
 }
}

	
#home .service {
	background-color: #f2f3f7;
	padding-bottom: 80px;
	padding-top: 80px;
}

#home .service_txt {
	margin: 0 auto 50px;
	max-width: 600px;
	text-align: center;
}

#home .service_cardWrap {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	justify-content: center;
}

#home .service .card__primary {
	width: calc((100% - 40px) / 3);
}

#home .service .card__primary .btn {
	font-size: 1.6rem;
	padding: 15px;
	width: 100%;
}

#home .service .btn {
	min-width: unset;
}

#home .message_top {
	display: flex;
	height: 280px;
	margin-bottom: 100px;
}

#home .message_top img {
	-o-object-fit: cover;
	object-fit: cover;
	width: 20%;
}

#home .message_top img:first-child,
#home .message_top img:last-child {
	width: 30%;
}

#home .message .media {
	color: #000;
	flex-direction: row-reverse;
}

#home .message .media_body {
	padding-right: 80px;
}

#home .message .media_heading {
	font-size: 2.2rem;
}

#home .message .media_heading__sub {
	font-size: 1.8rem;
	font-weight: 500;
}

#home .message .media_txt {
	margin-bottom: 40px;
}

#home .message .media_img {
	border-radius: 20px;
	height: 330px;
}

#home .faq {
	background-color: #f2f3f7;
	margin-bottom: 80px;
	padding-bottom: 80px;
	padding-top: 80px;
}

/* cta-2 */
/* .cta-2{
	background-color: #57944F;
	padding-top: 37px;
	padding-bottom: 37px;
}
.cta-2__title{
	color: #FFF;
	font-family: "Yu Gothic";
	font-size: clamp(18px, 3.5vw, 32px);
	font-style: normal;
	font-weight: 700;
	line-height: normal;
	letter-spacing: clamp(1.08px, 0.2vw, 1.92px);
	text-align: center;
	position: relative;
	width: 100%;
	margin: 0 auto;
	padding: 0 20px;
	box-sizing: border-box;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	gap: clamp(10px, 3vw, 30px);
}
.cta-2__title::before{
	content: "";
	display: block;
	width: clamp(25px, 4vw, 42px);
	height: clamp(30px, 5vw, 50px);
	background-image: url(../img/cta-2-left.svg);
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
	flex-shrink: 0;
	align-self: flex-end;
	margin-bottom: clamp(5px, 1.5vw, 15px);
}
.cta-2__title::after{
	content: "";
	display: block;
	width: clamp(25px, 4vw, 42px);
	height: clamp(30px, 5vw, 50px);
	background-image: url(../img/cta-2-right.svg);
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
	flex-shrink: 0;
	align-self: flex-end;
	margin-bottom: clamp(5px, 1.5vw, 15px);
}
.cta-2__title__sub{
	color: #FFF;
	text-align: center;
	font-family: "Yu Gothic";
	font-size: clamp(16px, 2.5vw, 24px);
	font-style: normal;
	font-weight: 700;
	line-height: normal;
	letter-spacing: clamp(0.96px, 0.15vw, 1.44px);
}

.cta-2__title__main{
	color: #FFF;
	font-family: "Yu Gothic";
	font-size: clamp(18px, 3.5vw, 32px);
	font-style: normal;
	font-weight: 700;
	line-height: normal;
	letter-spacing: clamp(1.08px, 0.2vw, 1.92px);
	text-align: center;
	margin: 0;
} */

/* タイトルテキスト部分のラッパー */
/* .cta-2__title-text {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	flex: 1;
	min-width: 0;
	gap: clamp(5px, 1vw, 10px);
}
.cta-2_text{
	color: #FFF;
	text-align: center;
	font-family: "Yu Gothic";
	font-size: clamp(10px, 1.5vw, 14px);
	font-style: normal;
	font-weight: 700;
	line-height: 1.6;
	letter-spacing: clamp(0.6px, 0.1vw, 0.84px);
	margin-top: clamp(15px, 2.5vw, 24px);
	padding: 0 clamp(10px, 2vw, 20px);
}
.cta-2__btn{
 display: flex;
 justify-content: center;
}
.cta-2__btn a{
border-radius: 70px;
border: 2px solid #03575D;
background: #24C6D1;
box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
width: fit-content;
margin-top: 33px;
display: flex;
align-items: center;
padding: 15px 54px 15px 48px;
}
.cta-2__btn a::before{
content: "無料";
border-radius: 8px;
padding: 7px 18px;
background: #FFF;
color: #24C6D1;
text-align: center;
font-family: "Yu Gothic";
font-size: 32px;
font-style: normal;
font-weight: 700;
line-height: normal;
letter-spacing: 1.92px;
margin-right: 20px;
	}
.cta-2__btn a span{
 color: #FFF;
text-align: center;
font-family: "Yu Gothic";
font-size: 32px;
font-style: normal;
font-weight: 700;
line-height: normal;
letter-spacing: 1.92px;
}
.cta-2__btn-a{
 font-weight: 100 !important;
} */

/* cta-2 レスポンシブ対応 - 革新的アプローチ */
/* @media screen and (max-width: 768px) {
 .cta-2 {
 padding-top: clamp(20px, 4vw, 40px);
 padding-bottom: clamp(20px, 4vw, 40px);
 }
 
 .cta-2__title {
 gap: clamp(8px, 2vw, 20px);
 padding: 0 15px;
 }
 
 .cta-2_text {
 font-size: clamp(10px, 1.5vw, 14px);
 letter-spacing: clamp(0.6px, 0.1vw, 0.84px);
 line-height: 1.8;
 margin-top: clamp(15px, 2.5vw, 25px);
 margin-bottom: clamp(20px, 3vw, 30px);
 padding: 0 clamp(10px, 2vw, 20px);
 }
 
 .cta-2__btn a {
 padding: clamp(10px, 2vw, 15px) clamp(20px, 4vw, 54px) clamp(10px, 2vw, 15px) clamp(15px, 3vw, 48px);
 margin-top: clamp(20px, 3vw, 33px);
 }
 
 .cta-2__btn a::before {
 font-size: clamp(16px, 2.5vw, 32px);
 letter-spacing: clamp(0.96px, 0.15vw, 1.92px);
 padding: clamp(4px, 1vw, 7px) clamp(10px, 2vw, 18px);
 }
 
 .cta-2__btn a span {
 font-size: clamp(16px, 2.5vw, 32px);
 letter-spacing: clamp(0.96px, 0.15vw, 1.92px);
 }
} */

/* 極小画面での最終調整 */
/* @media screen and (max-width: 320px) {
 .cta-2__title {
 gap: 5px;
 padding: 0 10px;
 }
 
 .cta-2__title::before,
 .cta-2__title::after {
 width: 20px;
 height: 25px;
 margin-bottom: 3px;
 }
} */

#home .about .media {
	gap: 100px;
	margin-bottom: 70px;
}

#home .about .media:nth-child(odd) {
	flex-direction: row-reverse;
}

#home .about .media_heading {
	font-size: 2.8rem;
}

#home .about .media_txt {
	margin-bottom: 40px;
}

#home .about .media_img {
	border-radius: 20px;
	width: 48%;
}

#home .news {
	background-color: #f2f3f7;
	padding-bottom: 80px;
	padding-top: 80px;
}

#home .news_inner {
	display: flex;
	gap: 80px;
}
@media screen and (max-width: 768px) {
	#home .news_inner {
		flex-direction: column;
	}

}

#home .news_contents {
	width: calc((100% - 80px) / 2);
}
@media screen and (max-width: 768px) {
	#home .news_contents {
		width: 100%;
	}
}
#home .news_ttl {
	line-height: 1.3;
}

#home .news_ttl__en {
	color: #55934f;
	font-family: "century-gothic", sans-serif;
	font-size: 4rem;
	font-weight: 500;
}

#home .news_ttl__ja {
	font-size: 1.6rem;
}

#home .news_item {
	padding: 30px 0;
}

#home .news_item:not(:first-child) {
	border-top: 1px dotted;
}

#home .news_heading {
	color: #000;
	margin-top: 5px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

#home .news time {
	font-family: "century-gothic", sans-serif;
}

#home .news .btn {
	padding: 15px;
}


#home .about{
	padding-top: 70px;
}

#home .message{
	padding-bottom: 70px;
}


/* ----------------------------------------
first
---------------------------------------- */

#first .section_txt {
	color: #000;
	margin: 0 auto 70px;
	max-width: 730px;
	padding: 0 30px;
	width: 100%;
}

#first .forVisitor {
	margin-bottom: 100px;
}

#first .cta {
	margin-bottom: 100px;
}

#first .aboutAGA {
	margin-bottom: 100px;
}

#first .aboutAGA_catch {
	color: #55934f;
	font-size: 2.6rem;
	margin: 0 auto 30px;
	position: relative;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
}

#first .aboutAGA_catch::before,
#first .aboutAGA_catch::after {
	background-color: #55934f;
	content: "";
	height: 1px;
	position: absolute;
	top: 17px;
	width: 1.4em;
}

#first .aboutAGA_catch::before {
	right: 100%;
	transform: rotate(60deg);
}

#first .aboutAGA_catch::after {
	left: 100%;
	transform: rotate(-60deg);
}

#first .aboutAGA_contents {
	display: flex;
	gap: 20px;
	justify-content: space-between;
}

#first .aboutAGA_item {
	border-radius: 14px;
	width: calc((100% - 40px) / 3);
}

#first .aboutAGA_img__sp {
	display: none;
}

#first .treatment {
	background-color: #f2f3f7;
	padding-bottom: 80px;
	padding-top: 70px;
}

#first .treatment_cardWrap {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	justify-content: center;
}

#first .treatment .card__primary {
	padding: 20px 30px;
	width: calc((100% - 40px) / 3);
}

#first .treatment .btn {
	font-size: 1.6rem;
	min-width: unset;
	padding: 15px 0;
	width: 100%;
}

#first .feature {
	background-color: #e9f0d3;
	padding-bottom: 100px;
	padding-top: 70px;
}

#first .feature_contents {
	display: flex;
	flex-wrap: wrap;
	gap: 20px 10px;
	justify-content: center;
	margin-bottom: 70px;
}

#first .feature_contents li {
	width: calc((100% - 30px) / 4);
}

#first .feature_contents__sp {
	display: none;
}

#first .feature .media {
	background-color: #fff;
	border-radius: 20px;
	gap: 25px;
	padding: 40px;
	padding-right: 60px;
}

#first .feature .media:not(:last-child) {
	margin-bottom: 40px;
}

#first .feature .media_heading {
	font-size: 3rem;
}

#first .feature .media_heading span {
	display: inline-block;
}

#first .feature .media_img {
	min-width: 135px;
}

#first .flow {
	background-color: #f2f3f7;
	padding-bottom: 100px;
	padding-top: 70px;
}

#first .flow .media {
	align-items: flex-start;
	background-color: #fff;
	border-radius: 20px;
	padding: 25px;
	padding-left: 60px;
}

#first .flow .media:not(:last-child) {
	margin-bottom: 40px;
	position: relative;
}

#first .flow .media:not(:last-child)::after {
	border-color: #55934f transparent transparent transparent;
	border-style: solid;
	border-width: 15px 15px 0 15px;
	bottom: -30px;
	content: "";
	height: 0;
	left: 50%;
	position: absolute;
	transform: translateX(-50%);
	width: 0;
}

#first .flow .media_body {
	flex: 1;
}

#first .flow .media_heading {
	font-size: 3rem;
}

#first .flow_contents__sp {
	display: none;
}

/* ----------------------------------------
message
---------------------------------------- */

#message .director {
	color: #000;
	flex-direction: row-reverse;
	margin-bottom: 60px;
}

#message .director dt {
	font-weight: bold;
}

#message .director .media_body {
	padding-right: 70px;
}

#message .director .media_heading {
	font-size: 3rem;
}

#message .director .media_heading__sm {
	font-size: 1.8rem;
	font-weight: 500;
}

#message .director .media_img {
	border-radius: 20px;
}

#message .message {
	align-items: flex-start;
	gap: 100px;
	margin-bottom: 100px;
}

#message .message .section_ttl {
	margin-bottom: 20px;
	text-align: left;
}

#message .message .media_body {
	flex: 1;
}

#message .message .media_txt {
	color: #000;
	line-height: calc(36 / 16);
}

#message .message .media_img {
	width: 400px;
}

#message .message .media_img img {
	border-radius: 20px;
}

#message .message .media_img img:first-child {
	margin-bottom: 15px;
}

#message .profile .media {
	gap: 30px;
	justify-content: flex-start;
}

#message .profile .media_body {
	flex: 1;
}

#message .profile .media_img {
	align-self: flex-start;
	border-radius: 20px;
	width: 200px;
}

#message .profile_block:not(:last-child) {
	margin-bottom: 40px;
}

#message .profile_heading {
	background-color: #55934f;
	border-bottom: 5px solid #b8d554;
	border-radius: 20px 20px 0 0;
	color: #fff;
	font-size: 3.4rem;
	font-weight: bold;
	padding: 17px 50px;
}

#message .profile_body {
	background-color: #f2f3f7;
	border-radius: 0 0 20px 20px;
	padding: 50px 45px;
	padding-bottom: 70px;
}

#message .profile_name {
	font-size: 2.2rem;
	font-weight: bold;
	margin-bottom: 20px;
}

#message .profile_name p {
	font-size: 1.8rem;
	font-weight: 500;
}

#message .profile_contents {
	display: flex;
	gap: 4%;
	justify-content: space-between;
}

#message .profile_top {
	border-bottom: 1px dashed #918b8b;
	color: #000;
	margin-bottom: 30px;
	padding-bottom: 30px;
}

#message .profile_top .profile_item {
	margin-bottom: 0;
	width: 48%;
}

#message .profile_item {
	color: #000;
}

#message .profile_item:not(:last-child) {
	margin-bottom: 30px;
}

#message .profile_item dl:not(:last-child) {
	margin-bottom: 15px;
}

#message .profile_item dt {
	margin-right: 20px;
	width: 150px;
}

#message .profile_item dd {
	flex: 1;
}

#message .profile_item dd a {
	color: #25c6d1;
}

#message .profile_society__sp {
	display: none;
}

#message .profile_ttl {
	font-size: 1.8rem;
	font-weight: bold;
	margin-bottom: 10px;
}

#message .profile_ttl__sub {
	margin-bottom: 5px;
	margin-left: -10px;
}

#message .profile_listWrap {
	display: flex;
}

#musasi .media {
	align-items: center;
	display: flex;
	gap: 50px;
	justify-content: space-between;
	margin-top: 78px;
}
/* #musasi .media:not(:first-child) {
	margin-top: 0px;
} */

#musasi .media_heading {
	font-size: 2.6rem;
	margin-bottom: 20px;
}

#musasi .media_heading__highlight {
	color: #55934f;
}

#musasi .media_heading__line {
	margin-bottom: 40px;
	position: relative;
}

#musasi .media_heading__line::after {
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	background-image: repeating-linear-gradient(-45deg, rgba(184, 213, 84, 0.7), rgba(184, 213, 84, 0.7) 3px, transparent 4px, transparent 8px);
	bottom: -15px;
	content: "";
	height: 8px;
	left: 0;
	position: absolute;
	width: 100%;
}

#musasi .media_heading__flex {
	align-items: center;
	display: flex;
}

#musasi .media_body {
	flex: 1;
}

#musasi .media_num {
	font-family: "century-gothic", sans-serif;
	font-weight: bold;
	line-height: 1;
}

#musasi .media_num__primary {
	color: #55934f;
	font-family: "century-gothic", sans-serif;
	font-size: 4rem;
	font-weight: bold;
	line-height: 1;
	padding-right: 30px;
}

#musasi .media_num__primary span {
	font-size: 3rem;
	font-weight: 500;
	margin-right: 8px;
}

#musasi .media_txt {
	line-height: 1.6;
}

#musasi 		.media_img {
	-o-object-fit: cover;
	object-fit: cover;
}

#musasi .halfMedia > * {
	width: calc((100% - 50px) / 2);
}

#musasi .media__ribbon {
	position: relative;
	z-index: 1;
}

#musasi .media__ribbon::after {
	border-color: transparent transparent #55934f transparent;
	border-style: solid;
	border-width: 0 10px 10px 10px;
	bottom: 100%;
	content: "";
	height: 0;
	left: 70px;
	position: absolute;
	width: 0;
	z-index: -1;
}

#musasi .media__ribbon .media_num {
	background-color: #b8d554;
	color: #fff;
	font-size: 2.6rem;
	height: 55px;
	left: 20px;
	padding-top: 10px;
	position: absolute;
	text-align: center;
	top: -10px;
	width: 60px;
}

#musasi .media__ribbon .media_num::before,
#musasi .media__ribbon .media_num::after {
	border-style: solid;
	content: "";
	height: 0;
	position: absolute;
	top: 100%;
	width: 0;
}

#musasi .media__ribbon .media_num::before {
	border-color: transparent transparent transparent #b8d554;
	border-width: 0 0 10px 30px;
	left: 0;
}

#musasi .media__ribbon .media_num::after {
	border-color: transparent #b8d554 transparent transparent;
	border-width: 0 30px 10px 0;
	right: 0;
}

/* ----------------------------------------
flow
---------------------------------------- */

#flow .flowChart {
	display: flex;
	gap: 20px;
	justify-content: space-between;
	margin-bottom: 70px;
}

#flow .flowChart li {
	position: relative;
	width: calc((100% - 60px) / 4);
}

#flow .flowChart li:not(:last-child)::after {
	border-color: transparent transparent transparent #55934f;
	border-style: solid;
	border-width: 15px 0 15px 15px;
	content: "";
	height: 0;
	position: absolute;
	right: -18px;
	top: 50%;
	transform: translateY(-50%);
	width: 0;
}

#flow .flow_cta {
	color: #000;
	margin: 0 auto 70px;
	max-width: 900px;
	padding: 0 30px;
	width: 100%;
}

#flow .flow_cta .btn_wrap {
	align-items: center;
	display: flex;
	flex-direction: column;
}

#flow .flow_cta__reserve {
	margin-bottom: 10px;
}

#flow .flow_cta__line {
	margin-bottom: 20px;
}

#flow .flow_cta .sp {
	display: none;
}

#flow .forMinor {
	background-color: #f2f3f7;
	color: #000;
	padding: 70px 0;
}

#flow .forMinor_ttl {
	font-size: 2.2rem;
	margin-bottom: 10px;
}

#flow .forMinor_txt {
	margin-bottom: 20px;
}

#flow .forMinor .media {
	flex-direction: row-reverse;
}

#flow .forMinor .media_img {
	aspect-ratio: 3/2;
	border-radius: 20px;
	width: 300px;
}

#flow .forMinor .btn {
	font-size: 1.6rem;
}

/* ----------------------------------------
experience
---------------------------------------- */

#experience .forPatient_txt {
	margin-bottom: 80px;
	padding: 0 60px;
}

#experience .graph {
	background-color: #f2f3f7;
	border-radius: 20px;
	margin-bottom: 120px;
	padding: 60px 100px;
}

#experience .graph > section:first-child {
	margin-bottom: 70px;
}

#experience .graph_ttl {
	border-bottom: 4px double #918b8b;
	font-size: 3rem;
	margin: 0 auto;
	margin-bottom: 50px;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
}

#experience .graph_img .sp {
	display: none;
}

#experience .graph_txt {
	position: absolute;
	transform: translate(-50%, -50%);
}

#experience .attempt_ttl {
	font-size: 2.6rem;
	margin-bottom: 70px;
	text-align: center;
}

#experience .attempt .media {
	align-items: flex-start;
	gap: 80px;
	margin-bottom: 70px;
}

#experience .attempt .media:nth-child(even) {
	flex-direction: row-reverse;
}

#experience .attempt .media_img {
	border-radius: 20px;
}

#experience .attempt .media_num {
	color: #55934f;
	font-size: 4rem;
	margin-right: 22px;
	padding-left: 30px;
	padding-top: 15px;
	position: relative;
}

#experience .attempt .media_num img {
	left: -10px;
	max-width: none;
	position: absolute;
	top: -20px;
	width: 70px;
	z-index: -1;
}

#experience .attempt .media_heading {
	display: flex;
	letter-spacing: -1px;
}

#experience .attempt .media_heading__main {
	flex: 1;
	font-size: 2.4rem;
}

#experience .attempt .media_heading__main:first-letter {
	margin-left: -15px;
}

#experience .attempt .media_heading__highlight {
	display: inline;
	font-size: 3rem;
}

/* ----------------------------------------
service
---------------------------------------- */

#service .treatment_txt {
	margin-bottom: 70px;
	padding: 0 140px;
}

#service .treatment_heading {
	color: #55934f;
	font-size: 3.6rem;
	line-height: 1;
	margin-bottom: 10px;
}

#service .treatment_heading__sm {
	font-size: 2.6rem;
	letter-spacing: -1px;
	margin-left: -10px;
}

#service .treatment .media {
	align-items: flex-start;
	background-color: #f2f3f7;
	border-radius: 20px;
	padding: 40px 60px;
	padding-right: 20px;
}

#service .treatment .media:not(:last-child) {
	margin-bottom: 40px;
}

#service .treatment .media_body {
	flex: 1;
}

#service .treatment .media_num__primary span {
	font-size: 2.2rem;
}

#service .treatment .media_img {
	max-width: 370px;
	width: 40%;
}

#service .treatment_listWrap {
	margin-bottom: 20px;
}

#service .treatment_list {
	align-items: flex-start;
	display: flex;
	padding-bottom: 15px;
	padding-top: 10px;
}

#service .treatment_list:not(:last-child) {
	border-bottom: 1px dashed #918b8b;
}

#service .treatment_desc {
	font-size: 2rem;
	font-weight: bold;
	line-height: 1.3;
	padding-top: 12px;
}

#service .treatment .btn {
	font-size: 1.6rem;
	padding: 15px 0;
	width: 390px;
}

/* ----------------------------------------
serviceDetail
---------------------------------------- */

.parent-pageid-218 .feature {
	margin-bottom: 100px;
}

.parent-pageid-218 .feature .media {
	align-items: flex-start;
	gap: 100px;
}

.parent-pageid-218 .feature .media:not(:last-child) {
	margin-bottom: 80px;
}

.parent-pageid-218 .feature .media:nth-child(even) {
	flex-direction: row-reverse;
}

.parent-pageid-218 .feature .media_heading {
	font-size: 3rem;
}

.parent-pageid-218 .feature .media_num__primary {
	margin-bottom: 5px;
}

.parent-pageid-218 .feature .media_img {
	border-radius: 20px;
}

.parent-pageid-218 .feature_desc {
	color: #000;
}

.parent-pageid-218 .treatment .media {
	align-items: flex-start;
	gap: 100px;
	margin-bottom: 60px;
}

.parent-pageid-218 .treatment .media_heading {
	font-size: 3rem;
}

.parent-pageid-218 .treatment .media_num {
	color: #55934f;
	font-size: 3.6rem;
}

.parent-pageid-218 .treatment .media_img {
	border-radius: 20px;
}

.parent-pageid-218 .treatment_contents:not(:last-child) {
	margin-bottom: 90px;
}

.parent-pageid-218 .treatment_list li {
	border-bottom: 1px dashed #918b8b;
	display: flex;
	padding: 15px 0;
}

.parent-pageid-218 .treatment_desc {
	color: #000;
	font-size: 2rem;
	letter-spacing: -1px;
	margin-left: 15px;
	padding-top: 7px;
}

.parent-pageid-218 .treatment_example {
	background-color: #f2f3f7;
	border-radius: 20px;
	color: #000;
	padding: 40px 50px;
}

.parent-pageid-218 .treatment_example h4 {
	font-size: 2.2rem;
	margin-bottom: 20px;
}

.parent-pageid-218 .treatment_example .accordion_heading {
	background-color: #d7dadf;
	border-radius: 0;
	color: #000;
	font-size: 2rem;
	margin-bottom: 20px;
	padding: 10px 15px;
	padding-right: 90px;
}

.parent-pageid-218 .treatment_example .accordion_heading::before,
.parent-pageid-218 .treatment_example .accordion_heading::after {
	background-color: #000;
}

.parent-pageid-218 .treatment_example .accordion_body {
	padding: 0;
}

.parent-pageid-218 .treatment_example .accordion dl {
	margin-top: 20px;
}

/* ----------------------------------------
monitor
---------------------------------------- */

#monitor .mainvisual {
	margin-bottom: 100px;
}

#monitor .mainvisual_img {
	border-radius: 20px;
	margin-bottom: 50px;
}

#monitor .mainvisual_img__sp {
	display: none;
}

#monitor .mainvisual_txt {
	color: #000;
	text-align: center;
}

#monitor .mainvisual .btn {
	font-size: 2.6rem;
	padding: 22px;
	width: 500px;
}

#monitor .merit_contents {
	display: flex;
	gap: 20px;
	margin-bottom: 100px;
}

#monitor .merit_item {
	border-radius: 14px;
	width: calc((100% - 40px) / 3);
}

#monitor .merit_item__sp {
	display: none;
}

#monitor .merit_mediaWrap {
	margin-bottom: 90px;
}

#monitor .merit .media {
	align-items: flex-start;
	background-color: #f2f3f7;
	border-radius: 20px;
	gap: 40px;
	padding: 40px 50px;
	padding-right: 30px;
}

#monitor .merit .media:not(:last-child) {
	margin-bottom: 30px;
}

#monitor .merit .media_body {
	flex: 1;
}

#monitor .merit .media_desc {
	border-bottom: 1px dashed #918b8b;
	color: #000;
	padding-bottom: 25px;
	padding-top: 15px;
}

#monitor .merit .media_img {
	display: flex;
	gap: 5px;
	max-width: 450px;
	position: relative;
	width: 45%;
}

#monitor .merit .media_img::after {
	background-image: url(../img/arrow.png);
	background-size: contain;
	content: "";
	filter: drop-shadow(0 0 3px rgba(0, 0, 0, 0.5));
	height: 57px;
	left: 47%;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 48px;
}

#monitor .merit .media_img img {
	aspect-ratio: 1;
	width: calc((100% - 5px) / 2);
}

#monitor .merit_discount {
	font-size: 2.2rem;
	line-height: 1;
	margin-bottom: 5px;
	margin-top: 20px;
}

#monitor .merit_discount p {
	color: #ea8776;
	display: inline-block;
	font-family: "century-gothic", sans-serif;
	font-size: 5.6rem;
	margin-left: 10px;
}

#monitor .merit_discount span {
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
	font-weight: normal;
}

#monitor .outline {
	margin-bottom: 100px;
}

#monitor .outline .heading_lv3 {
	margin-bottom: 30px;
	text-align: center;
}

/* ----------------------------------------
case
---------------------------------------- */

#case .case .heading_lv3,
.tax-case_age .case .heading_lv3,
.tax-case_type .case .heading_lv3,
.search .case .heading_lv3 {
	margin-bottom: 50px;
	text-align: center;
}

#case .case_txt,
.tax-case_age .case_txt,
.tax-case_type .case_txt,
.search .case_txt {
	color: #000;
	font-size: 2rem;
	margin-bottom: 40px;
	text-align: center;
}

#case .case_contents,
.tax-case_age .case_contents,
.tax-case_type .case_contents,
.search .case_contents {
	margin-bottom: 60px;
}

#case .case .media,
.tax-case_age .case .media,
.tax-case_type .case .media,
.search .case .media {
	align-items: flex-start;
	background-color: #f2f3f7;
	border-radius: 14px;
	gap: 40px;
	padding: 30px 50px;
}

#case .case .media:not(:last-of-type),
.tax-case_age .case .media:not(:last-of-type),
.tax-case_type .case .media:not(:last-of-type),
.search .case .media:not(:last-of-type) {
	margin-bottom: 25px;
}

#case .case .media_img,
.tax-case_age .case .media_img,
.tax-case_type .case .media_img,
.search .case .media_img {
	display: flex;
	gap: 20px;
	justify-content: center;
	position: relative;
	width: calc(50% - 20px);
}

#case .case .media_img::after,
.tax-case_age .case .media_img::after,
.tax-case_type .case .media_img::after,
.search .case .media_img::after {
	border-color: transparent transparent transparent #55934f;
	border-style: solid;
	border-width: 16px 0 16px 15px;
	content: "";
	height: 0;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 0;
}

#case .case .media_img img,
.tax-case_age .case .media_img img,
.tax-case_type .case .media_img img,
.search .case .media_img img {
	-o-object-fit: cover;
	aspect-ratio: 22/21;
	object-fit: cover;
	width: calc(50% - 10px);
}

#case .case .media_body,
.tax-case_age .case .media_body,
.tax-case_type .case .media_body,
.search .case .media_body {
	flex: 1;
}

#case .case .media_ttl,
.tax-case_age .case .media_ttl,
.tax-case_type .case .media_ttl,
.search .case .media_ttl {
	border-bottom: 1px dashed #918b8b;
	font-size: 2.2rem;
	margin-bottom: 20px;
	padding: 10px 0;
}

#case .case .media_desc,
.tax-case_age .case .media_desc,
.tax-case_type .case .media_desc,
.search .case .media_desc {
	color: #000;
	font-size: 1.8rem;
	font-weight: bold;
	margin-bottom: 30px;
}

/* ----------------------------------------
caseDetail
---------------------------------------- */

.single-case .caseDetail {
	margin-bottom: 100px;
}

.single-case .caseDetail .heading_lv3 {
	font-size: 4rem;
	margin-bottom: 40px;
	text-align: center;
}

.single-case .caseDetail_imgWrap {
	display: flex;
	gap: 40px;
	justify-content: center;
	margin-bottom: 70px;
	position: relative;
}

.single-case .caseDetail_imgWrap::after {
	border-color: transparent transparent transparent #55934f;
	border-style: solid;
	border-width: 16.5px 0 16.5px 15px;
	content: "";
	height: 0;
	left: 50%;
	position: absolute;
	top: 35%;
	transform: translateX(-50%);
	width: 0;
}

.single-case .caseDetail_img {
	text-align: center;
	width: 275px;
}

.single-case .caseDetail_img img {
	-o-object-fit: cover;
	aspect-ratio: 22/21;
	border: 1px solid #f2f3f7;
	object-fit: cover;
	width: 100%;
}

.single-case .caseDetail_img figcaption {
	background-color: #e9f0d3;
	color: #000;
	font-size: 1.8rem;
	font-weight: bold;
	margin-top: 5px;
	padding: 7px;
}

.single-case .caseDetail .table_desc {
	font-size: 1.8rem;
}

.single-case .caseDetail .btn {
	width: 360px;
}

.single-case .relationCase_heading {
	color: #55934f;
	font-size: 3.2rem;
	margin-bottom: 30px;
	text-align: center;
}

.single-case .relationCase_contents {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
}

.single-case .relationCase_item {
	background-color: #f2f3f7;
	border-radius: 14px;
	width: calc((100% - 20px) / 2);
}

.single-case .relationCase_item a {
	display: block;
	padding: 40px 35px 30px;
}

.single-case .relationCase_img {
	display: flex;
	gap: 30px;
	justify-content: center;
	margin-bottom: 20px;
	position: relative;
}

.single-case .relationCase_img::after {
	border-color: transparent transparent transparent #55934f;
	border-style: solid;
	border-width: 16.5px 0 16.5px 15px;
	content: "";
	height: 0;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 0;
}

.single-case .relationCase_img img {
	-o-object-fit: cover;
	aspect-ratio: 1;
	border: 1px solid #f2f3f7;
	object-fit: cover;
	width: calc(50% - 15px);
}

.single-case .relationCase_ttl {
	color: #000;
	display: flex;
	font-size: 1.8rem;
	gap: 10px;
	justify-content: space-between;
}

.single-case .relationCase_ttl p {
	padding-top: 2px;
}

.single-case .relationCase_ttl img {
	height: 30px;
	width: 30px;
}

.single-case .relationCase .btn {
	width: 360px;
}

/* ----------------------------------------
shop
---------------------------------------- */

#shop .shop_wrap {
	display: flex;
	gap: 60px;
}

#shop .shop {
	width: calc(50% - 30px);
}

#shop .shop_img {
	aspect-ratio: 26/15;
	border-radius: 20px;
	margin-bottom: 70px;
}

#shop .shop_name {
	font-size: 2.6rem;
	margin-bottom: 30px;
}

#shop .shop_name a {
	display: block;
}

#shop .shop .calendar {
	margin-bottom: 30px;
}

#shop .shop .calendar tbody .calendar_row:last-child {
	padding-top: 0;
}

#shop .shop .calendar_link a {
	padding-right: 15px;
}

#shop .shop_info {
	color: #000;
}

#shop .shop_info a {
	color: #000;
}

#shop .shop_list {
	display: flex;
}

#shop .shop_list:not(:last-of-type) {
	margin-bottom: 15px;
}

#shop .shop_ttl {
	font-weight: bold;
	width: 100px;
}

#shop .shop_desc {
	flex: 1;
}

/* /* ----------------------------------------
shopDetail
---------------------------------------- */
/* 
#musasi .shopDetail_img {
	max-width: 506px;	
	width: 100%;
}

#musasi .shopDetail_img__main {
	-o-object-fit: cover;
	max-width: 506px;
	aspect-ratio: 506/337;
	border-radius: 20px;
	margin-bottom: 40px;
	object-fit: cover;
	width: 100%;
}

#musasi .shopDetail_img__sub {
	display: flex;
	gap: 10px;
}

#musasi .shopDetail_img__sub li {
	width: calc((100% - 40px) / 3);
}

#musasi .shopDetail_img__sub li:hover {
	opacity: 0.7;
}

#musasi .shopDetail_img__sub img {
	aspect-ratio: 213/150;
	border-radius: 10px;
}

#musasi .shopDetail_container {
	margin: 0 auto;
	max-width: 1100px;
	padding: 0 60px;
}

#musasi .notice {
	margin-bottom: 60px;
}

#musasi .notice_heading {
	color: #ea8776;
	font-size: 2.2rem;
	margin-bottom: 20px;
	text-align: center;
}

#musasi .notice_txt {
	margin-bottom: 10px;
}

#musasi .notice_link {
	text-decoration: underline;
}

#musasi .calendar {
	background-color: #f2f3f7;
	border-radius: 20px;
	margin-bottom: 60px;
	padding: 20px 60px;
}

#musasi .calendar_row {
	grid-template-columns: 280px repeat(7, 1fr);
	padding-left: 15px;
	padding-right: 80px;
}

#musasi .calendar tbody .calendar_row {
	border-bottom: 1px dashed #918b8b;
}

#musasi .calendar_note {
	padding: 0 15px;
}

#musasi .access .media {
	margin-bottom: 70px;
}

#musasi .access_contents {
	flex: 1;
}

#musasi .access_list {
	padding: 10px 0;
}

#musasi .access_list:not(:last-child) {
	border-bottom: 1px dashed #918b8b;
}

#musasi .access iframe {
	height: 327px;
	width: 49%;
}

#musasi .way .accordion_heading {
	padding-left: 40px;
}

#musasi .way_contents {
	padding: 0;
}

#musasi .way_itemWrap {
	display: grid;
	gap: 40px;
	grid-template-columns: repeat(3, 1fr);
}

#musasi .way_num {
	border: 1px solid #55934f;
	border-radius: 50%;
	color: #00b900;
	display: grid;
	font-size: 2.5rem;
	height: 40px;
	line-height: 1;
	margin-bottom: 10px;
	place-items: center;
	width: 40px;
}

#musasi .way_img {
	-o-object-fit: cover;
	aspect-ratio: 34/25;
	border-radius: 20px;
	margin-bottom: 20px;
	object-fit: cover;
}

#musasi .way_txt {
	letter-spacing: -2px;
	padding-top: 0;
	text-align: justify;
}

#musasi .shopCta {
	margin-bottom: 100px;
}

#musasi .shopCta .cta {
	gap: 50px;
	margin-bottom: 0;
	margin-top: 100px;
	padding: 0 25px;
}

#musasi .shopCta .cta_telWrap {
	border: 1px solid #595757;
	border-radius: 20px;
	gap: 20px;
	padding: 30px 0;
}

#musasi .shopCta_txt {
	width: 14.5%;
}

#musasi .shopCta_tel {
	width: 25.9%;
}

#musasi .shopCta_tel img {
	width: 100%;
}

#musasi .shopCta_time {
	width: 38.1%;
}

#musasi .staffMessage {
	margin-bottom: 100px;
}

#musasi .staffMessage_contents {
	display: flex;
	gap: 60px;
}

#musasi .staffMessage .media {
	align-items: flex-start;
	gap: 20px;
	width: calc((100% - 60px) / 2);
}

#musasi .staffMessage .media_img {
	-o-object-fit: cover;
	aspect-ratio: 1;
	border-radius: 20px;
	max-width: 220px;
	object-fit: cover;
}

#musasi .staffMessage .media_img__sp {
	display: none;
}

#musasi .staffMessage .media_txt {
	color: #000;
	flex: 1;
	letter-spacing: -1px;
}

#musasi .doctor {
	margin-bottom: 90px;
}

#musasi .doctor .btn_wrap {
	padding-top: 60px;
}

#musasi .author {
	color: #000;
	margin-bottom: 50px;
}

#musasi .author .media {
	align-items: flex-start;
	flex-direction: row-reverse;
}

#musasi .author .media_img {
	border-radius: 20px;
	width: 50%;
}

#musasi .author .media_body {
	flex: 1;
	padding-right: 50px;
	padding-top: 50px;
}

#musasi .author .media_heading {
	font-size: 2.2rem;
}

#musasi .author .media_heading__sm {
	font-size: 1.8rem;
	font-weight: 500;
}

#musasi .toYou .media {
	align-items: flex-start;
	gap: 150px;
}

#musasi .toYou .media_body {
	padding-top: 20px;
	width: 50%;
}

#musasi .toYou .media_txt {
	color: #000;
}

#musasi .toYou .media_img {
	max-width: 400px;
	width: 40%;
}

#musasi .toYou .media_img img {
	-o-object-fit: cover;
	aspect-ratio: 40/27;
	border: 1px solid #d7dadf;
	border-radius: 20px;
	object-fit: cover;
	width: 100%;
}

#musasi .toYou .media_img img:not(:last-of-type) {
	margin-bottom: 15px;
}

#musasi .review {
	background-color: #e9f0d3;
	padding-bottom: 80px;
	padding-top: 70px;
}

#musasi .review_contents {
	display: grid;
	gap: 25px;
	grid-template-columns: repeat(3, 1fr);
}

#musasi .review_item {
	background-color: #fff;
	border: 1px solid #bcbcbc;
	border-radius: 14px;
	color: #000;
	padding: 35px;
}

#musasi .review_icon {
	background-color: #ec6941;
	border-radius: 50%;
	color: #fff;
	display: grid;
	font-size: 3.4rem;
	height: 60px;
	line-height: 1;
	margin: 0 auto 10px;
	place-items: center;
	width: 60px;
}

#musasi .review_name {
	font-size: 2.2rem;
	margin-bottom: 10px;
	text-align: center;
}

#musasi .review_star {
	color: #ffc64a;
	font-size: 2.2rem;
	letter-spacing: calc((40 / 1000) * 1em);
	margin-bottom: 20px;
	text-align: center;
}

#musasi .review_txt {
	letter-spacing: -1px;
	line-height: calc(26 / 16);
}

#musasi .faq {
	background-color: #f2f3f7;
	padding-bottom: 90px;
	padding-top: 70px;
} */ 
/* ----------------------------------------
contact
---------------------------------------- */

#contact .contact_txt {
	margin-bottom: 0;
}

#contact .contact_btn {
	display: inline-block;
	margin-bottom: 90px;
	width: 500px;
}

/* ----------------------------------------
reserve
---------------------------------------- */

#reserve .reserve .section_ttl {
	margin: 0 auto 80px;
	position: relative;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
}

#reserve .reserve_catch {
	position: absolute;
	right: calc(100% + 30px);
	top: 0;
	width: 125px;
}

/* ----------------------------------------]
faq
---------------------------------------- */

#faq .pageNav,
.tax-faq_cat .pageNav {
	text-align: center;
}

#faq .pageNav_link a,
.tax-faq_cat .pageNav_link a {
	padding-bottom: 34px;
	padding-top: 23px;
}

#faq .pageNav_link a::before,
#faq .pageNav_link a::after,
.tax-faq_cat .pageNav_link a::before,
.tax-faq_cat .pageNav_link a::after {
	top: calc(100% - 20px);
}

#faq .pageNav_link a::before,
.tax-faq_cat .pageNav_link a::before {
	right: 50%;
	transform: rotate(45deg);
}

#faq .pageNav_link a::after,
.tax-faq_cat .pageNav_link a::after {
	right: calc(50% + 1px);
	transform: rotate(135deg);
}

#faq .faq .heading_lv3,
.tax-faq_cat .faq .heading_lv3 {
	margin-bottom: 50px;
	text-align: center;
}

#faq .faq_contents:not(:last-of-type),
.tax-faq_cat .faq_contents:not(:last-of-type) {
	margin-bottom: 100px;
}

#faq .faq .accordion,
.tax-faq_cat .faq .accordion {
	margin-bottom: -15px;
}

#aga,
#price,
#counseling,
#reserve,
#shop,
#others {
	margin-top: -140px;
	padding-top: 140px;
}

/* ----------------------------------------
minor
---------------------------------------- */

#minor .minor_caution {
	color: #d9604c;
	font-size: 2.2rem;
	font-weight: bold;
	margin-bottom: 40px;
	text-align: center;
}

#minor .minor_txt {
	color: #000;
	margin: 0 auto 50px;
	max-width: 700px;
	text-align: center;
}

#minor .minor_contents {
	display: flex;
	gap: 60px;
	margin-bottom: 30px;
}

#minor .minor_contents img {
	width: calc(50% - 30px);
}

#minor .minor_note {
	color: #000;
	margin-bottom: 30px;
}

#minor .minor_dialog {
	color: #000;
	margin-top: 15px;
	text-align: center;
}

#minor .minor .btn span {
	align-items: center;
	display: flex;
	gap: 15px;
	justify-content: center;
}

#minor .minor .btn_icon {
	width: 30px;
}

/* ----------------------------------------
forMedia
---------------------------------------- */

#forMedia .contact_ttl {
	margin-bottom: 20px;
}

#forMedia .contact_txt {
	margin-bottom: 70px;
}

/* ----------------------------------------
sitemap
---------------------------------------- */

#sitemap .sitemap {
	color: #000;
	display: grid;
	gap: 50px 100px;
	grid-template-columns: 1fr 1fr;
}

#sitemap .sitemap a {
	color: #000;
}

#sitemap .sitemap_list {
	border-bottom: 1px dashed #918b8b;
	display: block;
	padding: 10px 0;
}

#sitemap .sitemap_list__child li {
	position: relative;
}

#sitemap .sitemap_list__child li::before {
	content: "-";
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
}

#sitemap .sitemap_list__child li a {
	padding-left: 15px;
}

/* ----------------------------------------
recruit
---------------------------------------- */

#recruit .heading_lv3 {
	margin-bottom: 40px;
	text-align: center;
}

#recruit .mainvisual {
	margin-bottom: 70px;
}

#recruit .mainvisual .sp {
	display: none;
}

#recruit .pageNav {
	text-align: center;
}

#recruit .pageNav_link a {
	padding-bottom: 34px;
	padding-top: 23px;
}

#recruit .pageNav_link a::before,
#recruit .pageNav_link a::after {
	top: calc(100% - 20px);
}

#recruit .pageNav_link a::before {
	right: 50%;
	transform: rotate(45deg);
}

#recruit .pageNav_link a::after {
	right: calc(50% + 1px);
	transform: rotate(135deg);
}

#recruit #counselor,
#recruit #doctor {
	margin-top: -140px;
	padding-top: 140px;
}

#recruit .counselor {
	margin-bottom: 70px;
}

#recruit .doctor {
	margin-bottom: 90px;
}

#recruit .flow {
	background-color: #f2f3f7;
	margin-bottom: 70px;
	padding-bottom: 70px;
	padding-top: 80px;
}

#recruit .flow .sp {
	display: none;
}

#recruit .flow_contents {
	display: flex;
	gap: 20px;
}

#recruit .flow_item {
	position: relative;
	width: calc((100% - 60px) / 4);
}

#recruit .flow_item:not(:last-child)::after {
	border-color: transparent transparent transparent #55934f;
	border-style: solid;
	border-width: 10px 0 10px 10px;
	content: "";
	height: 0;
	position: absolute;
	right: -15px;
	top: min(14.5322434151vw, 160px);
	width: 0;
}

#recruit .flow_txt {
	color: #000;
	margin-top: 20px;
	padding: 0 10px;
}

#recruit .form_radio label {
	margin-right: 5.3333333333vw;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
}

/* ----------------------------------------
price
---------------------------------------- */

#price .heading_lv3 {
	margin-bottom: 40px;
	text-align: center;
}

#price #faga .example_heading {
	background-color: #9a8ee2;
}

#price #faga .plan_ttl {
	color: #9a8ee2;
}

#price #circle .example_heading {
	background-color: #a69675;
}

#price #circle .plan_ttl {
	color: #a69675;
}

#price .option .heading_lv3 {
	color: #595757;
}

#price .option_contents {
	background-color: #f2f3f7;
	border-radius: 20px;
	color: #000;
	padding: 40px;
}

#price .option_heading {
	align-items: center;
	border-bottom: 1px dashed #918b8b;
	display: flex;
	font-size: 2.6rem;
	font-weight: bold;
	justify-content: space-between;
	line-height: 1.2;
	margin-bottom: 30px;
	padding-bottom: 10px;
}

#price .option_name span {
	margin-left: -10px;
}

#price .option_price {
	color: #55934f;
	font-family: "century-gothic", sans-serif;
	font-size: 5rem;
}

#price .option_price__note {
	color: #000;
	font-size: 2.6rem;
}

#price .option_price__sm {
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
	font-size: 4rem;
}

#price .option_desc:not(:last-of-type) {
	margin-bottom: 40px;
}

#price .payment {
	margin-bottom: 90px;
}

#price .payment_wrap {
	background-color: #f2f3f7;
	border-radius: 20px;
	color: #000;
	padding: 50px 40px;
}

#price .payment_ttl {
	color: #000;
	font-size: 2.6rem;
	margin-bottom: 30px;
	text-align: center;
}

#price .payment_item {
	background-color: #fff;
	border-radius: 10px;
	display: flex;
	flex-wrap: wrap;
	letter-spacing: -1px;
	padding: 30px;
}

#price .payment_item:not(:last-of-type) {
	margin-bottom: 15px;
}

#price .payment_heading {
	font-size: 2rem;
	font-weight: bold;
	width: 285px;
}

#price .payment_desc {
	padding-top: 5px;
	width: calc(100% - 285px);
}

#price .payment_creditCard {
	-o-object-fit: contain;
	height: 100%;
	object-fit: contain;
}

#price .payment .btn {
	font-size: 1.6rem;
	margin-top: 20px;
	min-width: unset;
	padding: 15px 0;
	width: 350px;
}

#price .faq {
	margin-bottom: 12vw;
}

/* ----------------------------------------
regrowth
---------------------------------------- */

#regrowth .mainvisual {
	margin-bottom: 20px;
}

#regrowth .mainvisual .pc {
	border-radius: 20px;
}

#regrowth .mainvisual .sp {
	display: none;
}

#regrowth .regrowth_btn {
	display: inline-block;
	font-size: 2.6rem;
	padding: 26px;
	width: 500px;
}

#regrowth .regrowth_btn span::after {
	border-width: 3px;
	margin-left: 20px;
	min-height: 12px;
	min-width: 12px;
}

#regrowth .point {
	margin-bottom: 100px;
	margin-top: 90px;
}

#regrowth .point .media {
	align-items: flex-start;
	gap: 100px;
}

#regrowth .point .media:not(:last-child) {
	margin-bottom: 80px;
}

#regrowth .point .media:nth-child(even) {
	flex-direction: row-reverse;
}

#regrowth .point .media_heading {
	font-size: 3rem;
}

#regrowth .point .media_img {
	border-radius: 20px;
}

#regrowth .point_txt {
	color: #000;
}

#regrowth .price {
	margin-bottom: 90px;
}

#regrowth .example_body {
	border-radius: 20px;
}

#regrowth .plan_item {
	align-items: center;
}

#regrowth .case_inner {
	background-color: #e9f0d3;
	border-radius: 20px;
	margin-bottom: 80px;
	padding: 50px 40px;
}

#regrowth .case .section_ttl {
	margin-bottom: 35px;
}

#regrowth .case_ttl {
	background-color: #f2f3f7;
	border-radius: 6px;
	font-size: 2.2rem;
	margin-bottom: 20px;
	padding: 10px 20px;
}

#regrowth .case_txtWrap {
	color: #000;
}

#regrowth .case_txtWrap:not(:last-child) {
	margin-bottom: 5px;
}

#regrowth .case_heading {
	display: inline-block;
	font-weight: bold;
}

#regrowth .case_desc {
	display: inline;
	letter-spacing: -1px;
}

#regrowth .case_desc__emphasis {
	font-size: 1.8rem;
	font-weight: bold;
	letter-spacing: 0;
}

#regrowth .case_content {
	background-color: #fff;
	border-radius: 14px;
	box-shadow: 2px 3.464px 8.19px 0.81px rgba(145, 139, 139, 0.1);
	margin-bottom: 30px;
	padding: 30px;
}

#regrowth .case .media {
	align-items: flex-start;
	gap: 30px;
}

#regrowth .case .media > * {
	width: calc((100% - 30px) / 2);
}

#regrowth .case .media_img {
	align-items: center;
	display: flex;
	gap: 20px;
	justify-content: center;
	position: relative;
}

#regrowth .case .media_img::after {
	border-color: transparent transparent transparent #55934f;
	border-style: solid;
	border-width: 12px 0 12px 11px;
	content: "";
	height: 0;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 0;
}

#regrowth .case .media_img img {
	aspect-ratio: 11/10;
	width: calc((100% - 20px) / 2);
}



/* ----------------------------------------
武蔵小杉院
---------------------------------------- */


#musasi .mainvisual {
	padding: 0;
}

#musasi .mainvisual_inner {
	border-radius: 50px;
	overflow: hidden;
	position: relative;
	padding:0 20px ;
}

#musasi .mainvisual_img__sp {
	display: none;
}


#musasi .notice {
	margin-bottom: 60px;
}
#musasi .notice_heading {
	color: #ea8776;
	font-size: 2.2rem;
	margin-bottom: 20px;
	text-align: center;
}

#musasi .notice_txt {
	margin-bottom: 10px;
}

#musasi .notice_link {
	text-decoration: underline;
}

/* アクセスセクション - マップと画像の横並び */
#musasi .access .access_list {
	display: flex;
	gap: 30px;
	align-items: flex-start;
}

#musasi .access_map {
	flex: 1;
	min-width: 0;
}

#musasi .access_map iframe {
	width: 100%;
	height: 300px;
	border-radius: 8px;
}

#musasi .access_map_link {
	display: inline-block;
    margin-top: 10px;
    color: blue;
    text-decoration: none;
    font-size: 14px;
    font-weight: 500;
    transition: color 0.3s ease;
    /* margin: auto; */
    width: 100%;
    /* margin-left: auto; */
    /* margin-right: auto; */
    text-align: end;
}

#musasi .access_map_link:hover {
	color: #57944F;
}

#musasi .access_image {
	flex: 1;
	min-width: 0;
}

#musasi .access_image img {
	width: 100%;
	height: 300px;
	object-fit: cover;
	border-radius: 8px;
}

/* レスポンシブ対応 */
@media screen and (max-width: 768px) {
	#musasi .access .access_list {
		flex-direction: column;
		gap: 20px;
		align-items: center;
	}
	
	#musasi .access_map iframe,
	#musasi .access_image img {
		height: 250px;
	}
}
/* 当院の特徴 */
.topSection_ttl__white{
	color: #fff;
}
#musasi .homePlan {
	background-color: #F2F3F7;
	margin-bottom: 0;
	padding-bottom: 170px;
	padding-top: 80px;
	position: relative;
}

#musasi .homePlan_bg {
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	height: 53%;
	position: absolute;
	top: 0;
	width: 100%;
}

#musasi .homePlan_bg__sp {
	display: none;
}

#musasi .homePlan .topSection_ttl {
	position: relative;
}

#musasi .homePlan_txt {
	color: #fff;
	margin-bottom: 60px;
	position: relative;
	text-align: center;
}

#musasi .homePlan_contents {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	justify-content: center;
}

#musasi .homePlan_item {
	background-color: #fff;
	border: none;
	border-radius: 14px;
	box-shadow: 2px 3.464px 8.19px 0.81px rgba(145, 139, 139, 0.31);
	display: block;
	overflow: hidden;
	padding: 0;
	position: relative;
	text-align: center;
	width: calc((100% - 40px) / 3);
}

#musasi .homePlan_heading {
	background-color: #55934f;
	border-bottom: 5px solid #b8d554;
	color: #fff;
	font-family: "century-gothic", sans-serif;
	font-size: 3.6rem;
	padding: 15px;
}

#musasi .homePlan_heading__sm {
	font-weight: 500;
}

#musasi .homePlan_body {
	padding: 30px;
	padding-bottom: 110px;
}

	#musasi .homePlan_catch {
	font-size: 2.6rem;
}

#musasi .homePlan_img {
	display: grid;
	height: 200px;
	place-items: center;
}

#musasi .homePlan_desc {
	line-height: 1.6;
	text-align: justify;
}

#musasi .homePlan_btn {
	bottom: 70px;
	font-size: 1.6rem;
	left: 50%;
	min-width: auto;
	position: absolute;
	transform: translateX(-50%);
	width: 328px;
}

	#musasi .calendar {
	background-color: #f2f3f7;
	border-radius: 20px;
	margin-bottom: 60px;
	padding: 20px 60px;
}

#musasi .calendar_row {
	grid-template-columns: 280px repeat(7, 1fr);
	padding-left: 15px;
	padding-right: 80px;
}

#musasi .calendar tbody .calendar_row {
	border-bottom: 1px dashed #918b8b;
}

#musasi .calendar_note {
	padding: 0 15px;
}

#musasi .access .media {
	margin-bottom: 70px;
}

#musasi .access_contents {
	flex: 1;
}

#musasi .access_list {
	padding: 10px 0;
}

#musasi .access_list:not(:last-child) {
	border-bottom: 1px dashed #918b8b;
}

#musasi .access iframe {
	height: 300px;
	width: 100%;
}

#musasi .way .accordion_heading {
	padding-left: 40px;
}

#musasi .way_contents {
	padding: 0;
}

#musasi .way_itemWrap {
	display: grid;
	gap: 40px;
	grid-template-columns: repeat(3, 1fr);
}

#musasi .way_num {
	border: 1px solid #55934f;
	border-radius: 50%;
	color: #00b900;
	display: grid;
	font-size: 2.5rem;
	height: 40px;
	line-height: 1;
	margin-bottom: 10px;
	place-items: center;
	width: 40px;
}

#musasi .way_img {
	-o-object-fit: cover;
	aspect-ratio: 34/25;
	border-radius: 20px;
	margin-bottom: 20px;
	object-fit: cover;
}

#musasi .way_txt {
	letter-spacing: -2px;
	padding-top: 0;
	text-align: justify;
}

#musasi .shopCta {
	margin-bottom: 100px;
}

#musasi .shopCta .cta {
	gap: 50px;
	margin-bottom: 0;
	margin-top: 100px;
	padding: 0 25px;
}

#musasi .shopCta .cta_telWrap {
	border: 1px solid #595757;
	border-radius: 20px;
	gap: 20px;
	padding: 30px 0;
}

#musasi .shopCta_txt {
	width: 14.5%;
}

#musasi .shopCta_tel {
	width: 25.9%;
}

#musasi .shopCta_tel img {
	width: 100%;
}

#musasi .shopCta_time {
	width: 38.1%;
}

#musasi .staffMessage {
	margin-bottom: 100px;
}

#musasi .staffMessage_contents {
	display: flex;
	gap: 60px;
}

#musasi .staffMessage .media {
	align-items: flex-start;
	gap: 20px;
	width: calc((100% - 60px) / 2);
}



#musasi .staffMessage .media_img__sp {
	display: none;
}

#musasi .staffMessage .media_txt {
	color: #000;
	flex: 1;
	letter-spacing: -1px;
}

#musasi .doctor {
	margin-bottom: 90px;
	margin-top: 90px;
}

#musasi .doctor .btn_wrap {
	padding-top: 60px;
}

#musasi .author {
	color: #000;
	margin-bottom: 50px;
}

#musasi .author .media {
	align-items: flex-start;
	flex-direction: row-reverse;
}

#musasi .author .media_img {
	border-radius: 20px;
	width: 50%;
}

#musasi .author .media_body {
	flex: 1;
	padding-right: 50px;
	padding-top: 50px;
}

#musasi .author .media_heading {
	font-size: 2.2rem;
}

#musasi .author .media_heading__sm {
	font-size: 1.8rem;
	font-weight: 500;
}

#musasi .toYou .media {
	align-items: flex-start;
	gap: 150px;
}

#musasi .toYou .media_body {
	padding-top: 20px;
	width: 50%;
}

#musasi .toYou .media_txt {
	color: #000;
}

#musasi .toYou .media_img {
	max-width: 400px;
	width: 40%;
}
#musasi .toYou .media_img img {
	-o-object-fit: cover;
	aspect-ratio: 40/27;
	border: 1px solid #d7dadf;
	border-radius: 20px;
	object-fit: cover;
	width: 100%;
}

#musasi .toYou .media_img img:not(:last-of-type) {
	margin-bottom: 15px;
}

#musasi .review {
	background-color: #e9f0d3;
	padding-bottom: 80px;
	padding-top: 70px;
}

#musasi .review_contents {
	display: grid;
	gap: 25px;
	grid-template-columns: repeat(3, 1fr);
}

#musasi .review_item {
	background-color: #fff;
	border: 1px solid #bcbcbc;
	border-radius: 14px;
	color: #000;
	padding: 35px;
}

#musasi .review_icon {
	background-color: #ec6941;
	border-radius: 50%;
	color: #fff;
	display: grid;
	font-size: 3.4rem;
	height: 60px;
	line-height: 1;
	margin: 0 auto 10px;
	place-items: center;
	width: 60px;
}
#musasi .review_name {
	font-size: 2.2rem;
	margin-bottom: 10px;
	text-align: center;
}
#musasi .review_star {
	color: #ffc64a;
	font-size: 2.2rem;
	letter-spacing: calc((40 / 1000) * 1em);
	margin-bottom: 20px;
	text-align: center;
}

#musasi .review_txt {
	letter-spacing: -1px;
	line-height: calc(26 / 16);
}

#musasi .faq {
	background-color: #f2f3f7;
	padding-bottom: 90px;
	padding-top: 70px;
}
#musasi .about {
	gap: 100px;
	margin-bottom: 70px;
}
#musasi .about .media_img__wrap{
	width: 48%;
}
#musasi .about .media_img__wrap img{
	width: 100%;
}
#musasi .about .media:nth-child(odd) {
	flex-direction: row-reverse;
}

#musasi .about .media_heading {
	font-size: 2.8rem;
}
#musasi .shopDetail_img__sub li{
	width: calc((100% - 40px) / 3);
}
#musasi .media_txt__lists li{
	color: #000;
font-family: "Yu Gothic";
font-size: 18px;
font-style: normal;
font-weight: 700;
line-height: normal;
letter-spacing: 1.08px;
padding-left: 30px;
position: relative;
}
.access_text{
	font-size: 16px;
	padding-bottom: 10px;
	text-align: center;

}
#musasi .about .media_txt {
	margin-top: 24px;
	margin-bottom: 14px;
}

#musasi .about .media_img {
	border-radius: 20px;
	width: 48%;
}
#musasi .basicInfo{
	padding-top: 122px;
}
#musasi .basicInfo_item-flex{
	display: flex;
	gap: 20px;
	justify-content: space-between;
}
@media screen and (max-width: 768px) {
	#musasi .basicInfo_item-flex{
		flex-direction: column;
	}
}
#musasi .about{
	padding-top: 99px;
}
#musasi.musasi-about-text{
	color: #616062;
text-shadow: 0px 0px 29.972px #FFF;
font-family: "Noto Sans JP";
font-size: 12px;
font-style: normal;
font-weight: 500;
line-height: normal;
letter-spacing: 0.6px;
}

.caseview{
	background-color: #F2F3F7;
	padding: 80px 0;
}
.caseview_contents{
	display: flex;
	gap: 24px;
	flex-direction: column;
}
.musasi-case-card {
	background: #FFFFFF;
	border-radius: 20px;
	padding: 32px;
	max-width: 920px;
	width: 100%;
	margin: 0 auto;
	position: relative;
}

/* .musasi-case-card::before,
.musasi-case-card::after {
	content: '';
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 44px;
	height: 44px;
	background-color: #D7D7D7;
	border-radius: 50%;
	cursor: pointer;
	transition: opacity 0.3s ease;
}

.musasi-case-card::before {
	left: -70px;
	background-image: url("data:image/svg+xml,%3csvg width='12' height='22' viewBox='0 0 12 22' fill='none' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M11 1L1 11L11 21' stroke='white' stroke-width='2'/%3e%3c/svg%3e");
	background-repeat: no-repeat;
	background-position: center;
	background-size: 12px 22px;
}

.musasi-case-card::after {
	right: -70px;
	background-image: url("data:image/svg+xml,%3csvg width='12' height='22' viewBox='0 0 12 22' fill='none' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M1 1L11 11L1 21' stroke='white' stroke-width='2'/%3e%3c/svg%3e");
	background-repeat: no-repeat;
	background-position: center;
	background-size: 12px 22px;
} */

.musasi-case-card::before:hover,
.musasi-case-card::after:hover {
	opacity: 0.8;
}

.musasi-case-card__header {
	display: flex;
	align-items: center;
	gap: 16px;
	margin-bottom: 24px;
}

.musasi-case-card__title {
	color: #56934E;
	font-family: "Yu Gothic";
	font-size: 24px;
	font-weight: 700;
	line-height: 1.6;
	letter-spacing: 0.06em;
	margin: 0;
}

.musasi-case-card__patient-info {
	color: #000000;
	font-family: "Yu Gothic";
	font-size: 16px;
	font-weight: 700;
	line-height: 1.6;
	letter-spacing: 0.06em;
	margin: 0;
}

.musasi-case-card__main {
	display: flex;
	gap: 16px;
	align-items: flex-start;
}

.musasi-case-card__images {
	flex-shrink: 0;
}

.musasi-case-card__before-after {
	display: flex;
	align-items: center;
	gap: 7px;
}

.musasi-case-card__image-item {
	text-align: center;
}

.musasi-case-card__image-placeholder {
	width: 132px;
	height: 132px;
	background: #D9D9D9;
	border-radius: 4px;
	margin-bottom: 4px;
}

.musasi-case-card__label {
	display: block;
	color: #000000;
	font-family: "Yu Gothic";
	font-size: 16px;
	font-weight: 700;
	line-height: 1.6;
	letter-spacing: 0.06em;
	text-align: center;
}

.musasi-case-card__label--after {
	color: #306B2C;
}

.musasi-case-card__arrow {
	margin: 0 10px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.musasi-case-card__details {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 8px;
	max-width: 547px;
}

.musasi-case-card__detail-item {
	display: flex;
	align-items: center;
	gap: 8px;
}

.musasi-case-card__detail-label {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	padding: 2px 8px;
	background: #FFFFFF;
	border: 1px solid #589450;
	border-radius: 50px;
	color: #000000;
	font-family: "Yu Gothic";
	font-size: 14px;
	font-weight: 700;
	line-height: 1.6;
	letter-spacing: 0.06em;
	width: 108px;
	min-width: 108px;
}

.musasi-case-card__detail-text {
	color: #000000;
	font-family: "Yu Gothic";
	font-size: 14px;
	font-weight: 700;
	line-height: 1.6;
	letter-spacing: 0.06em;
}

.musasi-case-card__footer {
	text-align: right;
	margin-top: 8px;
}

.musasi-case-card__link {
	color: #000000;
	font-family: "Yu Gothic";
	font-size: 14px;
	font-weight: 700;
	line-height: 1.6;
	letter-spacing: 0.06em;
	text-decoration: none;
	display: inline-block;
}

.musasi-case-card__link:hover {
	color: #46804A;
}

/* Swiperナビゲーションボタン */

.caseview_swiper .swiper-button-prev {
	width: 44px;
	height: 44px;
	margin-top: -10px; /* 中央配置のため（高さの半分） */
	background-color: #D7D7D7;
	border-radius: 50%;
	color: white;
	font-size: 0; /* デフォルトのテキストを非表示 */
	position: absolute;
	top: 50%;
	z-index: 10;
	cursor: pointer;
	transition: background-color 0.3s ease;
}
.caseview_swiper .swiper-button-next {
	width: 44px;
	height: 44px;
	margin-top: -10px; /* 中央配置のため（高さの半分） */
	background-color: #D7D7D7;
	border-radius: 50%;
	color: white;
	font-size: 0; /* デフォルトのテキストを非表示 */
	position: absolute;
	top: 50%;
	z-index: 10;
	cursor: pointer;
	transition: background-color 0.3s ease;
}

/* Swiperのデフォルト矢印を完全に削除 */
.caseview_swiper .swiper-button-next:after,
.caseview_swiper .swiper-button-prev:after {
	content: none !important;
	display: none !important;
}

/* カスタム矢印 - SVG背景 */
.caseview_swiper .swiper-button-prev {
	background-image: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="44" height="44" viewBox="0 0 44 44" fill="none"><circle cx="22" cy="22" r="22" transform="matrix(-1 0 0 1 44 0)" fill="%23D7D7D7"/><path d="M15.4394 20.8905C14.8535 21.5042 14.8535 22.5007 15.4394 23.1144L24.4376 32.5398C25.0234 33.1534 25.9748 33.1534 26.5606 32.5398C27.1465 31.9261 27.1465 30.9296 26.5606 30.316L18.6216 22L26.5559 13.684C27.1418 13.0704 27.1418 12.0739 26.5559 11.4602C25.9701 10.8466 25.0187 10.8466 24.4329 11.4602L15.4347 20.8856L15.4394 20.8905Z" fill="white"/></svg>');
	background-color: transparent;
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
}

.caseview_swiper .swiper-button-next {
	background-image: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="44" height="44" viewBox="0 0 44 44" fill="none"><circle cx="22" cy="22" r="22" fill="%23D7D7D7"/><path d="M28.5606 20.8905C29.1465 21.5042 29.1465 22.5007 28.5606 23.1144L19.5624 32.5398C18.9766 33.1534 18.0252 33.1534 17.4394 32.5398C16.8535 31.9261 16.8535 30.9296 17.4394 30.316L25.3784 22L17.4441 13.684C16.8582 13.0704 16.8582 12.0739 17.4441 11.4602C18.0299 10.8466 18.9813 10.8466 19.5671 11.4602L28.5653 20.8856L28.5606 20.8905Z" fill="white"/></svg>');
	background-color: transparent;
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
}


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

	.gnav_list a,.gnav_list_has-child{
		display: block;
		width: 100%;
		padding: 14px;
	}
	.gnav_list_has-child{
		position: relative;
	}
	.gnav_list_has-child::after{
		position: absolute;
		content: '▼';
		color: #00b900;
		transform: translateY(-50%);
		top: 50%;
		right: 18px;
		font-size: 14px;
		transition: 0.3s;
	}
	.gnav_list_has-child.is-actice::after{
		transform: translateY(-50%) rotate(180deg);
		transition: 0.3s;
	}

/* ----------------------------------------
  Base
  ---------------------------------------- */

main {
	margin-top: 9rem;
}

/* ----------------------------------------
  header
  ---------------------------------------- */

.header {
	height: 9rem;
	z-index: 9999;
}

.header_ttl {
	max-width: 330px;
}

.header_catch {
	display: none;
	opacity: 0;
	visibility: none;
}

.gnav_cta{
	display: block;
	width: 100%;
}
.gnav_cta .cta_contents{
	width: 100%;
}

.cta__primary.gnav_cta .cta_btn{
	margin-bottom: 12px;
}

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

.gnav_menu {
	display: none;
}

.gnav_list__child li::after{
	content: none;
}

.gnav_menu__sp {
	background-color: rgba(255, 255, 255,1);
	display: block;
	height: calc(100vh - 9rem);
	opacity: 0;
	overflow-y: auto;
	padding-bottom: 50px;
	padding-left: 30px;
	padding-right: 30px;
	position: absolute;
	right: -120%;
	top: 9rem;
	transition: opacity 0.5s, right 0.5s, visibility 0.5s;
	visibility: hidden;
	width: 350px;
}

.gnav_list {
	margin-bottom: 20px;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
}

.gnav_list__child {
	background-color: transparent;
	opacity: 1;
	position: unset;
	visibility: visible;
}

.gnav_list__child li {
	margin-top: 10px;
}

.gnav_list__child li:last-child {
	border-bottom: 1px dashed #918b8b;
}

.is_open .gnav_menu__sp {
	opacity: 1;
	right: 0;
	visibility: visible;
}

.is_open .hamburgerBtn {
	display: block;
}

.is_open .hamburgerBtn_line:nth-child(1) {
	top: 24px;
	transform: rotate(135deg);
}

.is_open .hamburgerBtn_line:nth-child(2) {
	opacity: 0;
}

.is_open .hamburgerBtn_line:nth-child(3) {
	top: 24px;
	transform: rotate(-135deg);
}

.hamburgerBtn {
	display: block;
}
.gnav_list {
	margin-bottom: 0;
	width:100%;
	border-bottom: dashed 1px #595757;
}
.gnav_list__hasChild{
	position: relative;
}
.gnav_list::after{
	content: none;
}
.gnav_switch{
	position: absolute;
	color: #55934f;
	font-size: 16px;
	font-weight: bold;
	top: 16px;
	right: 14px;
	display: block;
	z-index: +1;
	cursor:pointer;
}
.gnav_switch.is-actice{
	transform: rotate(180deg);
}

.gnav_list__first{
	border-top: dashed 1px #595757;
}

.gnav_list a{
	display: block;
	width: 100%;
	padding: 14px;
}

.gnav_list__child {
	width:100%;
	display: none;
}

.gnav_list__child li:last-child{
	border: none;
}
.gnav_list__child li a{
	text-indent: 1em;
}

.gnav_list .gnav_list__child li {
	margin-top: 0;
	border: none;
	border-top: dashed 1px #595757;
}

.gnav_list__child a::before{
	background-color: #595757;
	height: 2px;
    left: 14px;
	width: 8px;
}

/* ----------------------------------------
  subPageMv
  ---------------------------------------- */

.subPageMv {
	border-radius: 50px;
	height: 170px;
}

.subPageMv_img {
	right: 70px;
	width: 300px;
}

.subPageMv_mask {
	height: 170px;
}

.cta {
	gap: 1.8181818182vw;
}

.cta_contents {
	width: calc((100% - 1.8181818182vw) / 2);
}

.cta_catch {
	font-size: 1.6363636364vw;
	letter-spacing: -0.1818181818vw;
	margin-bottom: 0.4545454545vw;
}

.cta_catch__line::before {
	left: -1.3636363636vw;
}

.cta_catch__line::after {
	right: -0.9090909091vw;
}

.cta__primary .cta_btn {
	margin-bottom: 4.5454545455vw;
}

.cta__primary .cta_telWrap {
	margin-bottom: 1.8181818182vw;
}

/* ----------------------------------------
  tel
  ---------------------------------------- */

.tel .cta {
	border-radius: 2.1818181818vw;
	gap: 11.8181818182vw;
	margin-bottom: 7.2727272727vw;
	padding: 1.8181818182vw;
}

.tel .cta_content {
	width: 29.6363636364vw;
}

.tel .cta_name {
	margin-bottom: 0.9090909091vw;
}

.tel .cta_tel {
	margin-bottom: 0.9090909091vw;
}

/* ----------------------------------------
  access
  ---------------------------------------- */

.access .media {
	gap: 25px;
}

/* ----------------------------------------
  campaign
  ---------------------------------------- */

.campaign {
	margin-bottom: 40px;
}

.campaign_ttl {
	font-size: 2.6rem;
	margin-bottom: 10px;
}

/* ----------------------------------------
  footer
  ---------------------------------------- */

.footer_nav {
	font-size: 1.5rem;
	justify-content: space-between;
}

/* ----------------------------------------
  calendar
  ---------------------------------------- */

.calendar_row {
	grid-template-columns: max(140px, 16.348773842vw) repeat(7, 1fr);
}

.calendar_dot {
	font-size: 1.6rem;
}

/* ----------------------------------------
  form
  ---------------------------------------- */

#form {
	margin-top: -90px;
	padding-top: 90px;
}

.form_label {
	width: 270px;
}

.form_time {
	gap: 10px;
}

.form_time .wpcf7-list-item {
	width: calc((100% - 40px) / 5);
}

/* ----------------------------------------
  register
  ---------------------------------------- */

.register {
	gap: 4.5454545455vw;
	max-width: 90.9090909091vw;
	padding: 2.2727272727vw 4.0909090909vw;
}

.register_txt__sm {
	font-size: 1.4545454545vw;
}

.register_txt__md {
	font-size: 1.8181818182vw;
}

.register_txt__lg {
	font-size: 2.5454545455vw;
}

.register_btn {
	width: 39.0909090909vw;
}

.register_qr {
	width: 11.8181818182vw;
}

/* ----------------------------------------
  search
  ---------------------------------------- */

.searchform_ttl {
	font-size: 1.8rem;
	padding-left: 10px;
}

.searchform input {
	width: 15px;
}

.searchform_case {
	margin-bottom: 20px;
}

.searchform_case dd {
	gap: 10px;
}

.searchform_case dt {
	margin-bottom: 10px;
}

.searchform_case label {
	width: calc((100% - 20px) / 3);
}

.searchform_case input {
	left: 2.7272727273vw;
}

.searchform_age {
	gap: 30px;
}

.searchform_age dd {
	gap: 25px;
}

.searchform_age label {
	font-size: 1.6rem;
}

.searchform_age input {
	margin-right: 5px;
}

.searchform .btn_wrap {
	padding-top: 20px;
}

/* ----------------------------------------
  archive
  ---------------------------------------- */

.archive {
	grid-template-columns: repeat(3, 1fr);
}

/* ----------------------------------------
  pageNav
  ---------------------------------------- */

.pageNav_link {
	max-width: 350px;
	width: calc((100% - 20px) / 2);
}

/* ----------------------------------------
  br
  ---------------------------------------- */

.br_pc {
	display: none;
}

.br_onlyMd {
	display: block;
}

.br_underMd {
	display: block;
}

/* ----------------------------------------
  image
  ---------------------------------------- */

.image_inner {
	padding: 20px 30px 40px;
}

.image_ttl {
	font-size: 3rem;
	margin-bottom: 20px;
}

.image_heading span {
	display: block;
	font-size: 1.8rem;
}

.image .media {
	gap: 20px;
	padding: 30px 20px;
}

.image .media_heading {
	font-size: 2rem;
	margin-bottom: 15px;
}

.image .media_img {
	gap: 2.7272727273vw;
}

.image .media_img::after {
	border-width: 1.5vw 0 1.5vw 1.3636363636vw;
}

.image .media_img img {
	width: calc(50% - 1.3636363636vw);
}

.image_desc:not(:last-of-type) {
	margin-bottom: 15px;
}

/* ----------------------------------------
  example
  ---------------------------------------- */

.example#aga,
.example#faga,
.example#circle,
.example #plan01,
.example #plan02,
.example #plan03 {
	margin-top: -90px;
	padding-top: 90px;
}

.plan1 .plan_info {
	width: 100%;
}

.plan1 .plan_item {
	justify-content: center;
}

.plan1 .plan_item dt {
	width: 180px;
}

.plan2 .plan_item dd {
	width: 390px;
}

.plan3 .plan_item__price {
	height: auto;
}

.plan_wrap {
	flex-direction: column;
}

.plan_item {
	align-items: flex-start;
	height: auto;
	padding-left: 0;
}

.plan_item dt {
	width: 140px;
}

.plan_item dd {
	width: 425px;
}

.plan_heading {
	font-size: 2.4rem;
}

.plan_desc {
	font-size: 3.3rem;
	margin-top: -15px;
}

.plan_desc__md {
	font-size: 2.4rem;
}

.plan_desc__box {
	width: 150px;
}

.plan_desc > p:last-child {
	margin-bottom: -13px;
}

.plan_price {
	font-size: 3.6rem;
}

.plan_price__lg {
	font-size: 5rem;
}

.plan_price__sm {
	font-size: 2rem;
}

/* ----------------------------------------
  catch
  ---------------------------------------- */

.catch li {
	width: calc((100% - 60px) / 3);
}

/* ----------------------------------------
  flowStep
  ---------------------------------------- */

.flowStep .media {
	gap: 25px;
	padding: 20px;
	padding-left: 40px;
}

.flowStep .media_heading {
	font-size: 2.4rem;
}

.flowStep .media_img {
	max-width: 340px;
	width: 40%;
}

#home .case_item {
	margin: 0 10px;
}

#home .case_ttl {
	font-size: 2rem;
}

#home .case_img::after {
	height: 5.1818181818vw;
	width: 4.3636363636vw;
}

#home .case_heading p {
	font-size: 1.6rem;
	margin-left: 0;
}

#home .homePlan_bg {
	height: 35%;
}

#home .homePlan_item {
	width: calc(50% - 10px);
}

#home .service_cardWrap {
	gap: 40px 20px;
}

#home .service .card__primary {
	width: calc(50% - 10px);
}

#home .message_top {
	height: 220px;
}

#home .news_inner {
	gap: 40px;
}

#home .news_item {
	padding: 20px 0;
}

#first .treatment_cardWrap {
	gap: 40px 20px;
}

#first .treatment .card__primary {
	max-width: 400px;
	width: calc((100% - 20px) / 2);
}

#first .flow .media {
	gap: 25px;
	padding-left: 40px;
}

#first .flow .media_heading {
	font-size: 2.8rem;
}

#first .flow .media_img {
	width: 30vw;
}

#message .director {
	gap: 25px;
}

#message .director .media_body {
	padding-right: 50px;
}

#message .message {
	gap: 4.5454545455vw;
}

#message .message .media_txt {
	font-size: 1.5rem;
	line-height: 1.6;
}

#message .message .media_img {
	width: 40%;
}

#message .profile .media {
	gap: 20px;
}

#message .profile .media_img {
	width: 180px;
}

#message .profile_body {
	padding: 30px 25px;
	padding-bottom: 50px;
}

#message .profile_list {
	font-size: 1.5rem;
}

#flow .forMinor .btn {
	padding: 15px 35px;
}

#experience .graph {
	padding: 40px;
}

#experience .attempt_ttl {
	font-size: 2.3rem;
}

#experience .attempt .media {
	gap: 25px;
}

#experience .attempt .media_num {
	font-size: 3.4rem;
	margin-right: 15px;
	padding-left: 25px;
	padding-top: 10px;
}

#experience .attempt .media_num img {
	left: -10px;
	top: -20px;
	width: 55px;
}

#experience .attempt .media_heading__main {
	font-size: 2rem;
}

#experience .attempt .media_heading__highlight {
	font-size: 2.4rem;
}

#service .treatment_txt {
	padding: 0 100px;
}

#service .treatment_heading {
	font-size: 3.1rem;
}

#service .treatment_heading__sm {
	font-size: 2.1rem;
}

#service .treatment_desc {
	font-size: 1.7rem;
	padding-top: 11px;
}

#service .treatment .media {
	gap: 25px;
	padding: 40px 25px;
}

#service .treatment .media_num__primary {
	font-size: 3.4rem;
	padding-right: 15px;
}

#service .treatment .media_num__primary span {
	font-size: 1.8rem;
}

.parent-pageid-218 .feature .media {
	gap: 50px;
}

.parent-pageid-218 .feature .media_num__primary {
	font-size: 3.5rem;
}

.parent-pageid-218 .feature .media_num__primary span {
	font-size: 2.5rem;
}

.parent-pageid-218 .feature .media_heading {
	font-size: 2.5rem;
}

.parent-pageid-218 .treatment .media {
	gap: 50px;
}

.parent-pageid-218 .treatment .media_heading {
	font-size: 2.4rem;
}

.parent-pageid-218 .treatment_example {
	padding: 30px 40px;
}

#monitor .merit .heading_lv3__sm {
	display: none;
}

#monitor .merit .media {
	gap: 4.5454545455vw;
	padding: 3.6363636364vw 5.4545454545vw;
}

#monitor .merit .media_desc {
	font-size: 1.8rem;
}

#monitor .merit .media_img {
	flex-wrap: wrap;
	gap: 10px;
	max-width: 200px;
	width: 30%;
}

#monitor .merit .media_img::after {
	height: 50px;
	left: 50%;
	top: 45%;
	transform: translateX(-50%) rotate(90deg);
	width: 40px;
}

#monitor .merit .media_img img {
	width: 100%;
}

#monitor .merit_discount {
	font-size: 2rem;
}

#monitor .merit_discount p {
	font-size: 5rem;
}

#case .case .media,
.tax-case_age .case .media,
.tax-case_type .case .media,
.search .case .media {
	gap: 20px;
	padding: 30px;
}

#case .case .media_img,
.tax-case_age .case .media_img,
.tax-case_type .case .media_img,
.search .case .media_img {
	gap: 10px;
	width: calc(50% - 10px);
}

#case .case .media_img::after,
.tax-case_age .case .media_img::after,
.tax-case_type .case .media_img::after,
.search .case .media_img::after {
	border-width: 10px 0 10px 8px;
}

#case .case .media_img img,
.tax-case_age .case .media_img img,
.tax-case_type .case .media_img img,
.search .case .media_img img {
	width: calc(50% - 5px);
}

#case .case .media_ttl,
.tax-case_age .case .media_ttl,
.tax-case_type .case .media_ttl,
.search .case .media_ttl {
	padding-top: 5px;
}

#case .case .media .btn,
.tax-case_age .case .media .btn,
.tax-case_type .case .media .btn,
.search .case .media .btn {
	padding: 15px 0;
}

.single-case .caseDetail .heading_lv3 {
	font-size: 3.2rem;
}

.single-case .relationCase_contents {
	gap: 15px;
}

.single-case .relationCase_item {
	width: calc((100% - 15px) / 2);
}

.single-case .relationCase_item a {
	padding: 30px 20px 20px;
}

.single-case .relationCase_img {
	gap: 20px;
	margin-bottom: 15px;
}

.single-case .relationCase_img::after {
	border-width: 12px 0 12px 11px;
}

.single-case .relationCase_img img {
	width: calc(50% - 10px);
}

#shop .shop_wrap {
	gap: 30px;
}

#shop .shop {
	width: calc(50% - 15px);
}

#shop .shop_img {
	margin-bottom: 50px;
}

#shop .shop_name {
	font-size: 2.1rem;
	margin-bottom: 10px;
}

#shop .shop .btn {
	font-size: 1.6rem;
	padding: 15px 35px;
}

#musasi .shopDetail_container {
	padding: 0 5.4545454545vw;
}

#musasi .calendar {
	padding: 20px 5.4545454545vw;
}

#musasi .calendar_row {
	grid-template-columns: 25.4545454545vw repeat(7, 1fr);
	padding-right: 3.6363636364vw;
}

#musasi .way_itemWrap {
	gap: 25px;
}

#musasi .way_num {
	font-size: 2.2rem;
	height: 35px;
	width: 35px;
}

#musasi .shopCta .cta {
	gap: 4.5454545455vw;
	padding: 0 2.2727272727vw;
}

#musasi .shopCta .cta_telWrap {
	border-radius: 1.8181818182vw;
	gap: 1.8181818182vw;
	padding: 2.7272727273vw 0;
}

#musasi .staffMessage_contents {
	gap: 25px;
}

#musasi .staffMessage .media {
	flex-direction: column;
	width: calc((100% - 25px) / 2);
}

#musasi .staffMessage .media_img {
	display: none;
}

#musasi .staffMessage .media_img__sp {
	aspect-ratio: 68/29;
	border-radius: 20px;
	display: inline;
}

#musasi .author .media {
	gap: 25px;
}

#musasi .author .media_img {
	width: 48%;
}

#musasi .author .media_body {
	padding-right: 30px;
	padding-top: 25px;
}

#musasi .author .media_heading {
	font-size: 2.1rem;
	margin-bottom: 15px;
}

#musasi .author .media_heading__sm {
	font-size: 1.6rem;
}

#musasi .toYou .media {
	gap: 5%;
}

#musasi .toYou .media_body {
	padding-top: 0;
	width: 55%;
}

#musasi .toYou .media_txt {
	letter-spacing: -1px;
}

#musasi .review_contents {
	gap: 15px;
}

#musasi .review_item {
	padding: 35px 20px;
}

#aga,
#price,
#counseling,
#reserve,
#shop,
#others {
	margin-top: -90px;
	padding-top: 90px;
}

#minor .minor_contents {
	gap: 30px;
}

#minor .minor_contents img {
	width: calc(50% - 15px);
}

#sitemap .sitemap {
	gap: 50px 70px;
}

#recruit #counselor,
#recruit #doctor {
	margin-top: -90px;
	padding-top: 90px;
}

#price .payment_wrap {
	padding: 40px 30px;
}

#price .payment_ttl {
	font-size: 2.4rem;
}

#price .payment_item {
	padding: 20px;
}

#price .payment_heading {
	font-size: 1.8rem;
	width: 240px;
}

#price .payment_desc {
	padding-top: 3px;
	width: calc(100% - 240px);
}

#regrowth .point .media {
	gap: 50px;
}

#regrowth .point .media_heading {
	font-size: 2.3rem;
}

#regrowth .point .media_num__primary {
	font-size: 3.4rem;
}

#regrowth .point .media_num__primary span {
	font-size: 2.3rem;
}

#regrowth .case_inner {
	padding: 20px;
}

#regrowth .case_content {
	padding: 15px;
}

#regrowth .case .media {
	gap: 15px;
}

#regrowth .case .media > * {
	width: calc((100% - 15px) / 2);
}

#regrowth .case .media_img {
	gap: 15px;
}

#regrowth .case .media_img::after {
	border-width: 10px 0 10px 9px;
}

#regrowth .case .media_img img {
	width: calc((100% - 15px) / 2);
}

}

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

#home .about .media {
	gap: 50px;
}

#home .about .media_heading {
	margin-bottom: 10px;
}

#home .about .media_txt {
	margin-bottom: 20px;
}

}

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

/* ----------------------------------------
  Base
  ---------------------------------------- */

main {
	margin-top: 12vw;
}

.container {
	padding: 0 4vw;
}

.container_lg {
	padding: 0 4vw;
}

.container_sm {
	padding: 0 4vw;
}

.mb7 {
	margin-bottom: 9.3333333333vw;
}

/* ----------------------------------------
  header
  ---------------------------------------- */

.header {
	height: 12vw;
}

.header_ttl {
	width: 44vw;
}

.gnav {
	padding: 0 2.6666666667vw;
}

.gnav_menu__sp {
	background-color: transparent;
	height: calc(100vh - 12vw);
	padding-bottom: 33.3333333333vw;
	padding-left: 0;
	padding-right: 0;
	padding-top: 6.6666666667vw;
	scrollbar-width: none;
	top: 12vw;
	transform: translateX(50%);
	width: 84vw;
}

.gnav_menu__sp::-webkit-scrollbar {
	display: none;
}

.gnav_list {
	font-size: 3.7333333333vw;
	margin-bottom: 0;
	width:100%;
	border-bottom: dashed 1px #595757;
}
.gnav_list__hasChild{
	position: relative;
}
.gnav_list::after{
	content: none;
}
.gnav_switch{
	position: absolute;
	color: #55934f;
	font-size: 16px;
	font-weight: bold;
	top: 12px;
	right: 14px;
	display: block;
	z-index: +1;
}
.gnav_switch.is-actice{
	transform: rotate(180deg);
}

.gnav_list__first{
	border-top: dashed 1px #595757;
}

.gnav_list a,.gnav_list_has-child{
	display: block;
	width: 100%;
	padding: 14px;
}
.gnav_list_has-child{
	position: relative;
}
.gnav_list_has-child::after{
	position: absolute;
	content: '▼';
	color: #00b900;
	transform: translateY(-50%);
	top: 50%;
	right: 18px;
	font-size: 14px;
	transition: 0.3s;
}
.gnav_list_has-child.is-actice::after{
	transform: translateY(-50%) rotate(180deg);
	transition: 0.3s;
}

.gnav_list__child {
	font-size: 3.4666666667vw;
	width:100%;
	display: none;
}

.gnav_list__child li:last-child{
	border: none;
}
.gnav_list__child li a{
	text-indent: 1em;
}

.gnav_list .gnav_list__child li {
	margin-top: 0;
	border: none;
	border-top: dashed 1px #595757;
}

.gnav_list__child a::before{
	background-color: #595757;
	height: 2px;
    left: 14px;
	width: 8px;
}

.is_open .gnav_menu__sp {
	right: 50%;
}

.is_open .hamburgerBtn_line:nth-child(1) {
	top: 3.8666666667vw;
}

.is_open .hamburgerBtn_line:nth-child(3) {
	top: 3.8666666667vw;
}

.is_open .overlay {
	opacity: 1;
	right: 0;
	visibility: visible;
}

.hamburgerBtn {
	height: 7.7333333333vw;
	width: 7.7333333333vw;
}

.hamburgerBtn_line {
	height: 0.4vw;
}

.hamburgerBtn_line:nth-child(1) {
	top: 1.2vw;
}

.hamburgerBtn_line:nth-child(2) {
	top: 3.8666666667vw;
}

.hamburgerBtn_line:nth-child(3) {
	top: 6.5333333333vw;
}

.overlay {
	display: block;
	height: calc(100vh - 12vw);
	top: 12vw;
}

/* ----------------------------------------
  subPageMv
  ---------------------------------------- */

.subPageMv {
	border-radius: 0;
	height: 22.6666666667vw;
}

.subPageMv_ttl {
	font-size: 4.8vw;
	padding-left: 0;
}

.subPageMv_img {
	right: 2.6666666667vw;
	top: 4vw;
	width: 40vw;
}

.subPageMv_mask {
	height: 22.6666666667vw;
}

.breadcrumb {
	font-size: 3.4666666667vw;
	margin-bottom: 2.6666666667vw;
	padding: 2.6666666667vw 4vw;
}

/* ----------------------------------------
  btn
  ---------------------------------------- */

.btn_wrap {
	padding-top: 5.3333333333vw;
}

.btn {
	font-size: 3.7333333333vw;
	min-width: 74.6666666667vw;
	padding: 5.3333333333vw 10.6666666667vw;
}

.btn.pc {
	display: none;
}

.btn.sp {
	display: inline-block;
}

.btn__arrow span::after {
	border-width: 0.4vw;
	margin-left: 4vw;
	min-height: 2vw;
	min-width: 2vw;
}

.btn__back span::before {
	border-width: 0.4vw;
	margin-right: 4vw;
	min-height: 2vw;
	min-width: 2vw;
}

/* ----------------------------------------
  cta
  ---------------------------------------- */

.cta_catch {
	font-size: 2.9333333333vw;
	letter-spacing: -0.2666666667vw;
	margin-bottom: 0.4vw;
}

.cta_catch__line::before {
	left: -2vw;
}

.cta_catch__line::after {
	right: -1.3333333333vw;
}

.cta_btn.pc {
	display: none;
}

.cta_btn.sp {
	display: block;
}

.cta_info {
	display: none;
}

.cta_info__sp {
	display: block;
}

.cta_name {
	margin-top: -7px;
	width: 30%;
}

.cta_tel {
	margin-bottom: 10px;
	width: calc(70% - 1vw);
}

.cta_time:not(:last-child) {
	margin-bottom: 5.3333333333vw;
}

.cta__primary {
	flex-direction: column;
	gap: 0;
	margin-bottom: 8vw;
	margin-top: 8vw;
}

.cta__primary .cta_contents {
	width: 100%;
}

.cta__primary .cta_catch {
	font-size: 3.7333333333vw;
	margin-bottom: 0.6666666667vw;
}

.cta__primary .cta_catch__line::before {
	left: -3.3333333333vw;
}

.cta__primary .cta_catch__line::after {
	right: -2.6666666667vw;
}

.cta__primary .cta_btn {
	margin-bottom: 4vw;
}

.cta__primary .cta_info__sp {
	margin-top: 2.6666666667vw;
	width: 100%;
}

.cta__primary .cta_telWrap {
	margin-bottom: 1.3333333333vw;
}

.cta__primary .cta_name {
	width: 21%;
}

.cta__primary .cta_tel {
	margin-bottom: 1.3333333333vw;
	width: 55%;
}

.cta__primary .cta_time {
	width: 65vw;
}

/* ----------------------------------------
  tel
  ---------------------------------------- */

.tel {
	padding: 0 4vw;
}

.tel_ttl {
	font-size: 4vw;
	margin-bottom: 4vw;
}

.tel .cta {
	border-radius: 3.2vw;
	flex-direction: column;
	gap: 6.6666666667vw;
	margin-bottom: 13.3333333333vw;
	padding: 4vw 5.3333333333vw;
}

.tel .cta::after {
	height: 1px;
	width: calc(100% - 10.6666666667vw);
}

.tel .cta_content {
	width: 100%;
}

.tel .cta_name {
	display: none;
}

.tel .cta_name__sp {
	display: block;
	width: 18.6666666667vw;
}

.tel .cta_telWrap {
	align-items: center;
	display: flex;
	margin-bottom: 2.6666666667vw;
}

.tel .cta_tel {
	margin-bottom: 0;
	width: 51.2vw;
}

.tel .cta_time {
	width: 80%;
}

/* ----------------------------------------
  title
  ---------------------------------------- */

.topSection_ttl {
	font-size: 5.3333333333vw;
	margin-bottom: 4vw;
}

.section_ttl {
	margin-bottom: 6.6666666667vw;
}

.section_ttl__en {
	font-size: 8vw;
	margin-bottom: 2vw;
}

.section_ttl__ja {
	font-size: 3.4666666667vw;
}

.heading_lv3 {
	font-size: 5.3333333333vw;
}

.heading_lv3__sm {
	font-size: 3.4666666667vw;
}

/* ----------------------------------------
  card
  ---------------------------------------- */

.card__primary {
	border-radius: 0 0 2.6666666667vw 2.6666666667vw;
	box-shadow: 0.2666666667vw 0.2666666667vw 0.6666666667vw 0.2666666667vw rgba(0, 0, 0, 0.16);
	padding: 4vw 6.6666666667vw;
}

.card__primary::before {
	border-radius: 2.6666666667vw 2.6666666667vw 0 0;
	height: 4vw;
	top: -5.0666666667vw;
}

/* ----------------------------------------
  media
  ---------------------------------------- */

.media {
	gap: 6.6666666667vw;
	flex-direction: column;
}

.media_heading {
	font-size: 4vw;
	margin-bottom: 5.3333333333vw;
}

.media_heading__line {
	margin-bottom: 9.3333333333vw;
}

.media_heading__line::after {
	background-image: repeating-linear-gradient(-45deg, rgba(184, 213, 84, 0.7), rgba(184, 213, 84, 0.7) 0.4vw, transparent 0.5333333333vw, transparent 1.0666666667vw);
	bottom: -4vw;
	height: 1.6vw;
}

.media_num {
	font-size: 6.6666666667vw;
}

.media_num__primary {
	font-size: 5.3333333333vw;
	padding-right: 5.3333333333vw;
}

.media_num__primary span {
	font-size: 4vw;
	margin-right: 0.9333333333vw;
}

.media__ribbon::after {
	border-width: 0 1.3333333333vw 1.3333333333vw 1.3333333333vw;
	left: 9.3333333333vw;
}

.media__ribbon .media_num {
	font-size: 3.4666666667vw;
	height: 7.3333333333vw;
	left: 2.6666666667vw;
	padding-top: 1.3333333333vw;
	top: -1.3333333333vw;
	width: 8vw;
}

.media__ribbon .media_num::before {
	border-width: 0 0 1.3333333333vw 4vw;
}

.media__ribbon .media_num::after {
	border-width: 0 4vw 1.3333333333vw 0;
}

/* ----------------------------------------
  access
  ---------------------------------------- */

.access {
	margin-top: 13.3333333333vw;
	margin-bottom: 13.3333333333vw;
}

.access_contents {
	font-size: 3.4666666667vw;
	margin-bottom: 0;
}

.access .media {
	flex-direction: column;
	gap: 5.3333333333vw;
	margin-bottom: 10.6666666667vw;
}

.access .media > * {
	width: 100%;
}

.access .media_body {
	padding: 0 5vw;
}

.access .media_heading {
	font-size: 3.7333333333vw;
	margin-bottom: 2.6666666667vw;
}

.access_list {
	padding: 0.6666666667vw 0;
}

.access_ttl {
	width: 20vw;
}

.access_desc {
	width: calc(100% - 20vw);
}

.access iframe {
	height: 58.4vw;
}

.access .btn.sp {
	display: block;
	margin: 0 auto;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
}

/* ----------------------------------------
  accordion
  ---------------------------------------- */

.accordion_icon {
	left: 2.6666666667vw;
	width: 7.3333333333vw;
}

.accordion_heading {
	border-radius: 1.3333333333vw;
	font-size: 3.7333333333vw;
	margin-bottom: 4vw;
	padding: 2.6666666667vw 5.3333333333vw 2.6666666667vw 12vw;
}

.accordion_heading .accordion_icon {
	top: 1.2vw;
}

.accordion_heading::before,
.accordion_heading::after {
	right: 2.6666666667vw;
	width: 2vw;
}

.accordion_body {
	font-size: 3.4666666667vw;
	line-height: 1.2;
	padding-left: 12vw;
	padding-right: 4vw;
}

.accordion_body:not(:last-child) {
	margin-bottom: 5.3333333333vw;
}

.accordion_body p {
	padding-top: 1.6vw;
}

/* ----------------------------------------
  campaign
  ---------------------------------------- */

.campaign {
	margin-bottom: 8vw;
}

.campaign_ttl {
	font-size: 4.8vw;
	margin-bottom: 2.6666666667vw;
}

.campaign_contents {
	gap: 2.6666666667vw;
}

.campaign_item {
	width: 100%;
}

/* ----------------------------------------
  footer
  ---------------------------------------- */

.footer {
	padding-bottom: 6.6666666667vw;
	padding-top: 8vw;
}

.footer_ttl {
	margin-bottom: 5.3333333333vw;
}

.footer_ttl img {
	width: 62.6666666667vw;
}

.footer_nav {
	display: none;
}

.footer_txt {
	font-size: 2.9333333333vw;
	margin-bottom: 6.6666666667vw;
}

.copyright {
	font-size: 2.9333333333vw;
}

/* ----------------------------------------
  article
  ---------------------------------------- */

.article_heading {
	margin-bottom: 8vw;
}

.article_date {
	border-width: 0.6666666667vw;
	font-size: 2.9333333333vw;
	gap: 2.6666666667vw;
	padding-bottom: 0.6666666667vw;
}

.article_ttl {
	font-size: 3.7333333333vw;
	margin-bottom: 1.3333333333vw;
}

.article_sns {
	bottom: 1.3333333333vw;
	gap: 1.3333333333vw;
}

.article_sns img {
	width: 5.3333333333vw;
}

.article_img {
	margin-bottom: 8vw;
}

.article p {
	font-size: 3.4666666667vw;
	margin-bottom: 4vw;
}

.article h2,
.article h3,
.article h4,
.article h5,
.article h6 {
	margin-bottom: 4vw;
}

.article h2 {
	font-size: 4vw;
}

.article h3 {
	font-size: 3.7333333333vw;
	padding-left: 2vw;
}

.article h3::before {
	width: 0.6666666667vw;
}

.article h4 {
	font-size: 3.4666666667vw;
}

.article ul,
.article ol {
	font-size: 3.4666666667vw;
	margin-bottom: 4vw;
	padding: 4vw;
	padding-left: 8vw;
	width: 100%;
}

.article ul li::marker {
	font-size: 5.3333333333vw;
}

.article .checklist li::before {
	height: 3.6vw;
	left: -4.4vw;
	top: 0.5333333333vw;
	width: 3.6vw;
}

.article .wp-block-quote {
	font-size: 3.4666666667vw;
	margin-bottom: 4vw;
	padding: 4vw 9.3333333333vw;
	width: 100%;
}

.article .wp-block-quote::before,
.article .wp-block-quote::after {
	height: 4.4vw;
	width: 5.6vw;
}

.article .wp-block-quote::before {
	left: 2vw;
	top: 2vw;
}

.article .wp-block-quote::after {
	bottom: 2vw;
	right: 2vw;
}

.article .wp-block-quote cite {
	margin-top: 1.3333333333vw;
}

.article .wp-block-table {
	font-size: 3.2vw;
	margin-bottom: 4vw;
}

.article .wp-block-table tr:not(:last-child) {
	border-width: 0.4vw;
}

.article .wp-block-table td {
	height: 8.2666666667vw;
	padding: 1.3333333333vw 2vw;
	width: 36.6666666667vw;
}

.article .wp-block-table td:not(:last-child) {
	border-width: 0.4vw;
}

.article .wp-block-table.column tr:first-child td {
	font-size: 3.2vw;
}

.article .wp-block-table.row tr td:first-child {
	font-size: 3.2vw;
}

.article .wp-block-table.both td:first-child {
	font-size: 3.2vw;
}

.article .wp-block-table.both tr:first-child td {
	font-size: 3.2vw;
}

.article .wp-block-table.scroll {
	padding-bottom: 0.6666666667vw;
}

.article .wp-block-table.scroll td {
	min-width: 36.6666666667vw;
}

.article .wp-block-table.scroll td:first-child {
	font-size: 3.2vw;
}

.article .wp-block-table.scroll tr:first-child td {
	font-size: 3.2vw;
}

.article .wp-block-buttons {
	gap: 2.6666666667vw;
	margin-bottom: 6.6666666667vw;
}

.article .wp-block-button__link {
	border-radius: 1.6vw;
	font-size: 3.7333333333vw;
	/*max-width: 40vw;*/
	padding: 2.6666666667vw 5.3333333333vw;
}

.article .wp-block-button__link::after {
	border-width: 0.4vw;
	margin-left: 2vw;
	min-height: 2vw;
	min-width: 2vw;
}

.article .media {
	border-radius: 4vw;
	border-width: 0.2666666667vw;
	gap: 4vw;
	margin-bottom: 4vw;
	padding: 5.3333333333vw;
	width: 100%;
}

.article .media_img {
	height: 19.2vw;
	width: 26.6666666667vw;
}

.article .media_body {
	line-height: 1.3;
	padding-top: 0;
}

.article .media_body time {
	font-size: 2.9333333333vw;
	margin-bottom: 1.3333333333vw;
	margin-top: -0.6666666667vw;
}

.article .media_ttl {
	-webkit-line-clamp: 3;
	font-size: 3.4666666667vw;
}

.article .media_name {
	font-size: 3.7333333333vw;
	margin-bottom: 1.3333333333vw;
}

/* ----------------------------------------
  calendar
  ---------------------------------------- */

.calendar {
	margin-bottom: 6.6666666667vw;
}

.calendar_heading {
	font-size: 3.7333333333vw;
}

.calendar_row {
	grid-template-columns: 26.6666666667vw repeat(7, 1fr);
	padding: 1.3333333333vw 0;
}

.calendar tbody .calendar_row:last-child {
	margin-bottom: 1.3333333333vw;
}

.calendar tbody .calendar_hour {
	font-size: 3.4666666667vw;
	letter-spacing: -0.4vw;
}

.calendar_dot {
	font-size: 3.7333333333vw;
}

.calendar_note {
	font-size: 3.4666666667vw;
}

.calendar_link {
	font-size: 3.4666666667vw;
}

.calendar_link a::after {
	border-width: 0.4vw;
	margin-left: 2vw;
	min-height: 2vw;
	min-width: 2vw;
}

/* ----------------------------------------
  form
  ---------------------------------------- */

#form {
	margin-top: -12vw;
	padding-top: 12vw;
}

.form {
	margin-bottom: 5.3333333333vw;
}

.form_nextItem .form_item {
	margin-top: -2.6666666667vw;
}

.form_item {
	flex-wrap: wrap;
	gap: 2.6666666667vw;
	padding: 4vw 0;
}

.form_label {
	font-size: 3.4666666667vw;
	line-height: 2.1;
	margin-top: 0;
	padding-left: 10.6666666667vw;
	width: 100%;
}

.form_label span {
	font-size: 3.2vw;
	padding: 0.6666666667vw 1.0666666667vw;
	top: 0.6666666667vw;
}

.form_label p {
	margin-left: -10vw;
}

.form_inputWrap {
	gap: 2.6666666667vw;
}

.form_input,
.form_textarea {
	font-size: 3.2vw;
	padding: 2.6666666667vw 5.3333333333vw;
	width: 100%;
}

.form_textarea {
	height: 26.6666666667vw;
}

.form_radio {
	margin-left: 12vw;
}

.form_radio label {
	font-size: 3.4666666667vw;
	gap: 1.3333333333vw;
	padding-top: 0;
	width: 26.6666666667vw;
}

.form_radio input {
	width: 4vw;
}

.form select {
	padding: 2.6666666667vw;
}

.form_date,
.form_nextBtn {
	font-size: 3.2vw;
	padding: 2.6666666667vw 5.3333333333vw;
	width: 40vw;
}

.form_time {
	font-size: 3.2vw;
	gap: 1.3333333333vw 2.6666666667vw;
}

.form_time .wpcf7-list-item {
	width: calc((100% - 10.6666666667vw) / 5);
}

.form_time .wpcf7-list-item-label {
	padding: 0.6666666667vw 0;
}

.form_fileWrap {
	align-items: flex-start;
	flex-direction: column;
	font-size: 3.4666666667vw;
	gap: 2vw;
}

.form_file {
	line-height: 1;
	padding: 4vw 6.6666666667vw;
	padding: 4vw 10vw;
}

.form_selectWrap::after {
	border-width: 1.4666666667vw 0.8vw 0 0.8vw;
	right: 2.6666666667vw;
	top: 5.3333333333vw;
}

.form_selectWrap select {
	font-size: 3.2vw;
	padding-right: 6.6666666667vw;
	width: 44.8vw;
}

.form_submit {
	font-size: 4.2666666667vw;
	margin-top: 1.3333333333vw;
	padding: 2.8vw;
	width: 40vw;
}

/* ----------------------------------------
  privacy
  ---------------------------------------- */

.privacy {
	height: 29.3333333333vw;
	padding: 4vw 5.3333333333vw;
}

.privacy_ttl {
	font-size: 3.2vw;
	margin-bottom: 2.6666666667vw;
}

.privacy_txt {
	font-size: 3.2vw;
	margin-bottom: 2.6666666667vw;
}

.privacy_list dd:not(:last-child) {
	margin-bottom: 2.6666666667vw;
}

/* ----------------------------------------
  contact
  ---------------------------------------- */

.contact_ttl {
	font-size: 5.3333333333vw;
	margin-bottom: 5.3333333333vw;
}

.contact_txt {
	font-size: 3.4666666667vw;
	margin-bottom: 5.3333333333vw;
	text-align: left;
}

/* ----------------------------------------
  register
  ---------------------------------------- */

.register {
	border-radius: 3.2vw;
	flex-direction: column;
	gap: 0;
	max-width: 100%;
	padding: 6.6666666667vw 5.3333333333vw;
}

.register_txt {
	letter-spacing: -0.1333333333vw;
	margin-bottom: 3.3333333333vw;
	text-align: center;
}

.register_txt__sm {
	font-size: 3.4666666667vw;
}

.register_txt__md {
	font-size: 4vw;
}

.register_txt__lg {
	font-size: 4vw;
}

.register_btn {
	margin-bottom: 6.6666666667vw;
	width: 100%;
}

.register_btn .pc {
	display: none;
}

.register_btn .sp {
	display: block;
}

.register_qr {
	width: 52vw;
}

/* ----------------------------------------
  pagenation
  ---------------------------------------- */

.pagenation {
	gap: 2vw;
	margin-bottom: 10.6666666667vw;
}

.page-numbers {
	font-size: 3.2vw;
	padding: 1.2vw 1.8666666667vw;
}

.page-numbers.prev,
.page-numbers.next {
	padding: 1.2vw 0;
}

.page-numbers.prev {
	margin-left: -11.7333333333vw;
}

.page-numbers.next {
	margin-right: -11.7333333333vw;
}

/* ----------------------------------------
  search
  ---------------------------------------- */

.searchform {
	margin-bottom: 12vw;
	padding: 5.3333333333vw 0;
}

.searchform_ttl {
	font-size: 3.7333333333vw;
	padding-left: 0;
	text-align: center;
}

.searchform input {
	width: 4vw;
}

.searchform_case {
	margin-bottom: 5.3333333333vw;
}

.searchform_case dd {
	gap: 1.3333333333vw;
}

.searchform_case dt {
	margin-bottom: 4vw;
}

.searchform_case label {
	border-radius: 1.8666666667vw;
	width: calc((100% - 2.6666666667vw) / 3);
}

.searchform_case input {
	left: 50%;
	top: calc(100% - 6.6666666667vw);
	transform: translateX(-50%);
}

.searchform_icon.pc {
	display: none;
}

.searchform_icon.sp {
	display: block;
}

.searchform_age {
	flex-direction: column;
	gap: 4vw;
	padding: 0 5.3333333333vw;
}

.searchform_age dd {
	flex-wrap: wrap;
	gap: 2.6666666667vw 1.3333333333vw;
	justify-content: center;
}

.searchform_age label {
	font-size: 4vw;
	width: 20vw;
}

.searchform_age input {
	margin-right: 2vw;
}

.searchform .btn_wrap {
	padding-top: 6.6666666667vw;
}

/* ----------------------------------------
  table
  ---------------------------------------- */

.table_item {
	flex-direction: column;
}

.table_ttl {
	font-size: 4vw;
	padding: 2vw 5.3333333333vw;
	width: 100%;
}

.table_desc {
	font-size: 3.4666666667vw;
	letter-spacing: -0.1333333333vw;
	padding: 4vw 5.3333333333vw;
}

/* ----------------------------------------
  archive
  ---------------------------------------- */

.archive {
	gap: 5.3333333333vw;
	grid-template-columns: 1fr;
	justify-content: center;
	margin-bottom: 13.3333333333vw;
}

.archive_content a {
	display: flex;
	gap: 4vw;
}

.archive_img {
	margin-bottom: 0;
	width: 40%;
}

.archive time {
	display: block;
	font-size: 2.9333333333vw;
	margin-bottom: 1.3333333333vw;
}

.archive_ttl {
	-webkit-line-clamp: 4;
	font-size: 3.4666666667vw;
}

/* ----------------------------------------
  pageNav
  ---------------------------------------- */

.pageNav {
	gap: 2vw;
	margin-bottom: 8vw;
}

.pageNav_link {
	border-radius: 1.8666666667vw;
	width: calc((100% - 4vw) / 3);
}

.pageNav_link a {
	font-size: 3.2vw;
	padding: 2.9333333333vw 3.3333333333vw;
}

.pageNav_link a::before,
.pageNav_link a::after {
	height: 0.4vw;
	right: 3.3333333333vw;
	width: 1.7333333333vw;
}

.pageNav_link a::after {
	top: calc(50% - 0.2vw);
}

.pageNav_link .pc {
	display: none;
}

.pageNav_link .sp {
	display: inline;
}

.pageNav_heading {
	font-size: 4.5333333333vw;
	margin-bottom: 5.3333333333vw;
}

#column .pageNav_link,
#faq .pageNav_link,
.tax-faq_cat .pageNav_link {
	width: calc((100% - 2vw) / 2);
}

/* ----------------------------------------
  guideline
  ---------------------------------------- */

.guideline {
	margin-bottom: 17.3333333333vw;
}

.guideline_inner {
	padding: 0 5.3333333333vw;
}

.guideline_txt {
	font-size: 3.4666666667vw;
	margin-bottom: 8vw;
}

.guideline_content:not(:last-of-type) {
	margin-bottom: 8vw;
}

.guideline_heading {
	font-size: 4.2666666667vw;
	margin-bottom: 4vw;
	padding-bottom: 0.6666666667vw;
}

.guideline_desc {
	font-size: 3.4666666667vw;
}

.guideline_list {
	margin: 4vw 0;
}

.guideline_list li {
	text-indent: 2.6666666667vw;
}

.guideline_list li::before {
	left: -2.6666666667vw;
}

.thanks_ttl {
	font-size: 4.5333333333vw;
	line-height: 1.3;
	margin-bottom: 5.3333333333vw;
}

.thanks_txt {
	font-size: 3.4666666667vw;
	margin-bottom: 4vw;
	padding: 0 5.3333333333vw;
	text-align: left;
}

.thanks_txt:last-of-type {
	margin-bottom: 8vw;
}

/* ----------------------------------------
  br
  ---------------------------------------- */

.br_overMd {
	display: none;
}

.br_onlyMd {
	display: none;
}

.br_sp {
	display: block;
}

/* ----------------------------------------
  image
  ---------------------------------------- */

.image_inner {
	border-radius: 0;
	margin-bottom: 9.3333333333vw;
	padding: 5.3333333333vw 4vw 6.6666666667vw;
}

.image_ttl {
	font-size: 5.3333333333vw;
	margin-bottom: 4vw;
}

.image_heading {
	font-size: 3.4666666667vw;
}

.image_heading span {
	font-size: 4vw;
}

.image .media {
	border-radius: 1.8666666667vw;
	box-shadow: 0.2666666667vw 0.4618666667vw 1.092vw 0.108vw rgba(145, 139, 139, 0.1);
	flex-direction: column;
	gap: 5.3333333333vw;
	padding: 4vw 3.3333333333vw;
}

.image .media:not(:last-of-type) {
	margin-bottom: 2.6666666667vw;
}

.image .media > * {
	width: 100%;
}

.image .media_img {
	gap: 5.3333333333vw;
}

.image .media_img::after {
	border-width: 2.8vw 0 2.8vw 2.5333333333vw;
}

.image .media_img img {
	width: calc(50% - 2.6666666667vw);
}

.image .media_heading {
	border-radius: 0.8vw;
	font-size: 4.2666666667vw;
	margin-bottom: 2.6666666667vw;
	padding: 1.3333333333vw 2.6666666667vw;
}

.image_desc {
	font-size: 3.4666666667vw;
}

.image_desc:not(:last-of-type) {
	margin-bottom: 2.6666666667vw;
}

/* ----------------------------------------
  example
  ---------------------------------------- */

.example#aga,
.example#faga,
.example#circle,
.example #plan01,
.example #plan02,
.example #plan03 {
	margin-top: -12vw;
	padding-top: 12vw;
}

.example:not(:last-of-type) {
	margin-bottom: 12vw;
}

.example_ttl {
	font-size: 5.3333333333vw;
	margin-bottom: 4vw;
}

.example_ttl img {
	height: 8vw;
	margin-right: 2.6666666667vw;
}

.example_item:not(:last-of-type) {
	margin-bottom: 5.3333333333vw;
}

.example_heading {
	border-radius: 1.8666666667vw 1.8666666667vw 0 0;
	border-width: 0.6666666667vw;
	font-size: 4.5333333333vw;
	padding: 2vw 5.3333333333vw;
}

.example_num {
	font-size: 4.8vw;
	margin-right: 4vw;
}

.example_body {
	border-radius: 0 0 1.8666666667vw 1.8666666667vw;
	padding: 4vw 5.3333333333vw;
}

.example_beforeAfter {
	margin-bottom: 6.6666666667vw;
}

.example_beforeAfter p {
	font-size: 4.2666666667vw;
	margin-bottom: 4vw;

}

.example_beforeAfter div {
	gap: 4vw;
}

.example_beforeAfter div::after {
	border-width: 2.8vw 0 2.8vw 2.5333333333vw;
}

.example_beforeAfter img {
	margin-bottom: 1.3333333333vw;
}

.example_beforeAfter figcaption {
	font-size: 3.4666666667vw;
	padding: 0.4vw;
	width: 26.6666666667vw;
}

.example h5 {
	font-size: 3.7333333333vw;
	margin-bottom: 1.3333333333vw;
	padding-left: 1.3333333333vw;
}

.example .accordion_heading {
	font-size: 3.7333333333vw;
	letter-spacing: -0.1333333333vw;
	margin-bottom: 2vw;
	padding: 1.3333333333vw;
	padding-right: 4vw;
}

.example .accordion_body {
	padding: 0 1.3333333333vw;
}

.plan1 .plan_item dt,
.plan2 .plan_item dt {
	width: 18.6666666667vw;
}

.plan1 .plan_item dd,
.plan2 .plan_item dd {
	width: 53.3333333333vw;
}

.planCircle .plan_item dt {
	width: 14.6666666667vw;
}

.plan {
	margin-bottom: 8vw;
}

.plan_info {
	margin-bottom: 9.3333333333vw;
}

.plan_ttl {
	border-radius: 1.3333333333vw;
	font-size: 4.2666666667vw;
	margin-bottom: 4vw;
	padding: 1.3333333333vw;
}

.plan_item {
	padding: 2.6666666667vw 0;
	padding-left: 0;
}

.plan_item dt {
	width: 20vw;
}

.plan_item dd {
	width: 61.3333333333vw;
}

.plan_heading {
	font-size: 4vw;
}

.plan_desc {
	font-size: 4.8vw;
	margin-top: -2vw;
}

.plan_desc__md {
	font-size: 3.4666666667vw;
	margin-top: 0.4vw;
}

.plan_desc__box {
	width: 18.6666666667vw;
}

.plan_desc > p:last-child {
	margin-bottom: -2.4vw;
}

.plan_price {
	font-size: 5.3333333333vw;
}

.plan_price__sm {
	font-size: 3.4666666667vw;
}

.plan_note {
	font-size: 3.4666666667vw;
	margin-bottom: 2.6666666667vw;
	margin-top: 4vw;
}

.plan_link {
	font-size: 3.4666666667vw;
}

/* ----------------------------------------
  catch
  ---------------------------------------- */

.catch li {
	margin-bottom: 5.3333333333vw;
	width: 33.3333333333%;
}

.catch_heading {
	font-size: 3.7333333333vw;
	letter-spacing: -0.1333333333vw;
}

.catch_num {
	font-size: 8vw;
}

.catch_num__lg {
	font-size: 18.6666666667vw;
}

.catch_note {
	font-size: 3.4666666667vw;
	margin-bottom: 8vw;
}

/* ----------------------------------------
  list
  ---------------------------------------- */

.list {
	margin-bottom: 13.3333333333vw;
}

.list li {
	padding: 2vw 5.3333333333vw 2.6666666667vw;
}

.list_heading {
	font-size: 4.2666666667vw;
	padding-top: 1.3333333333vw;
}

.list_num {
	font-size: 6.1333333333vw;
}

.list_num__lg {
	font-size: 9.3333333333vw;
	margin-right: 0.6666666667vw;
}

/* ----------------------------------------
  flowStep
  ---------------------------------------- */

.flowStep {
	margin-bottom: 9.3333333333vw;
	padding-bottom: 9.3333333333vw;
	padding-top: 9.3333333333vw;
}

/* .flowStep .media_wrap {
	display: none;
} */
/* 
.flowStep__sp {
	display: block;
}

.flowStep__sp li:not(:last-child) {
	margin-bottom: 5.3333333333vw;
	position: relative;
}

.flowStep__sp li:not(:last-child)::after {
	border-color: #55934f transparent transparent transparent;
	border-style: solid;
	border-width: 2.4vw 2.4vw 0 2.4vw;
	bottom: -3.7333333333vw;
	content: "";
	height: 0;
	left: 50%;
	position: absolute;
	transform: translateX(-50%);
	width: 0;
} */

#home .mainvisual {
	padding: 0;
}

#home .mainvisual_inner {
	border-radius: 0;
	padding: 0;
}

#home .mainvisual_img__pc {
	display: none;
}

#home .mainvisual_img__sp {
	display: block;

}
#home .topCta {
	padding: 0 2vw;
}

#home .topCta_inner {
	border-radius: 3.2vw;
	box-shadow: 0.2666666667vw 0.4618666667vw 1.092vw 0.108vw rgba(145, 139, 139, 0.31);
	gap: 1.3333333333vw;
	margin-bottom: 8vw;
	margin-top: -7.3333333333vw;
	padding: 4vw 2vw;
}

#home .topCta .cta_contents {
	width: calc((100% - 1.3333333333vw) / 2);
}

#home .topCta .cta_btn {
	margin-bottom: 2vw;
}

#home .topCta .cta_info {
	flex-direction: column;
	gap: 1.3333333333vw;
}

#home .topCta .cta_telWrap {
	display: none;
}

#home .topCta .cta_tel {
	line-height: 0;
	margin-bottom: 0;
	width: 95%;
}

#home .topCta .cta_tel.sp {
	display: block;
}

#home .topCta .cta_time.pc {
	display: none;
}

#home .topCta .cta_time.sp {
	display: inline;
	width: 95%;
}

#home .campaign {
	margin-bottom: 10.6666666667vw;
}

#home .feature {
	padding-bottom: 8vw;
	padding-top: 8vw;
}

#home .feature_bg {
	display: none;
}

#home .feature_bg__sp {
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	display: block;
	height: 68%;
	position: absolute;
	top: 0;
	width: 100%;
	z-index: -1;
}

#home .feature_contents {
	flex-wrap: wrap;
	justify-content: center;
	margin: 0 auto;
}

#home .feature_contents li {
	width: 50%;
}

#home .feature_contents img {
	width: 100%;
}

#home .case {
	padding-bottom: 8vw;
	padding-top: 8vw;
}

#home .case_ttl {
	border-radius: 1.3333333333vw;
	font-size: 4.2666666667vw;
	margin-bottom: 3.3333333333vw;
}

#home .case_item {
	padding: 6.6666666667vw 4vw;
}

#home .case_img {
	gap: 1.3333333333vw;
}

#home .case_img::after {
	height: 9.3333333333vw;
	width: 6.6666666667vw;
}

#home .case_prev,
#home .case_next {
	height: 8vw;
	top: 40%;
	width: 8vw;
}

#home .case_prev::after,
#home .case_next::after {
	border-width: 0.4vw;
	content: "";
	height: 2vw;
	position: absolute;
	top: 3.0666666667vw;
	transform-origin: center;
	width: 2vw;
}

#home .case_prev {
	left: 2vw;
}

#home .case_prev::after {
	left: 3.3333333333vw;
}

#home .case_next {
	right: 2vw;
}

#home .case_next::after {
	right: 3.3333333333vw;
}

#home .case_dots {
	gap: 2.6666666667vw;
	margin-top: 5.3333333333vw;
}

#home .case_dots li {
	height: 2vw;
	width: 2vw;
}

#home .case_heading {
	font-size: 4vw;
}

#home .case_heading p {
	font-size: 4vw;
}

#home .case_txt {
	font-size: 3.4666666667vw;
}

#home .homePlan {
	padding-bottom: 10.6666666667vw;
	padding-top: 10.6666666667vw;
}

#home .homePlan_bg {
	height: 25%;
}

#home .homePlan_heading {
	font-size: 6.6666666667vw;
}

#home .homePlan_txt {
	font-size: 3.4666666667vw;
	margin-bottom: 6.6666666667vw;
}

#home .homePlan_contents {
	gap: 5.3333333333vw;
}

#home .homePlan_item {
	box-shadow: 0.2666666667vw 0.4618666667vw 1.092vw 0.108vw rgba(145, 139, 139, 0.31);
	width: 100%;
}

#home .homePlan_body {
	padding: 5.3333333333vw;
	padding-bottom: 26.6666666667vw;
}

#home .homePlan_catchWrap {
	align-items: center;
	display: flex;
	flex-direction: row-reverse;
	gap: 5vw;
	justify-content: center;
	margin-bottom: 5vw;
}

#home .homePlan_catch {
	font-size: 5.3333333333vw;
}

#home .homePlan_img {
	height: auto;
}

#home .homePlan_img img {
	height: 18vw;
}

#home .homePlan_desc {
	font-size: 3.4666666667vw;
}

#home .homePlan_btn {
	bottom: 8vw;
	font-size: 3.4666666667vw;
}

#home .service {
	padding-bottom: 10.6666666667vw;
	padding-top: 10.6666666667vw;
}

#home .service_txt {
	font-size: 3.4666666667vw;
	margin-bottom: 10.6666666667vw;
}

#home .service_cardWrap {
	gap: 10.6666666667vw;
}

#home .service .card__primary {
	width: 100%;
}

#home .service .card__primary .btn {
	font-size: 3.4666666667vw;
	padding: 4vw 10.6666666667vw;
	width: 95%;
}

#home .service .card_heading {
	font-size: 5.3333333333vw;
	margin-bottom: 0;
	text-align: left;
	width: 28vw;
}

#home .service .card_heading span {
	margin-left: -2.6666666667vw;
}

#home .service .card_img {
	margin-bottom: 0;
	width: 50%;
}

#home .service_contents {
	align-items: center;
	display: flex;
	justify-content: space-between;
	margin-bottom: 4vw;
}

#home .message_top {
	flex-wrap: wrap;
	height: 80vw;
	margin-bottom: 8vw;
}

#home .message_top img {
	height: 40vw;
	width: 40%;
}

#home .message_top img:first-child,
#home .message_top img:last-child {
	width: 60%;
}

#home .message_order__1 {
	order: 1;
}

#home .message_order__2 {
	order: 2;
}

#home .message_order__3 {
	order: 3;
}

#home .message_order__4 {
	order: 4;
}

#home .message .media {
	flex-direction: column-reverse;
	gap: 6.6666666667vw;
}

#home .message .media > * {
	width: 100%;
}

#home .message .media_body {
	padding: 0;
}

#home .message .media_txt {
	font-size: 3.4666666667vw;
	margin-bottom: 8vw;
}

#home .message .media_img {
	height: auto;
}

#home .message .media_heading {
	font-size: 4.2666666667vw;
	margin-bottom: 2.6666666667vw;
}

#home .message .media_heading__sub {
	font-size: 3.7333333333vw;
}

#home .message .btn {
	display: block;
	margin: 0 auto;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
}

#home .faq {
	margin-bottom: 10.6666666667vw;
	padding-bottom: 10.6666666667vw;
	padding-top: 10.6666666667vw;
}

#home .about .media {
	flex-direction: column-reverse;
	gap: 8vw;
	margin-bottom: 9.3333333333vw;
}

#home .about .media:nth-child(odd) {
	flex-direction: column-reverse;
}

#home .about .media_img {
	width: 100%;
}

#home .about .media_body {
	width: 90%;
}

#home .about .media_heading {
	font-size: 4.5333333333vw;
	margin-bottom: 2.6666666667vw;
}

#home .about .media_txt {
	font-size: 3.4666666667vw;
	margin-bottom: 6.6666666667vw;
}

#home .about .btn {
	display: block;
	margin: 0 auto;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
}

#home .news {
	padding-bottom: 10.6666666667vw;
	padding-top: 10.6666666667vw;
}

#home .news_inner {
	align-items: center;
	flex-direction: column;
	gap: 10.6666666667vw;
}

#home .news_contents {
	width: 90%;
}

#home .news_ttl__en {
	font-size: 6.6666666667vw;
}

#home .news_ttl__ja {
	font-size: 3.4666666667vw;
}

#home .news_item {
	padding: 3.3333333333vw 0;
}

#home .news time {
	font-size: 3.2vw;
}

#home .news_heading {
	font-size: 3.4666666667vw;
	margin-top: 0.6666666667vw;
}

#home .news .btn {
	padding: 4vw;
}

#first .section_txt {
	font-size: 3.4666666667vw;
	margin-bottom: 9.3333333333vw;
	padding: 0 4vw;
}

#first .forVisitor {
	margin-bottom: 13.3333333333vw;
}

#first .cta {
	margin-bottom: 13.3333333333vw;
}

#first .aboutAGA {
	margin-bottom: 13.3333333333vw;
}

#first .aboutAGA_catch {
	font-size: 4vw;
	margin-bottom: 4vw;
}

#first .aboutAGA_catch::before,
#first .aboutAGA_catch::after {
	top: 2.2666666667vw;
}

#first .aboutAGA_contents {
	gap: 1.3333333333vw;
}

#first .aboutAGA_item {
	border-radius: 1.8666666667vw;
	width: calc((100% - 2.6666666667vw) / 3);
}

#first .aboutAGA_img__pc {
	display: none;
}

#first .aboutAGA_img__sp {
	display: inline;
}

#first .treatment_cardWrap {
	align-items: center;
	flex-direction: column;
	gap: 9.3333333333vw;
}

#first .treatment .card__primary {
	max-width: none;
	padding: 5.3333333333vw 6.6666666667vw;
	width: 100%;
}

#first .treatment .card_heading {
	font-size: 5.3333333333vw;
	margin-bottom: 0;
	text-align: left;
	width: 28vw;
}

#first .treatment .card_heading span {
	display: inline-block;
	margin-left: -2.6666666667vw;
}

#first .treatment .card_img {
	margin-bottom: 0;
	width: 50%;
}

#first .treatment_contents {
	align-items: center;
	display: flex;
	justify-content: space-between;
	margin-bottom: 4vw;
}

#first .treatment .btn {
	font-size: 3.4666666667vw;
	padding: 4vw;
}

#first .feature {
	padding-bottom: 9.3333333333vw;
	padding-top: 9.3333333333vw;
}

#first .feature_contents {
	gap: 2.6666666667vw 1.3333333333vw;
	margin-bottom: 9.3333333333vw;
}

#first .feature_contents li {
	width: calc(50% - 0.6666666667vw);
}

#first .feature_contents__sp {
	display: block;
}

#first .feature_contents__sp li:not(:last-child) {
	margin-bottom: 2.6666666667vw;
}

#first .feature .media {
	display: none;
}

#first .flow {
	padding-bottom: 9.3333333333vw;
	padding-top: 9.3333333333vw;
}

 #first .flow .media {
	gap: 6.6666666667vw;
	flex-direction: column;
}
#first .flow .media_body{
	width: 100%;
}

#first .flow .media_heading {
	font-size: 4vw;
	margin-bottom: 5.3333333333vw;
}

#first .flow .media_heading__line {
	margin-bottom: 9.3333333333vw;
	justify-content: center;
}

#first .flow .media_heading__line::after {
	background-image: repeating-linear-gradient(-45deg, rgba(184, 213, 84, 0.7), rgba(184, 213, 84, 0.7) 0.4vw, transparent 0.5333333333vw, transparent 1.0666666667vw);
	bottom: -4vw;
	height: 1.6vw;
}

#first .flow .media_num {
	font-size: 6.6666666667vw;
}

#first .flow .media_num__primary {
	font-size: 5.3333333333vw;
	padding-right: 5.3333333333vw;
}

#first .flow .media_num__primary span {
	font-size: 4vw;
	margin-right: 0.9333333333vw;
}

#first .flow .media__ribbon::after {
	border-width: 0 1.3333333333vw 1.3333333333vw 1.3333333333vw;
	left: 9.3333333333vw;
}

#first .flow .media__ribbon .media_num {
	font-size: 3.4666666667vw;
	height: 7.3333333333vw;
	left: 2.6666666667vw;
	padding-top: 1.3333333333vw;
	top: -1.3333333333vw;
	width: 8vw;
}

#first .flow .media__ribbon .media_num::before {
	border-width: 0 0 1.3333333333vw 4vw;
}

#first .flow .media__ribbon .media_num::after {
	border-width: 0 4vw 1.3333333333vw 0;
}
#first .flow .media_img{
	width: 100%;
}
#first .flow .media {
	padding-left: 20px;
}


#message .director {
	align-items: flex-start;
	flex-direction: column-reverse;
	gap: 20px;
}

#message .director .media_img {
	width: 100%;
}

#message .director .media_body {
	padding: 0 3%;
	width: 100%;
}

#message .director .media_heading {
	font-size: 5.3333333333vw;
	margin-bottom: 1.3333333333vw;
}

#message .director .media_heading__sm {
	font-size: 3.7333333333vw;
}

#message .director dl {
	font-size: 3.4666666667vw;
}

#message .message .media_body {
	padding: 0 3vw;
}

#message .message .media_txt {
	font-size: 3.4666666667vw;
}

#message .message .media_img {
	display: none;
}

#message .profile_block:not(:last-child) {
	margin-bottom: 5.3333333333vw;
}

#message .profile .media {
	gap: 5.3333333333vw;
}

#message .profile .media_img {
	width: 34.6666666667vw;
}

#message .profile_heading {
	border-radius: 1.8666666667vw 1.8666666667vw 0 0;
	border-width: 0.6666666667vw;
	font-size: 4.8vw;
	padding: 1.3333333333vw 5.3333333333vw;
}

#message .profile_body {
	padding: 5.3333333333vw;
	padding-bottom: 9.3333333333vw;
}

#message .profile_name {
	font-size: 4.5333333333vw;
	margin-bottom: 1.3333333333vw;
}

#message .profile_name p {
	font-size: 3.7333333333vw;
}

#message .profile_ttl {
	font-size: 3.7333333333vw;
	margin-bottom: 0.6666666667vw;
}

#message .profile_ttl__sub {
	font-size: 3.4666666667vw;
	margin-bottom: 0.6666666667vw;
	margin-left: -1.3333333333vw;
}

#message .profile_list {
	font-size: 3.4666666667vw;
}

#message .profile_block {
	margin: 0 auto;
	max-width: 800px;
}

#message .profile_top {
	border-bottom: none;
	margin-bottom: 2.6666666667vw;
	padding-bottom: 0;
}

#message .profile_top div.profile_item {
	margin-bottom: 0;
	width: 100%;
}

#message .profile_society {
	display: none;
}

#message .profile_society__sp {
	border-bottom: 1px dashed #918b8b;
	display: block;
	padding-bottom: 5.3333333333vw;
}

#message .profile_item:not(:last-child) {
	margin-bottom: 5.3333333333vw;
}

#message .profile_item dt {
	margin-right: 0;
	width: 100%;
}

#message .profile_listWrap {
	flex-direction: column;
	font-size: 3.4666666667vw;
}

#message .profile_listWrap:not(:last-of-type) {
	margin-bottom: 1.3333333333vw;
}

#flow .flowChart {
	flex-wrap: wrap;
	gap: 1.3333333333vw;
	justify-content: center;
	margin-bottom: 9.3333333333vw;
}

#flow .flowChart li {
	width: calc(50% - 0.6666666667vw);
}

#flow .flowChart li:nth-child(odd)::after {
	border-width: 2.2666666667vw 0 2.2666666667vw 2.2666666667vw;
	right: -1.7333333333vw;
}

#flow .flowChart li:nth-child(even)::after {
	display: none;
}

#flow .flow {
	margin-bottom: 9.3333333333vw;
	padding: 0 4vw;
}

#flow .flow_cta {
	margin-bottom: 9.3333333333vw;
}

#flow .flow_cta p {
	font-size: 3.4666666667vw;
}

#flow .flow_cta__reserve {
	margin-bottom: 2.6666666667vw;
}

#flow .flow_cta__line {
	margin-bottom: 4.6666666667vw;
}

#flow .flow_cta .pc {
	display: none;
}

#flow .flow_cta .sp {
	display: inline;
}

#flow .forMinor {
	padding: 9.3333333333vw 0;
}

#flow .forMinor_ttl {
	font-size: 4.5333333333vw;
	margin-bottom: 2.6666666667vw;
}

#flow .forMinor_txt {
	font-size: 3.4666666667vw;
	margin-bottom: 5.3333333333vw;
}

#flow .forMinor .media {
	flex-direction: column-reverse;
	gap: 5.3333333333vw;
}

#flow .forMinor .media_img {
	width: 100%;
}

#flow .forMinor .btn {
	display: block;
	font-size: 3.4666666667vw;
	margin: 0 auto;
	padding: 4vw 10.6666666667vw;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
}

#experience .forPatient_txt {
	font-size: 3.4666666667vw;
	margin-bottom: 8vw;
	padding: 0 8vw;
}

#experience .graph {
	margin-bottom: 9.3333333333vw;
	padding: 8vw 5.3333333333vw;
}

#experience .graph > section:first-child {
	margin-bottom: 5.3333333333vw;
}

#experience .graph_ttl {
	font-size: 4vw;
	margin-bottom: 6.6666666667vw;
}

#experience .graph_img {
	text-align: center;
}

#experience .graph_img__hearing {
	width: 55.4666666667vw;
}

#experience .graph_img .pc {
	display: none;
}

#experience .graph_img .sp {
	display: inline;
}

#experience .attempt_ttl {
	font-size: 4vw;
	margin-bottom: 6.6666666667vw;
	padding: 0 5.3333333333vw;
	text-align: left;
}

#experience .attempt_desc {
	font-size: 3.4666666667vw;
}

#experience .attempt .media {
	align-items: center;
	flex-direction: column;
	gap: 5.3333333333vw;
	margin: 0 auto 9.3333333333vw;
	width: 100%;
}

#experience .attempt .media:nth-child(even) {
	flex-direction: column;
}

#experience .attempt .media_img {
	width: 100%;
}

#experience .attempt .media_body {
	padding: 0 4vw;
	width: 100%;
}

#experience .attempt .media_heading__main {
	font-size: 4vw;
}

#experience .attempt .media_heading__main:first-letter {
	margin-left: -2vw;
}

#experience .attempt .media_heading__highlight {
	font-size: 4.8vw;
}

#experience .attempt .media_num {
	font-size: 6.6666666667vw;
	margin-right: 2.6666666667vw;
	margin-top: 2vw;
	padding-left: 4vw;
	padding-top: 2vw;
}

#experience .attempt .media_num img {
	left: -1.3333333333vw;
	top: -2.6666666667vw;
	width: 10.1333333333vw;
}

#service .treatment_txt {
	font-size: 3.4666666667vw;
	margin-bottom: 8vw;
	padding: 0 9.3333333333vw;
}

#service .treatment_heading {
	font-size: 5.6vw;
	margin-bottom: 1.3333333333vw;
}

#service .treatment_heading__sm {
	font-size: 3.7333333333vw;
	letter-spacing: -0.1333333333vw;
	margin-left: -1.3333333333vw;
}

#service .treatment .media {
	border-radius: 2.6666666667vw;
	flex-direction: column-reverse;
	gap: 4vw;
	padding: 6.6666666667vw 5.3333333333vw 9.3333333333vw;
}

#service .treatment .media:not(:last-child) {
	margin-bottom: 4vw;
}

#service .treatment .media_num__primary {
	font-size: 6.6666666667vw;
	padding-right: 3.3333333333vw;
}

#service .treatment .media_num__primary span {
	font-size: 4vw;
	margin-right: 0.9333333333vw;
}

#service .treatment .media_body {
	width: 100%;
}

#service .treatment .media_img {
	max-width: none;
	width: 100%;
}

#service .treatment_listWrap {
	margin-bottom: 5.3333333333vw;
}

#service .treatment_list {
	padding: 1.3333333333vw 1.3333333333vw 2vw;
}

#service .treatment_desc {
	font-size: 3.7333333333vw;
	padding-top: 1.6vw;
}

#service .treatment .btn {
	display: block;
	font-size: 3.4666666667vw;
	margin: 0 auto;
	padding: 4vw 0;
	text-align: center;
	width: 74.6666666667vw;
}

.parent-pageid-218 .feature {
	margin-bottom: 13.3333333333vw;
}

.parent-pageid-218 .feature .media {
	flex-direction: column-reverse;
	gap: 5.3333333333vw;
}

.parent-pageid-218 .feature .media:not(:last-child) {
	margin-bottom: 10.6666666667vw;
}

.parent-pageid-218 .feature .media:nth-child(even) {
	flex-direction: column-reverse;
}

.parent-pageid-218 .feature .media_body {
	padding: 0 5.3333333333vw;
	width: 100%;
}

.parent-pageid-218 .feature .media_heading {
	font-size: 4.8vw;
}

.parent-pageid-218 .feature .media_num__primary {
	font-size: 6.6666666667vw;
	margin-bottom: 0.6666666667vw;
}

.parent-pageid-218 .feature .media_num__primary span {
	font-size: 4.8vw;
}

.parent-pageid-218 .feature .media_img {
	border-radius: 2.6666666667vw;
	width: 100%;
}

.parent-pageid-218 .feature_desc {
	font-size: 3.4666666667vw;
}

.parent-pageid-218 .treatment .media {
	flex-direction: column-reverse;
	gap: 6.6666666667vw;
	margin-bottom: 6.6666666667vw;
}

.parent-pageid-218 .treatment .media_body {
	padding: 0 5.3333333333vw;
	width: 100%;
}

.parent-pageid-218 .treatment .media_heading {
	font-size: 4.8vw;
}

.parent-pageid-218 .treatment .media_num {
	font-size: 6.6666666667vw;
}

.parent-pageid-218 .treatment .media_img {
	border-radius: 2.6666666667vw;
	width: 100%;
}

.parent-pageid-218 .treatment_contents:not(:last-child) {
	margin-bottom: 12vw;
}

.parent-pageid-218 .treatment_list li {
	padding: 2vw 0;
}

.parent-pageid-218 .treatment_desc {
	font-size: 3.7333333333vw;
	margin-left: 2vw;
	padding-top: 0.9333333333vw;
}

.parent-pageid-218 .treatment_example {
	border-radius: 2.6666666667vw;
	padding: 6.6666666667vw 5.3333333333vw;
}

.parent-pageid-218 .treatment_example h4 {
	font-size: 4vw;
	margin-bottom: 2.6666666667vw;
}

.parent-pageid-218 .treatment_example .accordion_heading {
	font-size: 3.7333333333vw;
	letter-spacing: -0.3333333333vw;
	margin-bottom: 2.6666666667vw;
	padding: 1.3333333333vw 2vw;
	padding-right: 5.3333333333vw;
}

.parent-pageid-218 .treatment_example .accordion dl {
	margin-top: 2.6666666667vw;
}

#monitor .mainvisual {
	margin-bottom: 12vw;
}

#monitor .mainvisual_img {
	display: none;
}

#monitor .mainvisual_img__sp {
	border-radius: 2.6666666667vw;
	display: inline;
	margin-bottom: 6.6666666667vw;
}

#monitor .mainvisual_txt {
	font-size: 3.4666666667vw;
	padding: 0 4vw;
	text-align: left;
}

#monitor .mainvisual .btn {
	font-size: 5.3333333333vw;
	padding: 3.0666666667vw;
	width: 84vw;
}

#monitor .merit_contents {
	flex-direction: column;
	gap: 3.3333333333vw;
	margin-bottom: 8vw;
}

#monitor .merit_item {
	width: 100%;
}

#monitor .merit_item__pc {
	display: none;
}

#monitor .merit_item__sp {
	display: inline;
}

#monitor .merit_mediaWrap {
	margin-bottom: 12vw;
}

#monitor .merit .media {
	border-radius: 2.6666666667vw;
	flex-direction: column-reverse;
	gap: 4vw;
	padding: 8vw 5.3333333333vw;
}

#monitor .merit .media:not(:last-child) {
	margin-bottom: 4vw;
}

#monitor .merit .media_desc {
	font-size: 3.4666666667vw;
	padding-bottom: 3.3333333333vw;
	padding-top: 1.3333333333vw;
}

#monitor .merit .media_img {
	gap: 0.6666666667vw;
	max-width: unset;
	width: 100%;
}

#monitor .merit .media_img::after {
	filter: drop-shadow(0 0 0.4vw rgba(0, 0, 0, 0.5));
	height: 10vw;
	left: 47%;
	top: 50%;
	transform: translateY(-50%);
	width: 8.2666666667vw;
}

#monitor .merit .media_img img {
	width: calc((100% - 0.6666666667vw) / 2);
}

#monitor .merit_discount {
	font-size: 4.2666666667vw;
	margin-bottom: 0.6666666667vw;
	margin-top: 2.6666666667vw;
}

#monitor .merit_discount p {
	font-size: 8vw;
	margin-left: 1.3333333333vw;
}

#monitor .merit_note {
	font-size: 3.4666666667vw;
}

#monitor .outline {
	margin-bottom: 10.6666666667vw;
}

#monitor .outline .heading_lv3 {
	margin-bottom: 4vw;
}

#case .case .heading_lv3,
.tax-case_age .case .heading_lv3,
.tax-case_type .case .heading_lv3,
.search .case .heading_lv3 {
	margin-bottom: 6.6666666667vw;
}

#case .case_txt,
.tax-case_age .case_txt,
.tax-case_type .case_txt,
.search .case_txt {
	font-size: 3.4666666667vw;
	margin-bottom: 5.3333333333vw;
}

#case .case_contents,
.tax-case_age .case_contents,
.tax-case_type .case_contents,
.search .case_contents {
	margin-bottom: 8vw;
}

#case .case .media,
.tax-case_age .case .media,
.tax-case_type .case .media,
.search .case .media {
	border-radius: 1.8666666667vw;
	flex-wrap: wrap;
	gap: 4vw;
	padding: 5.3333333333vw;
}

#case .case .media:not(:last-of-type),
.tax-case_age .case .media:not(:last-of-type),
.tax-case_type .case .media:not(:last-of-type),
.search .case .media:not(:last-of-type) {
	margin-bottom: 4vw;
}

#case .case .media_img,
.tax-case_age .case .media_img,
.tax-case_type .case .media_img,
.search .case .media_img {
	gap: 5.3333333333vw;
	width: 100%;
}

#case .case .media_img::after,
.tax-case_age .case .media_img::after,
.tax-case_type .case .media_img::after,
.search .case .media_img::after {
	border-width: 2.8vw 0 2.8vw 2.6666666667vw;
}

#case .case .media_img img,
.tax-case_age .case .media_img img,
.tax-case_type .case .media_img img,
.search .case .media_img img {
	width: calc(50% - 2.6666666667vw);
}

#case .case .media_ttl,
.tax-case_age .case .media_ttl,
.tax-case_type .case .media_ttl,
.search .case .media_ttl {
	font-size: 4.2666666667vw;
	margin-bottom: 2.6666666667vw;
	padding-bottom: 0.6666666667vw;
	padding-top: 0;
}

#case .case .media_desc,
.tax-case_age .case .media_desc,
.tax-case_type .case .media_desc,
.search .case .media_desc {
	font-size: 3.7333333333vw;
	margin-bottom: 4vw;
}

#case .case .media .btn,
.tax-case_age .case .media .btn,
.tax-case_type .case .media .btn,
.search .case .media .btn {
	display: block;
	margin: 0 auto;
	padding: 4vw;
	width: 74.6666666667vw;
}

.single-case .caseDetail {
	margin-bottom: 13.3333333333vw;
}

.single-case .caseDetail .heading_lv3 {
	font-size: 5.3333333333vw;
	margin-bottom: 5.3333333333vw;
}

.single-case .caseDetail_imgWrap {
	gap: 4vw;
	margin-bottom: 9.3333333333vw;
}

.single-case .caseDetail_imgWrap::after {
	border-width: 2.2666666667vw 0 2.2666666667vw 2.1333333333vw;
}

.single-case .caseDetail_img {
	width: 37.7333333333vw;
}

.single-case .caseDetail_img figcaption {
	font-size: 3.2vw;
	margin-top: 0.6666666667vw;
	padding: 0.4vw;
}

.single-case .caseDetail .table_desc {
	font-size: 3.4666666667vw;
}

.single-case .caseDetail .btn {
	width: 74.6666666667vw;
}

.single-case .relationCase_heading {
	font-size: 5.3333333333vw;
	margin-bottom: 5.3333333333vw;
}

.single-case .relationCase_contents {
	gap: 4vw;
}

.single-case .relationCase_item {
	border-radius: 1.8666666667vw;
	width: 100%;
}

.single-case .relationCase_item a {
	padding: 5.3333333333vw 5.3333333333vw 4vw;
}

.single-case .relationCase_img {
	gap: 4vw;
	margin-bottom: 4vw;
}

.single-case .relationCase_img::after {
	border-width: 2.8vw 0 2.8vw 2.5333333333vw;
}

.single-case .relationCase_img img {
	width: calc(50% - 2vw);
}

.single-case .relationCase_ttl {
	font-size: 3.7333333333vw;
	gap: 2vw;
}

.single-case .relationCase_ttl p {
	padding-top: 0;
}

.single-case .relationCase_ttl img {
	height: 5.3333333333vw;
	width: 5.3333333333vw;
}

.single-case .relationCase .btn {
	width: 74.6666666667vw;
}

#shop .shop_wrap {
	flex-wrap: wrap;
	gap: 13.3333333333vw;
}

#shop .shop {
	margin-bottom: 6.6666666667vw;
	width: 100%;
}

#shop .shop_body {
	padding: 0 5.3333333333vw;
}

#shop .shop_img {
	border-radius: 2.6666666667vw;
	margin-bottom: 6.6666666667vw;
}

#shop .shop_name {
	font-size: 4.5333333333vw;
	margin-bottom: 2vw;
}

#shop .shop .calendar_link a {
	padding-right: 1.3333333333vw;
}

#shop .shop_info {
	font-size: 3.4666666667vw;
}

#shop .shop_list:not(:last-of-type) {
	margin-bottom: 2vw;
}

#shop .shop_ttl {
	width: 20vw;
}

#shop .shop .btn {
	font-size: 3.7333333333vw;
	padding: 4vw 0;
	width: 74.6666666667vw;
}

.single-shop.shopDetail_img {
	margin-bottom: 10.6666666667vw;
}

.single-shop .shopDetail_img__main {
	border-radius: 2.6666666667vw;
	margin-bottom: 2.6666666667vw;
}

.single-shop .shopDetail_img__sub {
	gap: 0.6666666667vw;
}
.single-shop .shopDetail_img__sub li {
	width: calc((100% - 2.6666666667vw) / 5);
}

.single-shop .shopDetail_img__sub img {
	-o-object-fit: cover;
	border-radius: 1.3333333333vw;
	object-fit: cover;
}

.single-shop .shopDetail_container {
	padding: 0 4vw;
}

.single-shop .notice {
	margin-bottom: 9.3333333333vw;
	padding: 0 5.3333333333vw;
}

.single-shop .notice_heading {
	font-size: 4.2666666667vw;
	margin-bottom: 3.3333333333vw;
}

.single-shop .notice_txt {
	font-size: 3.4666666667vw;
	margin-bottom: 4vw;
}

.single-shop .notice_link {
	display: block;
	font-size: 3.4666666667vw;
	margin-left: auto;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
}

.single-shop .calendar {
	border-radius: 2.6666666667vw;
	margin-bottom: 8vw;
	padding: 5.3333333333vw;
}

.single-shop .calendar_row {
	grid-template-columns: 26.6666666667vw repeat(7, 1fr);
	padding: 1.3333333333vw 0;
}

.single-shop .calendar tbody .calendar_row:not(:last-child) {
	border-bottom: none;
	padding-bottom: 0;
}

.single-shop .calendar_note {
	padding: 0;
}

.single-shop .access_contents {
	padding: 0 5.3333333333vw;
}

.single-shop .access_list {
	line-height: 1.3;
	padding: 1.3333333333vw 0;
}

.single-shop .access_list:not(:last-child) {
	border-bottom: none;
}

.single-shop .access_list .pc {
	display: none;
}

.single-shop .access iframe {
	height: 58.2666666667vw;
	width: 100%;
}

.single-shop .way .accordion_heading {
	padding-left: 5.3333333333vw;
}

.single-shop .way_num {
	font-size: 4.1333333333vw;
	height: 6.6666666667vw;
	margin-bottom: 2vw;
	width: 6.6666666667vw;
}

.single-shop .way_media {
	align-items: flex-start;
	display: flex;
	gap: 4vw;
}

.single-shop .way_img {
	border-radius: 2.6666666667vw;
	margin-bottom: 0;
	width: 50%;
}

	.single-shop .way_txt {
	flex: 1;
	font-size: 3.4666666667vw;
	letter-spacing: -0.2666666667vw;
	line-height: calc(36 / 26);
}

.single-shop .shopCta {
	margin-bottom: 13.3333333333vw;
}

.single-shop .shopCta .cta {
	margin-bottom: 2.6666666667vw;
	margin-top: 17.3333333333vw;
}

.single-shop .shopCta .cta_telWrap {
	border-radius: 2.6666666667vw;
	flex-direction: column;
	gap: 2.6666666667vw;
	padding: 4vw 0;
}

.single-shop .shopCta_txt {
	width: 29.4%;
}

.single-shop .shopCta_tel {
	width: 56.3%;
}

.single-shop .shopCta_time {
	width: 82.6%;
}

.single-shop .staffMessage {
	margin-bottom: 16vw;
}

.single-shop .staffMessage_contents {
	flex-wrap: wrap;
	gap: 8vw;
}

.single-shop .staffMessage .media {
	gap: 5.3333333333vw;
	width: 100%;
}

.single-shop .staffMessage .media_img__sp {
	border-radius: 2.6666666667vw;
}

	.single-shop .staffMessage .media_txt {
	font-size: 3.4666666667vw;
	letter-spacing: -0.1333333333vw;
	padding: 0 5.3333333333vw;
}

.single-shop .doctor {
	margin-bottom: 12vw;
}

.single-shop .doctor .btn_wrap {
	padding-top: 8vw;
}

.single-shop .author {
	margin-bottom: 8vw;
}

.single-shop .author .media {
	flex-direction: column-reverse;
	gap: 5.3333333333vw;
}

.single-shop .author .media_img {
	border-radius: 3.2vw;
	width: 100%;
}

.single-shop .author .media_body {
	padding: 0 5.3333333333vw;
	width: 100%;
}

.single-shop .author .media_heading {
	font-size: 5.3333333333vw;
	margin-bottom: 4vw;
}

.single-shop .author .media_heading__sm {
	font-size: 3.7333333333vw;
}

.single-shop .author .media_txt {
	font-size: 3.4666666667vw;
}

.single-shop .toYou .media_heading {
	font-size: 4.2666666667vw;
	margin-bottom: 4vw;
}

		.single-shop .toYou .media_body {
	padding: 0 5.3333333333vw;
	width: 100%;
}

	.single-shop .toYou .media_txt {
	font-size: 3.4666666667vw;
}

	.single-shop .toYou .media_img {
	display: none;
}

	.single-shop .review {
	padding-bottom: 12vw;
	padding-top: 9.3333333333vw;
}

	.single-shop .review_contents {
	gap: 3.3333333333vw;
	grid-template-columns: 1fr;
}

	.single-shop .review_item {
	border-radius: 1.8666666667vw;
	padding: 6.6666666667vw 5.3333333333vw;
}

	.single-shop .review_icon {
	font-size: 8.8vw;
	height: 15.6vw;
	margin-bottom: 4vw;
	width: 15.6vw;
}

	.single-shop .review_name {
	font-size: 4.5333333333vw;
	margin-bottom: 1.3333333333vw;
}

	.single-shop .review_star {
	font-size: 4.5333333333vw;
	margin-bottom: 6.6666666667vw;
}

	.single-shop .review_txt {
	font-size: 3.4666666667vw;
	letter-spacing: 0;
}

	.single-shop .faq {
	padding-bottom: 10.6666666667vw;
	padding-top: 9.3333333333vw;
}


#contact .contact_btn {
	margin-bottom: 12vw;
	width: 84vw;
}

#reserve .reserve .section_ttl {
	margin-bottom: 10.6666666667vw;
}

#reserve .reserve_catch {
	right: calc(100% + 4vw);
	width: 16.6666666667vw;
}

#faq .pageNav,
.tax-faq_cat .pageNav {
	text-align: left;
}

#faq .pageNav_link a,
.tax-faq_cat .pageNav_link a {
	padding: 2.9333333333vw 3.3333333333vw;
}

#faq .pageNav_link a::before,
#faq .pageNav_link a::after,
.tax-faq_cat .pageNav_link a::before,
.tax-faq_cat .pageNav_link a::after {
	top: 54%;
}

#faq .pageNav_link a::before,
.tax-faq_cat .pageNav_link a::before {
	right: 3.6vw;
}

#faq .pageNav_link a::after,
.tax-faq_cat .pageNav_link a::after {
	right: 3.7333333333vw;
}

#faq .faq .heading_lv3,
.tax-faq_cat .faq .heading_lv3 {
	margin-bottom: 4.6666666667vw;
}

#faq .faq_contents:not(:last-of-type),
.tax-faq_cat .faq_contents:not(:last-of-type) {
	margin-bottom: 12vw;
}

#faq .faq .accordion,
.tax-faq_cat .faq .accordion {
	margin-bottom: -2vw;
}

#aga,
#price,
#counseling,
#reserve,
#shop,
#others {
	margin-top: -12vw;
	padding-top: 12vw;
}

#minor .minor_caution {
	font-size: 4vw;
	margin-bottom: 6.6666666667vw;
}

#minor .minor_txt {
	font-size: 3.4666666667vw;
	letter-spacing: -0.1333333333vw;
	margin-bottom: 8vw;
	padding: 0 5.3333333333vw;
	text-align: left;
}

#minor .minor_contents {
	flex-direction: column;
	gap: 4vw;
	margin-bottom: 5.3333333333vw;
}

#minor .minor_contents img {
	width: 100%;
}

#minor .minor_note {
	font-size: 3.4666666667vw;
	margin-bottom: 4vw;
	padding: 0 5.3333333333vw;
}

#minor .minor_dialog {
	font-size: 3.4666666667vw;
	margin-top: 2.6666666667vw;
}

#minor .minor .btn {
	padding: 4vw 0;
	width: 80vw;
}

#minor .minor .btn span {
	gap: 2vw;
}

#minor .minor .btn_icon {
	width: 5.0666666667vw;
}

#forMedia .contact_ttl {
	margin-bottom: 2.6666666667vw;
}

#forMedia .contact_txt {
	margin-bottom: 9.3333333333vw;
	text-align: center;
}

#sitemap .sitemap {
	font-size: 3.4666666667vw;
	gap: 6.6666666667vw;
	grid-template-columns: 1fr;
}

#sitemap .sitemap_list {
	padding: 2.6666666667vw 0;
}

#sitemap .sitemap_list__child li a {
	padding-left: 2.6666666667vw;
}

#recruit .heading_lv3 {
	margin-bottom: 5.3333333333vw;
}

#recruit .mainvisual {
	margin-bottom: 9.3333333333vw;
}

#recruit .mainvisual .pc {
	display: none;
}

#recruit .mainvisual .sp {
	border-radius: 2.6666666667vw;
	display: inline;
}

#recruit .pageNav {
	text-align: left;
}

#recruit .pageNav_link a {
	padding: 2.9333333333vw 3.3333333333vw;
}

#recruit .pageNav_link a::before,
#recruit .pageNav_link a::after {
	top: 54%;
}

#recruit .pageNav_link a::before {
	right: 3.6vw;
}

#recruit .pageNav_link a::after {
	right: 3.7333333333vw;
}

#recruit #counselor,
#recruit #doctor {
	margin-top: -12vw;
	padding-top: 12vw;
}

#recruit .counselor {
	margin-bottom: 9.3333333333vw;
}

#recruit .doctor {
	margin-bottom: 12vw;
}

#recruit .flow {
	margin-bottom: 9.3333333333vw;
	padding-bottom: 9.3333333333vw;
	padding-top: 10.6666666667vw;
}

#recruit .flow .pc {
	display: none;
}

#recruit .flow_contents {
	flex-wrap: wrap;
	gap: 5.3333333333vw 2.6666666667vw;
}

#recruit .flow_item {
	width: 100%;
}

#recruit .flow_item:not(:last-child)::after {
	border-color: #55934f transparent transparent transparent;
	border-width: 2vw 2vw 0 2vw;
	right: 50%;
	top: calc(100% + 1.6666666667vw);
}

#recruit .flow_txt {
	font-size: 3.4666666667vw;
	margin-top: 2.6666666667vw;
	padding: 0 5.3333333333vw;
}

#recruit .flow .media {
	align-items: flex-start;
	background-color: #fff;
	border-radius: 2.6666666667vw;
	box-shadow: 0.2666666667vw 0.4618666667vw 1.092vw 0.108vw rgba(145, 139, 139, 0.1);
	display: flex;
	gap: 2.6666666667vw;
	padding: 4vw 5.3333333333vw;
}

#recruit .flow .media_num__primary {
	margin-bottom: 9.3333333333vw;
	position: relative;
}

#recruit .flow .media_num__primary::after {
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	background-image: repeating-linear-gradient(-45deg, rgba(184, 213, 84, 0.7), rgba(184, 213, 84, 0.7) 0.4vw, transparent 0.5333333333vw, transparent 1.0666666667vw);
	bottom: -2vw;
	content: "";
	height: 1.0666666667vw;
	left: 0;
	position: absolute;
	width: 100%;
}

#recruit .flow .media_heading {
	line-height: 1;
	margin-bottom: 0;
}

#recruit .flow .media_heading p {
	font-size: 2.9333333333vw;
	margin-bottom: 1.3333333333vw;
}

#recruit .flow .media_img {
	aspect-ratio: 3/2;
	width: 50%;
}

#price .heading_lv3 {
	margin-bottom: 5.3333333333vw;
}

#price .option_contents {
	border-radius: 2.6666666667vw;
	padding: 6.6666666667vw 5.3333333333vw 9.3333333333vw;
}

#price .option_heading {
	font-size: 4vw;
	margin-bottom: 4vw;
	padding-bottom: 2.6666666667vw;
}

#price .option_heading.newLine {
	flex-wrap: wrap;
	justify-content: flex-end;
}

#price .option_heading.newLine .option_name {
	width: 100%;
}

#price .option_name span {
	margin-left: -1.3333333333vw;
}

#price .option_price {
	font-size: 8vw;
}

#price .option_price__note {
	font-size: 4vw;
}

#price .option_price__sm {
	font-size: 5.3333333333vw;
}

#price .option_desc {
	font-size: 3.4666666667vw;
	letter-spacing: -1px;
}

#price .option_desc:not(:last-of-type) {
	margin-bottom: 6.6666666667vw;
}

#price .payment {
	margin-bottom: 10.6666666667vw;
}

#price .payment_wrap {
	border-radius: 2.6666666667vw;
	padding: 8vw 5.3333333333vw;
}

#price .payment_ttl {
	font-size: 4vw;
	margin-bottom: 4vw;
}

#price .payment_item {
	border-radius: 1.3333333333vw;
	letter-spacing: -0.1333333333vw;
	padding: 4vw 5.3333333333vw;
}

#price .payment_item:not(:last-of-type) {
	margin-bottom: 2.6666666667vw;
}

#price .payment_heading {
	font-size: 3.7333333333vw;
	width: 100%;
}

#price .payment_desc {
	font-size: 3.4666666667vw;
	padding-top: 1.3333333333vw;
	width: 100%;
}

#price .payment .btn {
	font-size: 3.4666666667vw;
	margin-top: 4vw;
	padding: 4vw 0;
	width: 100%;
}

#regrowth .mainvisual {
	margin-bottom: 2.6666666667vw;
}

#regrowth .mainvisual .pc {
	display: none;
}

#regrowth .mainvisual .sp {
	border-radius: 2.6666666667vw;
	display: inline;
}

#regrowth .regrowth_btn {
	font-size: 4.8vw;
	padding: 3.8666666667vw;
	width: 80vw;
}

#regrowth .regrowth_btn span::after {
	border-width: 0.4vw;
	margin-left: 2.6666666667vw;
	min-height: 2.1333333333vw;
	min-width: 2.1333333333vw;
}

#regrowth .point {
	margin-bottom: 13.3333333333vw;
	margin-top: 12vw;
}

#regrowth .point .media {
	flex-direction: column-reverse;
	gap: 5.3333333333vw;
}

#regrowth .point .media:not(:last-child) {
	margin-bottom: 10.6666666667vw;
}

#regrowth .point .media:nth-child(even) {
	flex-direction: column-reverse;
}

#regrowth .point .media > * {
	width: 100%;
}

#regrowth .point .media_body {
	padding: 0 5.3333333333vw;
}

#regrowth .point .media_heading {
	font-size: 4.8vw;
}

#regrowth .point .media_num__primary {
	font-size: 5.3333333333vw;
}

#regrowth .point .media_num__primary span {
	font-size: 4vw;
}

#regrowth .point .media_img {
	border-radius: 2.6666666667vw;
}

#regrowth .point_txt {
	font-size: 3.4666666667vw;
}

#regrowth .price {
	margin-bottom: 12vw;
}

#regrowth .example_body {
	border-radius: 2.6666666667vw;
}

#regrowth .case {
	padding: 0;
}

#regrowth .case_inner {
	border-radius: 0;
	margin-bottom: 10.6666666667vw;
	padding: 6.6666666667vw 4vw;
}

#regrowth .case .section_ttl {
	margin-bottom: 4.6666666667vw;
}

#regrowth .case_ttl {
	border-radius: 0.8vw;
	font-size: 4.2666666667vw;
	margin-bottom: 2.6666666667vw;
	padding: 1.3333333333vw 2.6666666667vw;
}

#regrowth .case_txtWrap:not(:last-child) {
	margin-bottom: 0.6666666667vw;
}

#regrowth .case_heading {
	font-size: 3.4666666667vw;
}

#regrowth .case_desc {
	font-size: 3.4666666667vw;
	letter-spacing: -0.1333333333vw;
}

#regrowth .case_desc__emphasis {
	font-size: 4vw;
	letter-spacing: 0;
}

#regrowth .case_content {
	border-radius: 1.8666666667vw;
	box-shadow: 0.2666666667vw 0.4618666667vw 1.092vw 0.108vw rgba(145, 139, 139, 0.1);
	margin-bottom: 4vw;
	padding: 5.3333333333vw;
}

#regrowth .case .media {
	flex-direction: column;
	gap: 4vw;
}

#regrowth .case .media > * {
	width: 100%;
}

#regrowth .case .media_img {
	gap: 5.3333333333vw;
}

#regrowth .case .media_img::after {
	border-width: 2.4vw 0 2.4vw 2.2666666667vw;
}

#regrowth .case .media_img img {
	width: calc((100% - 5.3333333333vw) / 2);
}
#musasi .mainvisual {
	padding: 0;
}

#musasi .mainvisual_inner {
	border-radius: 0;
	padding: 0;
}

#musasi .mainvisual_img__pc {
	display: none;
}

#musasi .mainvisual_img__sp {
	display: block;

}
#musasi .shopDetail_img {
	margin-bottom: 10.6666666667vw;
}


#musasi .shopDetail_img__main {
	border-radius: 2.6666666667vw;
	margin-bottom: 2.6666666667vw;
}

#musasi .shopDetail_img__sub {
	gap: 0.6666666667vw;
	display: flex;
}

#musasi .shopDetail_img__sub li {
	width: calc((100% - 2.6666666667vw) / 3);
}

#musasi .shopDetail_img__sub img {
	-o-object-fit: cover;
	border-radius: 1.3333333333vw;
	object-fit: cover;
}

#musasi .shopDetail_container {
	padding: 0 4vw;
}
#musasi .about .media_img__wrap {
	width: 100%;
}

#musasi .notice {
	margin-bottom: 9.3333333333vw;
	padding: 0 5.3333333333vw;
}

#musasi .notice_heading {
	font-size: 4.2666666667vw;
	margin-bottom: 3.3333333333vw;
}

#musasi .notice_txt {
	font-size: 3.4666666667vw;
	margin-bottom: 4vw;
}

#musasi .notice_link {
	display: block;
	font-size: 3.4666666667vw;
	margin-left: auto;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
}

#musasi .calendar {
	border-radius: 2.6666666667vw;
	margin-bottom: 8vw;
	padding: 5.3333333333vw;
}

#musasi .calendar_row {
	grid-template-columns: 26.6666666667vw repeat(7, 1fr);
	padding: 1.3333333333vw 0;
}

#musasi .calendar tbody .calendar_row:not(:last-child) {
	border-bottom: none;
	padding-bottom: 0;
}

#musasi .calendar_note {
	padding: 0;
}

#musasi .access .media {
	margin-bottom: 10.6666666667vw;
}

#musasi .access_contents {
	padding: 0 5.3333333333vw;
}

#musasi .access_list {
	line-height: 1.3;
	padding: 1.3333333333vw 0;
}

#musasi .access_list:not(:last-child) {
	border-bottom: none;
}

#musasi .access_list .pc {
	display: none;
}

#musasi .access iframe {
	height: 58.2666666667vw;
	width: 100%;
}

#musasi .way .accordion_heading {
	padding-left: 5.3333333333vw;
}

#musasi .way_itemWrap {
	gap: 4vw;
	grid-template-columns: 1fr;
}

#musasi .way_num {
	font-size: 4.1333333333vw;
	height: 6.6666666667vw;
	margin-bottom: 2vw;
	width: 6.6666666667vw;
}

#musasi .way_media {
	align-items: flex-start;
	display: flex;
	gap: 4vw;
}
	/* 武蔵小杉院基本情報セクション */
	#musasi .basicInfo {
		padding-top: 7vw;
	}
#musasi .way_img {
	border-radius: 2.6666666667vw;
	margin-bottom: 0;
	width: 50%;
}

#musasi .way_txt {
	flex: 1;
	font-size: 3.4666666667vw;
	letter-spacing: -0.2666666667vw;
	line-height: calc(36 / 26);
}

#musasi .shopCta {
	margin-bottom: 13.3333333333vw;
}

#musasi .shopCta .cta {
	margin-bottom: 2.6666666667vw;
	margin-top: 17.3333333333vw;
}

#musasi .shopCta .cta_telWrap {
	border-radius: 2.6666666667vw;
	flex-direction: column;
	gap: 2.6666666667vw;
	padding: 4vw 0;
}

#musasi .shopCta_txt {
	width: 29.4%;
}

#musasi .shopCta_tel {
	width: 56.3%;
}

#musasi .shopCta_time {
	width: 82.6%;
}

#musasi .staffMessage {
	margin-bottom: 16vw;
}

#musasi .staffMessage_contents {
	flex-wrap: wrap;
	gap: 8vw;
}

#musasi .staffMessage .media {
	gap: 5.3333333333vw;
	width: 100%;
}

#musasi .staffMessage .media_img__sp {
	border-radius: 2.6666666667vw;
}

#musasi .staffMessage .media_txt {
	font-size: 3.4666666667vw;
	letter-spacing: -0.1333333333vw;
	padding: 0 5.3333333333vw;
}

#musasi .doctor {
	margin-bottom: 12vw;
	padding-top: 10vw;
	margin-top: 0;
}

#musasi .doctor .btn_wrap {
	padding-top: 8vw;
}

#musasi .author {
	margin-bottom: 8vw;
}

#musasi .author .media {
	flex-direction: column-reverse;
	gap: 5.3333333333vw;
}

#musasi .author .media_img {
	border-radius: 3.2vw;
	width: 100%;
}

#musasi .author .media_body {
	padding: 0 5.3333333333vw;
	width: 100%;
}

#musasi .author .media_heading {
	font-size: 5.3333333333vw;
	margin-bottom: 4vw;
}

#musasi .author .media_heading__sm {
	font-size: 3.7333333333vw;
}

#musasi .author .media_txt {
	font-size: 3.4666666667vw;
}

#musasi .toYou .media_heading {
	font-size: 4.2666666667vw;
	margin-bottom: 4vw;
}

#musasi .toYou .media_body {
	padding: 0 5.3333333333vw;
	width: 100%;
}

#musasi .toYou .media_txt {
	font-size: 3.4666666667vw;
}

#musasi .toYou .media_img {
	display: none;
}

#musasi .review {
	padding-bottom: 12vw;
	padding-top: 9.3333333333vw;
}

#musasi .review_contents {
	gap: 3.3333333333vw;
	grid-template-columns: 1fr;
}

#musasi .review_item {
	border-radius: 1.8666666667vw;
	padding: 6.6666666667vw 5.3333333333vw;
}

#musasi .review_icon {
	font-size: 8.8vw;
	height: 15.6vw;
	margin-bottom: 4vw;
	width: 15.6vw;
}

#musasi .review_name {
	font-size: 4.5333333333vw;
	margin-bottom: 1.3333333333vw;
}

#musasi .review_star {
	font-size: 4.5333333333vw;
	margin-bottom: 6.6666666667vw;
}

#musasi .review_txt {
	font-size: 3.4666666667vw;
	letter-spacing: 0;
}

#musasi .faq {
	padding-bottom: 10.6666666667vw;
	padding-top: 9.3333333333vw;
}

.price_contents{
	flex-direction: column;
	gap: 4.2666666667vw;
}
.musasi-price-card {
	max-width: 75vw;
	margin: 0 auto;
}

.musasi-price-card__image {
	height: 48vw;
}

.musasi-price-card__plans {
	padding: 5.3333333333vw;
}

.musasi-price-card__plan-price {
	font-size: 16vw;
	margin-bottom: 4.2666666667vw;
}

.musasi-price-card__plan-price__unit {
	font-size: 4.8vw;
}

.price_btn {
	font-size: 4.8vw;
	padding: 5.3333333333vw 13.3333333333vw;
	margin-top: 10.6666666667vw;
}

.caseview_contents {
	gap: 6.4vw;
	flex-direction: column;
}

.musasi-case-card {
	max-width: 87.4666666667vw;
	padding: 8.5333333333vw;
	margin: 0 auto;
}

.musasi-case-card__header {
	gap: 4.2666666667vw;
	margin-bottom: 6.4vw;
}

.musasi-case-card__title {
	font-size: 6.4vw;
}

.musasi-case-card__patient-info {
	font-size: 4.2666666667vw;
}

.musasi-case-card__main {
	flex-direction: column;
	gap: 6.4vw;
}

.musasi-case-card__before-after {
	justify-content: center;
}

.musasi-case-card__image-placeholder {
	width: 26.6666666667vw;
	height: 26.6666666667vw;
}

.musasi-case-card__label {
	font-size: 3.4666666667vw;
}

.musasi-case-card__arrow svg {
	width: 4.2666666667vw;
	height: 7.4666666667vw;
}

.musasi-case-card__details {
	max-width: 100%;
}

.musasi-case-card__detail-item {
	margin-bottom: 4.2666666667vw;
}

.musasi-case-card__detail-label {
	width: 21.3333333333vw;
	min-width: 21.3333333333vw;
	font-size: 3.2vw;
}

.musasi-case-card__detail-text {
	font-size: 3.2vw;
}

.musasi-case-card__link {
	font-size: 4.2666666667vw;
}

/* 武蔵小杉院特徴セクション */
	#musasi .homePlan_contents{
		flex-direction: column;}

#musasi .homePlan_item {
	width: 100%;
}

#musasi .homePlan_heading {
	font-size: 7.4666666667vw;
	padding: 4vw;
}

#musasi .homePlan_body {
	padding: 8vw;

}

#musasi .homePlan_catch {
	font-size: 5.6vw;
}

#musasi .homePlan_img {
	height: 53.3333333333vw;
}

#musasi .homePlan_desc {
	font-size: 3.7333333333vw;
	line-height: 1.6;
}

#musasi .homePlan_btn {
	width: 87.4666666667vw;
	font-size: 4.2666666667vw;
	bottom: 18.6666666667vw;
}
.price_contents{
	flex-direction: column;
	gap: 4.2666666667vw;
}
.musasi-price-card {
	max-width: 90vw;
	margin: 0 auto;
}
.musasi-price-card__title{
	font-size: 4.2666666667vw;
}
.musasi-price-card__image {
	height: 48vw;
}

.musasi-price-card__plans {
	padding: 5.3333333333vw;
}

.musasi-price-card__plan-price {
	font-size: 8vw;
	margin-bottom: 4.2666666667vw;
}

.musasi-price-card__plan-price__unit {
	font-size: 4.8vw;
}

.price_btn {
	font-size: 4.8vw;
	padding: 5.3333333333vw 13.3333333333vw;
	margin-top: 10.6666666667vw;
}

.caseview_contents {
	gap: 6.4vw;
	flex-direction: column;
}

.musasi-case-card {
	max-width: 87.4666666667vw;
	padding: 8.5333333333vw;
	margin: 0 auto;
}

.musasi-case-card__header {
	gap: 4.2666666667vw;
	margin-bottom: 6.4vw;
}

.musasi-case-card__title {
	font-size: 6.4vw;
}

.musasi-case-card__patient-info {
	font-size: 4.2666666667vw;
}

.musasi-case-card__main {
	flex-direction: column;
	gap: 6.4vw;
}

.musasi-case-card__before-after {
	justify-content: center;
}

.musasi-case-card__image-placeholder {
	width: 26.6666666667vw;
	height: 26.6666666667vw;
}

.musasi-case-card__label {
	font-size: 3.4666666667vw;
}

.musasi-case-card__arrow svg {
	width: 3.2666666667vw;
	height: 5.4666666667vw;
}

.musasi-case-card__details {
	max-width: 100%;
}

.musasi-case-card__detail-item {
	margin-bottom: 4.2666666667vw;
}

.musasi-case-card__detail-label {
	width: 21.3333333333vw;
	min-width: 21.3333333333vw;
	font-size: 3.2vw;
}

.musasi-case-card__detail-text {
	font-size: 3.2vw;
}

.musasi-case-card__link {
	font-size: 4.2666666667vw;
}

/* 武蔵小杉院特徴セクション */
	#musasi .homePlan_contents{
		flex-direction: column;}



#musasi .homePlan_heading {
	font-size: 7.4666666667vw;
	padding: 4vw;
}

#musasi .homePlan_body {
	padding: 8vw;
	padding-bottom: 10.3333333333vw;
}

#musasi .homePlan_catch {
	font-size: 5.6vw;
}

#musasi .homePlan_img {
	height: 50.3333333333vw;
}

#musasi .homePlan_desc {
	font-size: 3.7333333333vw;
	line-height: 1.6;
}

#musasi .homePlan_btn {
	width: 87.4666666667vw;
	font-size: 4.2666666667vw;
	bottom: 18.6666666667vw;
}

/* 武蔵小杉院メディアセクション */
#musasi .about{
	padding-top: 10vw;
	padding-bottom: 10vw;
}
#musasi .about .media {
	flex-direction: column;
	gap: 8vw;
	text-align: center;
	margin-bottom: 8vw;
}

#musasi .about .media_heading {
	font-size: 6.9333333333vw;
	margin-bottom: 5.3333333333vw;
}

#musasi .about .media_body {
	order: 2;
}

#musasi .about .media_img {
	order: 1;
	width: 100%;
	margin: 0 auto;
}
#musasi .about .media:nth-child(odd){
	flex-direction: column;
}
#musasi .about .halfMedia > * {
	width: 100%;
}

#musasi .about .media_txt {
	font-size: 4.2666666667vw;
	line-height: 1.6;
	text-align: left;
}

#musasi .media_txt__lists li {
	font-size: 4.2666666667vw;
	line-height: 1.6;
	text-align: left;
	padding-left: 30px;
}
#musasi .about .media_num__primary {
	font-size: 10.6666666667vw;
	padding-right: 8vw;
}

#musasi .about .media_num__primary span {
	font-size: 8vw;
	margin-right: 2.1333333333vw;
}

#musasi .about .media__ribbon .media_num {
	font-size: 6.9333333333vw;
	height: 14.6666666667vw;
	width: 16vw;
	left: 5.3333333333vw;
	padding-top: 2.6666666667vw;
	top: -2.6666666667vw;
}

.caseview {
		padding: 21.3333333333vw 0;
	}
	
	.caseview_contents {
		gap: 6.4vw;
	}
	
	.musasi-case-card {
		border-radius: 5.3333333333vw;
		padding: 6.4vw;
		max-width: 90vw;
		margin: 0 auto;
	}
	
	.musasi-case-card::before,
	.musasi-case-card::after {
		display: none;
	}
	
	.musasi-case-card__header {
		gap: 4.2666666667vw;
		margin-bottom: 6.4vw;
	}
	
	.musasi-case-card__title {
		font-size: 6.4vw;
	}
	
	.musasi-case-card__patient-info {
		font-size: 4.2666666667vw;
	}
	
	.musasi-case-card__main {
		gap: 6.4vw;
		flex-direction: column;
	}
	
	.musasi-case-card__before-after {
		gap: 1.8666666667vw;
		justify-content: center;
	}
	
	.musasi-case-card__image-placeholder {
		width: 35.2vw;
		height: 35.2vw;
		border-radius: 1.0666666667vw;
		margin-bottom: 1.0666666667vw;
	}
	
	.musasi-case-card__label {
		font-size: 4.2666666667vw;
	}
	
	.musasi-case-card__arrow {
		margin: 0 2.6666666667vw;
	}
	
	.musasi-case-card__details {
		gap: 2.1333333333vw;
		max-width: 100%;
	}
	
	.musasi-case-card__detail-item {
		gap: 2.1333333333vw;
		margin-bottom: 2.1333333333vw;
	}
	
	.musasi-case-card__detail-label {
		padding: 0.5333333333vw 2.1333333333vw;
		border: 0.2666666667vw solid #589450;
		border-radius: 13.3333333333vw;
		font-size: 3.7333333333vw;
		width: 28.8vw;
		min-width: 28.8vw;
	}
	/* .musasi-case-card__image-item {
		max-width: 100px;
		aspect-ratio: 100/1;
	} */
	.musasi-case-card__detail-text {
		font-size: 3.7333333333vw;
	}
	
	.musasi-case-card__footer {
		margin-top: 2.1333333333vw;
	}
	
	.musasi-case-card__link {
		font-size: 3.7333333333vw;
	}
	.caseview {
		padding: 21.3333333333vw 0;
	}
	
	.caseview_contents {
		gap: 6.4vw;
		padding: 0;
	}
	
	.musasi-case-card {
		border-radius: 5.3333333333vw;
		padding: 4.5333333333vw;
		width: 87.4666666667vw;
		max-width: fit-content;
	}
	
	.musasi-case-card::before,
	.musasi-case-card::after {
		display: none;
	}
	
	.musasi-case-card__header {
		gap: 4.2666666667vw;
		margin-bottom: 6.4vw;
	}
	
	.musasi-case-card__title {
		font-size: 6.4vw;
	}
	
	.musasi-case-card__patient-info {
		font-size: 4.2666666667vw;
	}
	
	.musasi-case-card__main {
		gap: 6.4vw;
		flex-direction: column;
		align-items: center;
		justify-content: center;
	}
	
	.musasi-case-card__before-after {
		gap: 1.8666666667vw;
		justify-content: center;
	}
	
	.musasi-case-card__image-placeholder {
		width: 30.2vw;
		height: 30.2vw;
		border-radius: 1.0666666667vw;
		margin-bottom: 1.0666666667vw;
	}
	
	.musasi-case-card__label {
		font-size: 4.2666666667vw;
	}
	
	.musasi-case-card__arrow {
		margin: 0 2.6666666667vw;
	}
	
	.musasi-case-card__details {
		gap: 2.1333333333vw;
		max-width: 100%;
	}
	
	.musasi-case-card__detail-item {
		gap: 2.1333333333vw;
		margin-bottom: 2.1333333333vw;
	}
	
	.musasi-case-card__detail-label {
		padding: 0.5333333333vw 2.1333333333vw;
		border: 0.2666666667vw solid #589450;
		border-radius: 13.3333333333vw;
		font-size: 3.7333333333vw;
		width: 28.8vw;
		min-width: 28.8vw;
	}
	
	.musasi-case-card__detail-text {
		font-size: 3.7333333333vw;
	}
	
	.musasi-case-card__footer {
		margin-top: 2.1333333333vw;
	}
	
	.musasi-case-card__link {
		font-size: 3.7333333333vw;
	}

	/* スマホサイズ用ナビボタン調整 */
	.caseview_swiper .swiper-button-prev,
	.caseview_swiper .swiper-button-next {
		width: 8vw;
		height: 8vw;
		margin-top: -20vw;
	}

	.caseview_swiper .swiper-button-prev {
		left: 1vw;
		background-image: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="30" height="30" viewBox="0 0 30 30" fill="none"><circle cx="15" cy="15" r="15" transform="matrix(-1 0 0 1 30 0)" fill="%23D7D7D7"/><path d="M10.4394 14.8905C9.8535 15.5042 9.8535 16.5007 10.4394 17.1144L17.4376 24.5398C18.0234 25.1534 18.9748 25.1534 19.5606 24.5398C20.1465 23.9261 20.1465 22.9296 19.5606 22.316L13.6216 15L19.5559 7.684C20.1418 7.0704 20.1418 6.0739 19.5559 5.4602C18.9701 4.8466 18.0187 4.8466 17.4329 5.4602L10.4347 12.8856L10.4394 14.8905Z" fill="white"/></svg>');
		background-size: contain;
		background-repeat: no-repeat;
		background-position: center;
		background-color: transparent;
	}

	.caseview_swiper .swiper-button-next {
		right: 1vw;
		background-image: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="30" height="30" viewBox="0 0 30 30" fill="none"><circle cx="15" cy="15" r="15" fill="%23D7D7D7"/><path d="M19.5606 14.8905C20.1465 15.5042 20.1465 16.5007 19.5606 17.1144L12.5624 24.5398C11.9766 25.1534 11.0252 25.1534 10.4394 24.5398C9.8535 23.9261 9.8535 22.9296 10.4394 22.316L16.3784 15L10.4441 7.684C9.8582 7.0704 9.8582 6.0739 10.4441 5.4602C11.0299 4.8466 11.9813 4.8466 12.5671 5.4602L19.5653 12.8856L19.5606 14.8905Z" fill="white"/></svg>');
		background-size: contain;
		background-repeat: no-repeat;
		background-position: center;
		background-color: transparent;
	}

	#musasi .media_heading__flex{
		justify-content: center;
	}

#musasi .media {
	gap: 6.6666666667vw;
	flex-direction: column;
	margin-top: 30px;
}
#musasi .media:not(:first-child) {
	margin-top: 0px;
}

#musasi .media_heading {
	font-size: 4vw;
	margin-bottom: 5.3333333333vw;
}

#musasi .media_heading__line {
	margin-bottom: 9.3333333333vw;
}

#musasi .media_heading__line::after {
	background-image: repeating-linear-gradient(-45deg, rgba(184, 213, 84, 0.7), rgba(184, 213, 84, 0.7) 0.4vw, transparent 0.5333333333vw, transparent 1.0666666667vw);
	bottom: -4vw;
	height: 1.6vw;
}

#musasi .media_num {
	font-size: 6.6666666667vw;
}

#musasi .media_num__primary {
	font-size: 5.3333333333vw;
	padding-right: 5.3333333333vw;
}

#musasi .media_num__primary span {
	font-size: 4vw;
	margin-right: 0.9333333333vw;
}

#musasi .media__ribbon::after {
	border-width: 0 1.3333333333vw 1.3333333333vw 1.3333333333vw;
	left: 9.3333333333vw;
}

#musasi .media__ribbon .media_num {
	font-size: 3.4666666667vw;
	height: 7.3333333333vw;
	left: 2.6666666667vw;
	padding-top: 1.3333333333vw;
	top: -1.3333333333vw;
	width: 8vw;
}

#musasi .media__ribbon .media_num::before {
	border-width: 0 0 1.3333333333vw 4vw;
}

#musasi .media__ribbon .media_num::after {
	border-width: 0 4vw 1.3333333333vw 0;
}
.flowStep .media_img{
	width: 100%;
}
.flowStep .media {
	padding-left: 20px;
}
.flowStep .media_heading{
	font-size: 3.7333333333vw;
	justify-content: center;
}
.flowStep .media_num{
	font-size: 3.7333333333vw;
}
.flowStep .media_num__primary{
	font-size: 3.7333333333vw;
}

}

.lgbt-icon{
	display: block;
	width: auto;
	height: 50px;
	margin-right: 4px;
}
.lgbt-icon-sp{
	display: none;
}
@media screen and (max-width: 1100px){
	.lgbt-icon-sp{
		display: block;
		height: 50px;
    	width: auto;
		padding-left: 40vw;
	}
}
@media screen and (max-width: 750px){
	.lgbt-icon-sp{
		display: block;
		height: 7.7333333333vw;
    	width: auto;
		padding-left: 28vw;
	}
	/* 表（見出し列） */
	.is-style-mob-table01 th, .is-style-mob-table01 tr:first-child td {
		background-color: #eff4de;
		font-size: 1.4rem;
	}

	/* 表（見出し行） */
	.is-style-mob-table02 th, .is-style-mob-table02 tr td:first-child {
		background-color: #eff4de;
		font-size: 1.4rem;
	}

	/* 表（見出し列・行） */
	.is-style-mob-table03 tr:first-child th, .is-style-mob-table03 tr:first-child td {
		background-color: #eff4de;
		font-size: 1.4rem;
	}
	.is-style-mob-table03 tr:not(:first-child) th, .is-style-mob-table03 tr:not(:first-child) td:first-child {
		background-color: #e2e5ea;
		font-size: 1.4rem;
	}
}

/* 武蔵小杉院ナビゲーションメニュー */
.clinic-nav {
 
  padding: 20px 0;
  margin-bottom: 40px;
}

.clinic-nav__menu {
  width: 100%;
}

.clinic-nav__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  list-style: none;
  margin: 0;
  padding: 0;
  column-gap: 23px;
  row-gap: 21px;
}


.clinic-nav__item {
  flex: 1;
  margin: 0;
  background-color: #f5f5f5;
}

.clinic-nav__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-direction: column;
  gap: 5px;
  padding: 15px 20px 0px 20px;
  background-color: #f5f5f5;
  border-radius: 8px;
  text-decoration: none;
  color: #333333;
  font-weight: 500;
  font-size: 14px;
  transition: all 0.3s ease;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  white-space: nowrap;
}

.clinic-nav__link:hover {
  background-color: #57944f;
  color: #ffffff;
  transform: translateY(-2px);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
}

.clinic-nav__text {
  flex: 1;
  text-align: center;
}

.clinic-nav__arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.3s ease;
}

.clinic-nav__link:hover .clinic-nav__arrow {
  transform: rotate(180deg);
}

.clinic-nav__arrow svg {
  width: 16px;
  height: 16px;
  color: #6BA165;
}

/* レスポンシブ対応 */
@media screen and (max-width: 1024px) {
  .clinic-nav__list {
    grid-template-columns: repeat(2, 1fr);
    column-gap: 23px;
    row-gap: 21px;
  }
  
  .clinic-nav__item {
    min-width: calc(33.333% - 8px);
  }
  
  .clinic-nav__link {
    padding: 12px 15px;
    font-size: 13px;
  }
}

@media screen and (max-width: 768px) {
  .clinic-nav {
    padding: 15px 0;
    margin-bottom: 30px;
  }
  
  .clinic-nav__list {
	grid-template-columns: repeat(1, 1fr);
    column-gap: 0px;
    row-gap: 10px;
  }
  
  .clinic-nav__item {
    min-width: 100%;
  }
  
  .clinic-nav__link {
    padding: 15px 20px;
    font-size: 14px;
  }
  
  .clinic-nav__text {
    text-align: left;
  }
}

/* ページ内リンク時のヘッダー分オフセット調整 */
#basicInfo,
#access,
#features,
#treatment,
#cases,
#pricing {
  scroll-margin-top: 160px;
}

@media screen and (max-width: 768px) {
  #basicInfo,
  #access,
  #features,
  #treatment,
  #cases,
  #pricing {
    scroll-margin-top: 80px;
  }
}
